Mercurial > libavcodec.hg
annotate ac3dec_data.c @ 10952:ea8f891d997d libavcodec
H264 DXVA2 implementation
It allows VLD H264 decoding using DXVA2 (GPU assisted decoding API under
VISTA and Windows 7).
It is implemented by using AVHWAccel API. It has been tested successfully
for some time in VLC using an nvidia card on Windows 7.
To compile it, you need to have the system header dxva2api.h (either from
microsoft or using http://downloads.videolan.org/pub/videolan/testing/contrib/dxva2api.h)
The generated libavcodec.dll does not depend directly on any new lib as
the necessary objects are given by the application using FFmpeg.
| author | fenrir |
|---|---|
| date | Wed, 20 Jan 2010 18:54:51 +0000 |
| parents | 68de5143aa45 |
| children | 444f4b594fdb |
| rev | line source |
|---|---|
| 7032 | 1 /* |
|
7470
1a93d3bbe3ee
cosmetics: make all references to AC-3 capitalized and hyphenated
jbr
parents:
7033
diff
changeset
|
2 * AC-3 and E-AC-3 decoder tables |
| 7032 | 3 * Copyright (c) 2007 Bartlomiej Wolowiec <bartek.wolowiec@gmail.com> |
| 4 * | |
| 5 * This file is part of FFmpeg. | |
| 6 * | |
| 7 * FFmpeg 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 * FFmpeg 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 FFmpeg; if not, write to the Free Software | |
| 19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |
| 20 */ | |
| 21 | |
| 22 /** | |
|
8718
e9d9d946f213
Use full internal pathname in doxygen @file directives.
diego
parents:
8142
diff
changeset
|
23 * @file libavcodec/ac3dec_data.c |
| 9978 | 24 * Tables taken directly from the AC-3 spec. |
| 7032 | 25 */ |
| 26 | |
| 27 #include "ac3dec_data.h" | |
| 28 #include "ac3.h" | |
| 29 | |
|
7472
83c16f531a90
Hardcode the table for ungrouping 3 values in 5 bits. It will be reused by
jbr
parents:
7470
diff
changeset
|
30 /** |
| 9978 | 31 * Table used to ungroup 3 values stored in 5 bits. |
| 32 * Used by bap=1 mantissas and GAQ. | |
|
7472
83c16f531a90
Hardcode the table for ungrouping 3 values in 5 bits. It will be reused by
jbr
parents:
7470
diff
changeset
|
33 * ff_ac3_ungroup_3_in_5_bits_tab[i] = { i/9, (i%9)/3, (i%9)%3 } |
|
83c16f531a90
Hardcode the table for ungrouping 3 values in 5 bits. It will be reused by
jbr
parents:
7470
diff
changeset
|
34 */ |
|
83c16f531a90
Hardcode the table for ungrouping 3 values in 5 bits. It will be reused by
jbr
parents:
7470
diff
changeset
|
35 const uint8_t ff_ac3_ungroup_3_in_5_bits_tab[32][3] = { |
|
83c16f531a90
Hardcode the table for ungrouping 3 values in 5 bits. It will be reused by
jbr
parents:
7470
diff
changeset
|
36 { 0, 0, 0 }, { 0, 0, 1 }, { 0, 0, 2 }, { 0, 1, 0 }, |
|
83c16f531a90
Hardcode the table for ungrouping 3 values in 5 bits. It will be reused by
jbr
parents:
7470
diff
changeset
|
37 { 0, 1, 1 }, { 0, 1, 2 }, { 0, 2, 0 }, { 0, 2, 1 }, |
|
83c16f531a90
Hardcode the table for ungrouping 3 values in 5 bits. It will be reused by
jbr
parents:
7470
diff
changeset
|
38 { 0, 2, 2 }, { 1, 0, 0 }, { 1, 0, 1 }, { 1, 0, 2 }, |
|
83c16f531a90
Hardcode the table for ungrouping 3 values in 5 bits. It will be reused by
jbr
parents:
7470
diff
changeset
|
39 { 1, 1, 0 }, { 1, 1, 1 }, { 1, 1, 2 }, { 1, 2, 0 }, |
|
83c16f531a90
Hardcode the table for ungrouping 3 values in 5 bits. It will be reused by
jbr
parents:
7470
diff
changeset
|
40 { 1, 2, 1 }, { 1, 2, 2 }, { 2, 0, 0 }, { 2, 0, 1 }, |
|
83c16f531a90
Hardcode the table for ungrouping 3 values in 5 bits. It will be reused by
jbr
parents:
7470
diff
changeset
|
41 { 2, 0, 2 }, { 2, 1, 0 }, { 2, 1, 1 }, { 2, 1, 2 }, |
|
83c16f531a90
Hardcode the table for ungrouping 3 values in 5 bits. It will be reused by
jbr
parents:
7470
diff
changeset
|
42 { 2, 2, 0 }, { 2, 2, 1 }, { 2, 2, 2 }, { 3, 0, 0 }, |
|
83c16f531a90
Hardcode the table for ungrouping 3 values in 5 bits. It will be reused by
jbr
parents:
7470
diff
changeset
|
43 { 3, 0, 1 }, { 3, 0, 2 }, { 3, 1, 0 }, { 3, 1, 1 } |
|
83c16f531a90
Hardcode the table for ungrouping 3 values in 5 bits. It will be reused by
jbr
parents:
7470
diff
changeset
|
44 }; |
|
83c16f531a90
Hardcode the table for ungrouping 3 values in 5 bits. It will be reused by
jbr
parents:
7470
diff
changeset
|
45 |
|
9980
ac31ff44d1a5
cosmetics: Reorder some tables/lines to make future diffs smaller.
diego
parents:
9978
diff
changeset
|
46 /** |
|
ac31ff44d1a5
cosmetics: Reorder some tables/lines to make future diffs smaller.
diego
parents:
9978
diff
changeset
|
47 * Table of bin locations for rematrixing bands |
|
ac31ff44d1a5
cosmetics: Reorder some tables/lines to make future diffs smaller.
diego
parents:
9978
diff
changeset
|
48 * reference: Section 7.5.2 Rematrixing : Frequency Band Definitions |
|
ac31ff44d1a5
cosmetics: Reorder some tables/lines to make future diffs smaller.
diego
parents:
9978
diff
changeset
|
49 */ |
|
ac31ff44d1a5
cosmetics: Reorder some tables/lines to make future diffs smaller.
diego
parents:
9978
diff
changeset
|
50 const uint8_t ff_ac3_rematrix_band_tab[5] = { 13, 25, 37, 61, 253 }; |
|
ac31ff44d1a5
cosmetics: Reorder some tables/lines to make future diffs smaller.
diego
parents:
9978
diff
changeset
|
51 |
| 7032 | 52 const uint8_t ff_eac3_hebap_tab[64] = { |
| 53 0, 1, 2, 3, 4, 5, 6, 7, 8, 8, | |
| 54 8, 8, 9, 9, 9, 10, 10, 10, 10, 11, | |
| 55 11, 11, 11, 12, 12, 12, 12, 13, 13, 13, | |
| 56 13, 14, 14, 14, 14, 15, 15, 15, 15, 16, | |
| 57 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, | |
| 58 18, 18, 18, 18, 18, 19, 19, 19, 19, 19, | |
| 59 19, 19, 19, 19, | |
| 60 }; | |
| 61 | |
| 62 /** | |
| 63 * Table E2.16 Default Coupling Banding Structure | |
| 64 */ | |
| 65 const uint8_t ff_eac3_default_cpl_band_struct[18] = | |
| 66 { 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 1, 1, 1, 1, 1 }; |
