ac3_descriptor.h 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  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_AC3_DESCRIPTOR
  22. #define _UCSI_DVB_AC3_DESCRIPTOR 1
  23. #ifdef __cplusplus
  24. extern "C"
  25. {
  26. #endif
  27. #include <libucsi/descriptor.h>
  28. #include <libucsi/endianops.h>
  29. /**
  30. * dvb_ac3_descriptor structure.
  31. */
  32. struct dvb_ac3_descriptor {
  33. struct descriptor d;
  34. EBIT5(uint8_t ac3_type_flag : 1; ,
  35. uint8_t bsid_flag : 1; ,
  36. uint8_t mainid_flag : 1; ,
  37. uint8_t asvc_flag : 1; ,
  38. uint8_t reserved : 4; );
  39. /* uint8_t additional_info[] */
  40. } __ucsi_packed;
  41. /**
  42. * Process a dvb_ac3_descriptor.
  43. *
  44. * @param d Generic descriptor structure.
  45. * @return dvb_ac3_descriptor pointer, or NULL on error.
  46. */
  47. static inline struct dvb_ac3_descriptor*
  48. dvb_ac3_descriptor_codec(struct descriptor* d)
  49. {
  50. if (d->len < (sizeof(struct dvb_ac3_descriptor) - 2))
  51. return NULL;
  52. return (struct dvb_ac3_descriptor*) d;
  53. }
  54. /**
  55. * Retrieve pointer to additional_info field of a dvb_ac3_descriptor.
  56. *
  57. * @param d dvb_ac3_descriptor pointer.
  58. * @return Pointer to additional_info field.
  59. */
  60. static inline uint8_t *dvb_ac3_descriptor_additional_info(struct dvb_ac3_descriptor *d)
  61. {
  62. return (uint8_t *) d + sizeof(struct dvb_ac3_descriptor);
  63. }
  64. /**
  65. * Determine length of additional_info field of a dvb_ac3_descriptor.
  66. *
  67. * @param d dvb_ac3_descriptor pointer.
  68. * @return Length of field in bytes.
  69. */
  70. static inline int dvb_ac3_descriptor_additional_info_length(struct dvb_ac3_descriptor *d)
  71. {
  72. return d->d.len - 1;
  73. }
  74. #ifdef __cplusplus
  75. }
  76. #endif
  77. #endif