Compare commits
199 Commits
Author | SHA1 | Date | |
---|---|---|---|
569a789432 | |||
b36890f293 | |||
7662805806 | |||
b445e67952 | |||
293a602e6f | |||
c98389f743 | |||
890a31b49b | |||
5762e8c223 | |||
c66e8654d3 | |||
dd58003f0c | |||
22009f8153 | |||
8bfb822127 | |||
80a178d335 | |||
90118b85ec | |||
ce5b0ae521 | |||
7d68bf05f2 | |||
741f9f09a7 | |||
9827d2a397 | |||
4e4ed6268c | |||
3f358307d4 | |||
49dc603a7e | |||
9c9d5bc9af | |||
833f59c056 | |||
c6105dcbcd | |||
34ba575e93 | |||
e8bc575304 | |||
778632362f | |||
d580fdacf9 | |||
fb68a11db0 | |||
5c662bbf4c | |||
27fe5ace74 | |||
5805c7d571 | |||
4684230ae5 | |||
e7592e5bbd | |||
99683552f4 | |||
946b581996 | |||
717556bb3c | |||
9e98f7ba0b | |||
fd2416deca | |||
70b0e356b5 | |||
ec49fc8f45 | |||
5b8b185a19 | |||
e276db8230 | |||
40c5f1b9f4 | |||
0793868642 | |||
9508b682df | |||
4304c8bd21 | |||
d642a7af5e | |||
15d39a0ae4 | |||
41d4be87e1 | |||
a5da390ad5 | |||
b96c771c02 | |||
a3d59f258f | |||
201ede0b46 | |||
3b64cf60ef | |||
c59743aed1 | |||
ce4fef8bf5 | |||
4d4388bf62 | |||
5d7ddc217d | |||
1f8d08089d | |||
c78e519a2c | |||
e4ca060d44 | |||
aee86b9b20 | |||
d505e5d46c | |||
a1f41de31c | |||
0f144b81bb | |||
6f0a2d7ad6 | |||
46ef28c470 | |||
270c6fce9c | |||
1ac33dab8a | |||
a8752554ef | |||
da34fb4599 | |||
93976e2534 | |||
0c82344961 | |||
7dd8c987d0 | |||
d039a386b7 | |||
873680be3f | |||
09f9013713 | |||
56f8c998f6 | |||
349b58eecc | |||
b959d27624 | |||
10c88876bc | |||
c6b92d2f4e | |||
70bda63e9d | |||
1c68c6335a | |||
e72bad0214 | |||
1804b4eb32 | |||
1d19b49727 | |||
cbd4dc48f7 | |||
9295130beb | |||
5598d953c3 | |||
396376fd07 | |||
0fe5d095d9 | |||
c760b3218c | |||
c14c227819 | |||
82d140e7d3 | |||
38ecab2019 | |||
38d71e2878 | |||
5db2bab432 | |||
eb230b209c | |||
724ad0736a | |||
8249dc670a | |||
9b3025cd76 | |||
a477f8d2ed | |||
c447171e55 | |||
bf890278c0 | |||
6ebcc05909 | |||
d715a754f1 | |||
d0d8aae880 | |||
b0449badb8 | |||
2ebeb3e9a4 | |||
73b5fc5d98 | |||
cef469de9b | |||
7c904d18ac | |||
f1f3fb794c | |||
737f74db0c | |||
0e1b67f310 | |||
a15bfc298b | |||
ad9364ec80 | |||
c0567694ab | |||
7b6aab919f | |||
4298e9a94d | |||
e7df369012 | |||
6786d1fe98 | |||
8046a30542 | |||
702e11e7ad | |||
47aaf438f6 | |||
c5660a2fe3 | |||
105f314c8e | |||
949b952ef9 | |||
e517e524cc | |||
70c8c16e55 | |||
4f07e4e84e | |||
6929f42dd6 | |||
20bf845ddf | |||
66bd1fb20d | |||
5857c8f7b3 | |||
3662187a26 | |||
2538643d8f | |||
b02d60ae70 | |||
4b2f10e62c | |||
77fa7d0425 | |||
b4843c3c93 | |||
a34f18b836 | |||
037df191bb | |||
011e815b21 | |||
87ee3a9deb | |||
8b1aa0203b | |||
c2e11fe458 | |||
f149931d2f | |||
512fe8083a | |||
f43a71aaa0 | |||
1b3becb8d8 | |||
cea23c6d3f | |||
09afe7f781 | |||
6d8af9bd2a | |||
cf5c490ca7 | |||
740c0f1443 | |||
8e736fc176 | |||
0794129eb3 | |||
a510ee6450 | |||
cadbae2468 | |||
eed4f3bfd2 | |||
1173e86544 | |||
e4f69871fa | |||
847b88a4b4 | |||
beb2862876 | |||
bf9c403d51 | |||
4fc92a4b53 | |||
1db41d1069 | |||
5fce763b97 | |||
8cd96d2a1e | |||
adbbe8b0e2 | |||
8c1377ac0b | |||
f6b6de8146 | |||
d5c4a80332 | |||
89e2887db4 | |||
df491a68fd | |||
4418828161 | |||
158a3f4219 | |||
02c8f9089f | |||
cf638258b7 | |||
ebe0343972 | |||
29d3ae53b9 | |||
2744a17ea0 | |||
649f8542d4 | |||
61b2af2760 | |||
6e5afa8bd5 | |||
3e5859259a | |||
62166944bf | |||
85b34eb0c1 | |||
702d6bda6a | |||
3f9ddde766 | |||
28facf1b5f | |||
c3109dbae1 | |||
6d5c133800 | |||
e979b4ee9d | |||
a2350f473d | |||
36ddb729c5 |
16
.github/actions/libfdkaac/action.yml
vendored
16
.github/actions/libfdkaac/action.yml
vendored
@ -1,7 +1,7 @@
|
|||||||
name: libfdkaac
|
name: libfdkaac
|
||||||
|
|
||||||
inputs:
|
inputs:
|
||||||
env:
|
refId:
|
||||||
type: string
|
type: string
|
||||||
required: true
|
required: true
|
||||||
config:
|
config:
|
||||||
@ -20,22 +20,14 @@ runs:
|
|||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v3
|
||||||
with:
|
with:
|
||||||
repository: mstorsjo/fdk-aac
|
repository: mstorsjo/fdk-aac
|
||||||
ref: v2.0.2
|
ref: ${{ inputs.refId }}
|
||||||
path: fdkaac
|
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
|
- name: Set up MSYS2
|
||||||
if: steps.libfdkaac-cache.outputs.cache-hit != 'true'
|
|
||||||
uses: msys2/setup-msys2@v2
|
uses: msys2/setup-msys2@v2
|
||||||
with:
|
with:
|
||||||
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
||||||
path-type: inherit
|
path-type: inherit
|
||||||
- name: Build FDK AAC
|
- name: Build FDK AAC
|
||||||
if: steps.libfdkaac-cache.outputs.cache-hit != 'true'
|
|
||||||
shell: cmd
|
shell: cmd
|
||||||
env:
|
env:
|
||||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||||
@ -43,9 +35,9 @@ runs:
|
|||||||
run: |
|
run: |
|
||||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||||
md build dist
|
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 *'
|
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 -j 2 ; make install ; cd ../build ; tar czf ../dist/libfdkaac.tgz *'
|
||||||
- name: Publish artifact
|
- name: Publish artifact
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
with:
|
with:
|
||||||
name: libfdkaac-${{ inputs.env }}-${{ inputs.config }}
|
name: libfdkaac-${{ runner.os }}-${{ inputs.config }}
|
||||||
path: dist/libfdkaac.tgz
|
path: dist/libfdkaac.tgz
|
||||||
|
44
.github/actions/libkvazaar/action.yml
vendored
Normal file
44
.github/actions/libkvazaar/action.yml
vendored
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
name: libkvazaar
|
||||||
|
|
||||||
|
inputs:
|
||||||
|
refId:
|
||||||
|
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 KVAZAAR
|
||||||
|
uses: actions/checkout@v3.0.0
|
||||||
|
with:
|
||||||
|
repository: ultravideo/kvazaar
|
||||||
|
ref: ${{ inputs.refId }}
|
||||||
|
path: kvazaar
|
||||||
|
- name: Set up MSYS2
|
||||||
|
uses: msys2/setup-msys2@v2
|
||||||
|
with:
|
||||||
|
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
||||||
|
path-type: inherit
|
||||||
|
- name: Build KVAZAAR
|
||||||
|
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 kvazaar ; ./autogen.sh ; CC=cl ./configure --prefix=$(realpath ../build) CPPFLAGS=-DKVZ_STATIC_LIB || true ; make -j ; make install-lib-static ; cd ../build ; tar czf ../dist/libkvazaar.tgz *'
|
||||||
|
- name: Publish artifact
|
||||||
|
uses: actions/upload-artifact@v2
|
||||||
|
with:
|
||||||
|
name: libopus-${{ runner.os }}-${{ inputs.config }}
|
||||||
|
path: dist/libkvazaar.tgz
|
18
.github/actions/libmfx/action.yml
vendored
Normal file
18
.github/actions/libmfx/action.yml
vendored
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
name: libmfx
|
||||||
|
|
||||||
|
inputs:
|
||||||
|
refId:
|
||||||
|
type: string
|
||||||
|
required: true
|
||||||
|
config:
|
||||||
|
type: string
|
||||||
|
required: true
|
||||||
|
|
||||||
|
runs:
|
||||||
|
using: "composite"
|
||||||
|
steps:
|
||||||
|
- name: Publish artifact
|
||||||
|
uses: actions/upload-artifact@v2
|
||||||
|
with:
|
||||||
|
name: libmfx-${{ runner.os }}-${{ inputs.config }}
|
||||||
|
path: .github/actions/libmfx/libmfx.tgz
|
BIN
.github/actions/libmfx/libmfx.tgz
vendored
Normal file
BIN
.github/actions/libmfx/libmfx.tgz
vendored
Normal file
Binary file not shown.
6
.github/actions/libmp3lame/action.yml
vendored
6
.github/actions/libmp3lame/action.yml
vendored
@ -1,7 +1,7 @@
|
|||||||
name: libmp3lame
|
name: libmp3lame
|
||||||
|
|
||||||
inputs:
|
inputs:
|
||||||
env:
|
refId:
|
||||||
type: string
|
type: string
|
||||||
required: true
|
required: true
|
||||||
config:
|
config:
|
||||||
@ -24,9 +24,9 @@ runs:
|
|||||||
run: |
|
run: |
|
||||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||||
md build dist
|
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 *
|
D:\a\_temp\setup-msys2\msys2.cmd -c 'svn co https://svn.code.sf.net/p/lame/svn/${{ inputs.refId }}/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
|
- name: Publish artifact
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
with:
|
with:
|
||||||
name: libmp3lame-${{ inputs.env }}-${{ inputs.config }}
|
name: libmp3lame-${{ runner.os }}-${{ inputs.config }}
|
||||||
path: dist/libmp3lame.tgz
|
path: dist/libmp3lame.tgz
|
||||||
|
20
.github/actions/liboggvorbis/action.yml
vendored
20
.github/actions/liboggvorbis/action.yml
vendored
@ -1,7 +1,10 @@
|
|||||||
name: liboggvorbis
|
name: liboggvorbis
|
||||||
|
|
||||||
inputs:
|
inputs:
|
||||||
env:
|
libogg_refId:
|
||||||
|
type: string
|
||||||
|
required: true
|
||||||
|
libvorbis_refId:
|
||||||
type: string
|
type: string
|
||||||
required: true
|
required: true
|
||||||
config:
|
config:
|
||||||
@ -20,28 +23,20 @@ runs:
|
|||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v3
|
||||||
with:
|
with:
|
||||||
repository: xiph/ogg
|
repository: xiph/ogg
|
||||||
ref: v1.3.5
|
ref: ${{ inputs.libogg_refId }}
|
||||||
path: ogg
|
path: ogg
|
||||||
- name: Checkout Vorbis
|
- name: Checkout Vorbis
|
||||||
uses: actions/checkout@v3.0.0
|
uses: actions/checkout@v3.0.0
|
||||||
with:
|
with:
|
||||||
repository: xiph/vorbis
|
repository: xiph/vorbis
|
||||||
ref: v1.3.7
|
ref: ${{ inputs.libvorbis_refId }}
|
||||||
path: vorbis
|
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
|
- name: Set up MSYS2
|
||||||
if: steps.liboggvorbis-cache.outputs.cache-hit != 'true'
|
|
||||||
uses: msys2/setup-msys2@v2
|
uses: msys2/setup-msys2@v2
|
||||||
with:
|
with:
|
||||||
install: base-devel binutils autotools automake
|
install: base-devel binutils autotools automake
|
||||||
path-type: inherit
|
path-type: inherit
|
||||||
- name: Build Ogg
|
- name: Build Ogg
|
||||||
if: steps.liboggvorbis-cache.outputs.cache-hit != 'true'
|
|
||||||
shell: cmd
|
shell: cmd
|
||||||
env:
|
env:
|
||||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||||
@ -51,7 +46,6 @@ runs:
|
|||||||
md build
|
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'
|
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
|
- name: Build Vorbis
|
||||||
if: steps.liboggvorbis-cache.outputs.cache-hit != 'true'
|
|
||||||
shell: cmd
|
shell: cmd
|
||||||
env:
|
env:
|
||||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||||
@ -63,5 +57,5 @@ runs:
|
|||||||
- name: Publish artifact
|
- name: Publish artifact
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
with:
|
with:
|
||||||
name: liboggvorbis-${{ inputs.env }}-${{ inputs.config }}
|
name: liboggvorbis-${{ runner.os }}-${{ inputs.config }}
|
||||||
path: dist/liboggvorbis.tgz
|
path: dist/liboggvorbis.tgz
|
||||||
|
12
.github/actions/libopus/action.yml
vendored
12
.github/actions/libopus/action.yml
vendored
@ -1,7 +1,7 @@
|
|||||||
name: libopus
|
name: libopus
|
||||||
|
|
||||||
inputs:
|
inputs:
|
||||||
env:
|
refId:
|
||||||
type: string
|
type: string
|
||||||
required: true
|
required: true
|
||||||
config:
|
config:
|
||||||
@ -22,20 +22,12 @@ runs:
|
|||||||
repository: xiph/opus
|
repository: xiph/opus
|
||||||
ref: v1.3.1
|
ref: v1.3.1
|
||||||
path: opus
|
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
|
- name: Set up MSYS2
|
||||||
if: steps.libopus-cache.outputs.cache-hit != 'true'
|
|
||||||
uses: msys2/setup-msys2@v2
|
uses: msys2/setup-msys2@v2
|
||||||
with:
|
with:
|
||||||
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
||||||
path-type: inherit
|
path-type: inherit
|
||||||
- name: Build OPUS
|
- name: Build OPUS
|
||||||
if: steps.libopus-cache.outputs.cache-hit != 'true'
|
|
||||||
shell: cmd
|
shell: cmd
|
||||||
env:
|
env:
|
||||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||||
@ -50,5 +42,5 @@ runs:
|
|||||||
- name: Publish artifact
|
- name: Publish artifact
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
with:
|
with:
|
||||||
name: libopus-${{ inputs.env }}-${{ inputs.config }}
|
name: libopus-${{ runner.os }}-${{ inputs.config }}
|
||||||
path: dist/libopus.tgz
|
path: dist/libopus.tgz
|
||||||
|
13
.github/actions/libsnappy/action.yml
vendored
13
.github/actions/libsnappy/action.yml
vendored
@ -1,7 +1,7 @@
|
|||||||
name: libsnappy
|
name: libsnappy
|
||||||
|
|
||||||
inputs:
|
inputs:
|
||||||
env:
|
refId:
|
||||||
type: string
|
type: string
|
||||||
required: true
|
required: true
|
||||||
config:
|
config:
|
||||||
@ -20,16 +20,9 @@ runs:
|
|||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v3
|
||||||
with:
|
with:
|
||||||
repository: google/snappy
|
repository: google/snappy
|
||||||
ref: 1.1.9
|
ref: ${{ inputs.refId }}
|
||||||
path: snappy
|
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
|
- name: Set up MSYS2
|
||||||
if: steps.libsnappy-cache.outputs.cache-hit != 'true'
|
|
||||||
uses: msys2/setup-msys2@v2
|
uses: msys2/setup-msys2@v2
|
||||||
with:
|
with:
|
||||||
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
||||||
@ -53,5 +46,5 @@ runs:
|
|||||||
- name: Publish artifact
|
- name: Publish artifact
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
with:
|
with:
|
||||||
name: libsnappy-${{ inputs.env }}-${{ inputs.config }}
|
name: libsnappy-${{ runner.os }}-${{ inputs.config }}
|
||||||
path: dist/libsnappy.tgz
|
path: dist/libsnappy.tgz
|
||||||
|
28
.github/actions/libsvtav1/action.yml
vendored
28
.github/actions/libsvtav1/action.yml
vendored
@ -1,7 +1,7 @@
|
|||||||
name: libsvtav1
|
name: libsvtav1
|
||||||
|
|
||||||
inputs:
|
inputs:
|
||||||
env:
|
refId:
|
||||||
type: string
|
type: string
|
||||||
required: true
|
required: true
|
||||||
config:
|
config:
|
||||||
@ -16,26 +16,22 @@ runs:
|
|||||||
run: |
|
run: |
|
||||||
git config --global core.autocrlf false
|
git config --global core.autocrlf false
|
||||||
git config --global core.eol lf
|
git config --global core.eol lf
|
||||||
- name: Checkout SVT AV1
|
git clone -b ${{ inputs.refId }} https://gitlab.com/AOMediaCodec/SVT-AV1 svtav1
|
||||||
uses: actions/checkout@v3
|
cd svtav1
|
||||||
with:
|
git apply --ignore-whitespace --verbose ..\.github\actions\libsvtav1\patches\A01-metadata-copy-segfault-fix.patch
|
||||||
repository: AOMediaCodec/SVT-AV1
|
cd ..
|
||||||
ref: v1.1.0
|
#- name: Checkout SVT AV1
|
||||||
path: svtav1
|
# uses: actions/checkout@v3
|
||||||
- name: Check cache
|
# with:
|
||||||
id: libsvtav1-cache
|
# repository: AOMediaCodec/SVT-AV1
|
||||||
uses: actions/cache@v3
|
# ref: ${{ inputs.refId }}
|
||||||
with:
|
# path: svtav1
|
||||||
path: dist
|
|
||||||
key: libsvtav1-${{ inputs.env }}-${{ inputs.config }}-${{ hashFiles('svtav1') }}
|
|
||||||
- name: Set up MSYS2
|
- name: Set up MSYS2
|
||||||
if: steps.libsvtav1-cache.outputs.cache-hit != 'true'
|
|
||||||
uses: msys2/setup-msys2@v2
|
uses: msys2/setup-msys2@v2
|
||||||
with:
|
with:
|
||||||
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
||||||
path-type: inherit
|
path-type: inherit
|
||||||
- name: Build SVT AV1
|
- name: Build SVT AV1
|
||||||
if: steps.libsvtav1-cache.outputs.cache-hit != 'true'
|
|
||||||
shell: cmd
|
shell: cmd
|
||||||
env:
|
env:
|
||||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||||
@ -47,5 +43,5 @@ runs:
|
|||||||
- name: Publish artifact
|
- name: Publish artifact
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
with:
|
with:
|
||||||
name: libsvtav1-${{ inputs.env }}-${{ inputs.config }}
|
name: libsvtav1-${{ runner.os }}-${{ inputs.config }}
|
||||||
path: dist/libsvtav1.tgz
|
path: dist/libsvtav1.tgz
|
||||||
|
37
.github/actions/libsvtav1/patches/A01-metadata-copy-segfault-fix.patch
vendored
Normal file
37
.github/actions/libsvtav1/patches/A01-metadata-copy-segfault-fix.patch
vendored
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
From 213854249dc8d69653a9f3281cdd4c2063cd3779 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Christopher Degawa <christopher.degawa@intel.com>
|
||||||
|
Date: Wed, 10 Aug 2022 13:53:17 -0500
|
||||||
|
Subject: [PATCH] copy_input_buffer: only copy metadata if a frame was actaully
|
||||||
|
sent
|
||||||
|
|
||||||
|
Fixes a segfault if EOS was send through the library without zeroing
|
||||||
|
out the metadata array
|
||||||
|
|
||||||
|
Signed-off-by: Christopher Degawa <christopher.degawa@intel.com>
|
||||||
|
---
|
||||||
|
Source/Lib/Encoder/Globals/EbEncHandle.c | 9 +++++----
|
||||||
|
1 file changed, 5 insertions(+), 4 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/Source/Lib/Encoder/Globals/EbEncHandle.c b/Source/Lib/Encoder/Globals/EbEncHandle.c
|
||||||
|
index ba5e719a4..fc7a2b1f4 100644
|
||||||
|
--- a/Source/Lib/Encoder/Globals/EbEncHandle.c
|
||||||
|
+++ b/Source/Lib/Encoder/Globals/EbEncHandle.c
|
||||||
|
@@ -4814,11 +4814,12 @@ static void copy_input_buffer(SequenceControlSet* scs, EbBufferHeaderType* dst,
|
||||||
|
} else if (pass != ENCODE_FIRST_PASS || copy_frame) {
|
||||||
|
// Bypass copy for the unecessary picture in IPPP pass
|
||||||
|
// Copy the picture buffer
|
||||||
|
- if (src->p_buffer != NULL)
|
||||||
|
+ if (src->p_buffer != NULL) {
|
||||||
|
copy_frame_buffer(scs, dst->p_buffer, dst_y8b->p_buffer, src->p_buffer, pass);
|
||||||
|
- // Copy the metadata array
|
||||||
|
- if (svt_aom_copy_metadata_buffer(dst, src->metadata) != EB_ErrorNone)
|
||||||
|
- dst->metadata = NULL;
|
||||||
|
+ // Copy the metadata array
|
||||||
|
+ if (svt_aom_copy_metadata_buffer(dst, src->metadata) != EB_ErrorNone)
|
||||||
|
+ dst->metadata = NULL;
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
|
||||||
|
// Copy the private data list
|
||||||
|
--
|
||||||
|
GitLab
|
20
.github/actions/libvpl/action.yml
vendored
20
.github/actions/libvpl/action.yml
vendored
@ -1,7 +1,7 @@
|
|||||||
name: libvpl
|
name: libvpl
|
||||||
|
|
||||||
inputs:
|
inputs:
|
||||||
env:
|
refId:
|
||||||
type: string
|
type: string
|
||||||
required: true
|
required: true
|
||||||
config:
|
config:
|
||||||
@ -20,26 +20,18 @@ runs:
|
|||||||
uses: actions/checkout@v3.0.0
|
uses: actions/checkout@v3.0.0
|
||||||
with:
|
with:
|
||||||
repository: oneapi-src/oneVPL
|
repository: oneapi-src/oneVPL
|
||||||
ref: master
|
ref: ${{ inputs.refId }}
|
||||||
path: onevpl
|
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
|
- name: Set up MSYS2
|
||||||
if: steps.libvpl-cache.outputs.cache-hit != 'true'
|
|
||||||
uses: msys2/setup-msys2@v2
|
uses: msys2/setup-msys2@v2
|
||||||
with:
|
with:
|
||||||
install: base-devel binutils autotools automake
|
install: base-devel binutils autotools automake
|
||||||
path-type: inherit
|
path-type: inherit
|
||||||
- name: Build oneVPL
|
- name: Build oneVPL
|
||||||
if: steps.libvpl-cache.outputs.cache-hit != 'true'
|
|
||||||
shell: cmd
|
shell: cmd
|
||||||
env:
|
#env:
|
||||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
# vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||||
msbuildConfig: ${{ inputs.config == 'release' && 'Release' || 'Debug' }}
|
# msbuildConfig: ${{ inputs.config == 'release' && 'Release' || 'Debug' }}
|
||||||
run: |
|
run: |
|
||||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||||
md temp build dist
|
md temp build dist
|
||||||
@ -52,5 +44,5 @@ runs:
|
|||||||
- name: Publish artifact
|
- name: Publish artifact
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
with:
|
with:
|
||||||
name: libvpl-${{ inputs.env }}-${{ inputs.config }}
|
name: libvpl-${{ runner.os }}-${{ inputs.config }}
|
||||||
path: dist/libvpl.tgz
|
path: dist/libvpl.tgz
|
||||||
|
16
.github/actions/libvpx/action.yml
vendored
16
.github/actions/libvpx/action.yml
vendored
@ -1,7 +1,7 @@
|
|||||||
name: libvpx
|
name: libvpx
|
||||||
|
|
||||||
inputs:
|
inputs:
|
||||||
env:
|
refId:
|
||||||
type: string
|
type: string
|
||||||
required: true
|
required: true
|
||||||
config:
|
config:
|
||||||
@ -16,21 +16,13 @@ runs:
|
|||||||
run: |
|
run: |
|
||||||
git config --global core.autocrlf false
|
git config --global core.autocrlf false
|
||||||
git config --global core.eol lf
|
git config --global core.eol lf
|
||||||
git clone --depth 1 -b v1.12.0 https://github.com/webmproject/libvpx.git vpx
|
git clone --depth 1 -b ${{ inputs.refId }} 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
|
- name: Set up MSYS2
|
||||||
if: steps.libvpx-cache.outputs.cache-hit != 'true'
|
|
||||||
uses: msys2/setup-msys2@v2
|
uses: msys2/setup-msys2@v2
|
||||||
with:
|
with:
|
||||||
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
||||||
path-type: inherit
|
path-type: inherit
|
||||||
- name: Build LibVpx
|
- name: Build LibVpx
|
||||||
if: steps.libvpx-cache.outputs.cache-hit != 'true'
|
|
||||||
shell: cmd
|
shell: cmd
|
||||||
env:
|
env:
|
||||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||||
@ -38,9 +30,9 @@ runs:
|
|||||||
run: |
|
run: |
|
||||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||||
md build build\include build\lib build\lib\pkgconfig dist
|
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 *'
|
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 ; 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
|
- name: Publish artifact
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
with:
|
with:
|
||||||
name: libvpx-${{ inputs.env }}-${{ inputs.config }}
|
name: libvpx-${{ runner.os }}-${{ inputs.config }}
|
||||||
path: dist/libvpx.tgz
|
path: dist/libvpx.tgz
|
||||||
|
14
.github/actions/libx264/action.yml
vendored
14
.github/actions/libx264/action.yml
vendored
@ -1,7 +1,7 @@
|
|||||||
name: libx264
|
name: libx264
|
||||||
|
|
||||||
inputs:
|
inputs:
|
||||||
env:
|
refId:
|
||||||
type: string
|
type: string
|
||||||
required: true
|
required: true
|
||||||
config:
|
config:
|
||||||
@ -20,22 +20,14 @@ runs:
|
|||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v3
|
||||||
with:
|
with:
|
||||||
repository: mirror/x264
|
repository: mirror/x264
|
||||||
ref: stable
|
ref: ${{ inputs.refId }}
|
||||||
path: x264
|
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
|
- name: Set up MSYS2
|
||||||
if: steps.libx264-cache.outputs.cache-hit != 'true'
|
|
||||||
uses: msys2/setup-msys2@v2
|
uses: msys2/setup-msys2@v2
|
||||||
with:
|
with:
|
||||||
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
||||||
path-type: inherit
|
path-type: inherit
|
||||||
- name: Build X264
|
- name: Build X264
|
||||||
if: steps.libx264-cache.outputs.cache-hit != 'true'
|
|
||||||
shell: cmd
|
shell: cmd
|
||||||
env:
|
env:
|
||||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||||
@ -47,5 +39,5 @@ runs:
|
|||||||
- name: Publish artifact
|
- name: Publish artifact
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
with:
|
with:
|
||||||
name: libx264-${{ inputs.env }}-${{ inputs.config }}
|
name: libx264-${{ runner.os }}-${{ inputs.config }}
|
||||||
path: dist/libx264.tgz
|
path: dist/libx264.tgz
|
||||||
|
17
.github/actions/libx265-10/action.yml
vendored
17
.github/actions/libx265-10/action.yml
vendored
@ -1,7 +1,7 @@
|
|||||||
name: libx265-10
|
name: libx265-10
|
||||||
|
|
||||||
inputs:
|
inputs:
|
||||||
env:
|
refId:
|
||||||
type: string
|
type: string
|
||||||
required: true
|
required: true
|
||||||
config:
|
config:
|
||||||
@ -16,21 +16,12 @@ runs:
|
|||||||
run: |
|
run: |
|
||||||
git config --global core.autocrlf false
|
git config --global core.autocrlf false
|
||||||
git config --global core.eol lf
|
git config --global core.eol lf
|
||||||
git clone -b Release_3.5 https://github.com/videolan/x265.git x265
|
git clone -b ${{ inputs.refId }} 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
|
- name: Set up MSBuild
|
||||||
if: steps.libx26510-cache.outputs.cache-hit != 'true'
|
|
||||||
uses: microsoft/setup-msbuild@v1.1
|
uses: microsoft/setup-msbuild@v1.1
|
||||||
- name: Set up NASM
|
- name: Set up NASM
|
||||||
if: steps.libx26510-cache.outputs.cache-hit != 'true'
|
|
||||||
uses: ilammy/setup-nasm@v1.2.1
|
uses: ilammy/setup-nasm@v1.2.1
|
||||||
- name: Build X265 (10 bit)
|
- name: Build X265 (10 bit)
|
||||||
if: steps.libx26510-cache.outputs.cache-hit != 'true'
|
|
||||||
shell: cmd
|
shell: cmd
|
||||||
run: |
|
run: |
|
||||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||||
@ -44,5 +35,5 @@ runs:
|
|||||||
- name: Publish artifact
|
- name: Publish artifact
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
with:
|
with:
|
||||||
name: x265_10bit-${{ inputs.env }}-${{ inputs.config }}
|
name: x265_10bit-${{ runner.os }}-${{ inputs.config }}
|
||||||
path: dist/x265_10bit.lib
|
path: dist/x265_10bit.lib
|
||||||
|
17
.github/actions/libx265-12/action.yml
vendored
17
.github/actions/libx265-12/action.yml
vendored
@ -1,7 +1,7 @@
|
|||||||
name: libx265-12
|
name: libx265-12
|
||||||
|
|
||||||
inputs:
|
inputs:
|
||||||
env:
|
refId:
|
||||||
type: string
|
type: string
|
||||||
required: true
|
required: true
|
||||||
config:
|
config:
|
||||||
@ -16,21 +16,12 @@ runs:
|
|||||||
run: |
|
run: |
|
||||||
git config --global core.autocrlf false
|
git config --global core.autocrlf false
|
||||||
git config --global core.eol lf
|
git config --global core.eol lf
|
||||||
git clone -b Release_3.5 https://github.com/videolan/x265.git x265
|
git clone -b ${{ inputs.refId }} 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
|
- name: Set up MSBuild
|
||||||
if: steps.libx26512-cache.outputs.cache-hit != 'true'
|
|
||||||
uses: microsoft/setup-msbuild@v1.1
|
uses: microsoft/setup-msbuild@v1.1
|
||||||
- name: Set up NASM
|
- name: Set up NASM
|
||||||
if: steps.libx26512-cache.outputs.cache-hit != 'true'
|
|
||||||
uses: ilammy/setup-nasm@v1.2.1
|
uses: ilammy/setup-nasm@v1.2.1
|
||||||
- name: Build X265 (12 bit)
|
- name: Build X265 (12 bit)
|
||||||
if: steps.libx26512-cache.outputs.cache-hit != 'true'
|
|
||||||
shell: cmd
|
shell: cmd
|
||||||
env:
|
env:
|
||||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||||
@ -48,5 +39,5 @@ runs:
|
|||||||
- name: Publish artifact
|
- name: Publish artifact
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
with:
|
with:
|
||||||
name: x265_12bit-${{ inputs.env }}-${{ inputs.config }}
|
name: x265_12bit-${{ runner.os }}-${{ inputs.config }}
|
||||||
path: dist/x265_12bit.lib
|
path: dist/x265_12bit.lib
|
||||||
|
19
.github/actions/libx265/action.yml
vendored
19
.github/actions/libx265/action.yml
vendored
@ -1,7 +1,7 @@
|
|||||||
name: libx265
|
name: libx265
|
||||||
|
|
||||||
inputs:
|
inputs:
|
||||||
env:
|
refId:
|
||||||
type: string
|
type: string
|
||||||
required: true
|
required: true
|
||||||
config:
|
config:
|
||||||
@ -17,31 +17,20 @@ runs:
|
|||||||
git config --global core.autocrlf false
|
git config --global core.autocrlf false
|
||||||
git config --global core.eol lf
|
git config --global core.eol lf
|
||||||
git clone -b Release_3.5 https://github.com/videolan/x265.git x265
|
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
|
- name: Set up MSYS2
|
||||||
if: steps.libx265-cache.outputs.cache-hit != 'true'
|
|
||||||
uses: msys2/setup-msys2@v2
|
uses: msys2/setup-msys2@v2
|
||||||
with:
|
with:
|
||||||
install: base-devel binutils autotools automake
|
install: base-devel binutils autotools automake
|
||||||
path-type: inherit
|
path-type: inherit
|
||||||
- name: Set up MSBuild
|
- name: Set up MSBuild
|
||||||
if: steps.libx265-cache.outputs.cache-hit != 'true'
|
|
||||||
uses: microsoft/setup-msbuild@v1.1
|
uses: microsoft/setup-msbuild@v1.1
|
||||||
- name: Set up NASM
|
- name: Set up NASM
|
||||||
if: steps.libx265-cache.outputs.cache-hit != 'true'
|
|
||||||
uses: ilammy/setup-nasm@v1.2.1
|
uses: ilammy/setup-nasm@v1.2.1
|
||||||
- name: Set up dependant libs
|
- name: Set up dependant libs
|
||||||
if: steps.libx265-cache.outputs.cache-hit != 'true'
|
|
||||||
uses: actions/download-artifact@v3
|
uses: actions/download-artifact@v3
|
||||||
with:
|
with:
|
||||||
path: build
|
path: build
|
||||||
- name: Build X265
|
- name: Build X265
|
||||||
if: steps.libx265-cache.outputs.cache-hit != 'true'
|
|
||||||
shell: cmd
|
shell: cmd
|
||||||
env:
|
env:
|
||||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||||
@ -59,11 +48,11 @@ runs:
|
|||||||
move ${{ inputs.config }}\x265-static.lib ..\..\..\..\build\
|
move ${{ inputs.config }}\x265-static.lib ..\..\..\..\build\
|
||||||
move x265_config.h ..\..\..\..\dist\include\
|
move x265_config.h ..\..\..\..\dist\include\
|
||||||
cd ..\..\..\..
|
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
|
"${{ 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-${{ runner.os }}-${{ inputs.config }}\x265_10bit.lib build\x265_12bit-${{ runner.os }}-${{ inputs.config }}\x265_12bit.lib
|
||||||
copy x265\source\x265.h dist\include\
|
copy x265\source\x265.h dist\include\
|
||||||
D:\a\_temp\setup-msys2\msys2.cmd -c 'cd dist ; tar czf ../di/libx265.tgz *'
|
D:\a\_temp\setup-msys2\msys2.cmd -c 'cd dist ; tar czf ../di/libx265.tgz *'
|
||||||
- name: Publish artifact
|
- name: Publish artifact
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
with:
|
with:
|
||||||
name: libx265-${{ inputs.env }}-${{ inputs.config }}
|
name: libx265-${{ runner.os }}-${{ inputs.config }}
|
||||||
path: di/libx265.tgz
|
path: di/libx265.tgz
|
||||||
|
14
.github/actions/libzimg/action.yml
vendored
14
.github/actions/libzimg/action.yml
vendored
@ -1,7 +1,7 @@
|
|||||||
name: libzimg
|
name: libzimg
|
||||||
|
|
||||||
inputs:
|
inputs:
|
||||||
env:
|
refId:
|
||||||
type: string
|
type: string
|
||||||
required: true
|
required: true
|
||||||
config:
|
config:
|
||||||
@ -20,22 +20,14 @@ runs:
|
|||||||
uses: actions/checkout@v3.0.0
|
uses: actions/checkout@v3.0.0
|
||||||
with:
|
with:
|
||||||
repository: sekrit-twc/zimg
|
repository: sekrit-twc/zimg
|
||||||
ref: release-3.0.4
|
ref: ${{ inputs.refId }}
|
||||||
path: zimg
|
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
|
- name: Set up MSYS2
|
||||||
if: steps.libzimg-cache.outputs.cache-hit != 'true'
|
|
||||||
uses: msys2/setup-msys2@v2
|
uses: msys2/setup-msys2@v2
|
||||||
with:
|
with:
|
||||||
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
install: base-devel binutils autotools automake mingw-w64-x86_64-cmake nasm
|
||||||
path-type: inherit
|
path-type: inherit
|
||||||
- name: Build ZIMG
|
- name: Build ZIMG
|
||||||
if: steps.libzimg-cache.outputs.cache-hit != 'true'
|
|
||||||
shell: cmd
|
shell: cmd
|
||||||
env:
|
env:
|
||||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
||||||
@ -48,5 +40,5 @@ runs:
|
|||||||
- name: Publish artifact
|
- name: Publish artifact
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
with:
|
with:
|
||||||
name: libzimg-${{ inputs.env }}-${{ inputs.config }}
|
name: libzimg-${{ runner.os }}-${{ inputs.config }}
|
||||||
path: dist/libzimg.tgz
|
path: dist/libzimg.tgz
|
||||||
|
14
.github/workflows/build.yml
vendored
14
.github/workflows/build.yml
vendored
@ -2,24 +2,22 @@ name: Build all
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
schedule:
|
# schedule:
|
||||||
- cron: "0 1 * * *"
|
# - cron: "0 1 * * *"
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
ffmpeg-static-debug:
|
ffmpeg-static-debug:
|
||||||
uses: ./.github/workflows/ffmpeg.yml
|
uses: ./.github/workflows/ffmpeg.yml
|
||||||
with:
|
with:
|
||||||
env: windows-2022
|
system: windows-2022
|
||||||
source: ffmpeg
|
|
||||||
type: static
|
type: static
|
||||||
config: debug
|
config: debug
|
||||||
ffmpegRef: release/5.0
|
ffmpegRef: release/5.1
|
||||||
|
|
||||||
ffmpeg-static-release:
|
ffmpeg-static-release:
|
||||||
uses: ./.github/workflows/ffmpeg.yml
|
uses: ./.github/workflows/ffmpeg.yml
|
||||||
with:
|
with:
|
||||||
env: windows-2022
|
system: windows-2022
|
||||||
source: ffmpeg
|
|
||||||
type: static
|
type: static
|
||||||
config: release
|
config: release
|
||||||
ffmpegRef: release/5.0
|
ffmpegRef: release/5.1
|
||||||
|
220
.github/workflows/ffmpeg-cartwheel.yml
vendored
Normal file
220
.github/workflows/ffmpeg-cartwheel.yml
vendored
Normal file
@ -0,0 +1,220 @@
|
|||||||
|
name: 'Build FFmpeg from cartwheel'
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
inputs:
|
||||||
|
system:
|
||||||
|
type: choice
|
||||||
|
required: true
|
||||||
|
default: 'windows-2022'
|
||||||
|
description: 'System'
|
||||||
|
options:
|
||||||
|
- windows-2022
|
||||||
|
|
||||||
|
type:
|
||||||
|
type: choice
|
||||||
|
required: true
|
||||||
|
default: 'static'
|
||||||
|
description: Type
|
||||||
|
options:
|
||||||
|
- static
|
||||||
|
- shared
|
||||||
|
|
||||||
|
config:
|
||||||
|
type: choice
|
||||||
|
required: true
|
||||||
|
default: 'debug'
|
||||||
|
description: 'Configuration'
|
||||||
|
options:
|
||||||
|
- debug
|
||||||
|
- release
|
||||||
|
|
||||||
|
workflow_call:
|
||||||
|
inputs:
|
||||||
|
system:
|
||||||
|
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-libvpl --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.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libvpl
|
||||||
|
with:
|
||||||
|
refId: master
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
liboggvorbis:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/liboggvorbis
|
||||||
|
with:
|
||||||
|
libogg_refId: v1.3.5
|
||||||
|
libvorbis_refId: v1.3.7
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
libsvtav1:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libsvtav1
|
||||||
|
with:
|
||||||
|
refId: v1.1.0
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
libsnappy:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libsnappy
|
||||||
|
with:
|
||||||
|
refId: 1.1.9
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
libvpx:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libvpx
|
||||||
|
with:
|
||||||
|
refId: v1.12.0
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
libmp3lame:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libmp3lame
|
||||||
|
with:
|
||||||
|
refId: tags/RELEASE__3_100
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
libzimg:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libzimg
|
||||||
|
with:
|
||||||
|
refId: release-3.0.4
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
libopus:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libopus
|
||||||
|
with:
|
||||||
|
refId: v1.3.1
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
libfdkaac:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libfdkaac
|
||||||
|
with:
|
||||||
|
refId: v2.0.2
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
libx264:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libx264
|
||||||
|
with:
|
||||||
|
refId: stable
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
libx265-12:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libx265-12
|
||||||
|
with:
|
||||||
|
refId: Release_3.5
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
libx265-10:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libx265-10
|
||||||
|
with:
|
||||||
|
refId: Release_3.5
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
libx265:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
needs: [libx265-12,libx265-10]
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libx265
|
||||||
|
with:
|
||||||
|
refId: Release_3.5
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
cartwheel:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
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 ; 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 ; git submodule update --init --recursive ; cd ffmpeg ; git am ../patches/*.patch ; git apply --ignore-whitespace --verbose ../../libfdkaac-dynlib-5.1.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 ${{ 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 ${{ runner.os }} ${{ inputs.type }} ${{ inputs.config }} package build
|
||||||
|
path: dist/ffmpeg-win64-${{ inputs.type }}-${{ inputs.config }}.tar.gz
|
205
.github/workflows/ffmpeg-lgpl.yaml
vendored
Normal file
205
.github/workflows/ffmpeg-lgpl.yaml
vendored
Normal file
@ -0,0 +1,205 @@
|
|||||||
|
name: 'Build FFmpeg (LGPL)'
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
inputs:
|
||||||
|
system:
|
||||||
|
type: choice
|
||||||
|
required: true
|
||||||
|
default: 'windows-2022'
|
||||||
|
description: 'System'
|
||||||
|
options:
|
||||||
|
- windows-2022
|
||||||
|
|
||||||
|
type:
|
||||||
|
type: choice
|
||||||
|
required: true
|
||||||
|
default: 'shared'
|
||||||
|
description: Type
|
||||||
|
options:
|
||||||
|
- static
|
||||||
|
- shared
|
||||||
|
|
||||||
|
config:
|
||||||
|
type: choice
|
||||||
|
required: true
|
||||||
|
default: 'release'
|
||||||
|
description: 'Configuration'
|
||||||
|
options:
|
||||||
|
- debug
|
||||||
|
- release
|
||||||
|
|
||||||
|
ffmpegRef:
|
||||||
|
type: string
|
||||||
|
required: true
|
||||||
|
default: 'release/6.1'
|
||||||
|
description: 'FFmpeg refId'
|
||||||
|
|
||||||
|
workflow_call:
|
||||||
|
inputs:
|
||||||
|
system:
|
||||||
|
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-libvpl --enable-libsvtav1 --enable-libsnappy --enable-libmp3lame --enable-libzimg --enable-libvpx --enable-libopus"
|
||||||
|
#--enable-libvorbis
|
||||||
|
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 --build-suffix=-voukoderpro' }}
|
||||||
|
msbuildConfig: ${{ inputs.config == 'release' && 'Release' || 'Debug' }}
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
libvpl:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libvpl
|
||||||
|
with:
|
||||||
|
refId: v2023.3.1
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
#liboggvorbis:
|
||||||
|
# runs-on: ${{ inputs.system }}
|
||||||
|
# steps:
|
||||||
|
# - uses: actions/checkout@v3
|
||||||
|
# - uses: ./.github/actions/liboggvorbis
|
||||||
|
# with:
|
||||||
|
# libogg_refId: v1.3.5
|
||||||
|
# libvorbis_refId: v1.3.7
|
||||||
|
# config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
libsvtav1:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libsvtav1
|
||||||
|
with:
|
||||||
|
refId: v1.4.1
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
libsnappy:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libsnappy
|
||||||
|
with:
|
||||||
|
refId: 1.1.9
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
libvpx:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libvpx
|
||||||
|
with:
|
||||||
|
refId: v1.13.0
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
libmp3lame:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libmp3lame
|
||||||
|
with:
|
||||||
|
refId: tags/RELEASE__3_100
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
libzimg:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libzimg
|
||||||
|
with:
|
||||||
|
refId: release-3.0.4
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
libopus:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libopus
|
||||||
|
with:
|
||||||
|
refId: v1.3.1
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
#libkvazaar:
|
||||||
|
# runs-on: ${{ inputs.system }}
|
||||||
|
# steps:
|
||||||
|
# - uses: actions/checkout@v3
|
||||||
|
# - uses: ./.github/actions/libkvazaar
|
||||||
|
# with:
|
||||||
|
# refId: v2.3.0
|
||||||
|
# config: ${{ inputs.config }}
|
||||||
|
|
||||||
|
ffmpeg:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
needs: [libvpl,libsvtav1,libsnappy,libvpx,libmp3lame,libzimg,libopus]
|
||||||
|
#libkvazaar,liboggvorbis
|
||||||
|
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: Create PFX certificate
|
||||||
|
id: create-pfx
|
||||||
|
shell: pwsh
|
||||||
|
env:
|
||||||
|
PFX_CONTENT: ${{ secrets.CODESIGN_PFX }}
|
||||||
|
run: |
|
||||||
|
$pfxPath = Join-Path -Path $env:RUNNER_TEMP -ChildPath "cert.pfx";
|
||||||
|
$encodedBytes = [System.Convert]::FromBase64String($env:PFX_CONTENT);
|
||||||
|
Set-Content $pfxPath -Value $encodedBytes -AsByteStream;
|
||||||
|
Write-Output "::set-output name=PFX_PATH::$pfxPath";
|
||||||
|
- 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
|
||||||
|
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 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 --extra-libs=Ole32.lib --extra-libs=Advapi32.lib --disable-doc ${{ env.variant }} --enable-runtime-cpudetect --enable-w32threads --enable-cuda ${{ env.COMPONENTS }} ; make -j 2 ; make install ; cd ../build/lib ; rm -rf cmake pkgconfig *.la ; 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.system }} ${{ inputs.config }}${{ inputs.config }} package build
|
||||||
|
path: dist/ffmpeg-win64-${{ inputs.type }}-${{ inputs.config }}.tar.gz
|
144
.github/workflows/ffmpeg.yml
vendored
144
.github/workflows/ffmpeg.yml
vendored
@ -1,25 +1,16 @@
|
|||||||
name: 'Build FFmpeg'
|
name: 'Build FFmpeg (GPL)'
|
||||||
|
|
||||||
on:
|
on:
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
inputs:
|
inputs:
|
||||||
env:
|
system:
|
||||||
type: choice
|
type: choice
|
||||||
required: true
|
required: true
|
||||||
default: 'windows-2022'
|
default: 'windows-2022'
|
||||||
description: 'Environment'
|
description: 'System'
|
||||||
options:
|
options:
|
||||||
- windows-2022
|
- windows-2022
|
||||||
|
|
||||||
source:
|
|
||||||
type: choice
|
|
||||||
required: true
|
|
||||||
default: 'ffmpeg'
|
|
||||||
description: Source
|
|
||||||
options:
|
|
||||||
- ffmpeg
|
|
||||||
- cartwheel
|
|
||||||
|
|
||||||
type:
|
type:
|
||||||
type: choice
|
type: choice
|
||||||
required: true
|
required: true
|
||||||
@ -32,7 +23,7 @@ on:
|
|||||||
config:
|
config:
|
||||||
type: choice
|
type: choice
|
||||||
required: true
|
required: true
|
||||||
default: 'debug'
|
default: 'release'
|
||||||
description: 'Configuration'
|
description: 'Configuration'
|
||||||
options:
|
options:
|
||||||
- debug
|
- debug
|
||||||
@ -41,15 +32,12 @@ on:
|
|||||||
ffmpegRef:
|
ffmpegRef:
|
||||||
type: string
|
type: string
|
||||||
required: true
|
required: true
|
||||||
default: 'release/5.0'
|
default: 'release/6.1'
|
||||||
description: 'FFmpeg refId'
|
description: 'FFmpeg refId'
|
||||||
|
|
||||||
workflow_call:
|
workflow_call:
|
||||||
inputs:
|
inputs:
|
||||||
env:
|
system:
|
||||||
type: string
|
|
||||||
required: true
|
|
||||||
source:
|
|
||||||
type: string
|
type: string
|
||||||
required: true
|
required: true
|
||||||
type:
|
type:
|
||||||
@ -64,184 +52,135 @@ on:
|
|||||||
|
|
||||||
env:
|
env:
|
||||||
vsPath: C:\Program Files\Microsoft Visual Studio\2022\Enterprise\
|
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 "
|
COMPONENTS: "--enable-libvpl --enable-libsvtav1 --enable-libsnappy --enable-libmp3lame --enable-libzimg --enable-libvorbis --enable-libopus --enable-libvpx --enable-libx264 --enable-libx265 --enable-libfdk-aac"
|
||||||
NASM_EXECUTABLE: nasm
|
NASM_EXECUTABLE: nasm
|
||||||
cFlags: ${{ inputs.config == 'release' && '-MD' || '-MDd' }}
|
cFlags: ${{ inputs.config == 'release' && '-MD' || '-MDd' }}
|
||||||
variant: ${{ inputs.type == 'static' && ' --pkg-config-flags="--static" --disable-shared --enable-static' || ' --disable-static --enable-shared' }}
|
variant: ${{ inputs.type == 'static' && ' --pkg-config-flags="--static" --disable-shared --enable-static' || ' --disable-static --enable-shared' }}
|
||||||
msbuildConfig: ${{ inputs.config == 'release' && 'Release' || 'Debug' }}
|
msbuildConfig: ${{ inputs.config == 'release' && 'Release' || 'Debug' }}
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
libvpl:
|
libvpl:
|
||||||
runs-on: ${{ inputs.env }}
|
runs-on: ${{ inputs.system }}
|
||||||
if: ${{ inputs.source == 'cartwheel' }}
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- uses: ./.github/actions/libvpl
|
- uses: ./.github/actions/libvpl
|
||||||
with:
|
with:
|
||||||
env: ${{ inputs.env }}
|
refId: v2023.4.0
|
||||||
config: ${{ inputs.config }}
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
liboggvorbis:
|
liboggvorbis:
|
||||||
runs-on: ${{ inputs.env }}
|
runs-on: ${{ inputs.system }}
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- uses: ./.github/actions/liboggvorbis
|
- uses: ./.github/actions/liboggvorbis
|
||||||
with:
|
with:
|
||||||
env: ${{ inputs.env }}
|
libogg_refId: v1.3.5
|
||||||
|
libvorbis_refId: v1.3.7
|
||||||
config: ${{ inputs.config }}
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
libsvtav1:
|
libsvtav1:
|
||||||
runs-on: ${{ inputs.env }}
|
runs-on: ${{ inputs.system }}
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- uses: ./.github/actions/libsvtav1
|
- uses: ./.github/actions/libsvtav1
|
||||||
with:
|
with:
|
||||||
env: ${{ inputs.env }}
|
refId: v1.7.0
|
||||||
config: ${{ inputs.config }}
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
libsnappy:
|
libsnappy:
|
||||||
runs-on: ${{ inputs.env }}
|
runs-on: ${{ inputs.system }}
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- uses: ./.github/actions/libsnappy
|
- uses: ./.github/actions/libsnappy
|
||||||
with:
|
with:
|
||||||
env: ${{ inputs.env }}
|
refId: 1.1.10
|
||||||
config: ${{ inputs.config }}
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
libvpx:
|
libvpx:
|
||||||
runs-on: ${{ inputs.env }}
|
runs-on: ${{ inputs.system }}
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- uses: ./.github/actions/libvpx
|
- uses: ./.github/actions/libvpx
|
||||||
with:
|
with:
|
||||||
env: ${{ inputs.env }}
|
refId: v1.13.1
|
||||||
config: ${{ inputs.config }}
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
libmp3lame:
|
libmp3lame:
|
||||||
runs-on: ${{ inputs.env }}
|
runs-on: ${{ inputs.system }}
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- uses: ./.github/actions/libmp3lame
|
- uses: ./.github/actions/libmp3lame
|
||||||
with:
|
with:
|
||||||
env: ${{ inputs.env }}
|
refId: tags/RELEASE__3_100
|
||||||
config: ${{ inputs.config }}
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
libzimg:
|
libzimg:
|
||||||
runs-on: ${{ inputs.env }}
|
runs-on: ${{ inputs.system }}
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- uses: ./.github/actions/libzimg
|
- uses: ./.github/actions/libzimg
|
||||||
with:
|
with:
|
||||||
env: ${{ inputs.env }}
|
refId: release-3.0.5
|
||||||
config: ${{ inputs.config }}
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
libopus:
|
libopus:
|
||||||
runs-on: ${{ inputs.env }}
|
runs-on: ${{ inputs.system }}
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- uses: ./.github/actions/libopus
|
- uses: ./.github/actions/libopus
|
||||||
with:
|
with:
|
||||||
env: ${{ inputs.env }}
|
refId: v1.4
|
||||||
config: ${{ inputs.config }}
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
libfdkaac:
|
libfdkaac:
|
||||||
runs-on: ${{ inputs.env }}
|
runs-on: ${{ inputs.system }}
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- uses: ./.github/actions/libfdkaac
|
- uses: ./.github/actions/libfdkaac
|
||||||
with:
|
with:
|
||||||
env: ${{ inputs.env }}
|
refId: v2.0.2
|
||||||
config: ${{ inputs.config }}
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
libx264:
|
libx264:
|
||||||
runs-on: ${{ inputs.env }}
|
runs-on: ${{ inputs.system }}
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- uses: ./.github/actions/libx264
|
- uses: ./.github/actions/libx264
|
||||||
with:
|
with:
|
||||||
env: ${{ inputs.env }}
|
refId: stable
|
||||||
config: ${{ inputs.config }}
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
libx265-12:
|
libx265-12:
|
||||||
runs-on: ${{ inputs.env }}
|
runs-on: ${{ inputs.system }}
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- uses: ./.github/actions/libx265-12
|
- uses: ./.github/actions/libx265-12
|
||||||
with:
|
with:
|
||||||
env: ${{ inputs.env }}
|
refId: Release_3.5
|
||||||
config: ${{ inputs.config }}
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
libx265-10:
|
libx265-10:
|
||||||
runs-on: ${{ inputs.env }}
|
runs-on: ${{ inputs.system }}
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- uses: ./.github/actions/libx265-10
|
- uses: ./.github/actions/libx265-10
|
||||||
with:
|
with:
|
||||||
env: ${{ inputs.env }}
|
refId: Release_3.5
|
||||||
config: ${{ inputs.config }}
|
config: ${{ inputs.config }}
|
||||||
|
|
||||||
libx265:
|
libx265:
|
||||||
runs-on: ${{ inputs.env }}
|
runs-on: ${{ inputs.system }}
|
||||||
needs: [libx265-12,libx265-10]
|
needs: [libx265-12,libx265-10]
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- uses: ./.github/actions/libx265
|
- uses: ./.github/actions/libx265
|
||||||
with:
|
with:
|
||||||
env: ${{ inputs.env }}
|
refId: Release_3.5
|
||||||
config: ${{ inputs.config }}
|
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:
|
ffmpeg:
|
||||||
runs-on: ${{ inputs.env }}
|
runs-on: ${{ inputs.system }}
|
||||||
if: ${{ inputs.source == 'ffmpeg' }}
|
needs: [libvpl,libsvtav1,libsnappy,libvpx,libmp3lame,libzimg,liboggvorbis,libopus,libfdkaac,libx264,libx265]
|
||||||
needs: [libopus,libsvtav1,libsnappy,libmp3lame,libzimg,liboggvorbis,libx264,libx265,libfdkaac,libvpx]
|
|
||||||
steps:
|
steps:
|
||||||
- name: Set up MSYS2
|
- name: Set up MSYS2
|
||||||
uses: msys2/setup-msys2@v2
|
uses: msys2/setup-msys2@v2
|
||||||
@ -257,7 +196,6 @@ jobs:
|
|||||||
- name: Checkout patches
|
- name: Checkout patches
|
||||||
uses: actions/checkout@v3.0.0
|
uses: actions/checkout@v3.0.0
|
||||||
- name: Checkout FFmpeg
|
- name: Checkout FFmpeg
|
||||||
if: ${{ inputs.source == 'ffmpeg' }}
|
|
||||||
uses: actions/checkout@v3.0.0
|
uses: actions/checkout@v3.0.0
|
||||||
with:
|
with:
|
||||||
repository: FFmpeg/FFmpeg.git
|
repository: FFmpeg/FFmpeg.git
|
||||||
@ -284,9 +222,9 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
call "${{ env.vsPath }}VC\Auxiliary\Build\vcvars64.bat"
|
||||||
md build dist
|
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 *'
|
D:\a\_temp\setup-msys2\msys2.cmd -c 'cd ffmpeg ; git apply --ignore-whitespace ../libfdkaac.patch ; 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 --extra-libs=Ole32.lib --extra-libs=Advapi32.lib --disable-doc ${{ env.variant }} --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-${{ inputs.type }}-${{ inputs.config }}.tar.gz *'
|
||||||
- name: Publish FFmpeg artifacts
|
- name: Publish FFmpeg artifacts
|
||||||
uses: actions/upload-artifact@v3
|
uses: actions/upload-artifact@v3
|
||||||
with:
|
with:
|
||||||
name: FFmpeg ${{ inputs.env }} ${{ inputs.config }}${{ inputs.config }} package build
|
name: FFmpeg ${{ inputs.system }} ${{ inputs.config }}${{ inputs.config }} package build
|
||||||
path: dist/ffmpeg-win64-${{ inputs.type }}-${{ inputs.config }}.tar.gz
|
path: dist/ffmpeg-win64-${{ inputs.type }}-${{ inputs.config }}.tar.gz
|
||||||
|
71
.github/workflows/test.yml
vendored
Normal file
71
.github/workflows/test.yml
vendored
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
name: 'Test'
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
inputs:
|
||||||
|
system:
|
||||||
|
type: choice
|
||||||
|
required: true
|
||||||
|
default: 'windows-2022'
|
||||||
|
description: 'System'
|
||||||
|
options:
|
||||||
|
- windows-2022
|
||||||
|
|
||||||
|
type:
|
||||||
|
type: choice
|
||||||
|
required: true
|
||||||
|
default: 'shared'
|
||||||
|
description: Type
|
||||||
|
options:
|
||||||
|
- static
|
||||||
|
- shared
|
||||||
|
|
||||||
|
config:
|
||||||
|
type: choice
|
||||||
|
required: true
|
||||||
|
default: 'release'
|
||||||
|
description: 'Configuration'
|
||||||
|
options:
|
||||||
|
- debug
|
||||||
|
- release
|
||||||
|
|
||||||
|
ffmpegRef:
|
||||||
|
type: string
|
||||||
|
required: true
|
||||||
|
default: 'release/6.1'
|
||||||
|
description: 'FFmpeg refId'
|
||||||
|
|
||||||
|
workflow_call:
|
||||||
|
inputs:
|
||||||
|
system:
|
||||||
|
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-libvpl --enable-libsvtav1 --enable-libsnappy --enable-libmp3lame --enable-libzimg --enable-libvpx --enable-libopus --enable-libkvazaar"
|
||||||
|
#--enable-libvorbis
|
||||||
|
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 --build-suffix=-voukoderpro' }}
|
||||||
|
msbuildConfig: ${{ inputs.config == 'release' && 'Release' || 'Debug' }}
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
libkvazaar:
|
||||||
|
runs-on: ${{ inputs.system }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: ./.github/actions/libkvazaar
|
||||||
|
with:
|
||||||
|
refId: v2.3.0
|
||||||
|
config: ${{ inputs.config }}
|
||||||
|
|
@ -1,248 +0,0 @@
|
|||||||
diff --git a/configure b/configure
|
|
||||||
index 7a62f0c248..73078ffa60 100755
|
|
||||||
--- a/configure
|
|
||||||
+++ b/configure
|
|
||||||
@@ -1783,7 +1783,6 @@ EXTERNAL_LIBRARY_GPL_LIST="
|
|
||||||
|
|
||||||
EXTERNAL_LIBRARY_NONFREE_LIST="
|
|
||||||
decklink
|
|
||||||
- libfdk_aac
|
|
||||||
libtls
|
|
||||||
"
|
|
||||||
|
|
||||||
@@ -1880,6 +1879,7 @@ EXTERNAL_LIBRARY_LIST="
|
|
||||||
openssl
|
|
||||||
pocketsphinx
|
|
||||||
vapoursynth
|
|
||||||
+ libfdk_aac
|
|
||||||
"
|
|
||||||
|
|
||||||
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 ||
|
|
||||||
- { require libfdk_aac fdk-aac/aacenc_lib.h aacEncOpen -lfdk-aac &&
|
|
||||||
- warn "using libfdk without pkg-config"; } }
|
|
||||||
+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-aac_internal.h b/libavcodec/libfdk-aac_internal.h
|
|
||||||
new file mode 100644
|
|
||||||
index 0000000000..cd1e6e3340
|
|
||||||
--- /dev/null
|
|
||||||
+++ b/libavcodec/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 */
|
|
||||||
diff --git a/libavcodec/libfdk-aacdec.c b/libavcodec/libfdk-aacdec.c
|
|
||||||
index ffa1fdcce3..b3ee1248ed 100644
|
|
||||||
--- a/libavcodec/libfdk-aacdec.c
|
|
||||||
+++ b/libavcodec/libfdk-aacdec.c
|
|
||||||
@@ -24,6 +24,7 @@
|
|
||||||
#include "libavutil/opt.h"
|
|
||||||
#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 {
|
|
||||||
typedef struct FDKAACDecContext {
|
|
||||||
const AVClass *class;
|
|
||||||
HANDLE_AACDECODER handle;
|
|
||||||
+ void *hLib;
|
|
||||||
+ aacDecLib pfn;
|
|
||||||
uint8_t *decoder_buffer;
|
|
||||||
int decoder_buffer_size;
|
|
||||||
uint8_t *anc_buffer;
|
|
||||||
@@ -101,7 +104,7 @@ static const AVClass fdk_aac_dec_class = {
|
|
||||||
static int get_stream_info(AVCodecContext *avctx)
|
|
||||||
{
|
|
||||||
FDKAACDecContext *s = avctx->priv_data;
|
|
||||||
- CStreamInfo *info = aacDecoder_GetStreamInfo(s->handle);
|
|
||||||
+ CStreamInfo *info = s->pfn.aacDecoder_GetStreamInfo(s->handle);
|
|
||||||
int channel_counts[0x24] = { 0 };
|
|
||||||
int i, ch_error = 0;
|
|
||||||
uint64_t ch_layout = 0;
|
|
||||||
@@ -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) {
|
|
||||||
+ s->pfn.aacDecoder_Close(s->handle);
|
|
||||||
+ dlclose(s->hLib);
|
|
||||||
+ }
|
|
||||||
av_freep(&s->decoder_buffer);
|
|
||||||
av_freep(&s->anc_buffer);
|
|
||||||
|
|
||||||
@@ -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;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ DLSYM(aacDecoder_Open);
|
|
||||||
+#define aacDecoder_Open s->pfn.aacDecoder_Open
|
|
||||||
+ DLSYM(aacDecoder_Close);
|
|
||||||
+ DLSYM(aacDecoder_Fill);
|
|
||||||
+#define aacDecoder_Fill s->pfn.aacDecoder_Fill
|
|
||||||
+ DLSYM(aacDecoder_DecodeFrame);
|
|
||||||
+#define aacDecoder_DecodeFrame s->pfn.aacDecoder_DecodeFrame
|
|
||||||
+ DLSYM(aacDecoder_GetStreamInfo);
|
|
||||||
+#define aacDecoder_GetStreamInfo s->pfn.aacDecoder_GetStreamInfo
|
|
||||||
+ DLSYM(aacDecoder_ConfigRaw);
|
|
||||||
+#define aacDecoder_ConfigRaw s->pfn.aacDecoder_ConfigRaw
|
|
||||||
+ DLSYM(aacDecoder_SetParam);
|
|
||||||
+#define aacDecoder_SetParam s->pfn.aacDecoder_SetParam
|
|
||||||
+ DLSYM(aacDecoder_AncDataInit);
|
|
||||||
+#define aacDecoder_AncDataInit s->pfn.aacDecoder_AncDataInit
|
|
||||||
+
|
|
||||||
s->handle = aacDecoder_Open(avctx->extradata_size ? TT_MP4_RAW : TT_MP4_ADTS, 1);
|
|
||||||
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 7ee2f13ac7..2a91d02c7f 100644
|
|
||||||
--- a/libavcodec/libfdk-aacenc.c
|
|
||||||
+++ b/libavcodec/libfdk-aacenc.c
|
|
||||||
@@ -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
|
|
||||||
@@ -47,6 +48,8 @@ typedef struct AACContext {
|
|
||||||
int header_period;
|
|
||||||
int vbr;
|
|
||||||
|
|
||||||
+ void *hLib;
|
|
||||||
+ aacEncLib pfn;
|
|
||||||
AudioFrameQueue afq;
|
|
||||||
} AACContext;
|
|
||||||
|
|
||||||
@@ -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);
|
|
||||||
+ }
|
|
||||||
ff_af_queue_close(&s->afq);
|
|
||||||
|
|
||||||
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;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ DLSYM(aacEncOpen);
|
|
||||||
+#define aacEncOpen s->pfn.aacEncOpen
|
|
||||||
+ DLSYM(aacEncClose);
|
|
||||||
+ DLSYM(aacEncEncode);
|
|
||||||
+#define aacEncEncode s->pfn.aacEncEncode
|
|
||||||
+ DLSYM(aacEncInfo);
|
|
||||||
+#define aacEncInfo s->pfn.aacEncInfo
|
|
||||||
+ DLSYM(aacEncoder_SetParam);
|
|
||||||
+#define aacEncoder_SetParam s->pfn.aacEncoder_SetParam
|
|
||||||
+
|
|
||||||
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));
|
|
20
hotfix.patch
20
hotfix.patch
@ -1,20 +0,0 @@
|
|||||||
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,8 +1,8 @@
|
|||||||
diff --git a/configure b/configure
|
diff --git a/configure b/configure
|
||||||
index 77facac8c9..ab117fba2c 100755
|
index b6616f00b6..d02f5099fe 100755
|
||||||
--- a/configure
|
--- a/configure
|
||||||
+++ b/configure
|
+++ b/configure
|
||||||
@@ -1785,7 +1785,6 @@ EXTERNAL_LIBRARY_GPL_LIST="
|
@@ -1774,7 +1774,6 @@ EXTERNAL_LIBRARY_GPL_LIST="
|
||||||
|
|
||||||
EXTERNAL_LIBRARY_NONFREE_LIST="
|
EXTERNAL_LIBRARY_NONFREE_LIST="
|
||||||
decklink
|
decklink
|
||||||
@ -10,7 +10,7 @@ index 77facac8c9..ab117fba2c 100755
|
|||||||
libtls
|
libtls
|
||||||
"
|
"
|
||||||
|
|
||||||
@@ -1882,6 +1881,7 @@ EXTERNAL_LIBRARY_LIST="
|
@@ -1873,6 +1872,7 @@ EXTERNAL_LIBRARY_LIST="
|
||||||
openssl
|
openssl
|
||||||
pocketsphinx
|
pocketsphinx
|
||||||
vapoursynth
|
vapoursynth
|
||||||
@ -18,7 +18,7 @@ index 77facac8c9..ab117fba2c 100755
|
|||||||
"
|
"
|
||||||
|
|
||||||
HWACCEL_AUTODETECT_LIBRARY_LIST="
|
HWACCEL_AUTODETECT_LIBRARY_LIST="
|
||||||
@@ -6524,9 +6524,7 @@ enabled libdav1d && require_pkg_config libdav1d "dav1d >= 0.5.0" "dav1d
|
@@ -6581,9 +6581,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 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 libdc1394 && require_pkg_config libdc1394 libdc1394-2 dc1394/dc1394.h dc1394_new
|
||||||
enabled libdrm && require_pkg_config libdrm libdrm xf86drm.h drmGetVersion
|
enabled libdrm && require_pkg_config libdrm libdrm xf86drm.h drmGetVersion
|
||||||
@ -29,138 +29,11 @@ index 77facac8c9..ab117fba2c 100755
|
|||||||
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"
|
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 libflite && require libflite "flite/flite.h" flite_init $flite_extralibs
|
||||||
enabled fontconfig && enable libfontconfig
|
enabled fontconfig && enable libfontconfig
|
||||||
diff --git a/libavcodec/libfdk-aacdec.c b/libavcodec/libfdk-aacdec.c
|
diff --git a/libavcodec/libfdk-aac_internal.h b/libavcodec/libfdk-aac_internal.h
|
||||||
index e9096a08e6..cc4d79c651 100644
|
|
||||||
--- a/libavcodec/libfdk-aacdec.c
|
|
||||||
+++ b/libavcodec/libfdk-aacdec.c
|
|
||||||
@@ -25,6 +25,7 @@
|
|
||||||
#include "avcodec.h"
|
|
||||||
#include "codec_internal.h"
|
|
||||||
#include "internal.h"
|
|
||||||
+#include "libfdk-aac_internal.h"
|
|
||||||
|
|
||||||
#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;
|
|
||||||
+ aacDecLib pfn;
|
|
||||||
uint8_t *decoder_buffer;
|
|
||||||
int decoder_buffer_size;
|
|
||||||
uint8_t *anc_buffer;
|
|
||||||
@@ -113,7 +116,7 @@ static const AVClass fdk_aac_dec_class = {
|
|
||||||
static int get_stream_info(AVCodecContext *avctx)
|
|
||||||
{
|
|
||||||
FDKAACDecContext *s = avctx->priv_data;
|
|
||||||
- CStreamInfo *info = aacDecoder_GetStreamInfo(s->handle);
|
|
||||||
+ CStreamInfo *info = s->pfn.aacDecoder_GetStreamInfo(s->handle);
|
|
||||||
int channel_counts[0x24] = { 0 };
|
|
||||||
int i, ch_error = 0;
|
|
||||||
uint64_t ch_layout = 0;
|
|
||||||
@@ -231,8 +234,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) {
|
|
||||||
+ s->pfn.aacDecoder_Close(s->handle);
|
|
||||||
+ dlclose(s->hLib);
|
|
||||||
+ }
|
|
||||||
av_freep(&s->decoder_buffer);
|
|
||||||
av_freep(&s->anc_buffer);
|
|
||||||
|
|
||||||
@@ -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))) {
|
|
||||||
+ av_log(avctx, AV_LOG_ERROR, "Unable to load " LIBNAME "\n");
|
|
||||||
+ return -1;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ DLSYM(aacDecoder_Open);
|
|
||||||
+#define aacDecoder_Open s->pfn.aacDecoder_Open
|
|
||||||
+ DLSYM(aacDecoder_Close);
|
|
||||||
+ DLSYM(aacDecoder_Fill);
|
|
||||||
+#define aacDecoder_Fill s->pfn.aacDecoder_Fill
|
|
||||||
+ DLSYM(aacDecoder_DecodeFrame);
|
|
||||||
+#define aacDecoder_DecodeFrame s->pfn.aacDecoder_DecodeFrame
|
|
||||||
+ DLSYM(aacDecoder_GetStreamInfo);
|
|
||||||
+#define aacDecoder_GetStreamInfo s->pfn.aacDecoder_GetStreamInfo
|
|
||||||
+ DLSYM(aacDecoder_ConfigRaw);
|
|
||||||
+#define aacDecoder_ConfigRaw s->pfn.aacDecoder_ConfigRaw
|
|
||||||
+ DLSYM(aacDecoder_SetParam);
|
|
||||||
+#define aacDecoder_SetParam s->pfn.aacDecoder_SetParam
|
|
||||||
+ DLSYM(aacDecoder_AncDataInit);
|
|
||||||
+#define aacDecoder_AncDataInit s->pfn.aacDecoder_AncDataInit
|
|
||||||
+
|
|
||||||
s->handle = aacDecoder_Open(avctx->extradata_size ? TT_MP4_RAW : TT_MP4_ADTS, 1);
|
|
||||||
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 d004ae00c3..902dddb365 100644
|
|
||||||
--- a/libavcodec/libfdk-aacenc.c
|
|
||||||
+++ b/libavcodec/libfdk-aacenc.c
|
|
||||||
@@ -27,6 +27,7 @@
|
|
||||||
#include "codec_internal.h"
|
|
||||||
#include "encode.h"
|
|
||||||
#include "profiles.h"
|
|
||||||
+#include "libfdk-aac_internal.h"
|
|
||||||
|
|
||||||
#ifdef AACENCODER_LIB_VL0
|
|
||||||
#define FDKENC_VER_AT_LEAST(vl0, vl1) \
|
|
||||||
@@ -47,6 +48,8 @@ typedef struct AACContext {
|
|
||||||
int header_period;
|
|
||||||
int vbr;
|
|
||||||
|
|
||||||
+ void *hLib;
|
|
||||||
+ aacEncLib pfn;
|
|
||||||
AudioFrameQueue afq;
|
|
||||||
} AACContext;
|
|
||||||
|
|
||||||
@@ -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);
|
|
||||||
+ }
|
|
||||||
ff_af_queue_close(&s->afq);
|
|
||||||
|
|
||||||
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;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ DLSYM(aacEncOpen);
|
|
||||||
+#define aacEncOpen s->pfn.aacEncOpen
|
|
||||||
+ DLSYM(aacEncClose);
|
|
||||||
+ DLSYM(aacEncEncode);
|
|
||||||
+#define aacEncEncode s->pfn.aacEncEncode
|
|
||||||
+ DLSYM(aacEncInfo);
|
|
||||||
+#define aacEncInfo s->pfn.aacEncInfo
|
|
||||||
+ DLSYM(aacEncoder_SetParam);
|
|
||||||
+#define aacEncoder_SetParam s->pfn.aacEncoder_SetParam
|
|
||||||
+
|
|
||||||
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));
|
|
||||||
diff --git a/libfdk-aac_internal.h b/libfdk-aac_internal.h
|
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 0000000000..9bcfdb9aba
|
index 0000000000..9bcfdb9aba
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/libfdk-aac_internal.h
|
+++ b/libavcodec/libfdk-aac_internal.h
|
||||||
@@ -0,0 +1,84 @@
|
@@ -0,0 +1,84 @@
|
||||||
+/*
|
+/*
|
||||||
+ * Copyright (c) 2018 Gianluigi Tiesi
|
+ * Copyright (c) 2018 Gianluigi Tiesi
|
||||||
@ -247,3 +120,130 @@ index 0000000000..9bcfdb9aba
|
|||||||
+
|
+
|
||||||
+#endif /* AVCODEC_LIBFDK_AAC_INTERNAL_H */
|
+#endif /* AVCODEC_LIBFDK_AAC_INTERNAL_H */
|
||||||
\ No newline at end of file
|
\ No newline at end of file
|
||||||
|
diff --git a/libavcodec/libfdk-aacdec.c b/libavcodec/libfdk-aacdec.c
|
||||||
|
index 8c1586e25e..25f68cdd10 100644
|
||||||
|
--- a/libavcodec/libfdk-aacdec.c
|
||||||
|
+++ b/libavcodec/libfdk-aacdec.c
|
||||||
|
@@ -25,6 +25,7 @@
|
||||||
|
#include "avcodec.h"
|
||||||
|
#include "codec_internal.h"
|
||||||
|
#include "decode.h"
|
||||||
|
+#include "libfdk-aac_internal.h"
|
||||||
|
|
||||||
|
#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;
|
||||||
|
+ aacDecLib pfn;
|
||||||
|
uint8_t *decoder_buffer;
|
||||||
|
int decoder_buffer_size;
|
||||||
|
uint8_t *anc_buffer;
|
||||||
|
@@ -113,7 +116,7 @@ static const AVClass fdk_aac_dec_class = {
|
||||||
|
static int get_stream_info(AVCodecContext *avctx)
|
||||||
|
{
|
||||||
|
FDKAACDecContext *s = avctx->priv_data;
|
||||||
|
- CStreamInfo *info = aacDecoder_GetStreamInfo(s->handle);
|
||||||
|
+ CStreamInfo *info = s->pfn.aacDecoder_GetStreamInfo(s->handle);
|
||||||
|
int channel_counts[0x24] = { 0 };
|
||||||
|
int i, ch_error = 0;
|
||||||
|
uint64_t ch_layout = 0;
|
||||||
|
@@ -231,8 +234,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) {
|
||||||
|
+ s->pfn.aacDecoder_Close(s->handle);
|
||||||
|
+ dlclose(s->hLib);
|
||||||
|
+ }
|
||||||
|
av_freep(&s->decoder_buffer);
|
||||||
|
av_freep(&s->anc_buffer);
|
||||||
|
|
||||||
|
@@ -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))) {
|
||||||
|
+ av_log(avctx, AV_LOG_ERROR, "Unable to load " LIBNAME "\n");
|
||||||
|
+ return -1;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ DLSYM(aacDecoder_Open);
|
||||||
|
+#define aacDecoder_Open s->pfn.aacDecoder_Open
|
||||||
|
+ DLSYM(aacDecoder_Close);
|
||||||
|
+ DLSYM(aacDecoder_Fill);
|
||||||
|
+#define aacDecoder_Fill s->pfn.aacDecoder_Fill
|
||||||
|
+ DLSYM(aacDecoder_DecodeFrame);
|
||||||
|
+#define aacDecoder_DecodeFrame s->pfn.aacDecoder_DecodeFrame
|
||||||
|
+ DLSYM(aacDecoder_GetStreamInfo);
|
||||||
|
+#define aacDecoder_GetStreamInfo s->pfn.aacDecoder_GetStreamInfo
|
||||||
|
+ DLSYM(aacDecoder_ConfigRaw);
|
||||||
|
+#define aacDecoder_ConfigRaw s->pfn.aacDecoder_ConfigRaw
|
||||||
|
+ DLSYM(aacDecoder_SetParam);
|
||||||
|
+#define aacDecoder_SetParam s->pfn.aacDecoder_SetParam
|
||||||
|
+ DLSYM(aacDecoder_AncDataInit);
|
||||||
|
+#define aacDecoder_AncDataInit s->pfn.aacDecoder_AncDataInit
|
||||||
|
+
|
||||||
|
s->handle = aacDecoder_Open(avctx->extradata_size ? TT_MP4_RAW : TT_MP4_ADTS, 1);
|
||||||
|
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 54549de473..9e93ce092c 100644
|
||||||
|
--- a/libavcodec/libfdk-aacenc.c
|
||||||
|
+++ b/libavcodec/libfdk-aacenc.c
|
||||||
|
@@ -27,6 +27,7 @@
|
||||||
|
#include "codec_internal.h"
|
||||||
|
#include "encode.h"
|
||||||
|
#include "profiles.h"
|
||||||
|
+#include "libfdk-aac_internal.h"
|
||||||
|
|
||||||
|
#ifdef AACENCODER_LIB_VL0
|
||||||
|
#define FDKENC_VER_AT_LEAST(vl0, vl1) \
|
||||||
|
@@ -46,6 +47,8 @@ typedef struct AACContext {
|
||||||
|
int latm;
|
||||||
|
int header_period;
|
||||||
|
int vbr;
|
||||||
|
+ void *hLib;
|
||||||
|
+ aacEncLib pfn;
|
||||||
|
|
||||||
|
AudioFrameQueue afq;
|
||||||
|
} AACContext;
|
||||||
|
@@ -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);
|
||||||
|
+ }
|
||||||
|
ff_af_queue_close(&s->afq);
|
||||||
|
|
||||||
|
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;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ DLSYM(aacEncOpen);
|
||||||
|
+#define aacEncOpen s->pfn.aacEncOpen
|
||||||
|
+ DLSYM(aacEncClose);
|
||||||
|
+ DLSYM(aacEncEncode);
|
||||||
|
+#define aacEncEncode s->pfn.aacEncEncode
|
||||||
|
+ DLSYM(aacEncInfo);
|
||||||
|
+#define aacEncInfo s->pfn.aacEncInfo
|
||||||
|
+ DLSYM(aacEncoder_SetParam);
|
||||||
|
+#define aacEncoder_SetParam s->pfn.aacEncoder_SetParam
|
||||||
|
+
|
||||||
|
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));
|
Reference in New Issue
Block a user