mirror of
https://github.com/levogevo/ffmpeg-av1-builder.git
synced 2026-01-15 16:56:18 +00:00
flags for rockchip and svt
This commit is contained in:
@@ -1,5 +1,50 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
usage() {
|
||||||
|
echo "./scripts/build.sh [-h] [-p] [-o] [r] [-a]"
|
||||||
|
echo -e "\th: display this help output"
|
||||||
|
echo -e "\tp: build svt-av1-psy with dovi library"
|
||||||
|
echo -e "\to: build other encoders x264/5 and vpx"
|
||||||
|
echo -e "\tr: build rockchip media libraries"
|
||||||
|
}
|
||||||
|
|
||||||
|
update_git() {
|
||||||
|
git config pull.rebase false
|
||||||
|
git stash && git stash drop
|
||||||
|
git pull
|
||||||
|
}
|
||||||
|
|
||||||
|
OPTS='hpao:'
|
||||||
|
NUM_OPTS=$(echo $OPTS | tr ':' '\n' | wc -l)
|
||||||
|
MIN_OPT=0
|
||||||
|
# using all
|
||||||
|
MAX_OPT=$(( NUM_OPTS ))
|
||||||
|
test "$#" -lt $MIN_OPT && echo "not enough arguments" && usage && exit 1
|
||||||
|
test "$#" -gt $MAX_OPT && echo "too many arguments" && usage && exit 1
|
||||||
|
while getopts "$OPTS" flag; do
|
||||||
|
case "${flag}" in
|
||||||
|
h)
|
||||||
|
usage
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
p)
|
||||||
|
export BUILD_PSY="true"
|
||||||
|
echo "building psy"
|
||||||
|
;;
|
||||||
|
o)
|
||||||
|
export BUILD_OTHERS="true"
|
||||||
|
echo "building other encoders"
|
||||||
|
;;
|
||||||
|
r)
|
||||||
|
export BUILD_ROCKCHIP="true"
|
||||||
|
echo "building rockchip media platform"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "building default"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
BASE_DIR=$(pwd)
|
BASE_DIR=$(pwd)
|
||||||
SVT_DIR="$BASE_DIR/svt"
|
SVT_DIR="$BASE_DIR/svt"
|
||||||
RAV1E_DIR="$BASE_DIR/rav1e"
|
RAV1E_DIR="$BASE_DIR/rav1e"
|
||||||
@@ -13,9 +58,6 @@ RKRGA_DIR="$BASE_DIR/rkrga"
|
|||||||
DOVI_DIR="$BASE_DIR/dovi"
|
DOVI_DIR="$BASE_DIR/dovi"
|
||||||
SVT_PSY_DIR="$BASE_DIR/svt-psy"
|
SVT_PSY_DIR="$BASE_DIR/svt-psy"
|
||||||
|
|
||||||
# build svt-psy + dovi_tool
|
|
||||||
BUILD_PSY="true"
|
|
||||||
|
|
||||||
# clone
|
# clone
|
||||||
git clone --depth 1 https://gitlab.com/AOMediaCodec/SVT-AV1.git "$SVT_DIR"
|
git clone --depth 1 https://gitlab.com/AOMediaCodec/SVT-AV1.git "$SVT_DIR"
|
||||||
git clone --depth 1 https://github.com/quietvoid/dovi_tool "$DOVI_DIR"
|
git clone --depth 1 https://github.com/quietvoid/dovi_tool "$DOVI_DIR"
|
||||||
@@ -43,10 +85,8 @@ export PATH="/usr/lib/ccache/:$PATH"
|
|||||||
|
|
||||||
# rockchip ffmpeg libs
|
# rockchip ffmpeg libs
|
||||||
FFMPEG_ROCKCHIP=""
|
FFMPEG_ROCKCHIP=""
|
||||||
IS_ROCKCHIP=$(uname -r | grep "rockchip" > /dev/null && echo "yes" || echo "no")
|
# IS_ROCKCHIP=$(uname -r | grep "rockchip" > /dev/null && echo "yes" || echo "no")
|
||||||
# disabling due to decode errors
|
if [[ "$BUILD_ROCKCHIP" == "true" ]]
|
||||||
IS_ROCKCHIP="no"
|
|
||||||
if [[ "$IS_ROCKCHIP" == "yes" ]]
|
|
||||||
then
|
then
|
||||||
FFMPEG_ROCKCHIP="--enable-gpl --enable-version3 --enable-libdrm --enable-rkmpp --enable-rkrga"
|
FFMPEG_ROCKCHIP="--enable-gpl --enable-version3 --enable-libdrm --enable-rkmpp --enable-rkrga"
|
||||||
FFMPEG_DIR="$BASE_DIR/ffmpeg-rkmpp"
|
FFMPEG_DIR="$BASE_DIR/ffmpeg-rkmpp"
|
||||||
@@ -58,8 +98,7 @@ then
|
|||||||
|
|
||||||
# build mpp
|
# build mpp
|
||||||
cd "$RKMPP_DIR/" || exit
|
cd "$RKMPP_DIR/" || exit
|
||||||
git stash && git stash drop
|
update_git
|
||||||
git pull
|
|
||||||
rm -rf mpp_build.user
|
rm -rf mpp_build.user
|
||||||
mkdir mpp_build.user
|
mkdir mpp_build.user
|
||||||
cd mpp_build.user || exit
|
cd mpp_build.user || exit
|
||||||
@@ -74,8 +113,7 @@ then
|
|||||||
|
|
||||||
# build rga
|
# build rga
|
||||||
cd "$RKRGA_DIR" || exit
|
cd "$RKRGA_DIR" || exit
|
||||||
git stash && git stash drop
|
update_git
|
||||||
git pull
|
|
||||||
rm -rf rga_build.user
|
rm -rf rga_build.user
|
||||||
mkdir rga_build.user
|
mkdir rga_build.user
|
||||||
cd rga_build.user || exit
|
cd rga_build.user || exit
|
||||||
@@ -90,8 +128,7 @@ if [[ "$BUILD_PSY" == "true" ]];
|
|||||||
then
|
then
|
||||||
# build dovi_tool
|
# build dovi_tool
|
||||||
cd "$DOVI_DIR/" || exit
|
cd "$DOVI_DIR/" || exit
|
||||||
git stash && git stash drop
|
update_git
|
||||||
git pull
|
|
||||||
rm -rf ffmpeg_build.user && mkdir ffmpeg_build.user || exit
|
rm -rf ffmpeg_build.user && mkdir ffmpeg_build.user || exit
|
||||||
source "$HOME/.cargo/env" # for good measure
|
source "$HOME/.cargo/env" # for good measure
|
||||||
cargo clean
|
cargo clean
|
||||||
@@ -110,7 +147,7 @@ then
|
|||||||
|
|
||||||
# build svt-avt-psy
|
# build svt-avt-psy
|
||||||
cd "$SVT_PSY_DIR/" || exit
|
cd "$SVT_PSY_DIR/" || exit
|
||||||
git pull
|
update_git
|
||||||
rm -rf build_svt.user
|
rm -rf build_svt.user
|
||||||
mkdir build_svt.user
|
mkdir build_svt.user
|
||||||
cd build_svt.user || exit
|
cd build_svt.user || exit
|
||||||
@@ -125,7 +162,7 @@ then
|
|||||||
else
|
else
|
||||||
# build svt-av1
|
# build svt-av1
|
||||||
cd "$SVT_DIR/" || exit
|
cd "$SVT_DIR/" || exit
|
||||||
git pull
|
update_git
|
||||||
rm -rf build_svt.user
|
rm -rf build_svt.user
|
||||||
mkdir build_svt.user
|
mkdir build_svt.user
|
||||||
cd build_svt.user || exit
|
cd build_svt.user || exit
|
||||||
@@ -141,8 +178,7 @@ fi
|
|||||||
|
|
||||||
# build rav1e
|
# build rav1e
|
||||||
cd "$RAV1E_DIR/" || exit
|
cd "$RAV1E_DIR/" || exit
|
||||||
git stash && git stash drop
|
update_git
|
||||||
git pull
|
|
||||||
rm -rf ffmpeg_build.user && mkdir ffmpeg_build.user || exit
|
rm -rf ffmpeg_build.user && mkdir ffmpeg_build.user || exit
|
||||||
source "$HOME/.cargo/env" # for good measure
|
source "$HOME/.cargo/env" # for good measure
|
||||||
cargo clean
|
cargo clean
|
||||||
@@ -156,8 +192,7 @@ sudo cp ./include/* /usr/local/include/ -r || exit
|
|||||||
|
|
||||||
# build aom
|
# build aom
|
||||||
cd "$AOM_DIR/" || exit
|
cd "$AOM_DIR/" || exit
|
||||||
git stash && git stash drop
|
update_git
|
||||||
git pull
|
|
||||||
rm -rf build_aom.user
|
rm -rf build_aom.user
|
||||||
mkdir build_aom.user
|
mkdir build_aom.user
|
||||||
cd build_aom.user || exit
|
cd build_aom.user || exit
|
||||||
@@ -171,8 +206,7 @@ sudo make install || exit
|
|||||||
|
|
||||||
# build libvmaf
|
# build libvmaf
|
||||||
cd "$VMAF_DIR/libvmaf" || exit
|
cd "$VMAF_DIR/libvmaf" || exit
|
||||||
git stash && git stash drop
|
update_git
|
||||||
git pull
|
|
||||||
python3 -m virtualenv .venv
|
python3 -m virtualenv .venv
|
||||||
source .venv/bin/activate
|
source .venv/bin/activate
|
||||||
rm -rf build.user
|
rm -rf build.user
|
||||||
@@ -186,8 +220,7 @@ sudo ninja -vC build.user install || exit
|
|||||||
|
|
||||||
# build dav1d
|
# build dav1d
|
||||||
cd "$DAV1D_DIR" || exit
|
cd "$DAV1D_DIR" || exit
|
||||||
git stash && git stash drop
|
update_git
|
||||||
git pull
|
|
||||||
rm -rf build.user
|
rm -rf build.user
|
||||||
mkdir build.user
|
mkdir build.user
|
||||||
cd build.user || exit
|
cd build.user || exit
|
||||||
@@ -198,8 +231,7 @@ sudo ninja -vC build.user install || exit
|
|||||||
|
|
||||||
# build opus
|
# build opus
|
||||||
cd "$OPUS_DIR" || exit
|
cd "$OPUS_DIR" || exit
|
||||||
git stash && git stash drop
|
update_git
|
||||||
git pull
|
|
||||||
./autogen.sh || exit
|
./autogen.sh || exit
|
||||||
export CFLAGS="-O3 -flto $COMP_FLAGS"
|
export CFLAGS="-O3 -flto $COMP_FLAGS"
|
||||||
./configure || exit
|
./configure || exit
|
||||||
@@ -214,8 +246,7 @@ sudo ldconfig
|
|||||||
|
|
||||||
# build ffmpeg
|
# build ffmpeg
|
||||||
cd "$FFMPEG_DIR/" || exit
|
cd "$FFMPEG_DIR/" || exit
|
||||||
git stash && git stash drop
|
update_git
|
||||||
git pull
|
|
||||||
export PKG_CONFIG_PATH+=":/usr/local/lib/pkgconfig"
|
export PKG_CONFIG_PATH+=":/usr/local/lib/pkgconfig"
|
||||||
make clean
|
make clean
|
||||||
./configure --enable-libsvtav1 --enable-librav1e \
|
./configure --enable-libsvtav1 --enable-librav1e \
|
||||||
@@ -237,3 +268,4 @@ source ~/.profile
|
|||||||
ffmpeg -encoders 2>&1 | grep "av1"
|
ffmpeg -encoders 2>&1 | grep "av1"
|
||||||
ffmpeg -encoders 2>&1 | grep "rkmpp"
|
ffmpeg -encoders 2>&1 | grep "rkmpp"
|
||||||
ffmpeg -decoders 2>&1 | grep "rkmpp"
|
ffmpeg -decoders 2>&1 | grep "rkmpp"
|
||||||
|
exit 0
|
||||||
|
|||||||
Reference in New Issue
Block a user