net_timeval2dsec.c 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. /****************************************************************************
  2. * net/utils/net_timeval2dsec.c
  3. *
  4. * Licensed to the Apache Software Foundation (ASF) under one or more
  5. * contributor license agreements. See the NOTICE file distributed with
  6. * this work for additional information regarding copyright ownership. The
  7. * ASF licenses this file to you under the Apache License, Version 2.0 (the
  8. * "License"); you may not use this file except in compliance with the
  9. * License. You may obtain a copy of the License at
  10. *
  11. * http://www.apache.org/licenses/LICENSE-2.0
  12. *
  13. * Unless required by applicable law or agreed to in writing, software
  14. * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
  15. * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
  16. * License for the specific language governing permissions and limitations
  17. * under the License.
  18. *
  19. ****************************************************************************/
  20. /****************************************************************************
  21. * Included Files
  22. ****************************************************************************/
  23. #include <nuttx/config.h>
  24. #include <sys/time.h>
  25. #include <nuttx/clock.h>
  26. #include "utils/utils.h"
  27. /****************************************************************************
  28. * Public Functions
  29. ****************************************************************************/
  30. /****************************************************************************
  31. * Name: net_timeval2dsec
  32. *
  33. * Description:
  34. * Convert a struct timeval to deciseconds. Needed by setsockopt() to
  35. * save new timeout values.
  36. *
  37. * Input Parameters:
  38. * tv - The struct timeval to convert
  39. * remainder - Determines how to handler the microsecond remainder
  40. *
  41. * Returned Value:
  42. * The converted value
  43. *
  44. * Assumptions:
  45. *
  46. ****************************************************************************/
  47. unsigned int net_timeval2dsec(FAR struct timeval *tv,
  48. enum tv2ds_remainder_e remainder)
  49. {
  50. unsigned long adjust = 0;
  51. switch (remainder)
  52. {
  53. default:
  54. case TV2DS_TRUNC: /* Truncate microsecond remainder */
  55. break;
  56. case TV2DS_ROUND: /* Round to the nearest full decisecond */
  57. adjust = (USEC_PER_DSEC / 2);
  58. break;
  59. case TV2DS_CEIL: /* Force to next larger full decisecond */
  60. adjust = (USEC_PER_DSEC - 1);
  61. break;
  62. }
  63. return (unsigned int)(tv->tv_sec * DSEC_PER_SEC +
  64. (tv->tv_usec + adjust) / USEC_PER_DSEC);
  65. }