short_smoothing_buffer_descriptor.h 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. /*
  2. * section and descriptor parser
  3. *
  4. * Copyright (C) 2005 Kenneth Aafloy (kenneth@linuxtv.org)
  5. * Copyright (C) 2005 Andrew de Quincey (adq_dvb@lidskialf.net)
  6. *
  7. * This library is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU Lesser General Public
  9. * License as published by the Free Software Foundation; either
  10. * version 2.1 of the License, or (at your option) any later version.
  11. *
  12. * This library is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. * Lesser General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU Lesser General Public
  18. * License along with this library; if not, write to the Free Software
  19. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
  20. */
  21. #ifndef _UCSI_DVB_SHORT_SMOOTHING_BUFFER_DESCRIPTOR
  22. #define _UCSI_DVB_SHORT_SMOOTHING_BUFFER_DESCRIPTOR 1
  23. #ifdef __cplusplus
  24. extern "C"
  25. {
  26. #endif
  27. #include <libucsi/descriptor.h>
  28. #include <libucsi/endianops.h>
  29. /**
  30. * dvb_short_smoothing_buffer_descriptor structure.
  31. */
  32. struct dvb_short_smoothing_buffer_descriptor {
  33. struct descriptor d;
  34. EBIT2(uint8_t sb_size : 2; ,
  35. uint8_t sb_leak_rate : 6; );
  36. /* uint8_t reserved [] */
  37. } __ucsi_packed;
  38. /**
  39. * Process a dvb_short_smoothing_buffer_descriptor.
  40. *
  41. * @param d Generic descriptor structure.
  42. * @return dvb_short_smoothing_buffer_descriptor pointer, or NULL on error.
  43. */
  44. static inline struct dvb_short_smoothing_buffer_descriptor*
  45. dvb_short_smoothing_buffer_descriptor_codec(struct descriptor* d)
  46. {
  47. if (d->len < (sizeof(struct dvb_short_smoothing_buffer_descriptor) - 2))
  48. return NULL;
  49. return (struct dvb_short_smoothing_buffer_descriptor*) d;
  50. }
  51. /**
  52. * Accessor for reserved field in a dvb_short_smoothing_buffer_descriptor.
  53. *
  54. * @param d dvb_short_smoothing_buffer_descriptor pointer.
  55. * @return Pointer to reserved field.
  56. */
  57. static inline uint8_t *
  58. dvb_short_smoothing_buffer_descriptor_reserved(struct dvb_short_smoothing_buffer_descriptor *d)
  59. {
  60. return (uint8_t*) d + sizeof(struct dvb_short_smoothing_buffer_descriptor);
  61. }
  62. /**
  63. * Calculate length of reserved field in a dvb_short_smoothing_buffer_descriptor.
  64. *
  65. * @param d dvb_short_smoothing_buffer_descriptor pointer.
  66. * @return Length of the field in bytes.
  67. */
  68. static inline int
  69. dvb_short_smoothing_buffer_descriptor_reserved_length(struct dvb_short_smoothing_buffer_descriptor *d)
  70. {
  71. return d->d.len - 1;
  72. }
  73. #ifdef __cplusplus
  74. }
  75. #endif
  76. #endif