Compare commits
608 Commits
Author | SHA1 | Date | |
---|---|---|---|
cae9b66875 | |||
713613ff6f | |||
c9f3103a02 | |||
de055eec1f | |||
42175c4654 | |||
b309463c3d | |||
82d1853964 | |||
3ea263c5fc | |||
76c5a4779f | |||
1fe245034f | |||
4f496673c2 | |||
06b1779fcb | |||
8872ea8748 | |||
55949027f5 | |||
8d121ed665 | |||
024632c2b0 | |||
30c24bd34a | |||
acf3df4ff3 | |||
9ed037f47d | |||
0add715f1d | |||
09891f4dab | |||
67ea676a43 | |||
10adcb4b30 | |||
51d04c226a | |||
92558ec0fe | |||
099bd45b65 | |||
30326de759 | |||
a0306f7482 | |||
42ba9ed16a | |||
8a99c8191a | |||
287a563a0d | |||
64ebdbb558 | |||
b79b78022a | |||
f5a74179a5 | |||
bb8dc83221 | |||
67c37cd9e2 | |||
e9e97ab726 | |||
181af0c684 | |||
4adf604017 | |||
5c122f7c9c | |||
c490f875e1 | |||
99448ba228 | |||
4f08126a5b | |||
21c9f2a966 | |||
46eb4b8996 | |||
bb34f9235d | |||
162bd7a657 | |||
62b44ac5ed | |||
f3e31a5c17 | |||
8c1c88860b | |||
d976c0a693 | |||
fa34f5e06f | |||
b7ba32c1cb | |||
0ca0001fdc | |||
cedfb4f831 | |||
721da5031c | |||
4cb460ae3a | |||
c4552ae9f6 | |||
49dbae0739 | |||
911b943b8b | |||
dd9b7f02f5 | |||
39020cb85a | |||
1d71c25774 | |||
c3a854dff1 | |||
b4e3a01b9f | |||
4ddec41343 | |||
3bbaab4377 | |||
11b61948a3 | |||
0e943a3418 | |||
6dfde52c97 | |||
4925f91bc5 | |||
cf751b6179 | |||
991e88165e | |||
d11a030f7a | |||
87b01c3d32 | |||
ca5c74009e | |||
2cce057825 | |||
199183c25c | |||
0b17eb8a08 | |||
3ee7f9a5e6 | |||
9531c5f046 | |||
59dacbeb07 | |||
da225b24af | |||
5e09eb862a | |||
e8dfbd5ac8 | |||
a88383e546 | |||
24a6513793 | |||
3527b9abea | |||
b9e4fee2ac | |||
86d9ba2011 | |||
a5954a0e56 | |||
af32d05e64 | |||
15b0e11e31 | |||
7937ee0b73 | |||
03b0960c08 | |||
325c0f2c72 | |||
55882fc657 | |||
8314a4c7c2 | |||
64699c8a2e | |||
5f1c4ec9a2 | |||
1a8e9092ec | |||
9498189e65 | |||
1f3c7e6d57 | |||
1305f7ddcd | |||
779e91a3bf | |||
bc009b7637 | |||
31eb1e7b87 | |||
0a08bf5f80 | |||
6f78cf679d | |||
fe04466198 | |||
89b4c341ce | |||
3882ff91bc | |||
8a7bdc7ac4 | |||
8c6eddfa2e | |||
efff34e346 | |||
4160e3f737 | |||
a9b35cc1c0 | |||
d98946d3e0 | |||
10e5d3f04b | |||
cef5186411 | |||
347ab57c10 | |||
3ebc11408c | |||
e835ae2861 | |||
929c490792 | |||
0ba74560f2 | |||
f649035653 | |||
1355133686 | |||
3916f5661e | |||
2c02ee41d7 | |||
6feb014328 | |||
cce0b1ecea | |||
bfe07187a3 | |||
3997fc0f17 | |||
5620a8c9e5 | |||
bb582ebe7d | |||
6d37472afb | |||
4fcb2b40d3 | |||
bccfb18f53 | |||
5f2ebad096 | |||
fe7561200c | |||
e7c75df13f | |||
8b35b2e525 | |||
4d674f761b | |||
40fe90bc20 | |||
9a8f96b2ed | |||
a10a573f5c | |||
25fa76a356 | |||
c665db4759 | |||
d5bd6f9ad4 | |||
374b082a01 | |||
17a884d920 | |||
2833480ca2 | |||
e6c1284fbb | |||
9439e9cfa5 | |||
1dc6173424 | |||
7f66fd906e | |||
0b265803a0 | |||
94cf0e710c | |||
c03d0d47fa | |||
09c7ec1ae1 | |||
40e5b7394e | |||
72b1609469 | |||
f3ee3cb50c | |||
fc970ce5c9 | |||
28fd5b70cd | |||
f0119c54c9 | |||
6871ab5572 | |||
69be189e3a | |||
31a8e39ab8 | |||
4b812a05a4 | |||
7a2c2d1297 | |||
40ed5758e1 | |||
133280383e | |||
d03e76320b | |||
93772c83b6 | |||
35ba7f701a | |||
f395ddff07 | |||
bdc83043ad | |||
b41416e745 | |||
f92671f85d | |||
3daa10a370 | |||
2556af1128 | |||
d601725d20 | |||
c5e092ec1e | |||
1a1a05ecd9 | |||
b2b694a10d | |||
06a2f9ee63 | |||
79d39d7a40 | |||
acf753a3c9 | |||
14a4ace9aa | |||
5160328d0e | |||
3de52bde87 | |||
8e0b5d08db | |||
caa2be03e7 | |||
6759fcdaa6 | |||
9243908055 | |||
fc1ad0b7bb | |||
d2f08199cc | |||
edab11447a | |||
9797be006b | |||
a6244a53a8 | |||
cce69a7d92 | |||
adb6587fc9 | |||
a6c8b50752 | |||
9224e4d449 | |||
651a8a08d5 | |||
5dae8ce9cb | |||
9acba09e18 | |||
9ff171ccbd | |||
17a391bbb6 | |||
88891083ae | |||
642db20562 | |||
b9b8ff6353 | |||
2a314c642f | |||
6fc9da30b6 | |||
f6ed7d555b | |||
02ad29180a | |||
d8e3b40488 | |||
9b7983ba63 | |||
03903b4c4d | |||
dd516f8032 | |||
4d8606e96c | |||
4b4bec3029 | |||
996f25a956 | |||
b5a7196ba4 | |||
2eb9e69e45 | |||
42d0096596 | |||
d239d88abd | |||
0b5a35f7c3 | |||
f9ab50d7d8 | |||
593861c0b6 | |||
7c87375614 | |||
efd8c865fe | |||
0dd38a5b50 | |||
87b9012ccd | |||
b868eeb3f1 | |||
f7393f5861 | |||
4e6ccf6c56 | |||
d8d0d2e8eb | |||
2cc55e1cba | |||
2cb2a3bab4 | |||
d1172f8441 | |||
8d1f51d2c0 | |||
0c989075bb | |||
e725a0291e | |||
de9323cb23 | |||
5a7523b534 | |||
33a831f9d4 | |||
67f7b7ec28 | |||
f0091d2f75 | |||
9405dd212b | |||
e9460972dd | |||
31f4a1ec6f | |||
abb525a1d3 | |||
95f11eb984 | |||
e9e46dd43a | |||
a9df5e9fd4 | |||
6d1f0b9507 | |||
2c08de2357 | |||
f468eefc97 | |||
e93fa0a7fd | |||
3dbfd7fa9c | |||
e8bbd70c56 | |||
32a6173004 | |||
02fcae1fa6 | |||
652fa4c037 | |||
a608d6fcf5 | |||
84439a368e | |||
491123bfbf | |||
e6fc6b82ea | |||
5090592ece | |||
b41f56e66b | |||
70f763dfd1 | |||
3e80e1b09e | |||
ba90fae02f | |||
17ed5c1f95 | |||
37498178d4 | |||
f2650e526d | |||
26bea9b7ba | |||
5515269387 | |||
c888450b19 | |||
f7903f59d8 | |||
e217d9ae97 | |||
2cd5353b0b | |||
0303cec0b5 | |||
f998889909 | |||
f9448e3906 | |||
a11e8c69f1 | |||
a321d474cb | |||
84f63524db | |||
664d9496ee | |||
28ae0b90f3 | |||
dd359a34c2 | |||
4db4403c3f | |||
e0e705c455 | |||
94cc7ac320 | |||
7e9b0ee660 | |||
12c7cf0b26 | |||
0589934b3f | |||
e6671fa416 | |||
75733a67ea | |||
96e212c554 | |||
08b3597377 | |||
e2cdac131c | |||
cbcba252f1 | |||
e5f2e27aef | |||
53155b3164 | |||
8bcc6956f5 | |||
d4037601d3 | |||
46547d09ff | |||
2ef26b9c22 | |||
0b356d3feb | |||
2c89db5816 | |||
e2d6124e40 | |||
def8638102 | |||
d474bdaf2b | |||
ae6f13027c | |||
edb7b34079 | |||
7fe2d31165 | |||
beb51219ed | |||
2e0bea186f | |||
a38fdfbee1 | |||
504e8288ee | |||
4030a24470 | |||
8e0e355762 | |||
4b60b9b19c | |||
d5e4c908d1 | |||
88676d0be9 | |||
bbc9b2233a | |||
3badc2ce20 | |||
e63d5a5a19 | |||
d90bf363bb | |||
9f3a20fb1e | |||
011d96337e | |||
be01219540 | |||
bfba420158 | |||
7b55091f9a | |||
ae8c11f6d0 | |||
fc15831f10 | |||
a24e6e9e1e | |||
8643245773 | |||
83f10810bb | |||
14a0934fda | |||
b29bb75259 | |||
c77e61ae8b | |||
b389ac1d9b | |||
288ec38050 | |||
bcbe50f12e | |||
5589bd05de | |||
bbf987a0a3 | |||
59b1ca51d3 | |||
ba1adb3f71 | |||
24be6f8054 | |||
66ff6f1516 | |||
c5f1e177aa | |||
3e9e11942a | |||
f030e626e3 | |||
12f45b19ba | |||
2818629b12 | |||
dace609a04 | |||
4df29d3ec1 | |||
7ccc3cbfaa | |||
1970b11e2d | |||
106f64d2f3 | |||
48f721831e | |||
e003c95221 | |||
3313bd3c65 | |||
38e83a336b | |||
a253c7f602 | |||
137e2e7786 | |||
4db3e3e146 | |||
5d2a19ce75 | |||
c1e5085b03 | |||
8069c65527 | |||
e6d2d7b090 | |||
dc3c3643c0 | |||
9d9efb7a4d | |||
248e681b42 | |||
003067f5d1 | |||
814210745a | |||
ecb1e01944 | |||
1daf48dad2 | |||
d1e080165b | |||
8a6b8f0489 | |||
2adee3dedd | |||
f49f9618be | |||
5082fe44c2 | |||
71d7d9bb0f | |||
16206b56df | |||
e7007c57a0 | |||
d36331543a | |||
d610ba9cff | |||
21dd6f02f7 | |||
e7052f0218 | |||
943d61793e | |||
37beea4929 | |||
2d34aa4ab7 | |||
a23d3161d7 | |||
7337becb65 | |||
ecbbef4213 | |||
7ec6e0861f | |||
cd38453a1f | |||
4591386b7c | |||
654595ce44 | |||
959a5f5cca | |||
5b7b0fbae7 | |||
86ca372f36 | |||
e4effbe818 | |||
7df59ab956 | |||
1f5f951819 | |||
9e64dcc10e | |||
b88abef4ed | |||
202c9b2294 | |||
b182e710ce | |||
321e5c624c | |||
f964c48a87 | |||
3462c4e846 | |||
4b01e39b51 | |||
a117053cf3 | |||
85dea9be3a | |||
4377d3fad3 | |||
bf75d4367d | |||
a80f7593b2 | |||
a6e94019d8 | |||
41394598ae | |||
a7926be90b | |||
bd19808ce8 | |||
6e11023709 | |||
c05b4d9fdd | |||
9bc98342e3 | |||
3f86a446f7 | |||
ab3ffd82fb | |||
bcd9da34e6 | |||
772db57862 | |||
97f7cf0387 | |||
61817fd735 | |||
eb9a8397db | |||
31b970a569 | |||
bf6ee242cd | |||
d6c9edfcbc | |||
9a7e0dbb75 | |||
135c3a29e3 | |||
bdb6b00e8c | |||
8bc227b871 | |||
b665f57aae | |||
f2d42b4370 | |||
66f982ab9e | |||
fd722ae3e6 | |||
2f7723b0ad | |||
433d15421e | |||
984a61f8fc | |||
d841b3b298 | |||
ab84a17b1f | |||
e6e4729035 | |||
037bd785ad | |||
7d71b3f0bd | |||
113d4c0895 | |||
5f82e5c644 | |||
b0d30c27f7 | |||
b3e3a99b54 | |||
63de746255 | |||
a30f7acba3 | |||
856e6266bf | |||
029d3c3bed | |||
94f8891d71 | |||
3c6beadec5 | |||
ecbfca8f73 | |||
2d7c1b85a3 | |||
b8fee02976 | |||
1a3a22085f | |||
3bf8f44286 | |||
11a6566093 | |||
de24492a0b | |||
4b2ab5dc19 | |||
d38c6f11df | |||
51373a4998 | |||
42f4912178 | |||
000720e9dc | |||
b64b0ebf02 | |||
38fa5b2ff7 | |||
2de1a9d686 | |||
d9c8c2bc4d | |||
67d0213c27 | |||
62eedc0447 | |||
e36e8e6b0f | |||
cde24dec05 | |||
551909adbd | |||
5744c8a54a | |||
f017fa549d | |||
070b16cc10 | |||
30a2be5bc9 | |||
f0c94ccc0f | |||
1850cec658 | |||
1181c49e06 | |||
6514b6475e | |||
63a79dc7ec | |||
714f8189e7 | |||
bc301388cc | |||
1117fde8fd | |||
af7c4292a4 | |||
56419ce603 | |||
029935ecc2 | |||
bfd09062e4 | |||
1203e68ec6 | |||
d07e03c584 | |||
f749c55b91 | |||
f5e1e84a75 | |||
539139e46b | |||
570981a779 | |||
996221e57d | |||
24158d40c9 | |||
c7ef38f813 | |||
4eafa791e3 | |||
269240128b | |||
ea715c4119 | |||
bf99a09ccf | |||
8974d80115 | |||
d750940807 | |||
b49cadb30a | |||
5bce2f65af | |||
4026ca277b | |||
8d52059629 | |||
966b931454 | |||
987f4ec700 | |||
cc32f9d618 | |||
3a9c9cbf8d | |||
b290815fbb | |||
1e694ac58f | |||
43e84a9660 | |||
c82f2c2638 | |||
b070b776f9 | |||
4ae7792806 | |||
59082dc913 | |||
8999f506a2 | |||
c48d04776a | |||
da7cd05efb | |||
54f0dff608 | |||
4ae60ecc95 | |||
394f7e74ae | |||
d696d7f7f3 | |||
677f8e2a67 | |||
91371bc17e | |||
caff3eb800 | |||
e643154f7b | |||
91507cbb94 | |||
5c3173a2f4 | |||
a3209ea914 | |||
3d252ffad3 | |||
fd7c2762e3 | |||
bb35c41a8d | |||
873f23f0c8 | |||
5a37931ae9 | |||
3b191aeb51 | |||
e65153c7f9 | |||
512485741f | |||
bab5f24e73 | |||
cd44a35b9f | |||
2288c79cf2 | |||
2c2fb948cd | |||
5a2a597ba1 | |||
58f52f56ac | |||
fea57bb55e | |||
1ce4abf089 | |||
9e4350759a | |||
3f53de0b1e | |||
fc05ed52b1 | |||
a3ad9bbf1d | |||
ac17b2aaa6 | |||
3ecc062e96 | |||
64a13744e4 | |||
cb48f7766b | |||
c41cfa07ad | |||
b079974229 | |||
861854a1b5 | |||
ccacc1c830 | |||
c326906198 | |||
10559b3466 | |||
b95f4fc3a3 | |||
1906c9276c | |||
4686b1c4b8 | |||
5bca236c4e | |||
1d3d5b973c | |||
4713cffc89 | |||
4573f0a0a9 | |||
bfddadff1f | |||
e0c329869d | |||
38241d8ad6 | |||
dfd32fe55e | |||
74138e59e9 | |||
ddbeba9021 | |||
5b0edc6888 | |||
011ff20b96 | |||
871a0c28aa | |||
628bf84e42 | |||
3cff1b4e85 | |||
55531b02a5 | |||
52fb49ed1c | |||
d948ba4ffe | |||
f5ddc9632e | |||
5576d4a4ca | |||
0a5eb81720 | |||
78d4b35ede | |||
ed7b3ce6e2 | |||
a0eeef3ef8 | |||
39db2912df | |||
b786a278f3 | |||
816eb3acab | |||
d2efe9c7de |
51
.github/actions/libfdkaac/action.yml
vendored
Normal file
51
.github/actions/libfdkaac/action.yml
vendored
Normal file
@ -0,0 +1,51 @@
|
||||
name: libfdkaac
|
||||
|
||||
inputs:
|
||||
env:
|
||||
type: string
|
||||
required: true
|
||||
config:
|
||||
type: string
|
||||
required: true
|
||||
|
||||
runs:
|
||||
using: "composite"
|
||||
steps:
|
||||
- name: Set up GIT
|
||||
shell: cmd
|
||||
run: |
|
||||
git config --global core.autocrlf false
|
||||
git config --global core.eol lf
|
||||
- name: Checkout FDK AAC
|
||||
uses: actions/checkout@v3
|
||||
with:
|
||||
repository: mstorsjo/fdk-aac
|
||||
ref: v2.0.2
|
||||
path: fdkaac
|
||||
- name: Check cache
|
||||
id: libfdkaac-cache
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: dist
|
||||
key: libfdkaac-${{ inputs.env }}-${{ inputs.config }}-${{ hashFiles('fdkaac') }}
|
||||
- name: Set up MSYS2
|
||||
if: steps.libfdkaac-cache.outputs.cache-hit != 'true'
|
||||
uses: msys2/setup-msys2@v2
|
||||
with:
|
||||
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
||||
path-type: inherit
|
||||
- name: Build FDK AAC
|
||||
if: steps.libfdkaac-cache.outputs.cache-hit != 'true'
|
||||
shell: cmd
|
||||
env:
|
||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||
cFlags: ${{ inputs.config == 'release' && '-MD' || '-MDd' }}
|
||||
run: |
|
||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||
md build dist
|
||||
D:\a\_temp\setup-msys2\msys2.cmd -c 'cd fdkaac ; autoreconf -fiv ; CC=cl.exe CXX=cl.exe CXXFLAGS=${{ env.cFlags }} ./configure --prefix=$(realpath ../build) --disable-shared --disable-static ; make ; make install ; cd ../build ; tar czf ../dist/libfdkaac.tgz *'
|
||||
- name: Publish artifact
|
||||
uses: actions/upload-artifact@v2
|
||||
with:
|
||||
name: libfdkaac-${{ inputs.env }}-${{ inputs.config }}
|
||||
path: dist/libfdkaac.tgz
|
32
.github/actions/libmp3lame/action.yml
vendored
Normal file
32
.github/actions/libmp3lame/action.yml
vendored
Normal file
@ -0,0 +1,32 @@
|
||||
name: libmp3lame
|
||||
|
||||
inputs:
|
||||
env:
|
||||
type: string
|
||||
required: true
|
||||
config:
|
||||
type: string
|
||||
required: true
|
||||
|
||||
runs:
|
||||
using: "composite"
|
||||
steps:
|
||||
- name: Set up MSYS2
|
||||
uses: msys2/setup-msys2@v2
|
||||
with:
|
||||
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm svn
|
||||
path-type: inherit
|
||||
- name: Build LAME
|
||||
shell: cmd
|
||||
env:
|
||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||
cFlags: ${{ inputs.config == 'release' && '-MD' || '-MDd' }}
|
||||
run: |
|
||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||
md build dist
|
||||
D:\a\_temp\setup-msys2\msys2.cmd -c 'svn co https://svn.code.sf.net/p/lame/svn/tags/RELEASE__3_100/lame lame ; cd lame ; autoreconf -i ; CC=cl.exe CXX=cl.exe CXXFLAGS=${{ env.cFlags }} ./configure --prefix=$(realpath ../build) --enable-nasm --disable-frontend --disable-shared --enable-static ; make -j ; make install ; cd ../build ; tar czf ../dist/libmp3lame.tgz *
|
||||
- name: Publish artifact
|
||||
uses: actions/upload-artifact@v2
|
||||
with:
|
||||
name: libmp3lame-${{ inputs.env }}-${{ inputs.config }}
|
||||
path: dist/libmp3lame.tgz
|
67
.github/actions/liboggvorbis/action.yml
vendored
Normal file
67
.github/actions/liboggvorbis/action.yml
vendored
Normal file
@ -0,0 +1,67 @@
|
||||
name: liboggvorbis
|
||||
|
||||
inputs:
|
||||
env:
|
||||
type: string
|
||||
required: true
|
||||
config:
|
||||
type: string
|
||||
required: true
|
||||
|
||||
runs:
|
||||
using: "composite"
|
||||
steps:
|
||||
- name: Set up GIT
|
||||
shell: cmd
|
||||
run: |
|
||||
git config --global core.autocrlf false
|
||||
git config --global core.eol lf
|
||||
- name: Checkout Ogg
|
||||
uses: actions/checkout@v3
|
||||
with:
|
||||
repository: xiph/ogg
|
||||
ref: v1.3.5
|
||||
path: ogg
|
||||
- name: Checkout Vorbis
|
||||
uses: actions/checkout@v3.0.0
|
||||
with:
|
||||
repository: xiph/vorbis
|
||||
ref: v1.3.7
|
||||
path: vorbis
|
||||
- name: Check cache
|
||||
id: liboggvorbis-cache
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: dist
|
||||
key: liboggvorbis-${{ inputs.env }}-${{ inputs.config }}-${{ hashFiles('ogg') }}-${{ hashFiles('vorbis') }}
|
||||
- name: Set up MSYS2
|
||||
if: steps.liboggvorbis-cache.outputs.cache-hit != 'true'
|
||||
uses: msys2/setup-msys2@v2
|
||||
with:
|
||||
install: base-devel binutils autotools automake
|
||||
path-type: inherit
|
||||
- name: Build Ogg
|
||||
if: steps.liboggvorbis-cache.outputs.cache-hit != 'true'
|
||||
shell: cmd
|
||||
env:
|
||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||
cFlags: ${{ inputs.config == 'release' && '-MD' || '-MDd' }}
|
||||
run: |
|
||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||
md build
|
||||
D:\a\_temp\setup-msys2\msys2.cmd -c 'cd ogg ; autoreconf -i ; CC=cl.exe CXX=cl.exe CXXFLAGS=${{ env.cFlags }} ./configure --prefix=$(realpath ../build) --disable-shared ; make -j ; make install'
|
||||
- name: Build Vorbis
|
||||
if: steps.liboggvorbis-cache.outputs.cache-hit != 'true'
|
||||
shell: cmd
|
||||
env:
|
||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||
cFlags: ${{ inputs.config == 'release' && '-MD' || '-MDd' }}
|
||||
run: |
|
||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||
md dist
|
||||
D:\a\_temp\setup-msys2\msys2.cmd -c 'cd vorbis ; autoreconf -i ; CC=cl.exe CXX=cl.exe CXXFLAGS=${{ env.cFlags }} ./configure --prefix=$(realpath ../build) --disable-shared ; make -j ; make install ; sed -i '/^Libs\.private.*/d' ../build/lib/pkgconfig/vorbis.pc ; cd ../build ; tar czf ../dist/liboggvorbis.tgz *'
|
||||
- name: Publish artifact
|
||||
uses: actions/upload-artifact@v2
|
||||
with:
|
||||
name: liboggvorbis-${{ inputs.env }}-${{ inputs.config }}
|
||||
path: dist/liboggvorbis.tgz
|
54
.github/actions/libopus/action.yml
vendored
Normal file
54
.github/actions/libopus/action.yml
vendored
Normal file
@ -0,0 +1,54 @@
|
||||
name: libopus
|
||||
|
||||
inputs:
|
||||
env:
|
||||
type: string
|
||||
required: true
|
||||
config:
|
||||
type: string
|
||||
required: true
|
||||
|
||||
runs:
|
||||
using: "composite"
|
||||
steps:
|
||||
- name: Set up GIT
|
||||
shell: cmd
|
||||
run: |
|
||||
git config --global core.autocrlf false
|
||||
git config --global core.eol lf
|
||||
- name: Checkout OPUS
|
||||
uses: actions/checkout@v3.0.0
|
||||
with:
|
||||
repository: xiph/opus
|
||||
ref: v1.3.1
|
||||
path: opus
|
||||
- name: Check cache
|
||||
id: libopus-cache
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: dist
|
||||
key: libopus-${{ inputs.env }}-${{ inputs.config }}-${{ hashFiles('opus') }}
|
||||
- name: Set up MSYS2
|
||||
if: steps.libopus-cache.outputs.cache-hit != 'true'
|
||||
uses: msys2/setup-msys2@v2
|
||||
with:
|
||||
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
||||
path-type: inherit
|
||||
- name: Build OPUS
|
||||
if: steps.libopus-cache.outputs.cache-hit != 'true'
|
||||
shell: cmd
|
||||
env:
|
||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||
cFlags: ${{ inputs.config == 'release' && '-MD' || '-MDd' }}
|
||||
msbuildConfig: ${{ inputs.config == 'release' && 'Release' || 'Debug' }}
|
||||
run: |
|
||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||
md build build\include build\lib build\lib\pkgconfig dist
|
||||
cd opus\win32\VS2015
|
||||
MSBuild.exe /property:Configuration="${{ env.msbuildConfig }}" /property:Platform=x64 /property:PlatformToolset=v143 opus.vcxproj
|
||||
D:\a\_temp\setup-msys2\msys2.cmd -c 'cp x64/${{ inputs.config }}/opus.lib ../../../build/lib/opus.lib ; cd ../../.. ; cp -r opus/include build/include/opus ; cp opus/opus.pc.in build/lib/pkgconfig/opus.pc ; sed -i "s#@prefix@#$(realpath ../../../build)#g" build/lib/pkgconfig/opus.pc ; sed -i "s/@exec_prefix@/\$\{prefix\}/g" build/lib/pkgconfig/opus.pc ; sed -i "s/@libdir@/\$\{prefix\}\/lib/g" build/lib/pkgconfig/opus.pc ; sed -i "s/@includedir@/\$\{prefix\}\/include/g" build/lib/pkgconfig/opus.pc ; sed -i "s/@LIBM@//g" build/lib/pkgconfig/opus.pc; sed -i "s/@VERSION@/2.0.0/g" build/lib/pkgconfig/opus.pc ; cd build ; tar czf ../dist/libopus.tgz *'
|
||||
- name: Publish artifact
|
||||
uses: actions/upload-artifact@v2
|
||||
with:
|
||||
name: libopus-${{ inputs.env }}-${{ inputs.config }}
|
||||
path: dist/libopus.tgz
|
57
.github/actions/libsnappy/action.yml
vendored
Normal file
57
.github/actions/libsnappy/action.yml
vendored
Normal file
@ -0,0 +1,57 @@
|
||||
name: libsnappy
|
||||
|
||||
inputs:
|
||||
env:
|
||||
type: string
|
||||
required: true
|
||||
config:
|
||||
type: string
|
||||
required: true
|
||||
|
||||
runs:
|
||||
using: "composite"
|
||||
steps:
|
||||
- name: Set up GIT
|
||||
shell: cmd
|
||||
run: |
|
||||
git config --global core.autocrlf false
|
||||
git config --global core.eol lf
|
||||
- name: Checkout Snappy
|
||||
uses: actions/checkout@v3
|
||||
with:
|
||||
repository: google/snappy
|
||||
ref: 1.1.9
|
||||
path: snappy
|
||||
- name: Check cache
|
||||
id: libsnappy-cache
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: dist
|
||||
key: libsnappy-${{ inputs.env }}-${{ inputs.config }}-${{ hashFiles('snappy') }}
|
||||
- name: Set up MSYS2
|
||||
if: steps.libsnappy-cache.outputs.cache-hit != 'true'
|
||||
uses: msys2/setup-msys2@v2
|
||||
with:
|
||||
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
||||
path-type: inherit
|
||||
- name: Build Snappy
|
||||
shell: cmd
|
||||
env:
|
||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||
cFlags: ${{ inputs.config == 'release' && '-MD' || '-MDd' }}
|
||||
msbuildConfig: ${{ inputs.config == 'release' && 'Release' || 'Debug' }}
|
||||
run: |
|
||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||
md build build\include build\lib build\lib\pkgconfig dist
|
||||
cd snappy
|
||||
git submodule update --init
|
||||
md work
|
||||
cd work
|
||||
cmake -G "Visual Studio 17 2022" .. -DCMAKE_INSTALL_PREFIX=..\..\build -DBUILD_SHARED_LIBS=OFF -DSNAPPY_BUILD_TESTS=OFF
|
||||
MSBuild.exe /property:Configuration="${{ env.msbuildConfig }}" Snappy.sln
|
||||
D:\a\_temp\setup-msys2\msys2.cmd -c 'cp ${{ inputs.config }}/snappy.lib ../../build/lib/snappy.lib ; cp ../snappy.h ../snappy-c.h ../../build/include/ ; cd ../../build ; tar czf ../dist/libsnappy.tgz *'
|
||||
- name: Publish artifact
|
||||
uses: actions/upload-artifact@v2
|
||||
with:
|
||||
name: libsnappy-${{ inputs.env }}-${{ inputs.config }}
|
||||
path: dist/libsnappy.tgz
|
51
.github/actions/libsvtav1/action.yml
vendored
Normal file
51
.github/actions/libsvtav1/action.yml
vendored
Normal file
@ -0,0 +1,51 @@
|
||||
name: libsvtav1
|
||||
|
||||
inputs:
|
||||
env:
|
||||
type: string
|
||||
required: true
|
||||
config:
|
||||
type: string
|
||||
required: true
|
||||
|
||||
runs:
|
||||
using: "composite"
|
||||
steps:
|
||||
- name: Set up GIT
|
||||
shell: cmd
|
||||
run: |
|
||||
git config --global core.autocrlf false
|
||||
git config --global core.eol lf
|
||||
- name: Checkout SVT AV1
|
||||
uses: actions/checkout@v3
|
||||
with:
|
||||
repository: AOMediaCodec/SVT-AV1
|
||||
ref: v1.1.0
|
||||
path: svtav1
|
||||
- name: Check cache
|
||||
id: libsvtav1-cache
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: dist
|
||||
key: libsvtav1-${{ inputs.env }}-${{ inputs.config }}-${{ hashFiles('svtav1') }}
|
||||
- name: Set up MSYS2
|
||||
if: steps.libsvtav1-cache.outputs.cache-hit != 'true'
|
||||
uses: msys2/setup-msys2@v2
|
||||
with:
|
||||
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
||||
path-type: inherit
|
||||
- name: Build SVT AV1
|
||||
if: steps.libsvtav1-cache.outputs.cache-hit != 'true'
|
||||
shell: cmd
|
||||
env:
|
||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||
cFlags: ${{ inputs.config == 'release' && '-MD' || '-MDd' }}
|
||||
run: |
|
||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||
md build build\include build\lib build\lib\pkgconfig dist
|
||||
D:\a\_temp\setup-msys2\msys2.cmd -c 'cd svtav1/Build/windows ; ./build.bat 2022 ${{ inputs.config }} static ; cp -r ../../Source/API ../../../build/include/svt-av1 ; cp ../../Bin/${{ inputs.config }}/SvtAv1Enc.lib ../../../build/lib/ ; cp SvtAv1Enc.pc ../../../build/lib/pkgconfig/ ; cd ../../../build ; tar czf ../dist/libsvtav1.tgz *'
|
||||
- name: Publish artifact
|
||||
uses: actions/upload-artifact@v2
|
||||
with:
|
||||
name: libsvtav1-${{ inputs.env }}-${{ inputs.config }}
|
||||
path: dist/libsvtav1.tgz
|
56
.github/actions/libvpl/action.yml
vendored
Normal file
56
.github/actions/libvpl/action.yml
vendored
Normal file
@ -0,0 +1,56 @@
|
||||
name: libvpl
|
||||
|
||||
inputs:
|
||||
env:
|
||||
type: string
|
||||
required: true
|
||||
config:
|
||||
type: string
|
||||
required: true
|
||||
|
||||
runs:
|
||||
using: "composite"
|
||||
steps:
|
||||
- name: Set up GIT
|
||||
shell: cmd
|
||||
run: |
|
||||
git config --global core.autocrlf false
|
||||
git config --global core.eol lf
|
||||
- name: Checkout oneVPL
|
||||
uses: actions/checkout@v3.0.0
|
||||
with:
|
||||
repository: oneapi-src/oneVPL
|
||||
ref: master
|
||||
path: onevpl
|
||||
- name: Check cache
|
||||
id: libvpl-cache
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: dist
|
||||
key: libvpl-${{ inputs.env }}-${{ inputs.config }}-${{ hashFiles('onevpl') }}
|
||||
- name: Set up MSYS2
|
||||
if: steps.libvpl-cache.outputs.cache-hit != 'true'
|
||||
uses: msys2/setup-msys2@v2
|
||||
with:
|
||||
install: base-devel binutils autotools automake
|
||||
path-type: inherit
|
||||
- name: Build oneVPL
|
||||
if: steps.libvpl-cache.outputs.cache-hit != 'true'
|
||||
shell: cmd
|
||||
env:
|
||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||
msbuildConfig: ${{ inputs.config == 'release' && 'Release' || 'Debug' }}
|
||||
run: |
|
||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||
md temp build dist
|
||||
cd temp
|
||||
cmake.exe -G "Visual Studio 17 2022" ..\onevpl -T host=x64 -A x64 -DBUILD_TOOLS=OFF -DBUILD_EXAMPLES=OFF -DBUILD_SHARED_LIBS=OFF -DCMAKE_INSTALL_PREFIX=..\build -DCMAKE_VS_INCLUDE_INSTALL_TO_DEFAULT_BUILD=ON
|
||||
MSBuild.exe -t:VPL,INSTALL -p:Configuration=${{ env.msbuildConfig }} -m vpl.sln
|
||||
cd ..\build
|
||||
IF EXIST "lib\vpld.lib" move "lib\vpld.lib" "lib\vpl.lib"
|
||||
D:\a\_temp\setup-msys2\msys2.cmd -c 'rm -rf bin/cmake ; tar czf ../dist/libvpl.tgz *'
|
||||
- name: Publish artifact
|
||||
uses: actions/upload-artifact@v2
|
||||
with:
|
||||
name: libvpl-${{ inputs.env }}-${{ inputs.config }}
|
||||
path: dist/libvpl.tgz
|
46
.github/actions/libvpx/action.yml
vendored
Normal file
46
.github/actions/libvpx/action.yml
vendored
Normal file
@ -0,0 +1,46 @@
|
||||
name: libvpx
|
||||
|
||||
inputs:
|
||||
env:
|
||||
type: string
|
||||
required: true
|
||||
config:
|
||||
type: string
|
||||
required: true
|
||||
|
||||
runs:
|
||||
using: "composite"
|
||||
steps:
|
||||
- name: Set up GIT
|
||||
shell: cmd
|
||||
run: |
|
||||
git config --global core.autocrlf false
|
||||
git config --global core.eol lf
|
||||
git clone --depth 1 -b v1.12.0 https://github.com/webmproject/libvpx.git vpx
|
||||
- name: Check cache
|
||||
id: libvpx-cache
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: dist
|
||||
key: libvpx-${{ inputs.env }}-${{ inputs.config }}-${{ hashFiles('vpx') }}
|
||||
- name: Set up MSYS2
|
||||
if: steps.libvpx-cache.outputs.cache-hit != 'true'
|
||||
uses: msys2/setup-msys2@v2
|
||||
with:
|
||||
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
||||
path-type: inherit
|
||||
- name: Build LibVpx
|
||||
if: steps.libvpx-cache.outputs.cache-hit != 'true'
|
||||
shell: cmd
|
||||
env:
|
||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||
cFlags: ${{ inputs.config == 'release' && '-MD' || '-MDd' }}
|
||||
run: |
|
||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||
md build build\include build\lib build\lib\pkgconfig dist
|
||||
D:\a\_temp\setup-msys2\msys2.cmd -c 'cd vpx ; ./configure --prefix=../build --target=x86_64-win64-vs17 --enable-vp9-highbitdepth --disable-shared --disable-examples --disable-tools --disable-docs --disable-libyuv --disable-unit_tests --disable-postproc ; make -j ; make install ; mv ../build/lib/x64/vpxmd.lib ../build/lib/vpx.lib ; rm -rf ../build/lib/x64 ; cd ../build ; tar czf ../dist/libvpx.tgz *'
|
||||
- name: Publish artifact
|
||||
uses: actions/upload-artifact@v2
|
||||
with:
|
||||
name: libvpx-${{ inputs.env }}-${{ inputs.config }}
|
||||
path: dist/libvpx.tgz
|
51
.github/actions/libx264/action.yml
vendored
Normal file
51
.github/actions/libx264/action.yml
vendored
Normal file
@ -0,0 +1,51 @@
|
||||
name: libx264
|
||||
|
||||
inputs:
|
||||
env:
|
||||
type: string
|
||||
required: true
|
||||
config:
|
||||
type: string
|
||||
required: true
|
||||
|
||||
runs:
|
||||
using: "composite"
|
||||
steps:
|
||||
- name: Set up GIT
|
||||
shell: cmd
|
||||
run: |
|
||||
git config --global core.autocrlf false
|
||||
git config --global core.eol lf
|
||||
- name: Checkout X264
|
||||
uses: actions/checkout@v3
|
||||
with:
|
||||
repository: mirror/x264
|
||||
ref: stable
|
||||
path: x264
|
||||
- name: Check cache
|
||||
id: libx264-cache
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: dist
|
||||
key: libx264-${{ inputs.env }}-${{ inputs.config }}-${{ hashFiles('x264') }}
|
||||
- name: Set up MSYS2
|
||||
if: steps.libx264-cache.outputs.cache-hit != 'true'
|
||||
uses: msys2/setup-msys2@v2
|
||||
with:
|
||||
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
||||
path-type: inherit
|
||||
- name: Build X264
|
||||
if: steps.libx264-cache.outputs.cache-hit != 'true'
|
||||
shell: cmd
|
||||
env:
|
||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||
cFlags: ${{ inputs.config == 'release' && '-MD' || '-MDd' }}
|
||||
run: |
|
||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||
md build build\include build\lib build\lib\pkgconfig dist
|
||||
D:\a\_temp\setup-msys2\msys2.cmd -c 'cd x264 ; CC=cl ./configure --prefix=$(realpath ../build) --disable-cli --enable-static --enable-pic --libdir=../build/lib ; make -j ; make install-lib-static ; cd ../build ; tar czf ../dist/libx264.tgz *'
|
||||
- name: Publish artifact
|
||||
uses: actions/upload-artifact@v2
|
||||
with:
|
||||
name: libx264-${{ inputs.env }}-${{ inputs.config }}
|
||||
path: dist/libx264.tgz
|
48
.github/actions/libx265-10/action.yml
vendored
Normal file
48
.github/actions/libx265-10/action.yml
vendored
Normal file
@ -0,0 +1,48 @@
|
||||
name: libx265-10
|
||||
|
||||
inputs:
|
||||
env:
|
||||
type: string
|
||||
required: true
|
||||
config:
|
||||
type: string
|
||||
required: true
|
||||
|
||||
runs:
|
||||
using: "composite"
|
||||
steps:
|
||||
- name: Checkout X265
|
||||
shell: cmd
|
||||
run: |
|
||||
git config --global core.autocrlf false
|
||||
git config --global core.eol lf
|
||||
git clone -b Release_3.5 https://github.com/videolan/x265.git x265
|
||||
- name: Check cache
|
||||
id: libx26510-cache
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: dist
|
||||
key: libx265-10-${{ inputs.env }}-${{ inputs.config }}-${{ hashFiles('x265') }}
|
||||
- name: Set up MSBuild
|
||||
if: steps.libx26510-cache.outputs.cache-hit != 'true'
|
||||
uses: microsoft/setup-msbuild@v1.1
|
||||
- name: Set up NASM
|
||||
if: steps.libx26510-cache.outputs.cache-hit != 'true'
|
||||
uses: ilammy/setup-nasm@v1.2.1
|
||||
- name: Build X265 (10 bit)
|
||||
if: steps.libx26510-cache.outputs.cache-hit != 'true'
|
||||
shell: cmd
|
||||
run: |
|
||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||
md build dist
|
||||
cd x265/build/vc15-x86_64
|
||||
md work
|
||||
cd work
|
||||
cmake -G "Visual Studio 17 2022" ..\..\..\source -DHIGH_BIT_DEPTH=ON -DEXPORT_C_API=OFF -DENABLE_SHARED=OFF -DENABLE_CLI=OFF
|
||||
MSBuild.exe /property:Configuration="${{ env.msbuildConfig }}" x265-static.vcxproj
|
||||
move ${{ inputs.config }}\x265-static.lib ..\..\..\..\dist\x265_10bit.lib
|
||||
- name: Publish artifact
|
||||
uses: actions/upload-artifact@v2
|
||||
with:
|
||||
name: x265_10bit-${{ inputs.env }}-${{ inputs.config }}
|
||||
path: dist/x265_10bit.lib
|
52
.github/actions/libx265-12/action.yml
vendored
Normal file
52
.github/actions/libx265-12/action.yml
vendored
Normal file
@ -0,0 +1,52 @@
|
||||
name: libx265-12
|
||||
|
||||
inputs:
|
||||
env:
|
||||
type: string
|
||||
required: true
|
||||
config:
|
||||
type: string
|
||||
required: true
|
||||
|
||||
runs:
|
||||
using: "composite"
|
||||
steps:
|
||||
- name: Checkout X265
|
||||
shell: cmd
|
||||
run: |
|
||||
git config --global core.autocrlf false
|
||||
git config --global core.eol lf
|
||||
git clone -b Release_3.5 https://github.com/videolan/x265.git x265
|
||||
- name: Check cache
|
||||
id: libx26512-cache
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: dist
|
||||
key: libx265-12-${{ inputs.env }}-${{ inputs.config }}-${{ hashFiles('x265') }}
|
||||
- name: Set up MSBuild
|
||||
if: steps.libx26512-cache.outputs.cache-hit != 'true'
|
||||
uses: microsoft/setup-msbuild@v1.1
|
||||
- name: Set up NASM
|
||||
if: steps.libx26512-cache.outputs.cache-hit != 'true'
|
||||
uses: ilammy/setup-nasm@v1.2.1
|
||||
- name: Build X265 (12 bit)
|
||||
if: steps.libx26512-cache.outputs.cache-hit != 'true'
|
||||
shell: cmd
|
||||
env:
|
||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||
cFlags: ${{ inputs.config == 'release' && '-MD' || '-MDd' }}
|
||||
msbuildConfig: ${{ inputs.config == 'release' && 'Release' || 'Debug' }}
|
||||
run: |
|
||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||
md build dist
|
||||
cd x265/build/vc15-x86_64
|
||||
md work
|
||||
cd work
|
||||
cmake -G "Visual Studio 17 2022" ..\..\..\source -DHIGH_BIT_DEPTH=ON -DEXPORT_C_API=OFF -DENABLE_SHARED=OFF -DENABLE_CLI=OFF -DMAIN12=ON
|
||||
MSBuild.exe /property:Configuration="${{ env.msbuildConfig }}" x265-static.vcxproj
|
||||
move ${{ inputs.config }}\x265-static.lib ..\..\..\..\dist\x265_12bit.lib
|
||||
- name: Publish artifact
|
||||
uses: actions/upload-artifact@v2
|
||||
with:
|
||||
name: x265_12bit-${{ inputs.env }}-${{ inputs.config }}
|
||||
path: dist/x265_12bit.lib
|
69
.github/actions/libx265/action.yml
vendored
Normal file
69
.github/actions/libx265/action.yml
vendored
Normal file
@ -0,0 +1,69 @@
|
||||
name: libx265
|
||||
|
||||
inputs:
|
||||
env:
|
||||
type: string
|
||||
required: true
|
||||
config:
|
||||
type: string
|
||||
required: true
|
||||
|
||||
runs:
|
||||
using: "composite"
|
||||
steps:
|
||||
- name: Checkout X265
|
||||
shell: cmd
|
||||
run: |
|
||||
git config --global core.autocrlf false
|
||||
git config --global core.eol lf
|
||||
git clone -b Release_3.5 https://github.com/videolan/x265.git x265
|
||||
- name: Check cache
|
||||
id: libx265-cache
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: di
|
||||
key: libx265-${{ inputs.env }}-${{ inputs.config }}-${{ hashFiles('x265') }}
|
||||
- name: Set up MSYS2
|
||||
if: steps.libx265-cache.outputs.cache-hit != 'true'
|
||||
uses: msys2/setup-msys2@v2
|
||||
with:
|
||||
install: base-devel binutils autotools automake
|
||||
path-type: inherit
|
||||
- name: Set up MSBuild
|
||||
if: steps.libx265-cache.outputs.cache-hit != 'true'
|
||||
uses: microsoft/setup-msbuild@v1.1
|
||||
- name: Set up NASM
|
||||
if: steps.libx265-cache.outputs.cache-hit != 'true'
|
||||
uses: ilammy/setup-nasm@v1.2.1
|
||||
- name: Set up dependant libs
|
||||
if: steps.libx265-cache.outputs.cache-hit != 'true'
|
||||
uses: actions/download-artifact@v3
|
||||
with:
|
||||
path: build
|
||||
- name: Build X265
|
||||
if: steps.libx265-cache.outputs.cache-hit != 'true'
|
||||
shell: cmd
|
||||
env:
|
||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||
cFlags: ${{ inputs.config == 'release' && '-MD' || '-MDd' }}
|
||||
msbuildConfig: ${{ inputs.config == 'release' && 'Release' || 'Debug' }}
|
||||
run: |
|
||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||
md di dist dist\include dist\lib dist\lib\pkgconfig
|
||||
cd x265/build/vc15-x86_64
|
||||
md work
|
||||
cd work
|
||||
cmake -G "Visual Studio 17 2022" ..\..\..\source -DCMAKE_INSTALL_PREFIX=..\..\..\..\build -DENABLE_SHARED=OFF -DENABLE_CLI=OFF -DEXTRA_LIB="libx265_10bit.lib;libx265_12bit.lib" -DLINKED_10BIT=ON -DLINKED_12BIT=ON
|
||||
MSBuild.exe /property:Configuration="${{ env.msbuildConfig }}" x265-static.vcxproj
|
||||
cp x265.pc ..\..\..\..\dist\lib\pkgconfig\x265.pc
|
||||
move ${{ inputs.config }}\x265-static.lib ..\..\..\..\build\
|
||||
move x265_config.h ..\..\..\..\dist\include\
|
||||
cd ..\..\..\..
|
||||
"${{ env.vsPath }}VC\Tools\MSVC\14.29.30133\bin\Hostx64\x64\lib.exe" /ignore:4006 /ignore:4221 /OUT:dist\lib\x265.lib build\x265-static.lib build\x265_10bit-${{ inputs.env }}-${{ inputs.config }}\x265_10bit.lib build\x265_12bit-${{ inputs.env }}-${{ inputs.config }}\x265_12bit.lib
|
||||
copy x265\source\x265.h dist\include\
|
||||
D:\a\_temp\setup-msys2\msys2.cmd -c 'cd dist ; tar czf ../di/libx265.tgz *'
|
||||
- name: Publish artifact
|
||||
uses: actions/upload-artifact@v2
|
||||
with:
|
||||
name: libx265-${{ inputs.env }}-${{ inputs.config }}
|
||||
path: di/libx265.tgz
|
52
.github/actions/libzimg/action.yml
vendored
Normal file
52
.github/actions/libzimg/action.yml
vendored
Normal file
@ -0,0 +1,52 @@
|
||||
name: libzimg
|
||||
|
||||
inputs:
|
||||
env:
|
||||
type: string
|
||||
required: true
|
||||
config:
|
||||
type: string
|
||||
required: true
|
||||
|
||||
runs:
|
||||
using: "composite"
|
||||
steps:
|
||||
- name: Set up GIT
|
||||
shell: cmd
|
||||
run: |
|
||||
git config --global core.autocrlf false
|
||||
git config --global core.eol lf
|
||||
- name: Checkout ZIMG
|
||||
uses: actions/checkout@v3.0.0
|
||||
with:
|
||||
repository: sekrit-twc/zimg
|
||||
ref: release-3.0.4
|
||||
path: zimg
|
||||
- name: Check cache
|
||||
id: libzimg-cache
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: dist
|
||||
key: libzimg-${{ inputs.env }}-${{ inputs.config }}-${{ hashFiles('zimg') }}
|
||||
- name: Set up MSYS2
|
||||
if: steps.libzimg-cache.outputs.cache-hit != 'true'
|
||||
uses: msys2/setup-msys2@v2
|
||||
with:
|
||||
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
||||
path-type: inherit
|
||||
- name: Build ZIMG
|
||||
if: steps.libzimg-cache.outputs.cache-hit != 'true'
|
||||
shell: cmd
|
||||
env:
|
||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||
cFlags: ${{ inputs.config == 'release' && '-MD' || '-MDd' }}
|
||||
msbuildConfig: ${{ inputs.config == 'release' && 'Release' || 'Debug' }}
|
||||
run: |
|
||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||
md build build\include build\lib build\lib\pkgconfig dist
|
||||
D:\a\_temp\setup-msys2\msys2.cmd -c 'cd zimg ; ./autogen.sh ; ./configure --prefix=$(realpath ../build) ; cd _msvc/zimg ; MSBuild.exe /property:Configuration="${{ env.msbuildConfig }}" /property:ConfigurationType=StaticLibrary /property:PlatformToolset=v143 /property:Platform=x64 /property:WholeProgramOptimization=false zimg.vcxproj ; cp x64/${{ inputs.config }}/z.lib ../../../build/lib/zimg.lib ; cd ../.. ; cp src/zimg/api/zimg.h ../build/include/zimg.h ; cp zimg.pc ../build/lib/pkgconfig/zimg.pc ; cd ../build ; tar czf ../dist/libzimg.tgz *'
|
||||
- name: Publish artifact
|
||||
uses: actions/upload-artifact@v2
|
||||
with:
|
||||
name: libzimg-${{ inputs.env }}-${{ inputs.config }}
|
||||
path: dist/libzimg.tgz
|
33
.github/workflows/build.yml
vendored
33
.github/workflows/build.yml
vendored
@ -1,18 +1,25 @@
|
||||
name: CI
|
||||
name: Build all
|
||||
|
||||
on:
|
||||
workflow_dispatch:
|
||||
schedule:
|
||||
- cron: "0 2 * * *"
|
||||
- cron: "0 1 * * *"
|
||||
|
||||
jobs:
|
||||
build:
|
||||
runs-on: windows-latest
|
||||
steps:
|
||||
- name: Build it!
|
||||
run:
|
||||
choco install msys2
|
||||
echo "::set-env name=CHERE_INVOKING::enabled_from_arguments"
|
||||
echo "::set-env name=MODE::release"
|
||||
echo "::set-env name=MSYS2_PATH_TYPE::inherit"
|
||||
echo "::set-env name=MSYSTEM::MINGW64"
|
||||
c:\tools\msys64\usr\bin\bash.exe -l -c "pacman -S base-devel binutils git make pkg-config"
|
||||
ffmpeg-static-debug:
|
||||
uses: ./.github/workflows/ffmpeg.yml
|
||||
with:
|
||||
env: windows-2022
|
||||
source: ffmpeg
|
||||
type: static
|
||||
config: debug
|
||||
ffmpegRef: release/5.0
|
||||
|
||||
ffmpeg-static-release:
|
||||
uses: ./.github/workflows/ffmpeg.yml
|
||||
with:
|
||||
env: windows-2022
|
||||
source: ffmpeg
|
||||
type: static
|
||||
config: release
|
||||
ffmpegRef: release/5.0
|
||||
|
292
.github/workflows/ffmpeg.yml
vendored
Normal file
292
.github/workflows/ffmpeg.yml
vendored
Normal file
@ -0,0 +1,292 @@
|
||||
name: 'Build FFmpeg'
|
||||
|
||||
on:
|
||||
workflow_dispatch:
|
||||
inputs:
|
||||
env:
|
||||
type: choice
|
||||
required: true
|
||||
default: 'windows-2022'
|
||||
description: 'Environment'
|
||||
options:
|
||||
- windows-2022
|
||||
|
||||
source:
|
||||
type: choice
|
||||
required: true
|
||||
default: 'ffmpeg'
|
||||
description: Source
|
||||
options:
|
||||
- ffmpeg
|
||||
- cartwheel
|
||||
|
||||
type:
|
||||
type: choice
|
||||
required: true
|
||||
default: 'static'
|
||||
description: Type
|
||||
options:
|
||||
- static
|
||||
- shared
|
||||
|
||||
config:
|
||||
type: choice
|
||||
required: true
|
||||
default: 'debug'
|
||||
description: 'Configuration'
|
||||
options:
|
||||
- debug
|
||||
- release
|
||||
|
||||
ffmpegRef:
|
||||
type: string
|
||||
required: true
|
||||
default: 'release/5.0'
|
||||
description: 'FFmpeg refId'
|
||||
|
||||
workflow_call:
|
||||
inputs:
|
||||
env:
|
||||
type: string
|
||||
required: true
|
||||
source:
|
||||
type: string
|
||||
required: true
|
||||
type:
|
||||
type: string
|
||||
required: true
|
||||
config:
|
||||
type: string
|
||||
required: true
|
||||
ffmpegRef:
|
||||
type: string
|
||||
required: true
|
||||
|
||||
env:
|
||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||
COMPONENTS: "--enable-libsvtav1 --enable-libsnappy --enable-libmp3lame --enable-libzimg --enable-libopus --enable-libvorbis --enable-libx264 --enable-libx265 --enable-libfdk-aac --enable-libvpx "
|
||||
NASM_EXECUTABLE: nasm
|
||||
cFlags: ${{ inputs.config == 'release' && '-MD' || '-MDd' }}
|
||||
variant: ${{ inputs.type == 'static' && ' --pkg-config-flags="--static" --disable-shared --enable-static' || ' --disable-static --enable-shared' }}
|
||||
msbuildConfig: ${{ inputs.config == 'release' && 'Release' || 'Debug' }}
|
||||
|
||||
jobs:
|
||||
libvpl:
|
||||
runs-on: ${{ inputs.env }}
|
||||
if: ${{ inputs.source == 'cartwheel' }}
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- uses: ./.github/actions/libvpl
|
||||
with:
|
||||
env: ${{ inputs.env }}
|
||||
config: ${{ inputs.config }}
|
||||
|
||||
liboggvorbis:
|
||||
runs-on: ${{ inputs.env }}
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- uses: ./.github/actions/liboggvorbis
|
||||
with:
|
||||
env: ${{ inputs.env }}
|
||||
config: ${{ inputs.config }}
|
||||
|
||||
libsvtav1:
|
||||
runs-on: ${{ inputs.env }}
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- uses: ./.github/actions/libsvtav1
|
||||
with:
|
||||
env: ${{ inputs.env }}
|
||||
config: ${{ inputs.config }}
|
||||
|
||||
libsnappy:
|
||||
runs-on: ${{ inputs.env }}
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- uses: ./.github/actions/libsnappy
|
||||
with:
|
||||
env: ${{ inputs.env }}
|
||||
config: ${{ inputs.config }}
|
||||
|
||||
libvpx:
|
||||
runs-on: ${{ inputs.env }}
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- uses: ./.github/actions/libvpx
|
||||
with:
|
||||
env: ${{ inputs.env }}
|
||||
config: ${{ inputs.config }}
|
||||
|
||||
libmp3lame:
|
||||
runs-on: ${{ inputs.env }}
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- uses: ./.github/actions/libmp3lame
|
||||
with:
|
||||
env: ${{ inputs.env }}
|
||||
config: ${{ inputs.config }}
|
||||
|
||||
libzimg:
|
||||
runs-on: ${{ inputs.env }}
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- uses: ./.github/actions/libzimg
|
||||
with:
|
||||
env: ${{ inputs.env }}
|
||||
config: ${{ inputs.config }}
|
||||
|
||||
libopus:
|
||||
runs-on: ${{ inputs.env }}
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- uses: ./.github/actions/libopus
|
||||
with:
|
||||
env: ${{ inputs.env }}
|
||||
config: ${{ inputs.config }}
|
||||
|
||||
libfdkaac:
|
||||
runs-on: ${{ inputs.env }}
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- uses: ./.github/actions/libfdkaac
|
||||
with:
|
||||
env: ${{ inputs.env }}
|
||||
config: ${{ inputs.config }}
|
||||
|
||||
libx264:
|
||||
runs-on: ${{ inputs.env }}
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- uses: ./.github/actions/libx264
|
||||
with:
|
||||
env: ${{ inputs.env }}
|
||||
config: ${{ inputs.config }}
|
||||
|
||||
libx265-12:
|
||||
runs-on: ${{ inputs.env }}
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- uses: ./.github/actions/libx265-12
|
||||
with:
|
||||
env: ${{ inputs.env }}
|
||||
config: ${{ inputs.config }}
|
||||
|
||||
libx265-10:
|
||||
runs-on: ${{ inputs.env }}
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- uses: ./.github/actions/libx265-10
|
||||
with:
|
||||
env: ${{ inputs.env }}
|
||||
config: ${{ inputs.config }}
|
||||
|
||||
libx265:
|
||||
runs-on: ${{ inputs.env }}
|
||||
needs: [libx265-12,libx265-10]
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- uses: ./.github/actions/libx265
|
||||
with:
|
||||
env: ${{ inputs.env }}
|
||||
config: ${{ inputs.config }}
|
||||
|
||||
cartwheel:
|
||||
runs-on: ${{ inputs.env }}
|
||||
if: ${{ inputs.source == 'cartwheel' }}
|
||||
needs: [libvpl,libopus,libsvtav1,libsnappy,libmp3lame,libzimg,liboggvorbis,libx264,libx265,libfdkaac,libvpx]
|
||||
steps:
|
||||
- name: Set up MSYS2
|
||||
uses: msys2/setup-msys2@v2
|
||||
with:
|
||||
install: base-devel binutils mingw-w64-x86_64-cmake nasm
|
||||
path-type: inherit
|
||||
- name: Set up GIT
|
||||
run: |
|
||||
git config --global core.autocrlf false
|
||||
git config --global core.eol lf
|
||||
git config --global user.email "daniel.stankewitz@gmail.com"
|
||||
git config --global user.name "Daniel Stankewitz"
|
||||
- name: Checkout patches
|
||||
uses: actions/checkout@v3.0.0
|
||||
- name: Checkout NvEnc
|
||||
uses: actions/checkout@v3.0.0
|
||||
with:
|
||||
repository: FFmpeg/nv-codec-headers
|
||||
ref: master
|
||||
path: nvenc
|
||||
- name: Checkout AMF
|
||||
uses: actions/checkout@v3.0.0
|
||||
with:
|
||||
repository: GPUOpen-LibrariesAndSDKs/AMF
|
||||
ref: master
|
||||
path: amf
|
||||
- name: Set up artifacts
|
||||
uses: actions/download-artifact@v3
|
||||
with:
|
||||
path: build_artifacts
|
||||
- name: Build FFmpeg from Cartwheel
|
||||
shell: cmd
|
||||
run: |
|
||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||
md build dist
|
||||
rem D:\a\_temp\setup-msys2\msys2.cmd -c 'git config --global user.email "daniel.stankewitz@gmail.com" ; git config --global user.name "Daniel Stankewitz" ; git clone https://github.com/intel-media-ci/cartwheel-ffmpeg --recursive cartwheel ; cd cartwheel ; git checkout b3f9843cffd4118e35bb000779444ca2f4196342 ; git submodule update --init --recursive ; cd ffmpeg ; git am ../patches/*.patch ; git apply --ignore-whitespace --verbose ../../0003-dynamic-loading-of-shared-fdk-aac-library-5.0.patch ; sed -i "s/#define X264_API_IMPORTS 1/\/\/#define X264_API_IMPORTS 1/g" libavcodec/libx264.c ; cd ../../build ; for file in `ls ../build_artifacts/**/*.tgz`; do tar -xzf $file; done ; rm -f bin/*.dll ; cd ../nvenc ; make PREFIX=../build install ; cp -a ../amf/amf/public/include ../build/include/AMF ; cd ../cartwheel/ffmpeg ; PKG_CONFIG_PATH=../../build/lib/pkgconfig ./configure --toolchain=msvc --extra-cflags="${{ env.cFlags }} -I../../build/include" --extra-ldflags="-LIBPATH:../../build/lib" --prefix=../../build --pkg-config-flags="--static" --extra-libs=Ole32.lib --extra-libs=Advapi32.lib --disable-doc --disable-shared --enable-static --enable-runtime-cpudetect --disable-devices --disable-demuxers --disable-decoders --disable-network --enable-w32threads --enable-gpl ${{ env.COMPONENTS }} ; make -j 2 ; make install ; cd ../../build/lib ; for file in *.a; do mv "$file" "`basename "$file" .a`.lib" ; done ; rm -rf fdk-aac.lib cmake pkgconfig *.la ../share ; cd .. ; tar czf ../dist/ffmpeg-win64-static-${{ inputs.config }}.tar.gz *'
|
||||
rem D:\a\_temp\setup-msys2\msys2.cmd -c 'git config --global user.email "daniel.stankewitz@gmail.com" ; git config --global user.name "Daniel Stankewitz" ; git clone https://github.com/intel-media-ci/cartwheel-ffmpeg --recursive cartwheel ; cd cartwheel ; git checkout 2757a1d43ca83a3762b24a7ddd74b3291873f89c ; cd patches ; git apply --ignore-whitespace ../../hotfix.patch ; cd .. ; git submodule update --init --recursive ; cd ffmpeg ; git am ../patches/*.patch ; git apply --ignore-whitespace --verbose ../../0001-dynamic-loading-of-shared-fdk-aac-library-cw-5.0.patch ; sed -i "s/#define X264_API_IMPORTS 1/\/\/#define X264_API_IMPORTS 1/g" libavcodec/libx264.c ; cd ../../build ; for file in `ls ../build_artifacts/**/*.tgz`; do tar -xzf $file; done ; rm -f bin/*.dll ; cd ../nvenc ; make PREFIX=../build install ; cp -a ../amf/amf/public/include ../build/include/AMF ; cd ../cartwheel/ffmpeg ; PKG_CONFIG_PATH=../../build/lib/pkgconfig ./configure --toolchain=msvc --extra-cflags="${{ env.cFlags }} -I../../build/include" --extra-ldflags="-LIBPATH:../../build/lib" --prefix=../../build --pkg-config-flags="--static" --extra-libs=Ole32.lib --extra-libs=Advapi32.lib --disable-doc --disable-shared --enable-static --enable-runtime-cpudetect --enable-w32threads --enable-gpl ${{ env.COMPONENTS }} ; make -j 2 ; make install ; cd ../../build/lib ; for file in *.a; do mv "$file" "`basename "$file" .a`.lib" ; done ; rm -rf fdk-aac.lib cmake pkgconfig *.la ../share ; cd .. ; tar czf ../dist/ffmpeg-win64-static-${{ inputs.config }}.tar.gz *'
|
||||
D:\a\_temp\setup-msys2\msys2.cmd -c 'git config --global user.email "daniel.stankewitz@gmail.com" ; git config --global user.name "Daniel Stankewitz" ; git clone https://github.com/intel-media-ci/cartwheel-ffmpeg --recursive cartwheel ; cd cartwheel ; cd patches ; git apply --ignore-whitespace ../../hotfix.patch ; cd .. ; git submodule update --init --recursive ; cd ffmpeg ; git am ../patches/*.patch ; git apply --ignore-whitespace --verbose ../../0001-dynamic-loading-of-shared-fdk-aac-library-cw-5.0.patch ; sed -i "s/#define X264_API_IMPORTS 1/\/\/#define X264_API_IMPORTS 1/g" libavcodec/libx264.c ; cd ../../build ; for file in `ls ../build_artifacts/**/*.tgz`; do tar -xzf $file; done ; rm -f bin/*.dll ; cd ../nvenc ; make PREFIX=../build install ; cp -a ../amf/amf/public/include ../build/include/AMF ; cd ../cartwheel/ffmpeg ; PKG_CONFIG_PATH=../../build/lib/pkgconfig ./configure --toolchain=msvc --extra-cflags="${{ env.cFlags }} -I../../build/include" --extra-ldflags="-LIBPATH:../../build/lib" --prefix=../../build --extra-libs=Ole32.lib --extra-libs=Advapi32.lib --disable-doc ${{ env.variant }} --enable-runtime-cpudetect --enable-w32threads --enable-gpl --enable-libvpl ${{ env.COMPONENTS }} ; make -j 2 ; make install ; cd ../../build/lib ; for file in *.a; do mv "$file" "`basename "$file" .a`.lib" ; done ; rm -rf fdk-aac.lib cmake pkgconfig *.la ../share ; cd .. ; tar czf ../dist/ffmpeg-win64-${{ inputs.type }}-${{ inputs.config }}.tar.gz *'
|
||||
- name: Publish artifacts
|
||||
uses: actions/upload-artifact@v3
|
||||
with:
|
||||
name: FFmpeg (Cartwheel) ${{ inputs.env }} ${{ inputs.config }} package build
|
||||
path: dist/ffmpeg-win64-${{ inputs.type }}-${{ inputs.config }}.tar.gz
|
||||
|
||||
ffmpeg:
|
||||
runs-on: ${{ inputs.env }}
|
||||
if: ${{ inputs.source == 'ffmpeg' }}
|
||||
needs: [libopus,libsvtav1,libsnappy,libmp3lame,libzimg,liboggvorbis,libx264,libx265,libfdkaac,libvpx]
|
||||
steps:
|
||||
- name: Set up MSYS2
|
||||
uses: msys2/setup-msys2@v2
|
||||
with:
|
||||
install: base-devel binutils mingw-w64-x86_64-cmake nasm
|
||||
path-type: inherit
|
||||
- name: Set up GIT
|
||||
run: |
|
||||
git config --global core.autocrlf false
|
||||
git config --global core.eol lf
|
||||
git config --global user.email "daniel.stankewitz@gmail.com"
|
||||
git config --global user.name "Daniel Stankewitz"
|
||||
- name: Checkout patches
|
||||
uses: actions/checkout@v3.0.0
|
||||
- name: Checkout FFmpeg
|
||||
if: ${{ inputs.source == 'ffmpeg' }}
|
||||
uses: actions/checkout@v3.0.0
|
||||
with:
|
||||
repository: FFmpeg/FFmpeg.git
|
||||
ref: ${{ inputs.ffmpegRef }}
|
||||
path: ffmpeg
|
||||
- name: Checkout NvEnc
|
||||
uses: actions/checkout@v3.0.0
|
||||
with:
|
||||
repository: FFmpeg/nv-codec-headers
|
||||
ref: master
|
||||
path: nvenc
|
||||
- name: Checkout AMF
|
||||
uses: actions/checkout@v3.0.0
|
||||
with:
|
||||
repository: GPUOpen-LibrariesAndSDKs/AMF
|
||||
ref: master
|
||||
path: amf
|
||||
- name: Set up artifacts
|
||||
uses: actions/download-artifact@v3
|
||||
with:
|
||||
path: build_artifacts
|
||||
- name: Build FFmpeg
|
||||
shell: cmd
|
||||
run: |
|
||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||
md build dist
|
||||
D:\a\_temp\setup-msys2\msys2.cmd -c 'cd ffmpeg ; git apply --ignore-whitespace --verbose ../0003-dynamic-loading-of-shared-fdk-aac-library-5.0.patch ; sed -i "s/#define X264_API_IMPORTS 1/\/\/#define X264_API_IMPORTS 1/g" libavcodec/libx264.c ; cd ../build ; for file in `ls ../build_artifacts/**/*.tgz`; do tar -xzf $file; done ; rm -f bin/*.dll ; cd ../nvenc ; make PREFIX=../build install ; cp -a ../amf/amf/public/include ../build/include/AMF ; cd ../ffmpeg ; PKG_CONFIG_PATH=../build/lib/pkgconfig ./configure --toolchain=msvc --extra-cflags="${{ env.cFlags }} -I../build/include" --extra-ldflags="-LIBPATH:../build/lib" --prefix=../build --pkg-config-flags="--static" --disable-doc ${{ env.variant }} --enable-runtime-cpudetect --disable-devices --disable-demuxers --disable-decoders --disable-network --enable-w32threads --enable-gpl ${{ env.COMPONENTS }} ; make -j 2 ; make install ; cd ../build/lib ; for file in *.a; do mv "$file" "`basename "$file" .a`.lib" ; done ; rm -rf fdk-aac.lib cmake pkgconfig *.la ../share ; cd .. ; tar czf ../dist/ffmpeg-win64-${{ inputs.type }}-${{ inputs.config }}.tar.gz *'
|
||||
- name: Publish FFmpeg artifacts
|
||||
uses: actions/upload-artifact@v3
|
||||
with:
|
||||
name: FFmpeg ${{ inputs.env }} ${{ inputs.config }}${{ inputs.config }} package build
|
||||
path: dist/ffmpeg-win64-${{ inputs.type }}-${{ inputs.config }}.tar.gz
|
@ -1,115 +1,56 @@
|
||||
From 3429a813b77a7658d2ee59be7c9228e306d86d14 Mon Sep 17 00:00:00 2001
|
||||
From: sherpya <sherpya@netfarm.it>
|
||||
Date: Sun, 4 Dec 2016 01:28:51 +0100
|
||||
Subject: [PATCH 1/6] dynamic loading of shared fdk-aac library
|
||||
|
||||
---
|
||||
configure | 6 ++--
|
||||
libavcodec/libfdk-aacdec.c | 73 ++++++++++++++++++++++++++++++++++++++++++++--
|
||||
libavcodec/libfdk-aacenc.c | 59 +++++++++++++++++++++++++++++++++++--
|
||||
3 files changed, 129 insertions(+), 9 deletions(-)
|
||||
|
||||
diff --git a/configure b/configure
|
||||
index 0b01a221c7..9dae091033 100755
|
||||
index 77facac8c9..ab117fba2c 100755
|
||||
--- a/configure
|
||||
+++ b/configure
|
||||
@@ -1563,7 +1563,6 @@ EXTERNAL_LIBRARY_GPL_LIST="
|
||||
@@ -1785,7 +1785,6 @@ EXTERNAL_LIBRARY_GPL_LIST="
|
||||
|
||||
EXTERNAL_LIBRARY_NONFREE_LIST="
|
||||
decklink
|
||||
libndi_newtek
|
||||
- libfdk_aac
|
||||
openssl
|
||||
libtls
|
||||
"
|
||||
@@ -1597,6 +1596,7 @@ EXTERNAL_LIBRARY_LIST="
|
||||
libcaca
|
||||
libcelt
|
||||
libdc1394
|
||||
|
||||
@@ -1882,6 +1881,7 @@ EXTERNAL_LIBRARY_LIST="
|
||||
openssl
|
||||
pocketsphinx
|
||||
vapoursynth
|
||||
+ libfdk_aac
|
||||
libdrm
|
||||
libflite
|
||||
libfontconfig
|
||||
@@ -5841,9 +5841,7 @@ enabled libcelt && require libcelt celt/celt.h celt_decode -lcelt0 &&
|
||||
enabled libcaca && require_pkg_config libcaca caca caca.h caca_create_canvas
|
||||
"
|
||||
|
||||
HWACCEL_AUTODETECT_LIBRARY_LIST="
|
||||
@@ -6524,9 +6524,7 @@ enabled libdav1d && require_pkg_config libdav1d "dav1d >= 0.5.0" "dav1d
|
||||
enabled libdavs2 && require_pkg_config libdavs2 "davs2 >= 1.6.0" davs2.h davs2_decoder_open
|
||||
enabled libdc1394 && require_pkg_config libdc1394 libdc1394-2 dc1394/dc1394.h dc1394_new
|
||||
enabled libdrm && require_pkg_config libdrm libdrm xf86drm.h drmGetVersion
|
||||
-enabled libfdk_aac && { check_pkg_config libfdk_aac fdk-aac "fdk-aac/aacenc_lib.h" aacEncOpen ||
|
||||
- { require libfdk_aac fdk-aac/aacenc_lib.h aacEncOpen -lfdk-aac &&
|
||||
- warn "using libfdk without pkg-config"; } }
|
||||
+enabled libfdk_aac && { check_header fdk-aac/aacenc_lib.h || die "ERROR: aacenc_lib.h not found"; }
|
||||
+enabled libfdk_aac && require_headers fdk-aac/aacenc_lib.h
|
||||
flite_extralibs="-lflite_cmu_time_awb -lflite_cmu_us_awb -lflite_cmu_us_kal -lflite_cmu_us_kal16 -lflite_cmu_us_rms -lflite_cmu_us_slt -lflite_usenglish -lflite_cmulex -lflite"
|
||||
enabled libflite && require libflite "flite/flite.h" flite_init $flite_extralibs
|
||||
enabled fontconfig && enable libfontconfig
|
||||
diff --git a/libavcodec/libfdk-aacdec.c b/libavcodec/libfdk-aacdec.c
|
||||
index 677b11088b..d191133ae0 100644
|
||||
index e9096a08e6..cc4d79c651 100644
|
||||
--- a/libavcodec/libfdk-aacdec.c
|
||||
+++ b/libavcodec/libfdk-aacdec.c
|
||||
@@ -17,6 +17,17 @@
|
||||
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||
*/
|
||||
|
||||
+#ifndef _WIN32
|
||||
+#include <dlfcn.h>
|
||||
+#define LIBNAME "libfdk-aac.so.1"
|
||||
+#else
|
||||
+#include <windows.h>
|
||||
+#define LIBNAME "libfdk-aac-1.dll"
|
||||
+#define dlopen(fname, f) ((void *) LoadLibraryA(fname))
|
||||
+#define dlclose(handle) FreeLibrary((HMODULE) handle)
|
||||
+#define dlsym(handle, name) GetProcAddress((HMODULE) handle, name)
|
||||
+#endif
|
||||
+
|
||||
#include <fdk-aac/aacdecoder_lib.h>
|
||||
|
||||
#include "libavutil/channel_layout.h"
|
||||
@@ -25,6 +36,37 @@
|
||||
@@ -25,6 +25,7 @@
|
||||
#include "avcodec.h"
|
||||
#include "codec_internal.h"
|
||||
#include "internal.h"
|
||||
+#include "libfdk-aac_internal.h"
|
||||
|
||||
+typedef LINKSPEC_H HANDLE_AACDECODER (*imp_aacDecoder_Open)(TRANSPORT_TYPE transportFmt, UINT nrOfLayers);
|
||||
+typedef LINKSPEC_H void (*imp_aacDecoder_Close)(HANDLE_AACDECODER self);
|
||||
+typedef LINKSPEC_H AAC_DECODER_ERROR (*imp_aacDecoder_Fill)(HANDLE_AACDECODER self, UCHAR *pBuffer[], const UINT bufferSize[], UINT *bytesValid);
|
||||
+typedef LINKSPEC_H AAC_DECODER_ERROR (*imp_aacDecoder_DecodeFrame)(HANDLE_AACDECODER self, INT_PCM *pTimeData, const INT timeDataSize, const UINT flags);
|
||||
+typedef LINKSPEC_H CStreamInfo* (*imp_aacDecoder_GetStreamInfo)(HANDLE_AACDECODER self);
|
||||
+typedef LINKSPEC_H AAC_DECODER_ERROR (*imp_aacDecoder_ConfigRaw)(HANDLE_AACDECODER self, UCHAR *conf[], const UINT length[]);
|
||||
+typedef LINKSPEC_H AAC_DECODER_ERROR (*imp_aacDecoder_SetParam)(const HANDLE_AACDECODER self, const AACDEC_PARAM param, const INT value);
|
||||
+typedef LINKSPEC_H AAC_DECODER_ERROR (*imp_aacDecoder_AncDataInit)(HANDLE_AACDECODER self, UCHAR *buffer, int size);
|
||||
+
|
||||
+typedef struct _aacDecLib {
|
||||
+ imp_aacDecoder_Open aacDecoder_Open;
|
||||
+ imp_aacDecoder_Close aacDecoder_Close;
|
||||
+ imp_aacDecoder_Fill aacDecoder_Fill;
|
||||
+ imp_aacDecoder_DecodeFrame aacDecoder_DecodeFrame;
|
||||
+ imp_aacDecoder_ConfigRaw aacDecoder_ConfigRaw;
|
||||
+ imp_aacDecoder_GetStreamInfo aacDecoder_GetStreamInfo;
|
||||
+ imp_aacDecoder_SetParam aacDecoder_SetParam;
|
||||
+ imp_aacDecoder_AncDataInit aacDecoder_AncDataInit;
|
||||
+} aacDecLib;
|
||||
+
|
||||
+#define DLSYM(x) \
|
||||
+ do \
|
||||
+ { \
|
||||
+ s->pfn.x = ( imp_##x ) dlsym(s->hLib, AV_STRINGIFY(x)); \
|
||||
+ if (!s->pfn.x ) \
|
||||
+ { \
|
||||
+ av_log(avctx, AV_LOG_ERROR, "Unable to find symbol " AV_STRINGIFY(x) " in dynamic " LIBNAME "\n"); \
|
||||
+ return -1; \
|
||||
+ } \
|
||||
+ } while (0)
|
||||
+
|
||||
/* The version macro is introduced the same time as the setting enum was
|
||||
* changed, so this check should suffice. */
|
||||
#ifndef AACDECODER_LIB_VL0
|
||||
@@ -41,6 +83,8 @@ enum ConcealMethod {
|
||||
#ifdef AACDECODER_LIB_VL0
|
||||
#define FDKDEC_VER_AT_LEAST(vl0, vl1) \
|
||||
@@ -48,6 +49,8 @@ enum ConcealMethod {
|
||||
typedef struct FDKAACDecContext {
|
||||
const AVClass *class;
|
||||
HANDLE_AACDECODER handle;
|
||||
+ void *hLib;
|
||||
+ void *hLib;
|
||||
+ aacDecLib pfn;
|
||||
uint8_t *decoder_buffer;
|
||||
int decoder_buffer_size;
|
||||
uint8_t *anc_buffer;
|
||||
@@ -88,7 +132,7 @@ static const AVClass fdk_aac_dec_class = {
|
||||
@@ -113,7 +116,7 @@ static const AVClass fdk_aac_dec_class = {
|
||||
static int get_stream_info(AVCodecContext *avctx)
|
||||
{
|
||||
FDKAACDecContext *s = avctx->priv_data;
|
||||
@ -118,7 +59,7 @@ index 677b11088b..d191133ae0 100644
|
||||
int channel_counts[0x24] = { 0 };
|
||||
int i, ch_error = 0;
|
||||
uint64_t ch_layout = 0;
|
||||
@@ -200,8 +244,10 @@ static av_cold int fdk_aac_decode_close(AVCodecContext *avctx)
|
||||
@@ -231,8 +234,10 @@ static av_cold int fdk_aac_decode_close(AVCodecContext *avctx)
|
||||
{
|
||||
FDKAACDecContext *s = avctx->priv_data;
|
||||
|
||||
@ -131,11 +72,11 @@ index 677b11088b..d191133ae0 100644
|
||||
av_freep(&s->decoder_buffer);
|
||||
av_freep(&s->anc_buffer);
|
||||
|
||||
@@ -213,6 +259,27 @@ static av_cold int fdk_aac_decode_init(AVCodecContext *avctx)
|
||||
@@ -244,6 +249,27 @@ static av_cold int fdk_aac_decode_init(AVCodecContext *avctx)
|
||||
FDKAACDecContext *s = avctx->priv_data;
|
||||
AAC_DECODER_ERROR err;
|
||||
|
||||
+ if (!(s->hLib = dlopen(LIBNAME, RTLD_NOW))) {
|
||||
+ if (!(s->hLib = dlopen(LIBNAME, RTLD_NOW))) {
|
||||
+ av_log(avctx, AV_LOG_ERROR, "Unable to load " LIBNAME "\n");
|
||||
+ return -1;
|
||||
+ }
|
||||
@ -160,60 +101,18 @@ index 677b11088b..d191133ae0 100644
|
||||
if (!s->handle) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Error opening decoder\n");
|
||||
diff --git a/libavcodec/libfdk-aacenc.c b/libavcodec/libfdk-aacenc.c
|
||||
index d47137b227..6295af3858 100644
|
||||
index d004ae00c3..902dddb365 100644
|
||||
--- a/libavcodec/libfdk-aacenc.c
|
||||
+++ b/libavcodec/libfdk-aacenc.c
|
||||
@@ -17,6 +17,17 @@
|
||||
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||
*/
|
||||
@@ -27,6 +27,7 @@
|
||||
#include "codec_internal.h"
|
||||
#include "encode.h"
|
||||
#include "profiles.h"
|
||||
+#include "libfdk-aac_internal.h"
|
||||
|
||||
+#ifndef _WIN32
|
||||
+#include <dlfcn.h>
|
||||
+#define LIBNAME "libfdk-aac.so.1"
|
||||
+#else
|
||||
+#include <windows.h>
|
||||
+#define LIBNAME "libfdk-aac-1.dll"
|
||||
+#define dlopen(fname, f) ((void *) LoadLibraryA(fname))
|
||||
+#define dlclose(handle) FreeLibrary((HMODULE) handle)
|
||||
+#define dlsym(handle, name) GetProcAddress((HMODULE) handle, name)
|
||||
+#endif
|
||||
+
|
||||
#include <fdk-aac/aacenc_lib.h>
|
||||
|
||||
#include "libavutil/channel_layout.h"
|
||||
@@ -26,6 +37,31 @@
|
||||
#include "audio_frame_queue.h"
|
||||
#include "internal.h"
|
||||
|
||||
+typedef AACENC_ERROR (*imp_aacEncOpen)(HANDLE_AACENCODER *phAacEncoder, const UINT encModules, const UINT maxChannels);
|
||||
+typedef AACENC_ERROR (*imp_aacEncClose)(HANDLE_AACENCODER *phAacEncoder);
|
||||
+typedef AACENC_ERROR (*imp_aacEncEncode)(const HANDLE_AACENCODER hAacEncoder, const AACENC_BufDesc *inBufDesc, const AACENC_BufDesc *outBufDesc, const AACENC_InArgs *inargs, AACENC_OutArgs *outargs);
|
||||
+typedef AACENC_ERROR (*imp_aacEncInfo)(const HANDLE_AACENCODER hAacEncoder, AACENC_InfoStruct *pInfo);
|
||||
+typedef AACENC_ERROR (*imp_aacEncoder_SetParam)(const HANDLE_AACENCODER hAacEncoder, const AACENC_PARAM param, const UINT value);
|
||||
+
|
||||
+typedef struct _aacEncLib {
|
||||
+ imp_aacEncOpen aacEncOpen;
|
||||
+ imp_aacEncClose aacEncClose;
|
||||
+ imp_aacEncEncode aacEncEncode;
|
||||
+ imp_aacEncInfo aacEncInfo;
|
||||
+ imp_aacEncoder_SetParam aacEncoder_SetParam;
|
||||
+} aacEncLib;
|
||||
+
|
||||
+#define DLSYM(x) \
|
||||
+ do \
|
||||
+ { \
|
||||
+ s->pfn.x = ( imp_##x ) dlsym(s->hLib, AV_STRINGIFY(x)); \
|
||||
+ if (!s->pfn.x ) \
|
||||
+ { \
|
||||
+ av_log(avctx, AV_LOG_ERROR, "Unable to find symbol " AV_STRINGIFY(x) " in dynamic " LIBNAME "\n"); \
|
||||
+ return -1; \
|
||||
+ } \
|
||||
+ } while (0)
|
||||
+
|
||||
typedef struct AACContext {
|
||||
const AVClass *class;
|
||||
HANDLE_AACENCODER handle;
|
||||
@@ -36,6 +72,8 @@ typedef struct AACContext {
|
||||
#ifdef AACENCODER_LIB_VL0
|
||||
#define FDKENC_VER_AT_LEAST(vl0, vl1) \
|
||||
@@ -47,6 +48,8 @@ typedef struct AACContext {
|
||||
int header_period;
|
||||
int vbr;
|
||||
|
||||
@ -222,7 +121,7 @@ index d47137b227..6295af3858 100644
|
||||
AudioFrameQueue afq;
|
||||
} AACContext;
|
||||
|
||||
@@ -96,8 +134,10 @@ static int aac_encode_close(AVCodecContext *avctx)
|
||||
@@ -111,8 +114,10 @@ static int aac_encode_close(AVCodecContext *avctx)
|
||||
{
|
||||
AACContext *s = avctx->priv_data;
|
||||
|
||||
@ -232,14 +131,14 @@ index d47137b227..6295af3858 100644
|
||||
+ s->pfn.aacEncClose(&s->handle);
|
||||
+ dlclose(s->hLib);
|
||||
+ }
|
||||
av_freep(&avctx->extradata);
|
||||
ff_af_queue_close(&s->afq);
|
||||
|
||||
@@ -114,6 +154,21 @@ static av_cold int aac_encode_init(AVCodecContext *avctx)
|
||||
return 0;
|
||||
@@ -128,6 +133,21 @@ static av_cold int aac_encode_init(AVCodecContext *avctx)
|
||||
int aot = FF_PROFILE_AAC_LOW + 1;
|
||||
int sce = 0, cpe = 0;
|
||||
|
||||
+ if (!(s->hLib = dlopen(LIBNAME, RTLD_NOW))) {
|
||||
+ if (!(s->hLib = dlopen(LIBNAME, RTLD_NOW))) {
|
||||
+ av_log(avctx, AV_LOG_ERROR, "Unable to load " LIBNAME "\n");
|
||||
+ return -1;
|
||||
+ }
|
||||
@ -254,8 +153,97 @@ index d47137b227..6295af3858 100644
|
||||
+ DLSYM(aacEncoder_SetParam);
|
||||
+#define aacEncoder_SetParam s->pfn.aacEncoder_SetParam
|
||||
+
|
||||
if ((err = aacEncOpen(&s->handle, 0, avctx->channels)) != AACENC_OK) {
|
||||
if ((err = aacEncOpen(&s->handle, 0, avctx->ch_layout.nb_channels)) != AACENC_OK) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Unable to open the encoder: %s\n",
|
||||
aac_get_error(err));
|
||||
--
|
||||
2.15.1
|
||||
diff --git a/libfdk-aac_internal.h b/libfdk-aac_internal.h
|
||||
new file mode 100644
|
||||
index 0000000000..9bcfdb9aba
|
||||
--- /dev/null
|
||||
+++ b/libfdk-aac_internal.h
|
||||
@@ -0,0 +1,84 @@
|
||||
+/*
|
||||
+ * Copyright (c) 2018 Gianluigi Tiesi
|
||||
+ *
|
||||
+ * This file is part of FFmpeg.
|
||||
+ *
|
||||
+ * FFmpeg is free software; you can redistribute it and/or
|
||||
+ * modify it under the terms of the GNU Lesser General Public
|
||||
+ * License as published by the Free Software Foundation; either
|
||||
+ * version 2.1 of the License, or (at your option) any later version.
|
||||
+ *
|
||||
+ * FFmpeg is distributed in the hope that it will be useful,
|
||||
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
+ * Lesser General Public License for more details.
|
||||
+ *
|
||||
+ * You should have received a copy of the GNU Lesser General Public
|
||||
+ * License along with FFmpeg; if not, write to the Free Software
|
||||
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
+ */
|
||||
+
|
||||
+#ifndef AVCODEC_LIBFDK_AAC_INTERNAL_H
|
||||
+#define AVCODEC_LIBFDK_AAC_INTERNAL_H
|
||||
+
|
||||
+#ifdef _WIN32
|
||||
+#include <windows.h>
|
||||
+#define LIBNAME "libfdk-aac-2.dll"
|
||||
+#define dlopen(fname, f) ((void *) LoadLibraryA(fname))
|
||||
+#define dlclose(handle) FreeLibrary((HMODULE) handle)
|
||||
+#define dlsym(handle, name) GetProcAddress((HMODULE) handle, name)
|
||||
+#else
|
||||
+#include <dlfcn.h>
|
||||
+#define LIBNAME "libfdk-aac.so.2"
|
||||
+#endif
|
||||
+
|
||||
+#define DLSYM(x) \
|
||||
+ do \
|
||||
+ { \
|
||||
+ s->pfn.x = ( imp_##x ) dlsym(s->hLib, AV_STRINGIFY(x)); \
|
||||
+ if (!s->pfn.x ) \
|
||||
+ { \
|
||||
+ av_log(avctx, AV_LOG_ERROR, "Unable to find symbol " AV_STRINGIFY(x) " in dynamic " LIBNAME "\n"); \
|
||||
+ return -1; \
|
||||
+ } \
|
||||
+ } while (0)
|
||||
+
|
||||
+
|
||||
+#include <fdk-aac/aacenc_lib.h>
|
||||
+#include <fdk-aac/aacdecoder_lib.h>
|
||||
+
|
||||
+typedef AACENC_ERROR (*imp_aacEncOpen)(HANDLE_AACENCODER *phAacEncoder, const UINT encModules, const UINT maxChannels);
|
||||
+typedef AACENC_ERROR (*imp_aacEncClose)(HANDLE_AACENCODER *phAacEncoder);
|
||||
+typedef AACENC_ERROR (*imp_aacEncEncode)(const HANDLE_AACENCODER hAacEncoder, const AACENC_BufDesc *inBufDesc, const AACENC_BufDesc *outBufDesc, const AACENC_InArgs *inargs, AACENC_OutArgs *outargs);
|
||||
+typedef AACENC_ERROR (*imp_aacEncInfo)(const HANDLE_AACENCODER hAacEncoder, AACENC_InfoStruct *pInfo);
|
||||
+typedef AACENC_ERROR (*imp_aacEncoder_SetParam)(const HANDLE_AACENCODER hAacEncoder, const AACENC_PARAM param, const UINT value);
|
||||
+
|
||||
+typedef struct _aacEncLib {
|
||||
+ imp_aacEncOpen aacEncOpen;
|
||||
+ imp_aacEncClose aacEncClose;
|
||||
+ imp_aacEncEncode aacEncEncode;
|
||||
+ imp_aacEncInfo aacEncInfo;
|
||||
+ imp_aacEncoder_SetParam aacEncoder_SetParam;
|
||||
+} aacEncLib;
|
||||
+
|
||||
+typedef LINKSPEC_H HANDLE_AACDECODER (*imp_aacDecoder_Open)(TRANSPORT_TYPE transportFmt, UINT nrOfLayers);
|
||||
+typedef LINKSPEC_H void (*imp_aacDecoder_Close)(HANDLE_AACDECODER self);
|
||||
+typedef LINKSPEC_H AAC_DECODER_ERROR (*imp_aacDecoder_Fill)(HANDLE_AACDECODER self, UCHAR *pBuffer[], const UINT bufferSize[], UINT *bytesValid);
|
||||
+typedef LINKSPEC_H AAC_DECODER_ERROR (*imp_aacDecoder_DecodeFrame)(HANDLE_AACDECODER self, INT_PCM *pTimeData, const INT timeDataSize, const UINT flags);
|
||||
+typedef LINKSPEC_H CStreamInfo* (*imp_aacDecoder_GetStreamInfo)(HANDLE_AACDECODER self);
|
||||
+typedef LINKSPEC_H AAC_DECODER_ERROR (*imp_aacDecoder_ConfigRaw)(HANDLE_AACDECODER self, UCHAR *conf[], const UINT length[]);
|
||||
+typedef LINKSPEC_H AAC_DECODER_ERROR (*imp_aacDecoder_SetParam)(const HANDLE_AACDECODER self, const AACDEC_PARAM param, const INT value);
|
||||
+typedef LINKSPEC_H AAC_DECODER_ERROR (*imp_aacDecoder_AncDataInit)(HANDLE_AACDECODER self, UCHAR *buffer, int size);
|
||||
+
|
||||
+typedef struct _aacDecLib {
|
||||
+ imp_aacDecoder_Open aacDecoder_Open;
|
||||
+ imp_aacDecoder_Close aacDecoder_Close;
|
||||
+ imp_aacDecoder_Fill aacDecoder_Fill;
|
||||
+ imp_aacDecoder_DecodeFrame aacDecoder_DecodeFrame;
|
||||
+ imp_aacDecoder_ConfigRaw aacDecoder_ConfigRaw;
|
||||
+ imp_aacDecoder_GetStreamInfo aacDecoder_GetStreamInfo;
|
||||
+ imp_aacDecoder_SetParam aacDecoder_SetParam;
|
||||
+ imp_aacDecoder_AncDataInit aacDecoder_AncDataInit;
|
||||
+} aacDecLib;
|
||||
+
|
||||
+#endif /* AVCODEC_LIBFDK_AAC_INTERNAL_H */
|
||||
\ No newline at end of file
|
@ -1,37 +1,25 @@
|
||||
From 099b9eaee7cc6dae0ace4d8ce83cbb65449eb901 Mon Sep 17 00:00:00 2001
|
||||
From: sherpya <sherpya@netfarm.it>
|
||||
Date: Sun, 4 Dec 2016 01:28:51 +0100
|
||||
Subject: [PATCH 1/6] dynamic loading of shared fdk-aac library
|
||||
|
||||
---
|
||||
configure | 6 +--
|
||||
libavcodec/libfdk-aac_internal.h | 84 ++++++++++++++++++++++++++++++++
|
||||
libavcodec/libfdk-aacdec.c | 32 ++++++++++--
|
||||
libavcodec/libfdk-aacenc.c | 25 +++++++++-
|
||||
4 files changed, 138 insertions(+), 9 deletions(-)
|
||||
create mode 100644 libavcodec/libfdk-aac_internal.h
|
||||
|
||||
diff --git a/configure b/configure
|
||||
index 25120337de..36e8d99f00 100755
|
||||
index 7a62f0c248..73078ffa60 100755
|
||||
--- a/configure
|
||||
+++ b/configure
|
||||
@@ -1675,6 +1675,5 @@ EXTERNAL_LIBRARY_GPL_LIST="
|
||||
@@ -1783,7 +1783,6 @@ EXTERNAL_LIBRARY_GPL_LIST="
|
||||
|
||||
EXTERNAL_LIBRARY_NONFREE_LIST="
|
||||
decklink
|
||||
- libfdk_aac
|
||||
openssl
|
||||
libtls
|
||||
"
|
||||
@@ -1713,6 +1712,7 @@ EXTERNAL_LIBRARY_LIST="
|
||||
libcelt
|
||||
libcodec2
|
||||
libdc1394
|
||||
|
||||
@@ -1880,6 +1879,7 @@ EXTERNAL_LIBRARY_LIST="
|
||||
openssl
|
||||
pocketsphinx
|
||||
vapoursynth
|
||||
+ libfdk_aac
|
||||
libdrm
|
||||
libflite
|
||||
libfontconfig
|
||||
@@ -6064,9 +6064,7 @@ enabled libcodec2 && require libcodec2 codec2/codec2.h codec2_create -lc
|
||||
enabled libdavs2 && require_pkg_config libdavs2 "davs2 >= 1.5.115" davs2.h davs2_decoder_open
|
||||
"
|
||||
|
||||
HWACCEL_AUTODETECT_LIBRARY_LIST="
|
||||
@@ -6532,9 +6532,7 @@ enabled libdav1d && require_pkg_config libdav1d "dav1d >= 0.5.0" "dav1d
|
||||
enabled libdavs2 && require_pkg_config libdavs2 "davs2 >= 1.6.0" davs2.h davs2_decoder_open
|
||||
enabled libdc1394 && require_pkg_config libdc1394 libdc1394-2 dc1394/dc1394.h dc1394_new
|
||||
enabled libdrm && require_pkg_config libdrm libdrm xf86drm.h drmGetVersion
|
||||
-enabled libfdk_aac && { check_pkg_config libfdk_aac fdk-aac "fdk-aac/aacenc_lib.h" aacEncOpen ||
|
||||
@ -132,7 +120,7 @@ index 0000000000..cd1e6e3340
|
||||
+
|
||||
+#endif /* AVCODEC_LIBFDK_AAC_INTERNAL_H */
|
||||
diff --git a/libavcodec/libfdk-aacdec.c b/libavcodec/libfdk-aacdec.c
|
||||
index 1abe1d8438..ef7728c368 100644
|
||||
index ffa1fdcce3..b3ee1248ed 100644
|
||||
--- a/libavcodec/libfdk-aacdec.c
|
||||
+++ b/libavcodec/libfdk-aacdec.c
|
||||
@@ -24,6 +24,7 @@
|
||||
@ -140,7 +128,7 @@ index 1abe1d8438..ef7728c368 100644
|
||||
#include "avcodec.h"
|
||||
#include "internal.h"
|
||||
+#include "libfdk-aac_internal.h"
|
||||
|
||||
|
||||
#ifdef AACDECODER_LIB_VL0
|
||||
#define FDKDEC_VER_AT_LEAST(vl0, vl1) \
|
||||
@@ -47,6 +48,8 @@ enum ConcealMethod {
|
||||
@ -152,7 +140,7 @@ index 1abe1d8438..ef7728c368 100644
|
||||
uint8_t *decoder_buffer;
|
||||
int decoder_buffer_size;
|
||||
uint8_t *anc_buffer;
|
||||
@@ -99,7 +102,7 @@ static const AVClass fdk_aac_dec_class = {
|
||||
@@ -101,7 +104,7 @@ static const AVClass fdk_aac_dec_class = {
|
||||
static int get_stream_info(AVCodecContext *avctx)
|
||||
{
|
||||
FDKAACDecContext *s = avctx->priv_data;
|
||||
@ -161,10 +149,10 @@ index 1abe1d8438..ef7728c368 100644
|
||||
int channel_counts[0x24] = { 0 };
|
||||
int i, ch_error = 0;
|
||||
uint64_t ch_layout = 0;
|
||||
@@ -211,8 +214,10 @@ static av_cold int fdk_aac_decode_close(AVCodecContext *avctx)
|
||||
@@ -216,8 +219,10 @@ static av_cold int fdk_aac_decode_close(AVCodecContext *avctx)
|
||||
{
|
||||
FDKAACDecContext *s = avctx->priv_data;
|
||||
|
||||
|
||||
- if (s->handle)
|
||||
- aacDecoder_Close(s->handle);
|
||||
+ if (s->hLib && s->handle) {
|
||||
@ -173,11 +161,11 @@ index 1abe1d8438..ef7728c368 100644
|
||||
+ }
|
||||
av_freep(&s->decoder_buffer);
|
||||
av_freep(&s->anc_buffer);
|
||||
|
||||
@@ -224,6 +229,27 @@ static av_cold int fdk_aac_decode_init(AVCodecContext *avctx)
|
||||
|
||||
@@ -229,6 +234,27 @@ static av_cold int fdk_aac_decode_init(AVCodecContext *avctx)
|
||||
FDKAACDecContext *s = avctx->priv_data;
|
||||
AAC_DECODER_ERROR err;
|
||||
|
||||
|
||||
+ if (!(s->hLib = dlopen(LIBNAME, RTLD_NOW))) {
|
||||
+ av_log(avctx, AV_LOG_ERROR, "Unable to load " LIBNAME "\n");
|
||||
+ return -1;
|
||||
@ -203,44 +191,43 @@ index 1abe1d8438..ef7728c368 100644
|
||||
if (!s->handle) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Error opening decoder\n");
|
||||
diff --git a/libavcodec/libfdk-aacenc.c b/libavcodec/libfdk-aacenc.c
|
||||
index 5620bb5951..c4519b6b74 100644
|
||||
index 7ee2f13ac7..2a91d02c7f 100644
|
||||
--- a/libavcodec/libfdk-aacenc.c
|
||||
+++ b/libavcodec/libfdk-aacenc.c
|
||||
@@ -26,6 +26,8 @@
|
||||
@@ -26,6 +26,7 @@
|
||||
#include "audio_frame_queue.h"
|
||||
#include "encode.h"
|
||||
#include "internal.h"
|
||||
|
||||
+#include "libfdk-aac_internal.h"
|
||||
+
|
||||
#include "profiles.h"
|
||||
|
||||
#ifdef AACENCODER_LIB_VL0
|
||||
#define FDKENC_VER_AT_LEAST(vl0, vl1) \
|
||||
((AACENCODER_LIB_VL0 > vl0) || \
|
||||
@@ -45,6 +47,8 @@ typedef struct AACContext {
|
||||
@@ -47,6 +48,8 @@ typedef struct AACContext {
|
||||
int header_period;
|
||||
int vbr;
|
||||
|
||||
|
||||
+ void *hLib;
|
||||
+ aacEncLib pfn;
|
||||
AudioFrameQueue afq;
|
||||
} AACContext;
|
||||
|
||||
@@ -108,8 +112,10 @@ static int aac_encode_close(AVCodecContext *avctx)
|
||||
|
||||
@@ -111,8 +114,10 @@ static int aac_encode_close(AVCodecContext *avctx)
|
||||
{
|
||||
AACContext *s = avctx->priv_data;
|
||||
|
||||
|
||||
- if (s->handle)
|
||||
- aacEncClose(&s->handle);
|
||||
+ if (s->hLib && s->handle) {
|
||||
+ s->pfn.aacEncClose(&s->handle);
|
||||
+ dlclose(s->hLib);
|
||||
+ }
|
||||
av_freep(&avctx->extradata);
|
||||
ff_af_queue_close(&s->afq);
|
||||
|
||||
@@ -126,6 +132,21 @@ static av_cold int aac_encode_init(AVCodecContext *avctx)
|
||||
|
||||
return 0;
|
||||
@@ -128,6 +133,21 @@ static av_cold int aac_encode_init(AVCodecContext *avctx)
|
||||
int aot = FF_PROFILE_AAC_LOW + 1;
|
||||
int sce = 0, cpe = 0;
|
||||
|
||||
|
||||
+ if (!(s->hLib = dlopen(LIBNAME, RTLD_NOW))) {
|
||||
+ av_log(avctx, AV_LOG_ERROR, "Unable to load " LIBNAME "\n");
|
||||
+ return -1;
|
||||
@ -259,5 +246,3 @@ index 5620bb5951..c4519b6b74 100644
|
||||
if ((err = aacEncOpen(&s->handle, 0, avctx->channels)) != AACENC_OK) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Unable to open the encoder: %s\n",
|
||||
aac_get_error(err));
|
||||
--
|
||||
2.19.0
|
24
README.md
24
README.md
@ -1,23 +1,3 @@
|
||||
# voukoder-ffmpeg-buildscript
|
||||
# voukoder-ffmpeg
|
||||
|
||||
Builds static libraries of ffmeg and external libraries (x264 8bit, x265 8,10 and 12bit) to be used in the voukoder project.
|
||||
|
||||
## Install msys2
|
||||
- Get the 64bit version of msys2 from msys2.org
|
||||
- Install it
|
||||
|
||||
## Start msys2
|
||||
- Open a command prompt
|
||||
- Run "vcvarsall.bat amd64" in "c:\program files (x86)\microsoft visual studio\2017\community\VC\Auxiliary\Build"
|
||||
- Run msys2 with "msys2_shell.cmd -mingw64 -full-path"
|
||||
|
||||
## Install development tools
|
||||
- Install CMakeGui in Windows to have the VisualStudio templates ready
|
||||
- Install "pacman -S base-devel binutils git make pkg-config" in msys2
|
||||
- Install nasm to /usr/bin/nasm.exe
|
||||
- Install cmake gui
|
||||
- Add cmake path to path variable
|
||||
|
||||
## Starting the build
|
||||
- Have the build.sh file at i.e. "/home/daniel/ffmpeg/build.sh"
|
||||
- Start the build by either "./build.sh debug" or "./build.sh release"
|
||||
Provides a FFmpeg static libs to be used with Voukoder. They are being built using a GitHub action worflow.
|
||||
|
282
build.sh
282
build.sh
@ -1,282 +0,0 @@
|
||||
#!/bin/bash
|
||||
|
||||
COMPONENTS=""
|
||||
|
||||
if [ "$MODE" == "debug" ]; then
|
||||
MSBUILD_CONFIG=Debug
|
||||
CFLAGS=-MDd
|
||||
elif [ "$MODE" == "release" ]; then
|
||||
MSBUILD_CONFIG=Release
|
||||
CFLAGS=-MD
|
||||
else
|
||||
echo "Please supply build mode [debug|release]!"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
function build {
|
||||
cd $SRC/$1
|
||||
if [ -f autogen.sh ]; then
|
||||
./autogen.sh
|
||||
fi
|
||||
CC=cl CXXFLAGS=$CFLAGS ./configure --prefix=$BUILD $2
|
||||
make -j $NUMBER_OF_PROCESSORS
|
||||
make install
|
||||
}
|
||||
|
||||
function build_nvenc {
|
||||
git clone git://github.com/FFmpeg/nv-codec-headers.git $SRC/ffnvcodec
|
||||
# git checkout sdk/9.0
|
||||
cd $SRC/ffnvcodec
|
||||
make PREFIX=$BUILD install
|
||||
add_comp nvenc
|
||||
}
|
||||
|
||||
function build_amf {
|
||||
git clone git://github.com/GPUOpen-LibrariesAndSDKs/AMF.git $SRC/amf
|
||||
cp -a $SRC/amf/amf/public/include $BUILD/include/AMF
|
||||
add_comp amf
|
||||
}
|
||||
|
||||
function build_mfx {
|
||||
git clone https://github.com/lu-zero/mfx_dispatch.git $SRC/libmfx
|
||||
cd $SRC/libmfx
|
||||
#git checkout c200d833e25a91e3e49d69890dac1ffa3486cbe9
|
||||
if [[ ! -f "configure" ]]; then
|
||||
autoreconf -fiv || exit 1
|
||||
fi
|
||||
build libmfx
|
||||
sed -i 's/-lstdc++/-ladvapi32/g' $BUILD/lib/pkgconfig/libmfx.pc
|
||||
add_comp libmfx
|
||||
}
|
||||
|
||||
function build_aom {
|
||||
git clone https://aomedia.googlesource.com/aom $SRC/libaom
|
||||
cd $SRC/libaom
|
||||
rm -rf work
|
||||
mkdir work
|
||||
cd work
|
||||
cmake -G "Visual Studio 15 2017" .. -A x64 -DENABLE_{DOCS,TOOLS,TESTS}=off -DAOM_TARGET_CPU=x86_64 -DCMAKE_INSTALL_PREFIX=$BUILD
|
||||
MSBuild.exe /maxcpucount:$NUMBER_OF_PROCESSORS /property:Configuration="$MSBUILD_CONFIG" AOM.sln
|
||||
cp $MSBUILD_CONFIG/aom.lib $BUILD/lib/aom.lib
|
||||
cp -r ../aom $BUILD/include/aom
|
||||
cmake -DAOM_CONFIG_DIR=. -DAOM_ROOT=.. -DCMAKE_INSTALL_PREFIX=@prefix@ -DCMAKE_PROJECT_NAME=aom -DCONFIG_MULTITHREAD=true -DHAVE_PTHREAD_H=false -P "../build/cmake/pkg_config.cmake"
|
||||
sed -i "s#@prefix@#$BUILD#g" aom.pc
|
||||
sed -i '/^Libs\.private.*/d' aom.pc
|
||||
sed -i 's/-lm//' aom.pc
|
||||
cp aom.pc $BUILD/lib/pkgconfig/aom.pc
|
||||
add_comp libaom
|
||||
}
|
||||
|
||||
function build_svt {
|
||||
# HEVC
|
||||
#git clone https://github.com/OpenVisualCloud/SVT-HEVC.git $SRC/svt-hevc
|
||||
#cd $SRC/svt-hevc/Build
|
||||
#cmake .. -G"Visual Studio 15 2017" -A x64 -DCMAKE_INSTALL_PREFIX=$BUILD -DCMAKE_CONFIGURATION_TYPES=$MSBUILD_CONFIG
|
||||
#MSBuild.exe /maxcpucount:$NUMBER_OF_PROCESSORS /property:Configuration=$MSBUILD_CONFIG /property:ConfigurationType=StaticLibrary /property:TargetExt=.lib svt-hevc.sln
|
||||
#cp -r ../Source/API $BUILD/include/svt-hevc ; cp ../Bin/$MSBUILD_CONFIG/SvtHevcEnc.lib $BUILD/lib/ ; cp SvtHevcEnc.pc $BUILD/lib/pkgconfig/
|
||||
#add_comp libsvthevc
|
||||
#
|
||||
# AV1 (patch needed for FFmpeg 4.3)
|
||||
git clone --depth 1 --branch v0.8.4 https://github.com/OpenVisualCloud/SVT-AV1.git $SRC/svt-av1
|
||||
cd $SRC/svt-av1/Build
|
||||
cmake .. -G"Visual Studio 15 2017" -A x64 -DCMAKE_INSTALL_PREFIX=$BUILD -DCMAKE_CONFIGURATION_TYPES=$MSBUILD_CONFIG
|
||||
MSBuild.exe /maxcpucount:$NUMBER_OF_PROCESSORS /property:Configuration=$MSBUILD_CONFIG /property:ConfigurationType=StaticLibrary /property:TargetExt=.lib Source/Lib/Encoder/SvtAv1Enc.vcxproj
|
||||
cp -r ../Source/API $BUILD/include/svt-av1 ; cp ../Bin/$MSBUILD_CONFIG/SvtAv1Enc.lib $BUILD/lib/ ; cp SvtAv1Enc.pc $BUILD/lib/pkgconfig/
|
||||
add_comp libsvtav1
|
||||
#
|
||||
# VP9
|
||||
#git clone https://github.com/OpenVisualCloud/SVT-VP9.git $SRC/svt-vp9
|
||||
#cd $SRC/svt-vp9/Build
|
||||
#cmake .. -G"Visual Studio 15 2017" -A x64 -DCMAKE_INSTALL_PREFIX=$BUILD -DCMAKE_CONFIGURATION_TYPES=$MSBUILD_CONFIG
|
||||
#MSBuild.exe /maxcpucount:$NUMBER_OF_PROCESSORS /property:Configuration=$MSBUILD_CONFIG /property:ConfigurationType=StaticLibrary /property:TargetExt=".lib" svt-vp9.sln
|
||||
#cp -r ../Source/API $BUILD/include/svt-vp9 ; cp ../Bin/$MSBUILD_CONFIG/SvtVp9Enc.lib $BUILD/lib/ ; cp SvtVp9Enc.pc $BUILD/lib/pkgconfig/
|
||||
#sed -i 's/ -lpthread//g' $BUILD/lib/pkgconfig/SvtVp9Enc.pc
|
||||
#sed -i 's/ -lm//g' $BUILD/lib/pkgconfig/SvtVp9Enc.pc
|
||||
#add_comp libsvtvp9
|
||||
cd $SRC/ffmpeg
|
||||
#git apply $SRC/svt-hevc/ffmpeg_plugin/0001-lavc-svt_hevc-add-libsvt-hevc-encoder-wrapper.patch
|
||||
#git apply $SRC/svt-av1/ffmpeg_plugin/0001-Add-ability-for-ffmpeg-to-run-svt-av1-with-svt-hevc.patch
|
||||
#git apply $SRC/svt-vp9/ffmpeg_plugin/0001-Add-ability-for-ffmpeg-to-run-svt-vp9-with-hevc-av1.patch
|
||||
#git am $SRC/svt-hevc/ffmpeg_plugin/0001*.patch
|
||||
git apply $SRC/svt-av1/ffmpeg_plugin/0001-Add-ability-for-ffmpeg-to-run-svt-av1.patch
|
||||
}
|
||||
|
||||
function build_ogg {
|
||||
git clone https://github.com/xiph/ogg.git $SRC/libogg
|
||||
cd $SRC/libogg
|
||||
build libogg "--disable-shared"
|
||||
}
|
||||
|
||||
function build_vorbis {
|
||||
git clone https://github.com/xiph/vorbis.git $SRC/libvorbis
|
||||
cd $SRC/libvorbis
|
||||
build libvorbis "--disable-shared"
|
||||
sed -i '/^Libs\.private.*/d' $BUILD/lib/pkgconfig/vorbis.pc # don't need m.lib on windows
|
||||
add_comp libvorbis
|
||||
}
|
||||
|
||||
function build_snappy {
|
||||
git clone https://github.com/google/snappy.git $SRC/snappy
|
||||
cd $SRC/snappy
|
||||
rm -rf work
|
||||
mkdir work
|
||||
cd work
|
||||
cmake -G "Visual Studio 15 Win64" .. -DCMAKE_INSTALL_PREFIX=$BUILD -DBUILD_SHARED_LIBS=OFF -DSNAPPY_BUILD_TESTS=OFF
|
||||
MSBuild.exe /maxcpucount:$NUMBER_OF_PROCESSORS /property:Configuration="$MSBUILD_CONFIG" Snappy.sln
|
||||
cp $MSBUILD_CONFIG/snappy.lib $BUILD/lib/snappy.lib
|
||||
cp ../snappy.h ../snappy-c.h $BUILD/include/
|
||||
add_comp libsnappy
|
||||
}
|
||||
|
||||
function build_libvpx {
|
||||
git clone https://github.com/webmproject/libvpx.git $SRC/libvpx
|
||||
cd $SRC/libvpx
|
||||
./configure --prefix=$BUILD --target=x86_64-win64-vs15 --enable-vp9-highbitdepth --disable-shared --disable-examples --disable-tools --disable-docs --disable-libyuv --disable-unit_tests --disable-postproc
|
||||
make -j $NUMBER_OF_PROCESSORS
|
||||
make install
|
||||
mv $BUILD/lib/x64/vpxmd.lib $BUILD/lib/vpx.lib
|
||||
rm -rf $BUILD/lib/x64
|
||||
add_comp libvpx
|
||||
}
|
||||
|
||||
function build_libfdkaac {
|
||||
git clone git://github.com/mstorsjo/fdk-aac.git $SRC/fdk-aac
|
||||
cd $SRC/fdk-aac
|
||||
build fdk-aac "--disable-static --disable-shared"
|
||||
add_comp libfdk-aac
|
||||
cd $SRC/ffmpeg
|
||||
patch -N -p1 -i ../../patches/0001-dynamic-loading-of-shared-fdk-aac-library.patch
|
||||
}
|
||||
|
||||
function build_lame {
|
||||
svn co svn://svn.code.sf.net/p/lame/svn/trunk/lame $SRC/lame
|
||||
cd $SRC/lame
|
||||
build lame "--enable-nasm --disable-frontend --disable-shared --enable-static"
|
||||
add_comp libmp3lame
|
||||
}
|
||||
|
||||
function build_zimg {
|
||||
git clone https://github.com/sekrit-twc/zimg.git $SRC/zimg
|
||||
cd $SRC/zimg
|
||||
git checkout release-2.9.2
|
||||
./autogen.sh
|
||||
./configure --prefix=$BUILD
|
||||
cd _msvc/zimg
|
||||
MSBuild.exe /maxcpucount:$NUMBER_OF_PROCESSORS /property:Configuration="$MSBUILD_CONFIG" /property:ConfigurationType=StaticLibrary /property:WindowsTargetPlatformVersion=10.0.17134.0 /property:PlatformToolset=v141 /property:Platform=x64 /property:WholeProgramOptimization=false zimg.vcxproj
|
||||
cp x64/$MSBUILD_CONFIG/z.lib $BUILD/lib/zimg.lib
|
||||
cd ../..
|
||||
cp $SRC/zimg/src/zimg/api/zimg.h $BUILD/include/zimg.h
|
||||
cp zimg.pc $BUILD/lib/pkgconfig/zimg.pc
|
||||
add_comp libzimg
|
||||
}
|
||||
|
||||
function build_x264 {
|
||||
git clone https://code.videolan.org/videolan/x264.git $SRC/x264
|
||||
cd $SRC/x264
|
||||
git checkout b5bc5d69c580429ff716bafcd43655e855c31b02
|
||||
#f9af2a0f71d0fca7c1cafa7657f03a302da0ca1c
|
||||
CC=cl ./configure --prefix=$BUILD --disable-cli --enable-static --enable-pic --libdir=$BUILD/lib
|
||||
make -j $NUMBER_OF_PROCESSORS
|
||||
make install-lib-static
|
||||
add_comp libx264
|
||||
}
|
||||
|
||||
function build_opus {
|
||||
git clone https://github.com/xiph/opus.git $SRC/opus
|
||||
cd $SRC/opus/win32/VS2015
|
||||
echo \nConverting project file ...
|
||||
sed -i 's/v140/v141/g' opus.vcxproj
|
||||
echo Building project 'opus' ...
|
||||
MSBuild.exe /maxcpucount:$NUMBER_OF_PROCESSORS /property:Configuration="$MSBUILD_CONFIG" /property:Platform=x64 opus.vcxproj
|
||||
echo Done.
|
||||
cp x64/$MSBUILD_CONFIG/opus.lib $BUILD/lib/opus.lib
|
||||
cp -r $SRC/opus/include $BUILD/include/opus
|
||||
cp $SRC/opus/opus.pc.in $BUILD/lib/pkgconfig/opus.pc
|
||||
sed -i "s#@prefix@#$BUILD#g" $BUILD/lib/pkgconfig/opus.pc
|
||||
sed -i "s/@exec_prefix@/\$\{prefix\}/g" $BUILD/lib/pkgconfig/opus.pc
|
||||
sed -i "s/@libdir@/\$\{prefix\}\/lib/g" $BUILD/lib/pkgconfig/opus.pc
|
||||
sed -i "s/@includedir@/\$\{prefix\}\/include/g" $BUILD/lib/pkgconfig/opus.pc
|
||||
sed -i "s/@LIBM@//g" $BUILD/lib/pkgconfig/opus.pc
|
||||
sed -i "s/@VERSION@/2.0.0/g" $BUILD/lib/pkgconfig/opus.pc
|
||||
add_comp libopus
|
||||
}
|
||||
|
||||
function build_x265 {
|
||||
git clone https://github.com/videolan/x265.git --branch stable $SRC/x265
|
||||
cd $SRC/x265/build/vc15-x86_64
|
||||
rm -rf work*
|
||||
mkdir work work10 work12
|
||||
# 12bit
|
||||
cd work12
|
||||
cmake -G "Visual Studio 15 Win64" ../../../source -DHIGH_BIT_DEPTH=ON -DEXPORT_C_API=OFF -DENABLE_SHARED=OFF -DENABLE_CLI=OFF -DMAIN12=ON
|
||||
MSBuild.exe /maxcpucount:$NUMBER_OF_PROCESSORS /property:Configuration="$MSBUILD_CONFIG" x265-static.vcxproj
|
||||
cp $MSBUILD_CONFIG/x265-static.lib ../work/x265_12bit.lib
|
||||
# 10bit
|
||||
cd ../work10
|
||||
cmake -G "Visual Studio 15 Win64" ../../../source -DHIGH_BIT_DEPTH=ON -DEXPORT_C_API=OFF -DENABLE_SHARED=OFF -DENABLE_CLI=OFF
|
||||
MSBuild.exe /maxcpucount:$NUMBER_OF_PROCESSORS /property:Configuration="$MSBUILD_CONFIG" x265-static.vcxproj
|
||||
cp $MSBUILD_CONFIG/x265-static.lib ../work/x265_10bit.lib
|
||||
# 8bit - main
|
||||
cd ../work
|
||||
cmake -G "Visual Studio 15 Win64" ../../../source -DCMAKE_INSTALL_PREFIX=$BUILD -DENABLE_SHARED=OFF -DENABLE_CLI=OFF -DEXTRA_LIB="x265_10bit.lib;x265_12bit.lib" -DLINKED_10BIT=ON -DLINKED_12BIT=ON
|
||||
#-DSTATIC_LINK_CRT=ON
|
||||
MSBuild.exe /maxcpucount:$NUMBER_OF_PROCESSORS /property:Configuration="$MSBUILD_CONFIG" x265-static.vcxproj
|
||||
cp $MSBUILD_CONFIG/x265-static.lib ./x265_main.lib
|
||||
LIB.EXE /ignore:4006 /ignore:4221 /OUT:x265.lib x265_main.lib x265_10bit.lib x265_12bit.lib
|
||||
cp x265.lib $BUILD/lib/x265.lib
|
||||
cp x265.pc $BUILD/lib/pkgconfig/x265.pc
|
||||
cp x265_config.h $BUILD/include/
|
||||
cp ../../../source/x265.h $BUILD/include/
|
||||
add_comp libx265
|
||||
}
|
||||
|
||||
function add_comp {
|
||||
COMPONENTS="$COMPONENTS --enable-$1"
|
||||
}
|
||||
|
||||
rm -rf src build
|
||||
mkdir src build build/include build/lib build/lib/pkgconfig
|
||||
|
||||
BUILD=`realpath build`
|
||||
SRC=`realpath src`
|
||||
|
||||
git clone -b release/4.3 git://source.ffmpeg.org/ffmpeg.git $SRC/ffmpeg
|
||||
|
||||
build_nvenc
|
||||
build_amf
|
||||
build_mfx
|
||||
build_svt
|
||||
build_ogg
|
||||
build_vorbis
|
||||
build_snappy
|
||||
build_libvpx
|
||||
build_libfdkaac
|
||||
build_lame
|
||||
build_zimg
|
||||
build_x264
|
||||
build_opus
|
||||
build_x265
|
||||
#build_aom
|
||||
|
||||
cd $SRC/ffmpeg
|
||||
PKG_CONFIG_PATH=$BUILD/lib/pkgconfig:$PKG_CONFIG_PATH ./configure --toolchain=msvc --extra-cflags="$CFLAGS -I$BUILD/include" --extra-ldflags="-LIBPATH:$BUILD/lib" --prefix=$BUILD --pkg-config-flags="--static" --disable-doc --disable-shared --enable-static --enable-runtime-cpudetect --disable-devices --disable-demuxers --disable-decoders --disable-network --enable-w32threads --enable-gpl $COMPONENTS
|
||||
sed -i 's/\x81/ue/g' config.h
|
||||
make -j $NUMBER_OF_PROCESSORS
|
||||
make install
|
||||
|
||||
# rename *.a to *.lib
|
||||
cd $BUILD/lib
|
||||
for file in *.a; do
|
||||
mv "$file" "`basename "$file" .a`.lib"
|
||||
done
|
||||
|
||||
# clean up
|
||||
rm -rf $BUILD/lib/pkgconfig $BUILD/lib/fdk-aac.lib $BUILD/lib/*.la
|
||||
|
||||
# Create archives
|
||||
cd $BUILD
|
||||
mkdir ../dist 2>/dev/null
|
||||
tar czf ../dist/ffmpeg-win64-static-$MODE.tar.gz *
|
||||
cd $SRC/ffmpeg
|
||||
tar czf ../../dist/ffmpeg-win64-static-src-$MODE.tar.gz *
|
||||
|
20
hotfix.patch
Normal file
20
hotfix.patch
Normal file
@ -0,0 +1,20 @@
|
||||
diff --git a/ffmpeg b/ffmpeg
|
||||
index 3721aae..336fe22 160000
|
||||
--- a/ffmpeg
|
||||
+++ b/ffmpeg
|
||||
@@ -1 +1 @@
|
||||
-Subproject commit 3721aaeaaae9f817abb843117ae8dae1dc280a7f
|
||||
+Subproject commit 336fe225a6a0e12d2ba701c641df63d36151f6fb-dirty
|
||||
diff --git a/patches/0075-qsv-use-a-new-method-to-create-mfx-session-when-usin.patch b/patches/0075-qsv-use-a-new-method-to-create-mfx-session-when-usin.patch
|
||||
index d1a787a..6a53eb0 100644
|
||||
--- a/patches/0075-qsv-use-a-new-method-to-create-mfx-session-when-usin.patch
|
||||
+++ b/patches/0075-qsv-use-a-new-method-to-create-mfx-session-when-usin.patch
|
||||
@@ -908,7 +908,7 @@ index 1e8ac56eed..500cf4c0bc 100644
|
||||
+ break;
|
||||
+ else if (sts != MFX_ERR_NONE) {
|
||||
+ impl_idx++;
|
||||
-+ continue;
|
||||
++ break;
|
||||
+ }
|
||||
+
|
||||
+ sts = MFXCreateSession(loader, impl_idx, &session);
|
@ -1,550 +0,0 @@
|
||||
diff --git a/configure b/configure
|
||||
index 48e8536..fa6a7f9 100755
|
||||
--- a/configure
|
||||
+++ b/configure
|
||||
@@ -213,6 +213,7 @@ External library support:
|
||||
--enable-libschroedinger Dirac video encoding/decoding
|
||||
--enable-libsnappy snappy compression
|
||||
--enable-libspeex Speex audio encoding/decoding
|
||||
+ --enable-libsvtav1 enable AV1 encoding via svt [no]
|
||||
--enable-libsrt Haivision SRT protocol
|
||||
--enable-libtheora Theora video encoding/decoding
|
||||
--enable-libtwolame MP2 audio encoding
|
||||
@@ -1376,6 +1377,7 @@ EXTERNAL_LIBRARY_LIST="
|
||||
libschroedinger
|
||||
libsnappy
|
||||
libspeex
|
||||
+ libsvtav1
|
||||
libsrt
|
||||
libtheora
|
||||
libtwolame
|
||||
@@ -2404,6 +2406,7 @@ libschroedinger_encoder_deps="libschroedinger"
|
||||
libspeex_decoder_deps="libspeex"
|
||||
libspeex_encoder_deps="libspeex"
|
||||
libspeex_encoder_select="audio_frame_queue"
|
||||
+libsvt_av1_encoder_deps="libsvtav1"
|
||||
libtheora_encoder_deps="libtheora"
|
||||
libtwolame_encoder_deps="libtwolame"
|
||||
libvo_aacenc_encoder_deps="libvo_aacenc"
|
||||
@@ -4692,6 +4695,7 @@ enabled libschroedinger && require_pkg_config libschroedinger schroedinger-1.0
|
||||
enabled libsnappy && require libsnappy snappy-c.h snappy_compress -lsnappy
|
||||
enabled libspeex && require_pkg_config libspeex speex speex/speex.h speex_decoder_init
|
||||
enabled libsrt && require_pkg_config libsrt "srt >= 1.3.0" srt/srt.h srt_socket
|
||||
+enabled libsvtav1 && require_pkg_config libsvtav1 SvtAv1Enc EbSvtAv1Enc.h eb_init_handle
|
||||
enabled libtheora && require libtheora theora/theoraenc.h th_info_init -ltheoraenc -ltheoradec -logg
|
||||
enabled libtwolame && require libtwolame twolame.h twolame_init -ltwolame
|
||||
enabled libvo_aacenc && require libvo_aacenc vo-aacenc/voAAC.h voGetAACEncAPI -lvo-aacenc
|
||||
diff --git a/libavcodec/Makefile b/libavcodec/Makefile
|
||||
index ea0c9dc..7f66c2f 100644
|
||||
--- a/libavcodec/Makefile
|
||||
+++ b/libavcodec/Makefile
|
||||
@@ -718,6 +718,7 @@ OBJS-$(CONFIG_LIBSCHROEDINGER_ENCODER) += libschroedingerenc.o \
|
||||
libschroedinger.o
|
||||
OBJS-$(CONFIG_LIBSPEEX_DECODER) += libspeexdec.o
|
||||
OBJS-$(CONFIG_LIBSPEEX_ENCODER) += libspeexenc.o
|
||||
+OBJS-$(CONFIG_LIBSVT_AV1_ENCODER) += libsvt_av1.o
|
||||
OBJS-$(CONFIG_LIBTHEORA_ENCODER) += libtheoraenc.o
|
||||
OBJS-$(CONFIG_LIBTWOLAME_ENCODER) += libtwolame.o
|
||||
OBJS-$(CONFIG_LIBVO_AACENC_ENCODER) += libvo-aacenc.o mpeg4audio.o
|
||||
diff --git a/libavcodec/allcodecs.c b/libavcodec/allcodecs.c
|
||||
index 4aee657..486405a 100644
|
||||
--- a/libavcodec/allcodecs.c
|
||||
+++ b/libavcodec/allcodecs.c
|
||||
@@ -436,6 +436,7 @@ void avcodec_register_all(void)
|
||||
REGISTER_ENCDEC (LIBSCHROEDINGER, libschroedinger);
|
||||
REGISTER_ENCDEC (LIBSPEEX, libspeex);
|
||||
REGISTER_ENCODER(LIBTHEORA, libtheora);
|
||||
+ REGISTER_ENCODER(LIBSVT_AV1, libsvt_av1);
|
||||
REGISTER_ENCODER(LIBTWOLAME, libtwolame);
|
||||
REGISTER_ENCODER(LIBVO_AACENC, libvo_aacenc);
|
||||
REGISTER_ENCODER(LIBVO_AMRWBENC, libvo_amrwbenc);
|
||||
new file mode 100644
|
||||
index 0000000..8f0e5a6
|
||||
--- /dev/null
|
||||
+++ b/libavcodec/libsvt_av1.c
|
||||
@@ -0,0 +1,483 @@
|
||||
+/*
|
||||
+* Scalable Video Technology for AV1 encoder library plugin
|
||||
+*
|
||||
+* Copyright (c) 2018 Intel Corporation
|
||||
+*
|
||||
+* This file is part of FFmpeg.
|
||||
+*
|
||||
+* FFmpeg is free software; you can redistribute it and/or
|
||||
+* modify it under the terms of the GNU Lesser General Public
|
||||
+* License as published by the Free Software Foundation; either
|
||||
+* version 2.1 of the License, or (at your option) any later version.
|
||||
+*
|
||||
+* FFmpeg is distributed in the hope that it will be useful,
|
||||
+* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
+* Lesser General Public License for more details.
|
||||
+*
|
||||
+* You should have received a copy of the GNU Lesser General Public
|
||||
+* License along with this program; if not, write to the Free Software
|
||||
+* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
+*/
|
||||
+
|
||||
+#include <stdint.h>
|
||||
+#include "EbSvtAv1ErrorCodes.h"
|
||||
+#include "EbSvtAv1Enc.h"
|
||||
+
|
||||
+#include "libavutil/common.h"
|
||||
+#include "libavutil/frame.h"
|
||||
+#include "libavutil/opt.h"
|
||||
+
|
||||
+#include "internal.h"
|
||||
+#include "avcodec.h"
|
||||
+
|
||||
+typedef enum eos_status {
|
||||
+ EOS_NOT_REACHED = 0,
|
||||
+ EOS_SENT,
|
||||
+ EOS_RECEIVED
|
||||
+}EOS_STATUS;
|
||||
+
|
||||
+typedef struct SvtContext {
|
||||
+ AVClass *class;
|
||||
+
|
||||
+ EbSvtAv1EncConfiguration enc_params;
|
||||
+ EbComponentType *svt_handle;
|
||||
+
|
||||
+ EbBufferHeaderType *in_buf;
|
||||
+ int raw_size;
|
||||
+
|
||||
+ EOS_STATUS eos_flag;
|
||||
+
|
||||
+ // User options.
|
||||
+ int hierarchical_level;
|
||||
+ int la_depth;
|
||||
+ int enc_mode;
|
||||
+ int rc_mode;
|
||||
+ int scd;
|
||||
+ int qp;
|
||||
+
|
||||
+ int forced_idr;
|
||||
+
|
||||
+ int aud;
|
||||
+
|
||||
+ int tier;
|
||||
+ int level;
|
||||
+
|
||||
+ int base_layer_switch_mode;
|
||||
+} SvtContext;
|
||||
+
|
||||
+static int error_mapping(EbErrorType svt_ret)
|
||||
+{
|
||||
+ int err;
|
||||
+
|
||||
+ switch (svt_ret) {
|
||||
+ case EB_ErrorInsufficientResources:
|
||||
+ err = AVERROR(ENOMEM);
|
||||
+ break;
|
||||
+
|
||||
+ case EB_ErrorUndefined:
|
||||
+ case EB_ErrorInvalidComponent:
|
||||
+ case EB_ErrorBadParameter:
|
||||
+ err = AVERROR(EINVAL);
|
||||
+ break;
|
||||
+
|
||||
+ case EB_ErrorDestroyThreadFailed:
|
||||
+ case EB_ErrorSemaphoreUnresponsive:
|
||||
+ case EB_ErrorDestroySemaphoreFailed:
|
||||
+ case EB_ErrorCreateMutexFailed:
|
||||
+ case EB_ErrorMutexUnresponsive:
|
||||
+ case EB_ErrorDestroyMutexFailed:
|
||||
+ err = AVERROR_EXTERNAL;
|
||||
+ break;
|
||||
+
|
||||
+ case EB_NoErrorEmptyQueue:
|
||||
+ err = AVERROR(EAGAIN);
|
||||
+
|
||||
+ case EB_ErrorNone:
|
||||
+ err = 0;
|
||||
+ break;
|
||||
+
|
||||
+ default:
|
||||
+ err = AVERROR_UNKNOWN;
|
||||
+ }
|
||||
+
|
||||
+ return err;
|
||||
+}
|
||||
+
|
||||
+static void free_buffer(SvtContext *svt_enc)
|
||||
+{
|
||||
+ if (svt_enc->in_buf) {
|
||||
+ EbSvtIOFormat *in_data = (EbSvtIOFormat *)svt_enc->in_buf->p_buffer;
|
||||
+ av_freep(&in_data);
|
||||
+ av_freep(&svt_enc->in_buf);
|
||||
+ }
|
||||
+}
|
||||
+
|
||||
+static int alloc_buffer(EbSvtAv1EncConfiguration *config, SvtContext *svt_enc)
|
||||
+{
|
||||
+ const int pack_mode_10bit =
|
||||
+ (config->encoder_bit_depth > 8) && (config->compressed_ten_bit_format == 0) ? 1 : 0;
|
||||
+ const size_t luma_size_8bit =
|
||||
+ config->source_width * config->source_height * (1 << pack_mode_10bit);
|
||||
+ const size_t luma_size_10bit =
|
||||
+ (config->encoder_bit_depth > 8 && pack_mode_10bit == 0) ? luma_size_8bit : 0;
|
||||
+
|
||||
+ EbSvtIOFormat *in_data;
|
||||
+
|
||||
+ svt_enc->raw_size = (luma_size_8bit + luma_size_10bit) * 3 / 2;
|
||||
+
|
||||
+ // allocate buffer for in and out
|
||||
+ svt_enc->in_buf = av_mallocz(sizeof(*svt_enc->in_buf));
|
||||
+ if (!svt_enc->in_buf)
|
||||
+ goto failed;
|
||||
+
|
||||
+ in_data = av_mallocz(sizeof(*in_data));
|
||||
+ if (!in_data)
|
||||
+ goto failed;
|
||||
+ svt_enc->in_buf->p_buffer = (unsigned char *)in_data;
|
||||
+
|
||||
+ svt_enc->in_buf->size = sizeof(*svt_enc->in_buf);
|
||||
+ svt_enc->in_buf->p_app_private = NULL;
|
||||
+
|
||||
+ return 0;
|
||||
+
|
||||
+failed:
|
||||
+ free_buffer(svt_enc);
|
||||
+ return AVERROR(ENOMEM);
|
||||
+}
|
||||
+
|
||||
+static int config_enc_params(EbSvtAv1EncConfiguration *param,
|
||||
+ AVCodecContext *avctx)
|
||||
+{
|
||||
+ SvtContext *svt_enc = avctx->priv_data;
|
||||
+ int ret;
|
||||
+
|
||||
+ param->source_width = avctx->width;
|
||||
+ param->source_height = avctx->height;
|
||||
+
|
||||
+ if (avctx->pix_fmt == AV_PIX_FMT_YUV420P10) {
|
||||
+ av_log(avctx, AV_LOG_DEBUG, "Set 10 bits depth input\n");
|
||||
+ param->encoder_bit_depth = 10;
|
||||
+ } else {
|
||||
+ av_log(avctx, AV_LOG_DEBUG, "Set 8 bits depth input\n");
|
||||
+ param->encoder_bit_depth = 8;
|
||||
+ }
|
||||
+
|
||||
+ param->encoder_color_format = EB_YUV420;
|
||||
+
|
||||
+ // Update param from options
|
||||
+ param->hierarchical_levels = svt_enc->hierarchical_level;
|
||||
+ param->enc_mode = svt_enc->enc_mode;
|
||||
+ param->tier = svt_enc->tier;
|
||||
+ param->level = svt_enc->level;
|
||||
+ param->rate_control_mode = svt_enc->rc_mode;
|
||||
+ param->scene_change_detection = svt_enc->scd;
|
||||
+ param->base_layer_switch_mode = svt_enc->base_layer_switch_mode;
|
||||
+ param->qp = svt_enc->qp;
|
||||
+
|
||||
+
|
||||
+ param->target_bit_rate = avctx->bit_rate;
|
||||
+ if (avctx->gop_size > 0)
|
||||
+ param->intra_period_length = avctx->gop_size - 1;
|
||||
+
|
||||
+ if (avctx->framerate.num > 0 && avctx->framerate.den > 0) {
|
||||
+ param->frame_rate_numerator = avctx->framerate.num;
|
||||
+ param->frame_rate_denominator = avctx->framerate.den * avctx->ticks_per_frame;
|
||||
+ } else {
|
||||
+ param->frame_rate_numerator = avctx->time_base.den;
|
||||
+ param->frame_rate_denominator = avctx->time_base.num * avctx->ticks_per_frame;
|
||||
+ }
|
||||
+
|
||||
+ if (param->rate_control_mode) {
|
||||
+ param->max_qp_allowed = avctx->qmax;
|
||||
+ param->min_qp_allowed = avctx->qmin;
|
||||
+ }
|
||||
+
|
||||
+ param->intra_refresh_type = svt_enc->forced_idr + 1;
|
||||
+
|
||||
+ if (svt_enc->la_depth != -1)
|
||||
+ param->look_ahead_distance = svt_enc->la_depth;
|
||||
+
|
||||
+ ret = alloc_buffer(param, svt_enc);
|
||||
+
|
||||
+ return ret;
|
||||
+}
|
||||
+
|
||||
+static void read_in_data(EbSvtAv1EncConfiguration *config,
|
||||
+ const AVFrame *frame,
|
||||
+ EbBufferHeaderType *headerPtr)
|
||||
+{
|
||||
+ uint8_t is16bit = config->encoder_bit_depth > 8;
|
||||
+ uint64_t luma_size =
|
||||
+ (uint64_t)config->source_width * config->source_height<< is16bit;
|
||||
+ EbSvtIOFormat *in_data = (EbSvtIOFormat *)headerPtr->p_buffer;
|
||||
+
|
||||
+ // support yuv420p and yuv420p010
|
||||
+ in_data->luma = frame->data[0];
|
||||
+ in_data->cb = frame->data[1];
|
||||
+ in_data->cr = frame->data[2];
|
||||
+
|
||||
+ // stride info
|
||||
+ in_data->y_stride = frame->linesize[0] >> is16bit;
|
||||
+ in_data->cb_stride = frame->linesize[1] >> is16bit;
|
||||
+ in_data->cr_stride = frame->linesize[2] >> is16bit;
|
||||
+
|
||||
+ headerPtr->n_filled_len += luma_size * 3/2u;
|
||||
+}
|
||||
+
|
||||
+static av_cold int eb_enc_init(AVCodecContext *avctx)
|
||||
+{
|
||||
+ SvtContext *svt_enc = avctx->priv_data;
|
||||
+ EbErrorType svt_ret;
|
||||
+
|
||||
+ svt_enc->eos_flag = EOS_NOT_REACHED;
|
||||
+
|
||||
+ svt_ret = eb_init_handle(&svt_enc->svt_handle, svt_enc, &svt_enc->enc_params);
|
||||
+ if (svt_ret != EB_ErrorNone) {
|
||||
+ av_log(avctx, AV_LOG_ERROR, "Error init encoder handle\n");
|
||||
+ goto failed;
|
||||
+ }
|
||||
+
|
||||
+ svt_ret = config_enc_params(&svt_enc->enc_params, avctx);
|
||||
+ if (svt_ret != EB_ErrorNone) {
|
||||
+ av_log(avctx, AV_LOG_ERROR, "Error configure encoder parameters\n");
|
||||
+ goto failed_init_handle;
|
||||
+ }
|
||||
+
|
||||
+ svt_ret = eb_svt_enc_set_parameter(svt_enc->svt_handle, &svt_enc->enc_params);
|
||||
+ if (svt_ret != EB_ErrorNone) {
|
||||
+ av_log(avctx, AV_LOG_ERROR, "Error setting encoder parameters\n");
|
||||
+ goto failed_init_handle;
|
||||
+ }
|
||||
+
|
||||
+ svt_ret = eb_init_encoder(svt_enc->svt_handle);
|
||||
+ if (svt_ret != EB_ErrorNone) {
|
||||
+ av_log(avctx, AV_LOG_ERROR, "Error init encoder\n");
|
||||
+ goto failed_init_handle;
|
||||
+ }
|
||||
+
|
||||
+ if (avctx->flags & AV_CODEC_FLAG_GLOBAL_HEADER) {
|
||||
+ EbBufferHeaderType *headerPtr = NULL;
|
||||
+
|
||||
+ svt_ret = eb_svt_enc_stream_header(svt_enc->svt_handle, &headerPtr);
|
||||
+ if (svt_ret != EB_ErrorNone) {
|
||||
+ av_log(avctx, AV_LOG_ERROR, "Error when build stream header.\n");
|
||||
+ goto failed_init_enc;
|
||||
+ }
|
||||
+
|
||||
+ avctx->extradata_size = headerPtr->n_filled_len;
|
||||
+ avctx->extradata = av_mallocz(avctx->extradata_size + AV_INPUT_BUFFER_PADDING_SIZE);
|
||||
+ if (!avctx->extradata) {
|
||||
+ av_log(avctx, AV_LOG_ERROR,
|
||||
+ "Cannot allocate AV1 header of size %d.\n", avctx->extradata_size);
|
||||
+ svt_ret = EB_ErrorInsufficientResources;
|
||||
+ goto failed_init_enc;
|
||||
+ }
|
||||
+
|
||||
+ memcpy(avctx->extradata, headerPtr->p_buffer, avctx->extradata_size);
|
||||
+
|
||||
+ svt_ret = eb_svt_release_enc_stream_header(headerPtr);
|
||||
+ if (svt_ret != EB_ErrorNone) {
|
||||
+ av_log(avctx, AV_LOG_ERROR, "Error when destroy stream header.\n");
|
||||
+ goto failed_init_enc;
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ return 0;
|
||||
+
|
||||
+failed_init_enc:
|
||||
+ eb_deinit_encoder(svt_enc->svt_handle);
|
||||
+failed_init_handle:
|
||||
+ eb_deinit_handle(svt_enc->svt_handle);
|
||||
+failed:
|
||||
+ free_buffer(svt_enc);
|
||||
+ return error_mapping(svt_ret);
|
||||
+}
|
||||
+
|
||||
+static int eb_send_frame(AVCodecContext *avctx, const AVFrame *frame)
|
||||
+{
|
||||
+ SvtContext *svt_enc = avctx->priv_data;
|
||||
+ EbBufferHeaderType *headerPtr = svt_enc->in_buf;
|
||||
+
|
||||
+ if (!frame) {
|
||||
+ EbBufferHeaderType headerPtrLast;
|
||||
+ headerPtrLast.n_alloc_len = 0;
|
||||
+ headerPtrLast.n_filled_len = 0;
|
||||
+ headerPtrLast.n_tick_count = 0;
|
||||
+ headerPtrLast.p_app_private = NULL;
|
||||
+ headerPtrLast.p_buffer = NULL;
|
||||
+ headerPtrLast.flags = EB_BUFFERFLAG_EOS;
|
||||
+
|
||||
+ eb_svt_enc_send_picture(svt_enc->svt_handle, &headerPtrLast);
|
||||
+ svt_enc->eos_flag = EOS_SENT;
|
||||
+ av_log(avctx, AV_LOG_DEBUG, "Finish sending frames!!!\n");
|
||||
+ return 0;
|
||||
+ }
|
||||
+
|
||||
+ read_in_data(&svt_enc->enc_params, frame, headerPtr);
|
||||
+
|
||||
+ headerPtr->flags = 0;
|
||||
+ headerPtr->p_app_private = NULL;
|
||||
+ headerPtr->pts = frame->pts;
|
||||
+
|
||||
+ eb_svt_enc_send_picture(svt_enc->svt_handle, headerPtr);
|
||||
+
|
||||
+ return 0;
|
||||
+}
|
||||
+
|
||||
+static int eb_receive_packet(AVCodecContext *avctx, AVPacket *pkt)
|
||||
+{
|
||||
+ SvtContext *svt_enc = avctx->priv_data;
|
||||
+ EbBufferHeaderType *headerPtr;
|
||||
+ EbErrorType svt_ret;
|
||||
+ int ret = 0;
|
||||
+
|
||||
+ if (svt_enc->eos_flag == EOS_RECEIVED)
|
||||
+ return AVERROR_EOF;
|
||||
+
|
||||
+ if ((ret = ff_alloc_packet2(avctx, pkt, svt_enc->raw_size, 0)) < 0) {
|
||||
+ av_log(avctx, AV_LOG_ERROR, "Failed to allocate output packet.\n");
|
||||
+ return ret;
|
||||
+ }
|
||||
+ svt_ret = eb_svt_get_packet(svt_enc->svt_handle, &headerPtr, svt_enc->eos_flag);
|
||||
+ if (svt_ret == EB_NoErrorEmptyQueue)
|
||||
+ return AVERROR(EAGAIN);
|
||||
+
|
||||
+ memcpy(pkt->data, headerPtr->p_buffer, headerPtr->n_filled_len);
|
||||
+ pkt->size = headerPtr->n_filled_len;
|
||||
+ pkt->pts = headerPtr->pts;
|
||||
+ pkt->dts = headerPtr->dts;
|
||||
+ if (headerPtr->pic_type == EB_AV1_KEY_PICTURE)
|
||||
+ pkt->flags |= AV_PKT_FLAG_KEY;
|
||||
+ if (headerPtr->pic_type == EB_AV1_NON_REF_PICTURE)
|
||||
+ pkt->flags |= AV_PKT_FLAG_DISPOSABLE;
|
||||
+
|
||||
+ if (headerPtr->flags & EB_BUFFERFLAG_EOS)
|
||||
+ svt_enc->eos_flag = EOS_RECEIVED;
|
||||
+
|
||||
+ eb_svt_release_out_buffer(&headerPtr);
|
||||
+
|
||||
+ return ret;
|
||||
+}
|
||||
+
|
||||
+static av_cold int eb_enc_close(AVCodecContext *avctx)
|
||||
+{
|
||||
+ SvtContext *svt_enc = avctx->priv_data;
|
||||
+
|
||||
+ eb_deinit_encoder(svt_enc->svt_handle);
|
||||
+ eb_deinit_handle(svt_enc->svt_handle);
|
||||
+
|
||||
+ free_buffer(svt_enc);
|
||||
+
|
||||
+ return 0;
|
||||
+}
|
||||
+
|
||||
+#define OFFSET(x) offsetof(SvtContext, x)
|
||||
+#define VE AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_ENCODING_PARAM
|
||||
+static const AVOption options[] = {
|
||||
+ { "aud", "Include AUD", OFFSET(aud),
|
||||
+ AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, VE },
|
||||
+
|
||||
+ { "hielevel", "Hierarchical prediction levels setting", OFFSET(hierarchical_level),
|
||||
+ AV_OPT_TYPE_INT, { .i64 = 4 }, 3, 4, VE , "hielevel"},
|
||||
+ { "flat", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = 1 }, INT_MIN, INT_MAX, VE, "hielevel" },
|
||||
+ { "2level", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = 2 }, INT_MIN, INT_MAX, VE, "hielevel" },
|
||||
+ { "3level", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = 3 }, INT_MIN, INT_MAX, VE, "hielevel" },
|
||||
+ { "4level", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = 4 }, INT_MIN, INT_MAX, VE, "hielevel" },
|
||||
+
|
||||
+ { "la_depth", "Look ahead distance [0, 256]", OFFSET(la_depth),
|
||||
+ AV_OPT_TYPE_INT, { .i64 = -1 }, -1, 256, VE },
|
||||
+
|
||||
+ { "preset", "Encoding preset [0, 7]",
|
||||
+ OFFSET(enc_mode), AV_OPT_TYPE_INT, { .i64 = MAX_ENC_PRESET }, 0, MAX_ENC_PRESET, VE },
|
||||
+
|
||||
+ { "tier", "Set tier (general_tier_flag)", OFFSET(tier),
|
||||
+ AV_OPT_TYPE_INT, { .i64 = 0 }, 0, 1, VE, "tier" },
|
||||
+ { "main", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = 0 }, 0, 0, VE, "tier" },
|
||||
+ { "high", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = 1 }, 0, 0, VE, "tier" },
|
||||
+
|
||||
+ { "level", "Set level (level_idc)", OFFSET(level),
|
||||
+ AV_OPT_TYPE_INT, { .i64 = 0 }, 0, 0x1f, VE, "level" },
|
||||
+
|
||||
+#define LEVEL(name, value) name, NULL, 0, AV_OPT_TYPE_CONST, \
|
||||
+ { .i64 = value }, 0, 0, VE, "level"
|
||||
+ { LEVEL("2.0", 20) },
|
||||
+ { LEVEL("2.1", 21) },
|
||||
+ { LEVEL("2.2", 22) },
|
||||
+ { LEVEL("2.3", 23) },
|
||||
+ { LEVEL("3.0", 30) },
|
||||
+ { LEVEL("3.1", 31) },
|
||||
+ { LEVEL("3.2", 32) },
|
||||
+ { LEVEL("3.3", 33) },
|
||||
+ { LEVEL("4.0", 40) },
|
||||
+ { LEVEL("4.1", 41) },
|
||||
+ { LEVEL("4.2", 42) },
|
||||
+ { LEVEL("4.3", 43) },
|
||||
+ { LEVEL("5.0", 50) },
|
||||
+ { LEVEL("5.1", 51) },
|
||||
+ { LEVEL("5.2", 52) },
|
||||
+ { LEVEL("5.3", 53) },
|
||||
+ { LEVEL("6.0", 60) },
|
||||
+ { LEVEL("6.1", 61) },
|
||||
+ { LEVEL("6.2", 62) },
|
||||
+ { LEVEL("6.3", 63) },
|
||||
+ { LEVEL("7.0", 70) },
|
||||
+ { LEVEL("7.1", 71) },
|
||||
+ { LEVEL("7.2", 72) },
|
||||
+ { LEVEL("7.3", 73) },
|
||||
+#undef LEVEL
|
||||
+
|
||||
+ { "rc", "Bit rate control mode", OFFSET(rc_mode),
|
||||
+ AV_OPT_TYPE_INT, { .i64 = 0 }, 0, 1, VE , "rc"},
|
||||
+ { "cqp", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = 0 }, INT_MIN, INT_MAX, VE, "rc" },
|
||||
+ { "vbr", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = 1 }, INT_MIN, INT_MAX, VE, "rc" },
|
||||
+
|
||||
+ { "qp", "QP value for intra frames", OFFSET(qp),
|
||||
+ AV_OPT_TYPE_INT, { .i64 = 50 }, 0, 63, VE },
|
||||
+
|
||||
+ { "sc_detection", "Scene change detection", OFFSET(scd),
|
||||
+ AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, VE },
|
||||
+
|
||||
+ { "bl_mode", "Random Access Prediction Structure type setting", OFFSET(base_layer_switch_mode),
|
||||
+ AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, VE },
|
||||
+
|
||||
+ { "forced-idr", "If forcing keyframes, force them as IDR frames.", OFFSET(forced_idr),
|
||||
+ AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, VE },
|
||||
+
|
||||
+ {NULL},
|
||||
+};
|
||||
+
|
||||
+static const AVClass class = {
|
||||
+ .class_name = "libsvt_av1",
|
||||
+ .item_name = av_default_item_name,
|
||||
+ .option = options,
|
||||
+ .version = LIBAVUTIL_VERSION_INT,
|
||||
+};
|
||||
+
|
||||
+static const AVCodecDefault eb_enc_defaults[] = {
|
||||
+ { "b", "7M" },
|
||||
+ { "g", "-2" },
|
||||
+ { "qmin", "0" },
|
||||
+ { "qmax", "63" },
|
||||
+ { NULL },
|
||||
+};
|
||||
+
|
||||
+AVCodec ff_libsvt_av1_encoder = {
|
||||
+ .name = "libsvt_av1",
|
||||
+ .long_name = NULL_IF_CONFIG_SMALL("SVT-AV1(Scalable Video Technology for AV1) encoder"),
|
||||
+ .priv_data_size = sizeof(SvtContext),
|
||||
+ .type = AVMEDIA_TYPE_VIDEO,
|
||||
+ .id = AV_CODEC_ID_AV1,
|
||||
+ .init = eb_enc_init,
|
||||
+ .send_frame = eb_send_frame,
|
||||
+ .receive_packet = eb_receive_packet,
|
||||
+ .close = eb_enc_close,
|
||||
+ .capabilities = AV_CODEC_CAP_DELAY | AV_CODEC_CAP_AUTO_THREADS,
|
||||
+ .pix_fmts = (const enum AVPixelFormat[]){ AV_PIX_FMT_YUV420P,
|
||||
+ AV_PIX_FMT_YUV420P10,
|
||||
+ AV_PIX_FMT_NONE },
|
||||
+ .priv_class = &class,
|
||||
+ .defaults = eb_enc_defaults,
|
||||
+ .caps_internal = FF_CODEC_CAP_INIT_CLEANUP,
|
||||
+ .wrapper_name = "libsvt_av1",
|
||||
+};
|
||||
--
|
||||
1.8.3.1
|
@ -1,57 +0,0 @@
|
||||
--- libavcodec/libfdk-aacenc.c.orig 2018-09-04 17:31:43.145385000 +0200
|
||||
+++ libavcodec/libfdk-aacenc.c 2018-09-04 17:39:10.786071200 +0200
|
||||
@@ -289,7 +289,7 @@
|
||||
}
|
||||
|
||||
avctx->frame_size = info.frameLength;
|
||||
- avctx->initial_padding = info.encoderDelay;
|
||||
+ avctx->initial_padding = info.nDelay;
|
||||
ff_af_queue_init(avctx, &s->afq);
|
||||
|
||||
if (avctx->flags & AV_CODEC_FLAG_GLOBAL_HEADER) {
|
||||
@@ -322,28 +322,35 @@
|
||||
int out_buffer_size, out_buffer_element_size;
|
||||
void *in_ptr, *out_ptr;
|
||||
int ret;
|
||||
+ uint8_t dummy_buf[1];
|
||||
AACENC_ERROR err;
|
||||
|
||||
/* handle end-of-stream small frame and flushing */
|
||||
if (!frame) {
|
||||
+ /* Must be a non-null pointer, even if it's a dummy. We could use
|
||||
+ * the address of anything else on the stack as well. */
|
||||
+ in_ptr = dummy_buf;
|
||||
+ in_buffer_size = 0;
|
||||
+
|
||||
in_args.numInSamples = -1;
|
||||
} else {
|
||||
- in_ptr = frame->data[0];
|
||||
- in_buffer_size = 2 * avctx->channels * frame->nb_samples;
|
||||
- in_buffer_element_size = 2;
|
||||
-
|
||||
- in_args.numInSamples = avctx->channels * frame->nb_samples;
|
||||
- in_buf.numBufs = 1;
|
||||
- in_buf.bufs = &in_ptr;
|
||||
- in_buf.bufferIdentifiers = &in_buffer_identifier;
|
||||
- in_buf.bufSizes = &in_buffer_size;
|
||||
- in_buf.bufElSizes = &in_buffer_element_size;
|
||||
+ in_ptr = frame->data[0];
|
||||
+ in_buffer_size = 2 * avctx->channels * frame->nb_samples;
|
||||
+
|
||||
+ in_args.numInSamples = avctx->channels * frame->nb_samples;
|
||||
|
||||
/* add current frame to the queue */
|
||||
if ((ret = ff_af_queue_add(&s->afq, frame)) < 0)
|
||||
return ret;
|
||||
}
|
||||
|
||||
+ in_buffer_element_size = 2;
|
||||
+ in_buf.numBufs = 1;
|
||||
+ in_buf.bufs = &in_ptr;
|
||||
+ in_buf.bufferIdentifiers = &in_buffer_identifier;
|
||||
+ in_buf.bufSizes = &in_buffer_size;
|
||||
+ in_buf.bufElSizes = &in_buffer_element_size;
|
||||
+
|
||||
/* The maximum packet size is 6144 bits aka 768 bytes per channel. */
|
||||
if ((ret = ff_alloc_packet2(avctx, avpkt, FFMAX(8192, 768 * avctx->channels), 0)) < 0)
|
||||
return ret;
|
@ -1,13 +0,0 @@
|
||||
--- libavformat/matroskaenc.c 2018-08-10 22:18:59.051659000 +0200
|
||||
+++ libavformat/matroskaenc2.c 2018-08-10 22:18:31.932030400 +0200
|
||||
@@ -2671,8 +2671,8 @@
|
||||
}
|
||||
|
||||
for (i = 0; i < s->nb_streams; i++) {
|
||||
- // ms precision is the de-facto standard timescale for mkv files
|
||||
- avpriv_set_pts_info(s->streams[i], 64, 1, 1000);
|
||||
+ // ms precision is the de-facto standard timescale for mkv files (Patched: We're using microseconds!!)
|
||||
+ avpriv_set_pts_info(s->streams[i], 64, 1, 1000000);
|
||||
}
|
||||
|
||||
return 0;
|
Reference in New Issue
Block a user