dcadec.h 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. /*
  2. * Copyright (C) 2016 foo86
  3. *
  4. * This file is part of FFmpeg.
  5. *
  6. * FFmpeg is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 2.1 of the License, or (at your option) any later version.
  10. *
  11. * FFmpeg is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public
  17. * License along with FFmpeg; if not, write to the Free Software
  18. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  19. */
  20. #ifndef AVCODEC_DCADEC_H
  21. #define AVCODEC_DCADEC_H
  22. #include "libavutil/common.h"
  23. #include "libavutil/crc.h"
  24. #include "libavutil/float_dsp.h"
  25. #include "avcodec.h"
  26. #include "get_bits.h"
  27. #include "dca.h"
  28. #include "dcadsp.h"
  29. #include "dca_core.h"
  30. #include "dca_exss.h"
  31. #include "dca_xll.h"
  32. #include "dca_lbr.h"
  33. #define DCA_PACKET_CORE 0x01
  34. #define DCA_PACKET_EXSS 0x02
  35. #define DCA_PACKET_XLL 0x04
  36. #define DCA_PACKET_LBR 0x08
  37. #define DCA_PACKET_MASK 0x0f
  38. #define DCA_PACKET_RECOVERY 0x10 ///< Sync error recovery flag
  39. #define DCA_PACKET_RESIDUAL 0x20 ///< Core valid for residual decoding
  40. typedef struct DCAContext {
  41. const AVClass *class; ///< class for AVOptions
  42. AVCodecContext *avctx;
  43. DCACoreDecoder core; ///< Core decoder context
  44. DCAExssParser exss; ///< EXSS parser context
  45. DCAXllDecoder xll; ///< XLL decoder context
  46. DCALbrDecoder lbr; ///< LBR decoder context
  47. DCADSPContext dcadsp;
  48. const AVCRC *crctab;
  49. uint8_t *buffer; ///< Packet buffer
  50. unsigned int buffer_size;
  51. int packet; ///< Packet flags
  52. int request_channel_layout; ///< Converted from avctx.request_channel_layout
  53. int core_only; ///< Core only decoding flag
  54. } DCAContext;
  55. int ff_dca_set_channel_layout(AVCodecContext *avctx, int *ch_remap, int dca_mask);
  56. void ff_dca_downmix_to_stereo_fixed(DCADSPContext *dcadsp, int32_t **samples,
  57. int *coeff_l, int nsamples, int ch_mask);
  58. void ff_dca_downmix_to_stereo_float(AVFloatDSPContext *fdsp, float **samples,
  59. int *coeff_l, int nsamples, int ch_mask);
  60. static inline int ff_dca_check_crc(AVCodecContext *avctx, GetBitContext *s,
  61. int p1, int p2)
  62. {
  63. DCAContext *dca = avctx->priv_data;
  64. if (!(avctx->err_recognition & (AV_EF_CRCCHECK | AV_EF_CAREFUL)))
  65. return 0;
  66. if (((p1 | p2) & 7) || p1 < 0 || p2 > s->size_in_bits || p2 - p1 < 16)
  67. return -1;
  68. if (av_crc(dca->crctab, 0xffff, s->buffer + p1 / 8, (p2 - p1) / 8))
  69. return -1;
  70. return 0;
  71. }
  72. static inline int ff_dca_seek_bits(GetBitContext *s, int p)
  73. {
  74. if (p < get_bits_count(s) || p > s->size_in_bits)
  75. return -1;
  76. skip_bits_long(s, p - get_bits_count(s));
  77. return 0;
  78. }
  79. #endif