mirror of
https://github.com/openwrt-xiaomi/builder.git
synced 2026-02-04 16:37:47 +05:00
Compare commits
14 Commits
v24
...
c5fe3ea00b
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
c5fe3ea00b | ||
|
|
6cd0f64b8d | ||
|
|
9cc255858e | ||
|
|
a775b82e5b | ||
|
|
f9ab8e3841 | ||
|
|
4e7389f304 | ||
|
|
887d928a4b | ||
|
|
5167d394e1 | ||
|
|
dd3a9395f2 | ||
|
|
2f112defb4 | ||
|
|
9104838c9b | ||
|
|
4e60cabc73 | ||
|
|
295d495e81 | ||
|
|
d147c0c72d |
534
.github/workflows/build.yml
vendored
534
.github/workflows/build.yml
vendored
@@ -3,21 +3,8 @@ name: build
|
|||||||
on:
|
on:
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
inputs:
|
inputs:
|
||||||
use_cache:
|
|
||||||
description: 'Restore cache for host tools'
|
|
||||||
required: true
|
|
||||||
default: 'true'
|
|
||||||
type: choice
|
|
||||||
options:
|
|
||||||
- true
|
|
||||||
- false
|
|
||||||
cache_ver:
|
|
||||||
description: 'Use cache version'
|
|
||||||
required: false
|
|
||||||
default: '0'
|
|
||||||
type: string
|
|
||||||
test_build:
|
test_build:
|
||||||
description: 'Test build (only spec target) '
|
description: 'Test build'
|
||||||
required: true
|
required: true
|
||||||
default: 'false'
|
default: 'false'
|
||||||
type: choice
|
type: choice
|
||||||
@@ -25,12 +12,12 @@ on:
|
|||||||
- true
|
- true
|
||||||
- false
|
- false
|
||||||
target_name:
|
target_name:
|
||||||
description: 'Target Name for test build'
|
description: 'Target Name'
|
||||||
required: false
|
required: false
|
||||||
default: 'r3d'
|
default: 'r3d'
|
||||||
type: string
|
type: string
|
||||||
package_dir:
|
package_dir:
|
||||||
description: 'Package Dir for test build'
|
description: 'Package Dir'
|
||||||
required: false
|
required: false
|
||||||
default: ''
|
default: ''
|
||||||
type: string
|
type: string
|
||||||
@@ -42,14 +29,6 @@ on:
|
|||||||
options:
|
options:
|
||||||
- true
|
- true
|
||||||
- false
|
- false
|
||||||
trx_build:
|
|
||||||
description: 'TRX images build'
|
|
||||||
required: true
|
|
||||||
default: 'false'
|
|
||||||
type: choice
|
|
||||||
options:
|
|
||||||
- true
|
|
||||||
- false
|
|
||||||
suffix:
|
suffix:
|
||||||
description: 'TAG suffix'
|
description: 'TAG suffix'
|
||||||
required: false
|
required: false
|
||||||
@@ -58,13 +37,16 @@ on:
|
|||||||
|
|
||||||
env:
|
env:
|
||||||
TEST_BUILD: ${{ github.event.inputs.test_build == 'true' }}
|
TEST_BUILD: ${{ github.event.inputs.test_build == 'true' }}
|
||||||
|
FAKE_BUILD: ${{ github.event.inputs.fake_build == 'true' }}
|
||||||
TAG_SUFFIX: ${{ github.event.inputs.fake_build == 'true' && '-fake' || github.event.inputs.test_build == 'true' && '-test' || '' }}
|
TAG_SUFFIX: ${{ github.event.inputs.fake_build == 'true' && '-fake' || github.event.inputs.test_build == 'true' && '-test' || '' }}
|
||||||
TARGET_NAME: ${{ github.event.inputs.target_name }}
|
TARGET_NAME: ${{ github.event.inputs.target_name }}
|
||||||
G_PKG_DIR: ${{ github.event.inputs.package_dir }}
|
PACKAGE_DIR: ${{ github.event.inputs.package_dir }}
|
||||||
REPO_URL: https://github.com/openwrt-xiaomi/openwrt
|
REPO_URL: https://github.com/openwrt-xiaomi/openwrt
|
||||||
REPO_LNK: openwrt-xiaomi/openwrt
|
REPO_LNK: openwrt-xiaomi/openwrt
|
||||||
REPO_BRANCH: xq-24.10
|
REPO_BRANCH: xq-25.12
|
||||||
TAG_PREFIX: v24-
|
TAG_PREFIX: v25-
|
||||||
|
BUILD_ROOT: ${{ github.workspace }}/openwrt
|
||||||
|
DEPENDENCIES: ${{ github.workspace }}/dependencies-ubuntu.txt
|
||||||
TZ: UTC
|
TZ: UTC
|
||||||
DEVICE_NAME: unknown
|
DEVICE_NAME: unknown
|
||||||
BUILD_DATE: unknown
|
BUILD_DATE: unknown
|
||||||
@@ -164,9 +146,8 @@ jobs:
|
|||||||
- rt-ax57m
|
- rt-ax57m
|
||||||
- rt-ax59u
|
- rt-ax59u
|
||||||
- rt-ax89x
|
- rt-ax89x
|
||||||
- tuf-ax4200
|
- tuf_ax4200
|
||||||
- tuf-ax4200q
|
- tuf_ax6000
|
||||||
- tuf-ax6000
|
|
||||||
- zen-bt8
|
- zen-bt8
|
||||||
isTest:
|
isTest:
|
||||||
- ${{ needs.check.outputs.test_build == 'true' }}
|
- ${{ needs.check.outputs.test_build == 'true' }}
|
||||||
@@ -181,13 +162,12 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
sudo apt-get -qq update
|
sudo apt-get -qq update
|
||||||
#sudo apt-get -qq update && sudo apt-get -qq upgrade
|
#sudo apt-get -qq update && sudo apt-get -qq upgrade
|
||||||
sudo apt-get -qq install build-essential gawk flex rsync swig unzip zlib1g-dev file wget
|
sudo apt-get -qq install $(cat $DEPENDENCIES)
|
||||||
sudo apt-get -qq install libc6-dev clang bison g++ gcc-multilib g++-multilib
|
sudo apt-get -qq install libc6-dev pkg-config
|
||||||
sudo apt-get -qq install gettext git libncurses5-dev libssl-dev python3-setuptools
|
|
||||||
sudo apt-get -qq install libc6-dev pkg-config squashfs-tools
|
|
||||||
sudo apt-get -qq autoremove --purge
|
sudo apt-get -qq autoremove --purge
|
||||||
sudo apt-get -qq clean
|
sudo apt-get -qq clean
|
||||||
sudo timedatectl set-timezone "$TZ"
|
sudo timedatectl set-timezone "$TZ"
|
||||||
|
ls -l /usr/include/bits/
|
||||||
|
|
||||||
- name: Maximize build disk space
|
- name: Maximize build disk space
|
||||||
uses: easimon/maximize-build-space@master
|
uses: easimon/maximize-build-space@master
|
||||||
@@ -197,83 +177,45 @@ jobs:
|
|||||||
remove-haskell: true
|
remove-haskell: true
|
||||||
remove-codeql: true
|
remove-codeql: true
|
||||||
remove-docker-images: true
|
remove-docker-images: true
|
||||||
|
|
||||||
- name: Set fixed workspace
|
|
||||||
env:
|
|
||||||
GITHUB_WORKSPACE: ${{ github.workspace }}
|
|
||||||
run: |
|
|
||||||
sudo mkdir -p $GITHUB_WORKSPACE/_temp
|
|
||||||
#sudo chown -R $USER:$USER $GITHUB_WORKSPACE
|
|
||||||
echo "GITHUB_WORKSPACE = $GITHUB_WORKSPACE"
|
|
||||||
echo "GITHUB_WORKSPACE=$GITHUB_WORKSPACE" >> $GITHUB_ENV
|
|
||||||
echo "RUNNER_TEMP=$GITHUB_WORKSPACE/_temp" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
- name: Checkout builder
|
- name: Checkout builder
|
||||||
uses: actions/checkout@main
|
uses: actions/checkout@main
|
||||||
|
|
||||||
- name: Prepare env params
|
|
||||||
env:
|
|
||||||
INP_FAKE_BUILD: ${{ github.event.inputs.fake_build == 'true' }}
|
|
||||||
INP_TRX_BUILD: ${{ github.event.inputs.trx_build == 'true' }}
|
|
||||||
TARGET: ${{ matrix.target }}
|
|
||||||
run: |
|
|
||||||
FAKE_BUILD=$INP_FAKE_BUILD
|
|
||||||
TRX_BUILD=false
|
|
||||||
if [ "$INP_TRX_BUILD" = true ]; then
|
|
||||||
CFG="./_initramfs/$TARGET.config"
|
|
||||||
if [ -f "$CFG" ]; then
|
|
||||||
TRX_BUILD=true
|
|
||||||
echo "Start TRX build for $CFG"
|
|
||||||
echo "OPT_INITRAMFS=-i" >> $GITHUB_ENV
|
|
||||||
else
|
|
||||||
FAKE_BUILD=true
|
|
||||||
echo "Start FAKE build for $TARGET"
|
|
||||||
echo "SKIP_ME=true" >> $GITHUB_ENV
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
echo "FAKE_BUILD = $FAKE_BUILD"
|
|
||||||
echo "TRX_BUILD = $TRX_BUILD"
|
|
||||||
echo "FAKE_BUILD=$FAKE_BUILD" >> $GITHUB_ENV
|
|
||||||
echo "TRX_BUILD=$TRX_BUILD" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
- name: Download OpenWrt sources
|
- name: Download OpenWrt sources
|
||||||
run: |
|
run: git clone --branch $REPO_BRANCH $REPO_URL.git $BUILD_ROOT
|
||||||
git clone --branch $REPO_BRANCH $REPO_URL.git openwrt
|
|
||||||
rm -rf .git
|
|
||||||
rsync -a openwrt/ ./
|
|
||||||
rm -rf openwrt
|
|
||||||
|
|
||||||
- name: Init builder
|
- name: Init builder
|
||||||
env:
|
env:
|
||||||
TOOLS_SRC_HASH: ${{ hashFiles('tools/**') }}
|
BLDROOT: ${{ github.workspace }}
|
||||||
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
|
rsync -avq --exclude=".*" --exclude="$(basename $BUILD_ROOT)" $BLDROOT/ $BUILD_ROOT/
|
||||||
|
cd $BUILD_ROOT
|
||||||
chmod +x *.sh
|
chmod +x *.sh
|
||||||
wget https://github.com/fantastic-packages/packages/raw/refs/heads/24.10/keys/usign/53FF2B6672243D28.pub
|
wget https://github.com/fantastic-packages/packages/raw/refs/heads/25.12/keys/usign/53FF2B6672243D28.pub
|
||||||
echo "TOOLS_SRC_HASH=$TOOLS_SRC_HASH" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
- name: Update OpenWrt packages
|
- name: Update OpenWrt packages
|
||||||
id: update
|
id: update
|
||||||
run: |
|
run: |
|
||||||
./xupdate.sh -f
|
cd $BUILD_ROOT && ./xupdate.sh -f
|
||||||
mkdir -p logs
|
|
||||||
echo "status=success" >> $GITHUB_OUTPUT
|
echo "status=success" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
- name: Configure
|
- name: Configure
|
||||||
id: configure
|
id: configure
|
||||||
if: steps.update.outputs.status == 'success'
|
if: steps.update.outputs.status == 'success'
|
||||||
env:
|
env:
|
||||||
TARGET: ${{ matrix.target }}
|
TARGET: ${{ matrix.target }}
|
||||||
FW_VER: ${{ needs.check.outputs.fw_ver }}
|
FW_VER: ${{ needs.check.outputs.fw_ver }}
|
||||||
run: |
|
run: |
|
||||||
./xmake.sh $OPT_INITRAMFS -I -t $TARGET
|
cd $BUILD_ROOT && echo "init build config"
|
||||||
|
FILE_DATE=$(date --utc +'%y%m%d')
|
||||||
|
./xmake.sh -I -t $TARGET
|
||||||
G_DEVICE_NAME=$( grep -so '^CONFIG_TARGET.*DEVICE.*=y' .config | sed -r 's/.*DEVICE_(.*)=y/\1/' )
|
G_DEVICE_NAME=$( grep -so '^CONFIG_TARGET.*DEVICE.*=y' .config | sed -r 's/.*DEVICE_(.*)=y/\1/' )
|
||||||
[ -z "$G_DEVICE_NAME" ] && exit 31
|
[ -z "$G_DEVICE_NAME" ] && exit 31
|
||||||
G_BOARD_NAME=$( grep -so '^CONFIG_TARGET_BOARD=.*' .config | cut -d'"' -f2 )
|
G_BOARD_NAME=$( grep -so '^CONFIG_TARGET_BOARD=.*' .config | cut -d'"' -f2 )
|
||||||
[ -z "$G_BOARD_NAME" ] && exit 32
|
[ -z "$G_BOARD_NAME" ] && exit 32
|
||||||
G_SUBTARGET_NAME=$( grep -so '^CONFIG_TARGET_SUBTARGET=.*' .config | cut -d'"' -f2 )
|
G_SUBTARGET_NAME=$( grep -so '^CONFIG_TARGET_SUBTARGET=.*' .config | cut -d'"' -f2 )
|
||||||
[ -z "$G_SUBTARGET_NAME" ] && exit 33
|
[ -z "$G_SUBTARGET_NAME" ] && exit 33
|
||||||
G_TARGET_ARCH=$( grep -so '^CONFIG_TARGET_ARCH_PACKAGES=.*' .config | cut -d'"' -f2 )
|
|
||||||
echo "G_TARGET_ARCH = $G_TARGET_ARCH"
|
|
||||||
VERMAGIC_LIST="vermagic-$G_BOARD_NAME-$G_SUBTARGET_NAME-*.list"
|
VERMAGIC_LIST="vermagic-$G_BOARD_NAME-$G_SUBTARGET_NAME-*.list"
|
||||||
if [ $(find . -maxdepth 1 -name "$VERMAGIC_LIST" | wc -l) = "0" ]; then
|
if [ $(find . -maxdepth 1 -name "$VERMAGIC_LIST" | wc -l) = "0" ]; then
|
||||||
./vermagic_update.sh $G_BOARD_NAME $G_SUBTARGET_NAME
|
./vermagic_update.sh $G_BOARD_NAME $G_SUBTARGET_NAME
|
||||||
@@ -281,320 +223,163 @@ jobs:
|
|||||||
if [ $(find . -maxdepth 1 -name "$VERMAGIC_LIST" | wc -l) = "0" ]; then
|
if [ $(find . -maxdepth 1 -name "$VERMAGIC_LIST" | wc -l) = "0" ]; then
|
||||||
exit 41
|
exit 41
|
||||||
fi
|
fi
|
||||||
FILE_DATE=$(date --utc +'%y%m%d')
|
|
||||||
echo "status=success" >> $GITHUB_OUTPUT
|
echo "status=success" >> $GITHUB_OUTPUT
|
||||||
echo "FW_VER=$FW_VER" >> $GITHUB_ENV
|
echo "FW_VER=$FW_VER" >> $GITHUB_ENV
|
||||||
echo "G_DEVICE_NAME=$G_DEVICE_NAME" >> $GITHUB_ENV
|
echo "G_DEVICE_NAME=$G_DEVICE_NAME" >> $GITHUB_ENV
|
||||||
echo "G_BOARD_NAME=$G_BOARD_NAME" >> $GITHUB_ENV
|
echo "G_BOARD_NAME=$G_BOARD_NAME" >> $GITHUB_ENV
|
||||||
echo "G_SUBTARGET_NAME=$G_SUBTARGET_NAME" >> $GITHUB_ENV
|
echo "G_SUBTARGET_NAME=$G_SUBTARGET_NAME" >> $GITHUB_ENV
|
||||||
echo "G_TARGET_ARCH=$G_TARGET_ARCH" >> $GITHUB_ENV
|
|
||||||
echo "FILE_DATE=$FILE_DATE" >> $GITHUB_ENV
|
echo "FILE_DATE=$FILE_DATE" >> $GITHUB_ENV
|
||||||
|
|
||||||
- name: Dump .config file
|
- name: Dump .config file
|
||||||
run: |
|
run: |
|
||||||
echo "====== .config ========="
|
echo "====== .config ========="
|
||||||
cat .config
|
cat $BUILD_ROOT/.config
|
||||||
echo "========================"
|
echo "========================"
|
||||||
cp -f .config logs/config1
|
|
||||||
cp -f .config config1
|
|
||||||
|
|
||||||
- name: Prepare for host tools
|
- name: Download tools and toolchain
|
||||||
id: tools_prepare
|
id: tools_download
|
||||||
env:
|
if: steps.configure.outputs.status == 'success'
|
||||||
TARGET: ${{ matrix.target }}
|
|
||||||
USE_CACHE: ${{ github.event.inputs.use_cache }}
|
|
||||||
CACHE_VER: ${{ github.event.inputs.cache_ver }}
|
|
||||||
run: |
|
run: |
|
||||||
echo USE_CACHE = $USE_CACHE
|
cd $BUILD_ROOT
|
||||||
HOST_TOOLS_STG_DIR=staging_dir/host
|
G_TARGET_ARCH=$( grep -so '^CONFIG_TARGET_ARCH_PACKAGES=' .config | cut -d'"' -f2 )
|
||||||
HOST_TOOLS_BLD_DIR=build_dir/host
|
echo "G_TARGET_ARCH=$G_TARGET_ARCH" >> $GITHUB_ENV
|
||||||
rm -rf staging_dir/
|
echo "OpenWrt version: $FW_VER"
|
||||||
rm -rf build_dir/
|
SDK_URL_BASE="https://downloads.openwrt.org/releases/${FW_VER}/targets/${G_BOARD_NAME}/${G_SUBTARGET_NAME}"
|
||||||
mkdir -p staging_dir/host
|
echo "Searching SDK at $SDK_URL_BASE"
|
||||||
mkdir -p build_dir/host
|
SDK_TARBALL=$( curl -s "$SDK_URL_BASE/" | grep -oE 'openwrt-sdk-[^"]+Linux-x86_64\.tar\.(xz|zst)' | head -n1 )
|
||||||
#############################################
|
if [ -z "$SDK_TARBALL" ]; then
|
||||||
CONFIG_BUILD_ALL_HOST_TOOLS=n
|
echo "ERROR: SDK not found for ${G_BOARD_NAME}/${G_SUBTARGET_NAME}"
|
||||||
if grep '^CONFIG_BUILD_ALL_HOST_TOOLS=y' $CFG ; then
|
exit 81
|
||||||
CONFIG_BUILD_ALL_HOST_TOOLS=y
|
|
||||||
fi
|
fi
|
||||||
########### check tools Makefile ############
|
echo "Found SDK: $SDK_TARBALL"
|
||||||
if [ "$CONFIG_BUILD_ALL_HOST_TOOLS" != y ]; then
|
#curl -L --fail --retry 5 --retry-delay 5 --progress-bar -o "$SDK_TARBALL" "$SDK_URL_BASE/$SDK_TARBALL"
|
||||||
if grep -q '(CONFIG_USES_MINOR),y) += yafut' tools/Makefile ; then
|
wget --progress=dot:mega "$SDK_URL_BASE/$SDK_TARBALL"
|
||||||
echo WARN: file tools/Makefile allowed compile yafut
|
if [[ "$SDK_TARBALL" == *.tar.xz ]]; then
|
||||||
echo ERROR: yafut compile not supported !!!
|
tar -xf "$SDK_TARBALL"
|
||||||
exit 51
|
elif [[ "$SDK_TARBALL" == *.tar.zst ]]; then
|
||||||
fi
|
tar -I zstd -xf "$SDK_TARBALL"
|
||||||
|
else
|
||||||
|
echo "Unknown archive format: $SDK_TARBALL"
|
||||||
|
exit 82
|
||||||
fi
|
fi
|
||||||
########### get hash of dir with tools Makefiles ############
|
SDK_DIR=$(tar -tf "$SDK_TARBALL" | head -n1 | cut -d/ -f1)
|
||||||
TOOLS_SRC_CRC=$( echo $TOOLS_SRC_HASH | cksum | awk '{print $1}' )
|
echo "Using SDK dir: $SDK_DIR"
|
||||||
echo $TOOLS_SRC_CRC > logs/host_tools_sources.crc
|
rm -rf staging_dir
|
||||||
echo "TOOLS_SRC_CRC=$TOOLS_SRC_CRC" >> $GITHUB_ENV
|
mv "$SDK_DIR/staging_dir" .
|
||||||
########### get prereq tools (w/o compile) ############
|
echo "========= staging_dir =========="
|
||||||
ls -la $HOST_TOOLS_DIR/bin | awk '{print $9 " -> " $11}' | sort > $HOST_TOOLS_STG_DIR/.prereq-build-list
|
ls -l staging_dir
|
||||||
TOOLS_PREREQ_CRC=$( cat $HOST_TOOLS_STG_DIR/.prereq-build-list | cksum | awk '{print $1}' )
|
echo "================================"
|
||||||
cp -f $HOST_TOOLS_STG_DIR/.prereq-build-list logs/prereq-build-list.txt
|
#cp -a "$SDK_DIR"/toolchain/* toolchain/ 2>/dev/null || true
|
||||||
echo "TOOLS_PREREQ_CRC=$TOOLS_PREREQ_CRC" >> $GITHUB_ENV
|
TOOLS_DIR=staging_dir/host
|
||||||
########### patch for tools/Makefile ###############
|
touch $TOOLS_DIR/.prepared
|
||||||
cat <<'EOF' >> tools/Makefile
|
TOOLS_STAMP_DIR=$TOOLS_DIR/stamp
|
||||||
###
|
TOOLS_PKGS=$(
|
||||||
### patch for getinfo
|
find tools/ -maxdepth 1 -mindepth 1 -type d | while read -r d; do
|
||||||
###
|
mk="$d/Makefile"
|
||||||
TOOLS_COMPILE_LIST := $(STAGING_DIR_HOST)/.tools_compile_list
|
[ -f "$mk" ] || continue
|
||||||
define gen_tools_compile_list
|
awk -F':=' '
|
||||||
@echo "Generating $(TOOLS_COMPILE_LIST)"
|
/^[[:space:]]*PKG_NAME[[:space:]]*:=/ {
|
||||||
@mkdir -p $(STAGING_DIR_HOST)
|
v=$2
|
||||||
rm -f $(STAGING_DIR_HOST)/.tools_compile_*
|
gsub(/\r/, "", v)
|
||||||
@{ \
|
gsub(/^[[:space:]]+/, "", v)
|
||||||
TOOLS_STATUS=""; \
|
gsub(/[[:space:]]+$/, "", v)
|
||||||
for tool in $(sort $(tools-y) $(tools-)); do \
|
if (v != "") print v
|
||||||
T_STATUS="n"; \
|
}
|
||||||
if echo " $(tools-y) " | grep -q " $$tool " ; then T_STATUS="y"; printf "+"; else printf " "; fi; \
|
' "$mk"
|
||||||
TOOLS_STATUS="$${TOOLS_STATUS}$${T_STATUS}" ; \
|
done | sort -u
|
||||||
printf " %s\n" "$$tool"; \
|
)
|
||||||
done; \
|
mkdir -p "$TOOLS_STAMP_DIR"
|
||||||
printf "$$TOOLS_STATUS" > $(STAGING_DIR_HOST)/.tools_compile_mask; \
|
echo "Found host tools packages: $TOOLS_PKGS"
|
||||||
} > $(TOOLS_COMPILE_LIST)
|
for pkg in $TOOLS_PKGS; do
|
||||||
endef
|
touch "$TOOLS_STAMP_DIR/.$pkg"_installed
|
||||||
|
done
|
||||||
$(curdir)/getinfo: .config prereq
|
TOOLCHAIN_DIR=$( find staging_dir -maxdepth 1 -type d -name "toolchain-*" )
|
||||||
$(call gen_tools_compile_list)
|
echo "Found toolchain directory: $TOOLCHAIN_DIR"
|
||||||
|
#touch $TOOLCHAIN_DIR/.prepared
|
||||||
$(curdir)/prepare: $(curdir)/getinfo
|
mkdir -p "$TOOLCHAIN_DIR/stamp"
|
||||||
EOF
|
touch $TOOLCHAIN_DIR/stamp/.binutils_installed
|
||||||
########## end of patch tools/Makefile ############
|
#touch $TOOLCHAIN_DIR/stamp/.fortify-headers_installed
|
||||||
make tools/getinfo
|
touch $TOOLCHAIN_DIR/stamp/.gcc_final_installed
|
||||||
if [ ! -f $HOST_TOOLS_STG_DIR/.tools_compile_list ]; then
|
touch $TOOLCHAIN_DIR/stamp/.gcc_initial_installed
|
||||||
echo ERROR: File $HOST_TOOLS_STG_DIR/.tools_compile_list not found!
|
touch $TOOLCHAIN_DIR/stamp/.gdb_installed
|
||||||
exit 55
|
#touch $TOOLCHAIN_DIR/stamp/.linux_installed
|
||||||
fi
|
touch $TOOLCHAIN_DIR/stamp/.musl_installed
|
||||||
cp -f $HOST_TOOLS_STG_DIR/.tools_compile_list logs/tools_compile_list.txt
|
touch $TOOLCHAIN_DIR/stamp/.toolchain_compile
|
||||||
TOOLS_COMPILE_CRC=$( cat $TOOLS_STG_DIR/.tools_compile_list | cksum | awk '{print $1}' )
|
echo "Checking cross-compiler..."
|
||||||
echo "TOOLS_COMPILE_CRC=$TOOLS_COMPILE_CRC" >> $GITHUB_ENV
|
find staging_dir -name '*gcc' | head -n 10
|
||||||
#######
|
|
||||||
TOOLS_COMPILE_MASK=$( cat $TOOLS_STG_DIR/.tools_compile_mask )
|
|
||||||
cp -f $HOST_TOOLS_STG_DIR/.tools_compile_mask logs/tools_compile_mask.txt
|
|
||||||
touch logs/tools_compile_$TOOLS_COMPILE_MASK
|
|
||||||
echo TOOLS_COMPILE_MASK = $TOOLS_COMPILE_MASK
|
|
||||||
###################################################
|
|
||||||
if [ "$USE_CACHE" = "true" ]; then
|
|
||||||
echo USE_CACHE = $USE_CACHE
|
|
||||||
fi
|
|
||||||
echo "USE_CACHE=$USE_CACHE" >> $GITHUB_ENV
|
|
||||||
echo "CACHE_VER=$CACHE_VER" >> $GITHUB_ENV
|
|
||||||
echo "HOST_TOOLS_STG_DIR=$HOST_TOOLS_STG_DIR" >> $GITHUB_ENV
|
|
||||||
echo "HOST_TOOLS_BLD_DIR=$HOST_TOOLS_BLD_DIR" >> $GITHUB_ENV
|
|
||||||
echo "status=success" >> $GITHUB_OUTPUT
|
|
||||||
|
|
||||||
- name: Restore host tools from cache
|
|
||||||
id: tools_cache_restore
|
|
||||||
if: github.event.inputs.use_cache == 'true'
|
|
||||||
uses: actions/cache/restore@v4
|
|
||||||
with:
|
|
||||||
key: host-tools-${{ env.CACHE_VER }}-${{ env.TOOLS_SRC_CRC }}-${{ env.TOOLS_PREREQ_CRC }}-${{ env.TOOLS_COMPILE_CRC }}
|
|
||||||
path: |
|
|
||||||
staging_dir/host
|
|
||||||
build_dir/host
|
|
||||||
|
|
||||||
- name: Fix time stamps into restored dirs
|
|
||||||
if: github.event.inputs.use_cache == 'true' && steps.tools_cache_restore.outputs.cache-hit == 'true'
|
|
||||||
run: |
|
|
||||||
touch $HOST_TOOLS_STG_DIR/.prepared
|
|
||||||
touch $HOST_TOOLS_STG_DIR/.prereq-build
|
|
||||||
touch $HOST_TOOLS_STG_DIR/stamp/.* 2>/dev/null
|
|
||||||
find $HOST_TOOLS_BLD_DIR -name ".prepared*" -exec touch {} +
|
|
||||||
find $HOST_TOOLS_BLD_DIR -name ".configured" -exec touch {} +
|
|
||||||
find $HOST_TOOLS_BLD_DIR -name ".built" -exec touch {} +
|
|
||||||
|
|
||||||
- name: Inspect restored host tools
|
|
||||||
if: github.event.inputs.use_cache == 'true'
|
|
||||||
run: |
|
|
||||||
echo "====== openwrt-native.txt ======"
|
|
||||||
cat $HOST_TOOLS_BLD_DIR/pkgconf-*/openwrt-native.txt || true
|
|
||||||
echo "====== staging_dir/host ====="
|
|
||||||
du -sh $HOST_TOOLS_STG_DIR || true
|
|
||||||
ls -la $HOST_TOOLS_STG_DIR || true
|
|
||||||
echo "====== staging_dir/host/bin ====="
|
|
||||||
du -sh $HOST_TOOLS_STG_DIR/bin || true
|
|
||||||
ls -1 $HOST_TOOLS_STG_DIR/bin | head -20 || true
|
|
||||||
echo "====== build_dir/host ======="
|
|
||||||
du -sh $HOST_TOOLS_BLD_DIR || true
|
|
||||||
ls -1 $HOST_TOOLS_BLD_DIR | head -20 || true
|
|
||||||
echo "====== path info ========"
|
|
||||||
grep -R "/home/runner" $HOST_TOOLS_BLD_DIR | head
|
|
||||||
|
|
||||||
- name: Monitor memory
|
|
||||||
run: |
|
|
||||||
echo "CPU cores = $(nproc)"
|
|
||||||
echo "Memory and swap:"
|
|
||||||
sudo free -h
|
|
||||||
echo
|
|
||||||
sudo swapon --show
|
|
||||||
echo
|
|
||||||
echo "Available storage:"
|
|
||||||
sudo df -h
|
|
||||||
|
|
||||||
- name: Download sources (dl)
|
|
||||||
id: download
|
|
||||||
if: ${{ steps.configure.outputs.status == 'success' && env.FAKE_BUILD != 'true' }}
|
|
||||||
run: |
|
|
||||||
make -j$(nproc) download
|
|
||||||
echo "status=success" >> $GITHUB_OUTPUT
|
echo "status=success" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
- name: Build tools and toolchain
|
- name: Build tools and toolchain
|
||||||
id: tools
|
id: tools
|
||||||
if: ${{ steps.configure.outputs.status == 'success' && env.FAKE_BUILD != 'true' }}
|
if: steps.configure.outputs.status == 'success'
|
||||||
run: |
|
run: |
|
||||||
make toolchain/install -j$(nproc)
|
cd $BUILD_ROOT
|
||||||
|
MAKE_JOBS=$(nproc)
|
||||||
|
echo "$MAKE_JOBS thread compile"
|
||||||
|
export CCACHE=1
|
||||||
|
make tools/install -j$MAKE_JOBS
|
||||||
|
make toolchain/install -j$MAKE_JOBS
|
||||||
echo "status=success" >> $GITHUB_OUTPUT
|
echo "status=success" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
- name: Save cache for host tools
|
|
||||||
id: tools_cache_save
|
|
||||||
if: steps.tools.outputs.status == 'success'
|
|
||||||
uses: actions/cache/save@v4
|
|
||||||
with:
|
|
||||||
key: host-tools-${{ env.CACHE_VER }}-${{ env.TOOLS_SRC_CRC }}-${{ env.TOOLS_PREREQ_CRC }}-${{ env.TOOLS_COMPILE_CRC }}
|
|
||||||
path: |
|
|
||||||
staging_dir/host
|
|
||||||
build_dir/host
|
|
||||||
|
|
||||||
- name: Show host tools stamps
|
|
||||||
run: |
|
|
||||||
ls -la staging_dir/host/stamp/
|
|
||||||
ls -la staging_dir/host/stamp/ > logs/host_stamp_dir.txt
|
|
||||||
|
|
||||||
- name: Configure 2
|
|
||||||
id: configure2
|
|
||||||
if: steps.tools.outputs.status == 'success'
|
|
||||||
env:
|
|
||||||
TARGET: ${{ matrix.target }}
|
|
||||||
run: |
|
|
||||||
rm -rf logs_backup/
|
|
||||||
cp -a logs logs_backup
|
|
||||||
make clean
|
|
||||||
rm -rf logs
|
|
||||||
cp -a logs_backup logs
|
|
||||||
./xmake.sh $OPT_INITRAMFS -I -t $TARGET
|
|
||||||
cp -f .config logs/config2
|
|
||||||
|
|
||||||
- name: Kernel compile
|
|
||||||
id: kernel
|
|
||||||
if: ${{ steps.tools.outputs.status == 'success' && env.FAKE_BUILD != 'true' }}
|
|
||||||
run: |
|
|
||||||
make target/linux/compile -j$(nproc)
|
|
||||||
echo "status=success" >> $GITHUB_OUTPUT
|
|
||||||
|
|
||||||
- name: Monitor memory 2
|
|
||||||
run: |
|
|
||||||
echo "Memory and swap:"
|
|
||||||
sudo free -h
|
|
||||||
echo
|
|
||||||
sudo swapon --show
|
|
||||||
echo
|
|
||||||
echo "Available storage:"
|
|
||||||
sudo df -h
|
|
||||||
|
|
||||||
- name: Build the firmware image
|
- name: Build the firmware image
|
||||||
id: compile
|
id: compile
|
||||||
if: steps.tools.outputs.status == 'success'
|
if: steps.tools.outputs.status == 'success'
|
||||||
env:
|
env:
|
||||||
TARGET: ${{ matrix.target }}
|
TARGET: ${{ matrix.target }}
|
||||||
run: |
|
run: |
|
||||||
echo "Run $(nproc) thread compile"
|
cd $BUILD_ROOT
|
||||||
if [ "$FAKE_BUILD" != "true" -a "$TEST_BUILD" = "true" -a "$G_PKG_DIR" != "" ]; then
|
MAKE_JOBS=$(nproc)
|
||||||
make target/linux/compile -j$(npoc)
|
echo "$MAKE_JOBS thread compile"
|
||||||
echo "=============== BUILD PACKAGE: $G_PKG_DIR ==============="
|
export CCACHE=1
|
||||||
make $G_PKG_DIR/compile V=sc BUILD_LOG=1
|
if [ "$FAKE_BUILD" != "true" -a "$TEST_BUILD" = "true" -a "$PACKAGE_DIR" != "" ]; then
|
||||||
|
make $PACKAGE_DIR/compile V=sc BUILD_LOG=1
|
||||||
exit 99
|
exit 99
|
||||||
fi
|
fi
|
||||||
if [ "$FAKE_BUILD" != "true" ]; then
|
if [ "$FAKE_BUILD" != "true" ]; then
|
||||||
if [ "$TEST_BUILD" != "true" ]; then
|
if [ "$TEST_BUILD" != "true" ]; then
|
||||||
make -j$(nproc) world
|
make -j $MAKE_JOBS download world
|
||||||
else
|
else
|
||||||
make V=sc world
|
make V=sc download world
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
echo "status=success" >> $GITHUB_OUTPUT
|
# process results
|
||||||
|
OUT_DIR=$BUILD_ROOT/bin/targets/$G_BOARD_NAME/$G_SUBTARGET_NAME
|
||||||
- name: Process out results
|
if [ "$FAKE_BUILD" = "true" ]; then
|
||||||
id: install
|
|
||||||
if: steps.compile.outputs.status == 'success' || env.FAKE_BUILD == 'true'
|
|
||||||
env:
|
|
||||||
TARGET: ${{ matrix.target }}
|
|
||||||
OUT_DIR: ./bin/targets/${{ env.G_BOARD_NAME }}/${{ env.G_SUBTARGET_NAME }}
|
|
||||||
run: |
|
|
||||||
if [ "$FAKE_BUILD" = true ]; then
|
|
||||||
mkdir -p logs
|
mkdir -p logs
|
||||||
mkdir -p "$OUT_DIR"
|
mkdir -p $OUT_DIR
|
||||||
cd "$OUT_DIR"
|
echo "$G_BOARD_NAME $G_SUBTARGET_NAME $G_DEVICE_NAME" > "$OUT_DIR/$G_DEVICE_NAME.txt"
|
||||||
echo "$G_BOARD_NAME $G_SUBTARGET_NAME $G_DEVICE_NAME" > "$G_DEVICE_NAME.txt"
|
touch "$OUT_DIR/kernel-debug.tar.zst"
|
||||||
touch FAKE_BUILD.bin
|
ls -la
|
||||||
touch kernel-debug.tar.zst
|
|
||||||
BLD_VER=$FW_VER
|
BLD_VER=$FW_VER
|
||||||
else
|
else
|
||||||
if [ ! -d "$OUT_DIR" ]; then
|
BLD_VER=$( cat $OUT_DIR/profiles.json | grep -so '"version_number":"[^"]*' | grep -so '[^"]*$' )
|
||||||
echo "OUT_DIR not found!"
|
|
||||||
exit 99
|
|
||||||
fi
|
|
||||||
cd "$OUT_DIR"
|
|
||||||
BLD_VER=$( cat profiles.json | grep -so '"version_number":"[^"]*' | grep -so '[^"]*$' )
|
|
||||||
fi
|
|
||||||
if [ "$SKIP_ME" = true ]; then
|
|
||||||
touch FLAG-SKIP_ME
|
|
||||||
fi
|
|
||||||
if [ "$TRX_BUILD" = true ]; then
|
|
||||||
touch FLAG-TRX_BUILD
|
|
||||||
fi
|
fi
|
||||||
echo "Firmware $BLD_VER [$FILE_DATE] builded!"
|
echo "Firmware $BLD_VER [$FILE_DATE] builded!"
|
||||||
if [ ! -f kernel-debug.tar.zst ]; then
|
if [ ! -f $OUT_DIR/kernel-debug.tar.zst ]; then
|
||||||
echo "File kernel-debug.tar.zst not found!"
|
echo "File kernel-debug.tar.zst not found!"
|
||||||
exit 100
|
exit 100
|
||||||
fi
|
fi
|
||||||
if [ "$TRX_BUILD" = true ]; then
|
|
||||||
find . -maxdepth 1 -type f ! -name '*-initramfs*' ! -name 'FLAG-*' -delete
|
|
||||||
VER_MAJOR=$( echo "$BLD_VER" | cut -d. -f1 )
|
|
||||||
STD_IMG_DIR="openwrt-initramfs-bin-for-luci"
|
|
||||||
mkdir $STD_IMG_DIR
|
|
||||||
find . -maxdepth 1 -type f -name '*-initramfs*.bin' -exec mv -f {} $STD_IMG_DIR/openwrt-${VER_MAJOR}_${TARGET}_initramfs.bin \;
|
|
||||||
find . -maxdepth 1 -type f -name '*-initramfs*.trx' -exec mv -f {} openwrt-${VER_MAJOR}_${TARGET}_initramfs.trx \;
|
|
||||||
fi
|
|
||||||
echo "status=success" >> $GITHUB_OUTPUT
|
echo "status=success" >> $GITHUB_OUTPUT
|
||||||
echo "FW_BUILD_OK=1" >> $GITHUB_ENV
|
echo "DEVICE_NAME=$G_DEVICE_NAME" >> $GITHUB_ENV
|
||||||
|
echo "BOARD_NAME=$G_BOARD_NAME" >> $GITHUB_ENV
|
||||||
|
echo "SUBTARGET_NAME=$G_SUBTARGET_NAME" >> $GITHUB_ENV
|
||||||
echo "BLD_VER=$BLD_VER" >> $GITHUB_ENV
|
echo "BLD_VER=$BLD_VER" >> $GITHUB_ENV
|
||||||
echo "OUT_DIR=$OUT_DIR" >> $GITHUB_ENV
|
echo "OUT_DIR=$OUT_DIR" >> $GITHUB_ENV
|
||||||
|
|
||||||
- name: Mark firmware build failed
|
|
||||||
if: false # steps.install.outcome == 'failure' || steps.compile.outcome == 'failure'
|
|
||||||
run: |
|
|
||||||
echo "Firmware build failed, continuing pipeline"
|
|
||||||
echo "FW_BUILD_OK=0" >> $GITHUB_ENV
|
|
||||||
OUT_DIR=_bin_fake
|
|
||||||
mkdir -p $OUT_DIR
|
|
||||||
echo "$G_BOARD_NAME $G_SUBTARGET_NAME $G_DEVICE_NAME" > "$OUT_DIR/$G_DEVICE_NAME.txt"
|
|
||||||
touch "$OUT_DIR/kernel-debug.tar.zst"
|
|
||||||
echo "BUILD FAILED" > $OUT_DIR/FAILED.txt
|
|
||||||
echo "BLD_VER=$FW_VER" >> $GITHUB_ENV
|
|
||||||
echo "OUT_DIR=$OUT_DIR" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
- name: Check space usage
|
- name: Check space usage
|
||||||
run: df -hT
|
run: df -hT
|
||||||
|
|
||||||
- name: Check OOM error
|
|
||||||
if: failure()
|
|
||||||
run: |
|
|
||||||
dmesg | grep -i -E 'oom|killed process' || true
|
|
||||||
echo "================== Memory ================="
|
|
||||||
free -h
|
|
||||||
|
|
||||||
- name: Compress build logs
|
- name: Compress build logs
|
||||||
if: always()
|
if: always()
|
||||||
env:
|
env:
|
||||||
TARGET: ${{ matrix.target }}
|
TARGET: ${{ matrix.target }}
|
||||||
FW_DATE: ${{ needs.check.outputs.fw_date }}
|
FW_DATE: ${{ needs.check.outputs.fw_date }}
|
||||||
|
LOGS_DIR: ${{ env.BUILD_ROOT }}/logs
|
||||||
run: |
|
run: |
|
||||||
tar -cJvf logs-$TARGET-$FW_DATE.tar.xz logs
|
tar -cJvf logs-$TARGET-$FW_DATE.tar.xz $LOGS_DIR
|
||||||
|
|
||||||
- name: Cleanup OUT directory
|
- name: Cleanup OUT directory
|
||||||
if: steps.install.outputs.status == 'success'
|
if: steps.compile.outputs.status == 'success'
|
||||||
env:
|
env:
|
||||||
OUT_DIR: ${{ env.OUT_DIR }}
|
OUT_DIR: ${{ env.OUT_DIR }}
|
||||||
run: |
|
run: |
|
||||||
@@ -614,9 +399,9 @@ jobs:
|
|||||||
|
|
||||||
- name: Upload OUT directory
|
- name: Upload OUT directory
|
||||||
uses: actions/upload-artifact@main
|
uses: actions/upload-artifact@main
|
||||||
if: steps.install.outputs.status == 'success'
|
if: steps.compile.outputs.status == 'success'
|
||||||
with:
|
with:
|
||||||
name: openwrt-${{ env.BLD_VER }}-${{ needs.check.outputs.build_date }}-${{ env.G_DEVICE_NAME }}
|
name: openwrt-${{ env.BLD_VER }}-${{ needs.check.outputs.build_date }}-${{ env.DEVICE_NAME }}
|
||||||
path: ${{ env.OUT_DIR }}
|
path: ${{ env.OUT_DIR }}
|
||||||
if-no-files-found: error
|
if-no-files-found: error
|
||||||
|
|
||||||
@@ -624,7 +409,7 @@ jobs:
|
|||||||
if: always()
|
if: always()
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: logs-${{ matrix.target }}-${{ needs.check.outputs.fw_date }}
|
name: logs-${{ matrix.target }}-${{ env.FW_DATE }}
|
||||||
path: logs-*.tar.xz
|
path: logs-*.tar.xz
|
||||||
|
|
||||||
release:
|
release:
|
||||||
@@ -640,65 +425,22 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
pattern: openwrt-*
|
pattern: openwrt-*
|
||||||
|
|
||||||
- name: Check for failed builds
|
|
||||||
run: |
|
|
||||||
echo "Checking for FAILED.txt in openwrt-* directories..."
|
|
||||||
FAILED_DIRS=$( find . -maxdepth 1 -type d -name 'openwrt-*' -exec test -f '{}/FAILED.txt' \; -print )
|
|
||||||
if [ -n "$FAILED_DIRS" ]; then
|
|
||||||
echo "❌ Build failures detected in:"
|
|
||||||
exit 201
|
|
||||||
fi
|
|
||||||
echo "✅ No FAILED.txt found, proceeding to release"
|
|
||||||
|
|
||||||
- name: Put images into zip
|
- name: Put images into zip
|
||||||
run: |
|
run: |
|
||||||
mkdir -p public
|
mkdir -p public
|
||||||
for DIR in openwrt-*; do
|
find . -mindepth 1 -type d -name 'openwrt-*' -exec sh -c 'zip -0 ./public/$(basename {}).zip -j {} {}/*' \;
|
||||||
[ -d "$DIR" ] || continue
|
|
||||||
if [ -f "$DIR/FLAG-SKIP_ME" ]; then
|
|
||||||
echo "Skip $DIR"
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
ZIP_SUFFIX=""
|
|
||||||
if [ -f "$DIR/FLAG-TRX_BUILD" ]; then
|
|
||||||
echo "TRX_BUILD=true" >> $GITHUB_ENV
|
|
||||||
ZIP_SUFFIX=".trx"
|
|
||||||
fi
|
|
||||||
rm -f "$DIR"/FLAG-*
|
|
||||||
zip_name="./public/$(basename "$DIR")${ZIP_SUFFIX}.zip"
|
|
||||||
echo "Creating $zip_name"
|
|
||||||
( cd "$DIR"; zip -0 -r "../$zip_name" . )
|
|
||||||
done
|
|
||||||
|
|
||||||
- name: Show all zip files
|
|
||||||
run: |
|
|
||||||
ls -lh ./public/*.zip
|
ls -lh ./public/*.zip
|
||||||
|
|
||||||
- name: Generate names
|
|
||||||
env:
|
|
||||||
TAG: ${{ needs.check.outputs.tag }}
|
|
||||||
FW_VER: ${{ needs.check.outputs.fw_ver }}
|
|
||||||
FW_DATE: ${{ needs.check.outputs.fw_date }}
|
|
||||||
run: |
|
|
||||||
NAME="$TAG"
|
|
||||||
DESC="OpenWrt $FW_VER [$FW_DATE]"
|
|
||||||
if [ "$TRX_BUILD" = true ]; then
|
|
||||||
NAME="TRX-$TAG"
|
|
||||||
TAG="$TAG-trx"
|
|
||||||
DESC="TRX images based on $DESC"
|
|
||||||
fi
|
|
||||||
echo "REL_TAG=$TAG" >> $GITHUB_ENV
|
|
||||||
echo "REL_NAME=$NAME" >> $GITHUB_ENV
|
|
||||||
echo "REL_DESC=$DESC" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
- name: Upload assets
|
- name: Upload assets
|
||||||
uses: softprops/action-gh-release@v2
|
uses: andelf/nightly-release@main
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
TAG: ${{ needs.check.outputs.tag }}
|
||||||
with:
|
with:
|
||||||
draft: ${{ env.TEST_BUILD == 'true' || github.event.inputs.fake_build == 'true' }}
|
prerelease: ${{ env.TEST_BUILD == 'true' || env.FAKE_BUILD == 'true' }}
|
||||||
prerelease: true
|
tag_name: ${{ needs.check.outputs.tag }}${{ env.TAG_SUFFIX }}
|
||||||
tag_name: ${{ env.REL_TAG }}${{ env.TAG_SUFFIX }}
|
name: '${{ needs.check.outputs.tag }}'
|
||||||
name: '${{ env.REL_NAME }}'
|
|
||||||
body: |
|
body: |
|
||||||
${{ env.REL_DESC }}
|
OpenWrt ${{ needs.check.outputs.fw_ver }} [${{ needs.check.outputs.fw_date }}]
|
||||||
author: [remittor](https://github.com/remittor)
|
author: [remittor](https://github.com/remittor)
|
||||||
files: ./public/*.zip
|
files: ./public/*.zip
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
[](https://github.com/openwrt-xiaomi/builder/releases)
|
[](https://github.com/openwrt-xiaomi/builder/releases)
|
||||||
[](https://github.com/openwrt-xiaomi/builder/releases)
|
|
||||||
[](https://github.com/openwrt-xiaomi/builder/releases)
|
[](https://github.com/openwrt-xiaomi/builder/releases)
|
||||||
|
[](https://github.com/openwrt-xiaomi/builder/releases)
|
||||||
[](https://github.com/remittor/donate)
|
[](https://github.com/remittor/donate)
|
||||||
|
|
||||||
# OpenWrt builder
|
# OpenWrt builder
|
||||||
|
|||||||
@@ -45,8 +45,6 @@ CONFIG_PACKAGE_luci-app-filemanager=y
|
|||||||
CONFIG_PACKAGE_luci-i18n-filemanager-ru=y
|
CONFIG_PACKAGE_luci-i18n-filemanager-ru=y
|
||||||
#CONFIG_PACKAGE_atftp=y
|
#CONFIG_PACKAGE_atftp=y
|
||||||
#CONFIG_PACKAGE_atftpd=y
|
#CONFIG_PACKAGE_atftpd=y
|
||||||
CONFIG_PACKAGE_lscpu=y
|
|
||||||
CONFIG_PACKAGE_bind-tools=y
|
|
||||||
CONFIG_PACKAGE_facinstall=y
|
CONFIG_PACKAGE_facinstall=y
|
||||||
|
|
||||||
### Add-on programs
|
### Add-on programs
|
||||||
@@ -123,7 +121,6 @@ CONFIG_PACKAGE_relayd=y
|
|||||||
CONFIG_PACKAGE_luci-proto-relay=y
|
CONFIG_PACKAGE_luci-proto-relay=y
|
||||||
|
|
||||||
### Luci proto
|
### Luci proto
|
||||||
CONFIG_PACKAGE_luci-proto-gre=y
|
|
||||||
CONFIG_PACKAGE_luci-proto-3g=y
|
CONFIG_PACKAGE_luci-proto-3g=y
|
||||||
CONFIG_PACKAGE_luci-proto-ipv6=y
|
CONFIG_PACKAGE_luci-proto-ipv6=y
|
||||||
|
|
||||||
@@ -189,7 +186,6 @@ CONFIG_OPENSSL_WITH_MDC2=y
|
|||||||
CONFIG_OPENSSL_WITH_WHIRLPOOL=y
|
CONFIG_OPENSSL_WITH_WHIRLPOOL=y
|
||||||
|
|
||||||
### SSL certificates
|
### SSL certificates
|
||||||
CONFIG_PACKAGE_ca-bundle=y
|
|
||||||
CONFIG_PACKAGE_ca-certificates=y
|
CONFIG_PACKAGE_ca-certificates=y
|
||||||
|
|
||||||
### Luci
|
### Luci
|
||||||
@@ -37,14 +37,12 @@ CONFIG_PACKAGE_uboot-envtools=y
|
|||||||
CONFIG_PACKAGE_mtd-utils=y
|
CONFIG_PACKAGE_mtd-utils=y
|
||||||
CONFIG_PACKAGE_iw=y
|
CONFIG_PACKAGE_iw=y
|
||||||
CONFIG_PACKAGE_mc=y
|
CONFIG_PACKAGE_mc=y
|
||||||
CONFIG_PACKAGE_rsync=y
|
|
||||||
CONFIG_PACKAGE_luci-app-ttyd=y
|
CONFIG_PACKAGE_luci-app-ttyd=y
|
||||||
CONFIG_PACKAGE_luci-i18n-ttyd-ru=y
|
CONFIG_PACKAGE_luci-i18n-ttyd-ru=y
|
||||||
CONFIG_PACKAGE_luci-app-filemanager=y
|
CONFIG_PACKAGE_luci-app-filemanager=y
|
||||||
CONFIG_PACKAGE_luci-i18n-filemanager-ru=y
|
CONFIG_PACKAGE_luci-i18n-filemanager-ru=y
|
||||||
CONFIG_PACKAGE_atftp=y
|
CONFIG_PACKAGE_atftp=y
|
||||||
#CONFIG_PACKAGE_atftpd=y
|
#CONFIG_PACKAGE_atftpd=y
|
||||||
CONFIG_PACKAGE_lscpu=y
|
|
||||||
CONFIG_PACKAGE_facinstall=y
|
CONFIG_PACKAGE_facinstall=y
|
||||||
|
|
||||||
CONFIG_PACKAGE_kmod-mtd-rw=y
|
CONFIG_PACKAGE_kmod-mtd-rw=y
|
||||||
@@ -57,7 +55,6 @@ CONFIG_PACKAGE_iperf3=y
|
|||||||
CONFIG_PACKAGE_htop=y
|
CONFIG_PACKAGE_htop=y
|
||||||
CONFIG_PACKAGE_nano=y
|
CONFIG_PACKAGE_nano=y
|
||||||
CONFIG_PACKAGE_ccrypt=y
|
CONFIG_PACKAGE_ccrypt=y
|
||||||
CONFIG_PACKAGE_curl=y
|
|
||||||
CONFIG_PACKAGE_wget=y
|
CONFIG_PACKAGE_wget=y
|
||||||
CONFIG_PACKAGE_patch=y
|
CONFIG_PACKAGE_patch=y
|
||||||
CONFIG_PACKAGE_diffutils=y
|
CONFIG_PACKAGE_diffutils=y
|
||||||
@@ -67,10 +64,6 @@ CONFIG_PACKAGE_terminfo=y
|
|||||||
CONFIG_PACKAGE_zlib=y
|
CONFIG_PACKAGE_zlib=y
|
||||||
CONFIG_PACKAGE_ethtool=y
|
CONFIG_PACKAGE_ethtool=y
|
||||||
|
|
||||||
### SSL certificates
|
|
||||||
CONFIG_PACKAGE_ca-bundle=y
|
|
||||||
CONFIG_PACKAGE_ca-certificates=y
|
|
||||||
|
|
||||||
### Luci
|
### Luci
|
||||||
CONFIG_LUCI_LANG_en=y
|
CONFIG_LUCI_LANG_en=y
|
||||||
CONFIG_LUCI_LANG_ru=y
|
CONFIG_LUCI_LANG_ru=y
|
||||||
@@ -1,14 +0,0 @@
|
|||||||
CONFIG_TARGET_mediatek=y
|
|
||||||
CONFIG_TARGET_mediatek_filogic=y
|
|
||||||
CONFIG_TARGET_mediatek_filogic_DEVICE_asus_tuf-ax4200q=y
|
|
||||||
|
|
||||||
#include _addons.config
|
|
||||||
#include _base_initrd.config
|
|
||||||
#include _wifi_en.config
|
|
||||||
|
|
||||||
|
|
||||||
CONFIG_TARGET_INITRAMFS_FORCE=y
|
|
||||||
CONFIG_TARGET_ROOTFS_INITRAMFS=y
|
|
||||||
CONFIG_USES_SEPARATE_INITRAMFS=n
|
|
||||||
CONFIG_TARGET_ROOTFS_INITRAMFS_SEPARATE=n
|
|
||||||
|
|
||||||
@@ -9,7 +9,12 @@ CONFIG_PACKAGE_luci-i18n-https-dns-proxy-ru=y
|
|||||||
CONFIG_PACKAGE_igmpproxy=y
|
CONFIG_PACKAGE_igmpproxy=y
|
||||||
|
|
||||||
CONFIG_PACKAGE_zapret=y
|
CONFIG_PACKAGE_zapret=y
|
||||||
|
CONFIG_PACKAGE_zapret-tpws=y
|
||||||
|
CONFIG_PACKAGE_zapret-mdig=y
|
||||||
|
CONFIG_PACKAGE_zapret-ip2net=y
|
||||||
CONFIG_PACKAGE_luci-app-zapret=y
|
CONFIG_PACKAGE_luci-app-zapret=y
|
||||||
|
|
||||||
CONFIG_PACKAGE_zapret2=y
|
CONFIG_PACKAGE_zapret2=y
|
||||||
|
CONFIG_PACKAGE_zapret2-mdig=y
|
||||||
|
CONFIG_PACKAGE_zapret2-ip2net=y
|
||||||
CONFIG_PACKAGE_luci-app-zapret2=y
|
CONFIG_PACKAGE_luci-app-zapret2=y
|
||||||
@@ -1 +1 @@
|
|||||||
build-essential clang flex bison g++ gawk gcc-multilib g++-multilib gettext git libncurses5-dev libssl-dev python3-setuptools rsync swig unzip zlib1g-dev file wget
|
build-essential libc6-dev clang flex bison g++ gawk gcc-multilib g++-multilib gettext git libncurses5-dev libssl-dev python3-setuptools rsync swig unzip zlib1g-dev file wget
|
||||||
@@ -16,6 +16,7 @@ CONFIG_TARGET_ipq806x_generic_DEVICE_xiaomi_r3d=y
|
|||||||
|
|
||||||
### Temp and sensors
|
### Temp and sensors
|
||||||
CONFIG_PACKAGE_lm-sensors=y
|
CONFIG_PACKAGE_lm-sensors=y
|
||||||
|
CONFIG_PACKAGE_lm-sensors-detect=y
|
||||||
CONFIG_PACKAGE_alpine-fan-control=y
|
CONFIG_PACKAGE_alpine-fan-control=y
|
||||||
CONFIG_PACKAGE_luci-app-alpine-fan-control=y
|
CONFIG_PACKAGE_luci-app-alpine-fan-control=y
|
||||||
CONFIG_PACKAGE_luci-app-temp-status=y
|
CONFIG_PACKAGE_luci-app-temp-status=y
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ CONFIG_TARGET_mediatek_filogic_DEVICE_asus_rt-ax52=y
|
|||||||
|
|
||||||
### Temp and sensors
|
### Temp and sensors
|
||||||
CONFIG_PACKAGE_lm-sensors=y
|
CONFIG_PACKAGE_lm-sensors=y
|
||||||
|
CONFIG_PACKAGE_lm-sensors-detect=y
|
||||||
CONFIG_PACKAGE_luci-app-temp-status=y
|
CONFIG_PACKAGE_luci-app-temp-status=y
|
||||||
CONFIG_PACKAGE_luci-i18n-temp-status-ru=y
|
CONFIG_PACKAGE_luci-i18n-temp-status-ru=y
|
||||||
|
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ CONFIG_TARGET_mediatek_filogic_DEVICE_asus_rt-ax57m=y
|
|||||||
|
|
||||||
### Temp and sensors
|
### Temp and sensors
|
||||||
CONFIG_PACKAGE_lm-sensors=y
|
CONFIG_PACKAGE_lm-sensors=y
|
||||||
|
CONFIG_PACKAGE_lm-sensors-detect=y
|
||||||
CONFIG_PACKAGE_luci-app-temp-status=y
|
CONFIG_PACKAGE_luci-app-temp-status=y
|
||||||
CONFIG_PACKAGE_luci-i18n-temp-status-ru=y
|
CONFIG_PACKAGE_luci-i18n-temp-status-ru=y
|
||||||
|
|
||||||
|
|||||||
@@ -14,6 +14,7 @@ CONFIG_TARGET_mediatek_filogic_DEVICE_asus_rt-ax59u=y
|
|||||||
|
|
||||||
### Temp and sensors
|
### Temp and sensors
|
||||||
CONFIG_PACKAGE_lm-sensors=y
|
CONFIG_PACKAGE_lm-sensors=y
|
||||||
|
CONFIG_PACKAGE_lm-sensors-detect=y
|
||||||
CONFIG_PACKAGE_luci-app-temp-status=y
|
CONFIG_PACKAGE_luci-app-temp-status=y
|
||||||
CONFIG_PACKAGE_luci-i18n-temp-status-ru=y
|
CONFIG_PACKAGE_luci-i18n-temp-status-ru=y
|
||||||
CONFIG_PACKAGE_collectd-mod-sensors=y
|
CONFIG_PACKAGE_collectd-mod-sensors=y
|
||||||
|
|||||||
@@ -16,6 +16,7 @@ CONFIG_TARGET_qualcommax_ipq807x_DEVICE_asus_rt-ax89x=y
|
|||||||
|
|
||||||
### Temp and sensors
|
### Temp and sensors
|
||||||
CONFIG_PACKAGE_lm-sensors=y
|
CONFIG_PACKAGE_lm-sensors=y
|
||||||
|
CONFIG_PACKAGE_lm-sensors-detect=y
|
||||||
CONFIG_PACKAGE_luci-app-temp-status=y
|
CONFIG_PACKAGE_luci-app-temp-status=y
|
||||||
CONFIG_PACKAGE_luci-i18n-temp-status-ru=y
|
CONFIG_PACKAGE_luci-i18n-temp-status-ru=y
|
||||||
CONFIG_PACKAGE_collectd-mod-sensors=y
|
CONFIG_PACKAGE_collectd-mod-sensors=y
|
||||||
|
|||||||
@@ -1,43 +0,0 @@
|
|||||||
CONFIG_TARGET_mediatek=y
|
|
||||||
CONFIG_TARGET_mediatek_filogic=y
|
|
||||||
CONFIG_TARGET_mediatek_filogic_DEVICE_asus_tuf-ax4200q=y
|
|
||||||
|
|
||||||
#include _addons.config
|
|
||||||
#include _base.config
|
|
||||||
#include _wifi_en.config
|
|
||||||
#include _printer.config
|
|
||||||
#include _samba.config
|
|
||||||
#include _torrents.config
|
|
||||||
#include _proxy.config
|
|
||||||
#include _argon.config
|
|
||||||
#include _vpn.config
|
|
||||||
|
|
||||||
### Temp and sensors
|
|
||||||
CONFIG_PACKAGE_lm-sensors=y
|
|
||||||
CONFIG_PACKAGE_luci-app-temp-status=y
|
|
||||||
CONFIG_PACKAGE_luci-i18n-temp-status-ru=y
|
|
||||||
CONFIG_PACKAGE_collectd-mod-sensors=y
|
|
||||||
|
|
||||||
### HDD tools
|
|
||||||
CONFIG_PACKAGE_smartmontools=y
|
|
||||||
CONFIG_PACKAGE_hdparm=y
|
|
||||||
CONFIG_PACKAGE_hd-idle=y
|
|
||||||
CONFIG_PACKAGE_luci-app-hd-idle=y
|
|
||||||
#CONFIG_PACKAGE_luci-i18n-hd-idle-ru=y
|
|
||||||
CONFIG_PACKAGE_luci-app-disks-info=y
|
|
||||||
#CONFIG_PACKAGE_luci-i18n-disks-info-ru=y
|
|
||||||
CONFIG_PACKAGE_luci-app-diskman=y
|
|
||||||
|
|
||||||
### Luci dashboard
|
|
||||||
CONFIG_PACKAGE_luci-mod-dashboard=y
|
|
||||||
CONFIG_PACKAGE_luci-i18n-dashboard-ru=y
|
|
||||||
|
|
||||||
### Network Ports viewer
|
|
||||||
CONFIG_PACKAGE_luci-app-tn-netports=y
|
|
||||||
CONFIG_PACKAGE_luci-i18n-tn-netports-ru=y
|
|
||||||
|
|
||||||
### TimeControl
|
|
||||||
CONFIG_PACKAGE_luci-app-timecontrol=m
|
|
||||||
|
|
||||||
CONFIG_PACKAGE_fantastic-feeds=m
|
|
||||||
|
|
||||||
@@ -14,6 +14,7 @@ CONFIG_TARGET_mediatek_filogic_DEVICE_asus_tuf-ax4200=y
|
|||||||
|
|
||||||
### Temp and sensors
|
### Temp and sensors
|
||||||
CONFIG_PACKAGE_lm-sensors=y
|
CONFIG_PACKAGE_lm-sensors=y
|
||||||
|
CONFIG_PACKAGE_lm-sensors-detect=y
|
||||||
CONFIG_PACKAGE_luci-app-temp-status=y
|
CONFIG_PACKAGE_luci-app-temp-status=y
|
||||||
CONFIG_PACKAGE_luci-i18n-temp-status-ru=y
|
CONFIG_PACKAGE_luci-i18n-temp-status-ru=y
|
||||||
CONFIG_PACKAGE_collectd-mod-sensors=y
|
CONFIG_PACKAGE_collectd-mod-sensors=y
|
||||||
@@ -14,6 +14,7 @@ CONFIG_TARGET_mediatek_filogic_DEVICE_asus_tuf-ax6000=y
|
|||||||
|
|
||||||
### Temp and sensors
|
### Temp and sensors
|
||||||
CONFIG_PACKAGE_lm-sensors=y
|
CONFIG_PACKAGE_lm-sensors=y
|
||||||
|
CONFIG_PACKAGE_lm-sensors-detect=y
|
||||||
CONFIG_PACKAGE_luci-app-temp-status=y
|
CONFIG_PACKAGE_luci-app-temp-status=y
|
||||||
CONFIG_PACKAGE_luci-i18n-temp-status-ru=y
|
CONFIG_PACKAGE_luci-i18n-temp-status-ru=y
|
||||||
CONFIG_PACKAGE_collectd-mod-sensors=y
|
CONFIG_PACKAGE_collectd-mod-sensors=y
|
||||||
216
xmake.sh
216
xmake.sh
@@ -15,6 +15,7 @@ OPT_FULL_REBUILD=false
|
|||||||
KALLSYMS=false
|
KALLSYMS=false
|
||||||
TESTING_KERNEL=false
|
TESTING_KERNEL=false
|
||||||
BUILD_ONLY_INITRAMFS=false
|
BUILD_ONLY_INITRAMFS=false
|
||||||
|
BUILD_SKIP_INITRAMFS=false
|
||||||
ONLY_INIT=false
|
ONLY_INIT=false
|
||||||
|
|
||||||
while getopts "j:t:fiskTI" opt; do
|
while getopts "j:t:fiskTI" opt; do
|
||||||
@@ -25,6 +26,7 @@ while getopts "j:t:fiskTI" opt; do
|
|||||||
k) KALLSYMS=true;;
|
k) KALLSYMS=true;;
|
||||||
T) TESTING_KERNEL=true;;
|
T) TESTING_KERNEL=true;;
|
||||||
i) BUILD_ONLY_INITRAMFS=true;;
|
i) BUILD_ONLY_INITRAMFS=true;;
|
||||||
|
s) BUILD_SKIP_INITRAMFS=true;;
|
||||||
I) ONLY_INIT=true;;
|
I) ONLY_INIT=true;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
@@ -68,7 +70,7 @@ function build_target {
|
|||||||
fi
|
fi
|
||||||
inclst=$( get_cfg_inc_lst $CFG )
|
inclst=$( get_cfg_inc_lst $CFG )
|
||||||
for inc in $inclst; do
|
for inc in $inclst; do
|
||||||
incfn=$XDIR/_cfginc/$inc
|
incfn=$XDIR/$inc
|
||||||
[ ! -f $incfn ] && die "File '$inc' not found!"
|
[ ! -f $incfn ] && die "File '$inc' not found!"
|
||||||
sed -i "/#include $inc/a <<LF>><<LF>>" $CFG
|
sed -i "/#include $inc/a <<LF>><<LF>>" $CFG
|
||||||
sed -i "s/<<LF>>/\n/g" $CFG
|
sed -i "s/<<LF>>/\n/g" $CFG
|
||||||
@@ -101,74 +103,27 @@ function build_target {
|
|||||||
echo "CONFIG_TESTING_KERNEL=y" >> $CFG
|
echo "CONFIG_TESTING_KERNEL=y" >> $CFG
|
||||||
fi
|
fi
|
||||||
|
|
||||||
X_VERSION_MK=$XDIR/include/version.mk
|
|
||||||
X_VERSION_NUMBER=$( grep -o -P '(?<=,\$\(VERSION_NUMBER\),).*(?=\))' $X_VERSION_MK 2>/dev/null )
|
|
||||||
[ -z "$X_VERSION_NUMBER" ] && { echo "ERROR: Cannot determine VERSION_NUMBER"; exit 30; }
|
|
||||||
echo "VERSION_NUMBER = $X_VERSION_NUMBER"
|
|
||||||
|
|
||||||
X_BOARD_NAME=$( sed -n 's/^CONFIG_TARGET_\([^_=\n]\+\)=y$/\1/p' $CFG )
|
|
||||||
[ -z "$X_BOARD_NAME" ] && { echo "ERROR: cannot found BOARD_NAME"; exit 31; }
|
|
||||||
X_SUBTARGET_NAME=$( sed -n 's/^CONFIG_TARGET_[^_=\n]\+_\([^_=\n]\+\)=y$/\1/p' $CFG )
|
|
||||||
[ -z "$X_SUBTARGET_NAME" ] && { echo "ERROR: cannot found SUBTARGET"; exit 31; }
|
|
||||||
echo "BOARD_NAME = $X_BOARD_NAME SUBTARGET = $X_SUBTARGET_NAME"
|
|
||||||
|
|
||||||
VERMAGIC_FN=$XDIR/vermagic-$X_BOARD_NAME-$X_SUBTARGET_NAME-$X_VERSION_NUMBER.list
|
|
||||||
if [ ! -f $VERMAGIC_FN -a -f $XDIR/vermagic_update.sh ]; then
|
|
||||||
bash $XDIR/vermagic_update.sh $X_BOARD_NAME $X_SUBTARGET_NAME
|
|
||||||
if [ ! -f $VERMAGIC_FN ]; then
|
|
||||||
echo "ERROR: cannot create file $VERMAGIC_FN"
|
|
||||||
exit 41
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ 1 = 1 ]; then
|
if [ 1 = 1 ]; then
|
||||||
MK_IMAGE=$XDIR/include/image.mk
|
|
||||||
CURDATE=$( date --utc +%y%m%d )
|
CURDATE=$( date --utc +%y%m%d )
|
||||||
if ! grep -q "(VERSION_NUMBER))-$CURDATE" $MK_IMAGE ; then
|
############ change images prefix ############
|
||||||
############ change images prefix ############
|
# IMG_PREFIX:=$(VERSION_DIST_SANITIZED)-$(IMG_PREFIX_VERNUM)$(IMG_PREFIX_VERCODE)$(IMG_PREFIX_EXTRA)$(BOARD)$(if $(SUBTARGET),-$(SUBTARGET))
|
||||||
# IMG_PREFIX:=$(VERSION_DIST_SANITIZED)-$(IMG_PREFIX_VERNUM)$(IMG_PREFIX_VERCODE)$(IMG_PREFIX_EXTRA)$(BOARD)$(if $(SUBTARGET),-$(SUBTARGET))
|
sed -i -e 's/^IMG_PREFIX:=.*/IMG_PREFIX:=$(VERSION_DIST_SANITIZED)-$(call sanitize,$(VERSION_NUMBER))-'$CURDATE'/g' $XDIR/include/image.mk
|
||||||
sed -i -e 's/^IMG_PREFIX:=.*/IMG_PREFIX:=$(VERSION_DIST_SANITIZED)-$(call sanitize,$(VERSION_NUMBER))-'$CURDATE'/g' $MK_IMAGE
|
|
||||||
echo ">>> image.mk patched !!! (IMG_PREFIX)"
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
if [ 1 = 1 ]; then
|
if [ 1 = 1 ]; then
|
||||||
############ remove "squashfs" suffix ############
|
############ remove "squashfs" suffix ############
|
||||||
MK_IMAGE=$XDIR/include/image.mk
|
# DEVICE_IMG_NAME = $$(DEVICE_IMG_PREFIX)-$$(1)-$$(2)
|
||||||
if grep -q 'DEVICE_IMG_NAME = $$(DEVICE_IMG_PREFIX)-$$(1)-$$(2)' $MK_IMAGE ; then
|
sed -i -e 's/.*DEVICE_IMG_NAME =.*/ DEVICE_IMG_NAME = $$(DEVICE_IMG_PREFIX)-$$(2)/g' $XDIR/include/image.mk
|
||||||
sed -i -e 's/.*DEVICE_IMG_NAME =.*/ DEVICE_IMG_NAME = $$(DEVICE_IMG_PREFIX)-$$(2)/g' $MK_IMAGE
|
if grep "squashfs-sys" $XDIR/target/linux/mediatek/image/filogic.mk >/dev/null ; then
|
||||||
echo ">>> image.mk patched !!! (DEVICE_IMG_NAME)"
|
|
||||||
fi
|
|
||||||
if grep -q "squashfs-sys" $XDIR/target/linux/mediatek/image/filogic.mk ; then
|
|
||||||
sed -i 's/ squashfs-sys/ sys/g' $XDIR/target/linux/mediatek/image/filogic.mk
|
sed -i 's/ squashfs-sys/ sys/g' $XDIR/target/linux/mediatek/image/filogic.mk
|
||||||
sed -i 's/ squashfs-sys/ sys/g' $XDIR/target/linux/mediatek/image/mt7622.mk
|
sed -i 's/ squashfs-sys/ sys/g' $XDIR/target/linux/mediatek/image/mt7622.mk
|
||||||
sed -i 's/ squashfs-sys/ sys/g' $XDIR/target/linux/mediatek/image/mt7623.mk
|
sed -i 's/ squashfs-sys/ sys/g' $XDIR/target/linux/mediatek/image/mt7623.mk
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if ! grep '^CONFIG_BUILD_ALL_HOST_TOOLS=y' $CFG ; then
|
AWG_LUCI_MK=$XDIR/package/feeds/_ruantiblock/luci-app-ruantiblock/Makefile
|
||||||
MK_HOST_TOOLS=$XDIR/tools/Makefile
|
if [ -f $AWG_LUCI_MK ]; then
|
||||||
# tools-$(if $(CONFIG_BUILD_ALL_HOST_TOOLS)$(CONFIG_USES_MINOR),y) += yafut
|
if ! grep "PKG_PROVIDES" $AWG_LUCI_MK >/dev/null ; then
|
||||||
if grep -q '(CONFIG_USES_MINOR),y)' $MK_HOST_TOOLS ; then
|
sed -i 's/LUCI_PKGARCH:=all/LUCI_PKGARCH:=all\nPKG_PROVIDES:=luci-app-ruantiblock/g' $AWG_LUCI_MK
|
||||||
# disable build yafut - not support devices with yaffs !!!
|
|
||||||
sed -i 's/\$(CONFIG_USES_MINOR),y)/,y)/g' $MK_HOST_TOOLS
|
|
||||||
echo ">>> tools/Makefile patched !!! (disable yafut)"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
BATADV_DIR=$XDIR/feeds/luci/protocols/luci-proto-batman-adv/htdocs/luci-static/resources/protocol
|
|
||||||
if [ -d $BATADV_DIR ]; then
|
|
||||||
if [ ! -f $BATADV_DIR/batadv_vlan.js ]; then
|
|
||||||
BATADV_VLAN_URL="https://github.com/luminem/luci/raw/4e0612a45e4be8c58de2bbd21c3bffbcf5252be4/protocols/luci-proto-batman-adv/htdocs/luci-static/resources/protocol/batadv_vlan.js"
|
|
||||||
curl -sSL "$BATADV_VLAN_URL" -o "$BATADV_DIR/batadv_vlan.js"
|
|
||||||
echo ">>> batman_adv patched !!!"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
RAB_LUCI_MK=$XDIR/package/feeds/_ruantiblock/luci-app-ruantiblock/Makefile
|
|
||||||
if [ -f $RAB_LUCI_MK ]; then
|
|
||||||
if ! grep "PKG_PROVIDES" $RAB_LUCI_MK >/dev/null ; then
|
|
||||||
sed -i 's/LUCI_PKGARCH:=all/LUCI_PKGARCH:=all\nPKG_PROVIDES:=luci-app-ruantiblock/g' $RAB_LUCI_MK
|
|
||||||
echo ">>> ruantiblock patched !!!"
|
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -179,42 +134,38 @@ function build_target {
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
PODKOP_DIR=$XDIR/package/feeds/_podkop
|
PODKOP_MK=$XDIR/package/feeds/_podkop/podkop/Makefile
|
||||||
if [ -d $PODKOP_DIR ]; then
|
if [ -f $PODKOP_MK ]; then
|
||||||
PODKOP_PATCH=
|
sed -i 's/+sing-box / /g' $PODKOP_MK
|
||||||
PODKOP_MK=$PODKOP_DIR/podkop/Makefile
|
sed -i 's/CONFLICTS:=.*/CONFLICTS:=/g' $PODKOP_MK
|
||||||
if [ -f $PODKOP_MK ] && grep -q '+sing-box' $PODKOP_MK ; then
|
fi
|
||||||
sed -i 's/+sing-box / /g' $PODKOP_MK
|
PODKOP_SH=$XDIR/package/feeds/_podkop/podkop/files/usr/bin/podkop
|
||||||
sed -i 's/CONFLICTS:=.*/CONFLICTS:=/g' $PODKOP_MK
|
if [ -f $PODKOP_SH ] && ! grep -q '(which sing-box)' $PODKOP_SH ; then
|
||||||
PODKOP_PATCH="$PODKOP_PATCH (del depend sing-box)"
|
sed -i '/,\\"dns_configured\\":/i [ -z "$(which sing-box)" ] && status="not installed"' $PODKOP_SH
|
||||||
fi
|
|
||||||
PODKOP_SH=$PODKOP_DIR/podkop/files/usr/bin/podkop
|
|
||||||
if [ -f $PODKOP_SH ] && ! grep -q '(which sing-box)' $PODKOP_SH ; then
|
|
||||||
sed -i '/,\\"dns_configured\\":/i [ -z "$(which sing-box)" ] && status="not installed"' $PODKOP_SH
|
|
||||||
PODKOP_PATCH="$PODKOP_PATCH (status for sing-box)"
|
|
||||||
fi
|
|
||||||
if [ -f $PODKOP_MK ] && grep -q 'PODKOP_VERSION' $PODKOP_MK ; then
|
|
||||||
PKGVERLIST=$( git ls-remote --tags https://github.com/itdoginfo/podkop.git | awk -F/ '{print $3}' | grep -Ev '^v' | sort -V | tail -n 2 )
|
|
||||||
VER_PREV=$( sed -n '1p' <<< "$PKGVERLIST" )
|
|
||||||
VER_LATEST=$( sed -n '2p' <<< "$PKGVERLIST" )
|
|
||||||
[ -z "$VER_LATEST" ] && { echo "ERROR: cannot detect version of podkop!"; exit 1; }
|
|
||||||
sed -i 's/PKG_VERSION :=.*/PKG_VERSION:='$VER_LATEST'/g' $PODKOP_MK
|
|
||||||
PODKOP_PATCH="$PODKOP_PATCH (set ver $VER_LATEST)"
|
|
||||||
fi
|
|
||||||
PODKOP_MK=$PODKOP_DIR/luci-app-podkop/Makefile
|
|
||||||
if [ -f $PODKOP_MK ] && grep -q 'PODKOP_VERSION' $PODKOP_MK ; then
|
|
||||||
PKGVERLIST=$( git ls-remote --tags https://github.com/itdoginfo/podkop.git | awk -F/ '{print $3}' | grep -Ev '^v' | sort -V | tail -n 2 )
|
|
||||||
VER_PREV=$( sed -n '1p' <<< "$PKGVERLIST" )
|
|
||||||
VER_LATEST=$( sed -n '2p' <<< "$PKGVERLIST" )
|
|
||||||
[ -z "$VER_LATEST" ] && { echo "ERROR: cannot detect version of podkop!"; exit 1; }
|
|
||||||
sed -i 's/PKG_VERSION :=.*/PKG_VERSION:='$VER_LATEST'/g' $PODKOP_MK
|
|
||||||
PODKOP_PATCH="$PODKOP_PATCH (Set Ver $VER_LATEST)"
|
|
||||||
fi
|
|
||||||
[ "$PODKOP_PATCH" != "" ] && echo ">>> podkop patched !!! $PODKOP_PATCH"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
DROPBEAR_MK=$XDIR/package/network/services/dropbear/Makefile
|
DROPBEAR_DIR=$XDIR/package/network/services/dropbear
|
||||||
|
TMP_DROPBEAR_DIR=$XDIR/_dropbear2024
|
||||||
if [ -f $DROPBEAR_MK ]; then
|
if [ -f $DROPBEAR_MK ]; then
|
||||||
|
# download dropbear 2024.86 (OpenWrt v24.10)
|
||||||
|
if [ ! -f $TMP_DROPBEAR_DIR/Makefile ]; then
|
||||||
|
rm -rf $TMP_DROPBEAR_DIR
|
||||||
|
git clone --depth 1 --filter=blob:none --sparse https://github.com/openwrt/openwrt.git $TMP_DROPBEAR_DIR && (
|
||||||
|
cd $TMP_DROPBEAR_DIR
|
||||||
|
git sparse-checkout set package/network/services/dropbear
|
||||||
|
git checkout a2f0cd35ac1d15e69f4897b35c049e175dd06825 # commit 2024-12-12 https://github.com/openwrt/openwrt/commits/openwrt-25.12/package/network/services/dropbear
|
||||||
|
mv package/network/services/dropbear/* .
|
||||||
|
)
|
||||||
|
rm -rf $TMP_DROPBEAR_DIR/package
|
||||||
|
rm -rf $TMP_DROPBEAR_DIR/.git
|
||||||
|
fi
|
||||||
|
rm -rf $DROPBEAR_DIR/files
|
||||||
|
rm -rf $DROPBEAR_DIR/patches
|
||||||
|
fi
|
||||||
|
DROPBEAR_MK=$DROPBEAR_DIR/Makefile
|
||||||
|
if [ -f $DROPBEAR_MK ]; then
|
||||||
|
# downgrade dropbear to 2024.86 (OpenWrt v24.10)
|
||||||
|
cp -a $TMP_DROPBEAR_DIR/. $DROPBEAR_DIR/
|
||||||
# patch: Disable MODERN and enable RSA/DH-SHA1
|
# patch: Disable MODERN and enable RSA/DH-SHA1
|
||||||
sed -i 's/^PKG_RELEASE:=.*/PKG_RELEASE:=0/g' $DROPBEAR_MK
|
sed -i 's/^PKG_RELEASE:=.*/PKG_RELEASE:=0/g' $DROPBEAR_MK
|
||||||
sed -i '/,CONFIG_DROPBEAR_MODERN_ONLY,/d' $DROPBEAR_MK
|
sed -i '/,CONFIG_DROPBEAR_MODERN_ONLY,/d' $DROPBEAR_MK
|
||||||
@@ -222,19 +173,9 @@ function build_target {
|
|||||||
sed -i 's/ CONFIG_DROPBEAR_MODERN_ONLY/ /g' $DROPBEAR_MK
|
sed -i 's/ CONFIG_DROPBEAR_MODERN_ONLY/ /g' $DROPBEAR_MK
|
||||||
sed -i 's/DROPBEAR_DH_GROUP14_SHA1,0/ /g' $DROPBEAR_MK
|
sed -i 's/DROPBEAR_DH_GROUP14_SHA1,0/ /g' $DROPBEAR_MK
|
||||||
sed -i 's/DROPBEAR_SHA1_HMAC,0/ /g' $DROPBEAR_MK
|
sed -i 's/DROPBEAR_SHA1_HMAC,0/ /g' $DROPBEAR_MK
|
||||||
echo ">>> dropbear patched !!! (disable MODERN_ONLY)"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
HOST_TOOLS_DIR=$XDIR/staging_dir/host
|
|
||||||
HOST_TOOLS_STAGE=0
|
|
||||||
[ -d $HOST_TOOLS_DIR ] && HOST_TOOLS_STAGE=1
|
|
||||||
|
|
||||||
make defconfig
|
make defconfig
|
||||||
|
|
||||||
if [ -d $HOST_TOOLS_DIR -a $HOST_TOOLS_STAGE = 0 ]; then
|
|
||||||
ls -la $HOST_TOOLS_DIR/bin | awk '{print $9 " -> " $11}' | sort > $HOST_TOOLS_DIR/.prereq-build-list
|
|
||||||
#cat $HOST_TOOLS_DIR/.prereq-build-list | cksum | awk '{print $1}' > $HOST_TOOLS_DIR/.prereq-build-list.crc
|
|
||||||
fi
|
|
||||||
|
|
||||||
NSS_DRV_PPPOE_ENABLE=$( get_cfg_opt_flag $CFG NSS_DRV_PPPOE_ENABLE )
|
NSS_DRV_PPPOE_ENABLE=$( get_cfg_opt_flag $CFG NSS_DRV_PPPOE_ENABLE )
|
||||||
if [ "$NSS_DRV_PPPOE_ENABLE" = y ]; then
|
if [ "$NSS_DRV_PPPOE_ENABLE" = y ]; then
|
||||||
@@ -269,10 +210,7 @@ function build_target {
|
|||||||
echo -e "\nCONFIG_PACKAGE_wpad-openssl=y\n" >> $CFG
|
echo -e "\nCONFIG_PACKAGE_wpad-openssl=y\n" >> $CFG
|
||||||
fi
|
fi
|
||||||
|
|
||||||
DASHBRDPO=$XDIR/feeds/luci/modules/luci-mod-dashboard/po/ru/dashboard.po
|
#DASHBRDPO=$XDIR/feeds/luci/modules/luci-mod-dashboard/po/ru/dashboard.po
|
||||||
if [ -f $DASHBRDPO ]; then
|
|
||||||
sed -i 's/msgid "Dashboard"/msgid "__dash_board__"/g' $DASHBRDPO
|
|
||||||
fi
|
|
||||||
DASHBRDPO=$XDIR/package/feeds/luci/luci-mod-dashboard/po/ru/dashboard.po
|
DASHBRDPO=$XDIR/package/feeds/luci/luci-mod-dashboard/po/ru/dashboard.po
|
||||||
if [ -f $DASHBRDPO ]; then
|
if [ -f $DASHBRDPO ]; then
|
||||||
sed -i 's/msgid "Dashboard"/msgid "__dash_board__"/g' $DASHBRDPO
|
sed -i 's/msgid "Dashboard"/msgid "__dash_board__"/g' $DASHBRDPO
|
||||||
@@ -363,13 +301,10 @@ function build_target {
|
|||||||
echo "src/gz fantastic_packages_special $PKG_LINK/special" >> $OPKG_CFEED_FN
|
echo "src/gz fantastic_packages_special $PKG_LINK/special" >> $OPKG_CFEED_FN
|
||||||
TARGET_ARCH_PACKAGES=$( get_cfg_opt_value $CFG TARGET_ARCH_PACKAGES )
|
TARGET_ARCH_PACKAGES=$( get_cfg_opt_value $CFG TARGET_ARCH_PACKAGES )
|
||||||
[ -z "$TARGET_ARCH_PACKAGES" ] && die "Cannot find TARGET ARCH"
|
[ -z "$TARGET_ARCH_PACKAGES" ] && die "Cannot find TARGET ARCH"
|
||||||
sed -i "s/<<VER>>/24.10/g" $OPKG_CFEED_FN
|
sed -i "s/<<VER>>/25.12/g" $OPKG_CFEED_FN
|
||||||
sed -i "s/<<ARCH>>/$TARGET_ARCH_PACKAGES/g" $OPKG_CFEED_FN
|
sed -i "s/<<ARCH>>/$TARGET_ARCH_PACKAGES/g" $OPKG_CFEED_FN
|
||||||
logmsg "Added support of Fantastic packages [https://fantastic-packages.github.io/packages]"
|
logmsg "Added support of Fantastic packages [https://fantastic-packages.github.io/packages]"
|
||||||
fi
|
fi
|
||||||
if [ $BUILD_ONLY_INITRAMFS = true ]; then
|
|
||||||
rm -f $OPKG_DIR/customfeeds.conf
|
|
||||||
fi
|
|
||||||
|
|
||||||
SYSCTLCONF_FN=$XDIR/files/etc/sysctl.conf
|
SYSCTLCONF_FN=$XDIR/files/etc/sysctl.conf
|
||||||
if [ -f $SYSCTLCONF_FN ]; then
|
if [ -f $SYSCTLCONF_FN ]; then
|
||||||
@@ -387,6 +322,8 @@ function build_target {
|
|||||||
make_jobs=$( grep processor /proc/cpuinfo | tail -n 1 | awk '{print $3}' )
|
make_jobs=$( grep processor /proc/cpuinfo | tail -n 1 | awk '{print $3}' )
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
cp -af $XDIR/.config $XDIR/tmp/.config
|
||||||
|
|
||||||
#make tools/install -j$make_jobs
|
#make tools/install -j$make_jobs
|
||||||
#make toolchain/install -j$make_jobs
|
#make toolchain/install -j$make_jobs
|
||||||
|
|
||||||
@@ -399,19 +336,13 @@ function build_config {
|
|||||||
local cfg=$1
|
local cfg=$1
|
||||||
local cfg_name=$( basename $cfg )
|
local cfg_name=$( basename $cfg )
|
||||||
local target_name=${cfg_name%.*}
|
local target_name=${cfg_name%.*}
|
||||||
local initramfs=false
|
|
||||||
local board=$( get_cfg_board $cfg )
|
local board=$( get_cfg_board $cfg )
|
||||||
local subtarget=$( get_cfg_subtarget $cfg $board )
|
local subtarget=$( get_cfg_subtarget $cfg $board )
|
||||||
local device=$( get_cfg_dev_lst $cfg $board $subtarget )
|
local device=$( get_cfg_dev_lst $cfg $board $subtarget )
|
||||||
local outdir=$XDIR/bin/targets/$board/$subtarget
|
local outdir=$XDIR/bin/targets/$board/$subtarget
|
||||||
|
echo Start build for target $cfg_name "($board-$subtarget-$device)"
|
||||||
if echo "$cfg" | grep -q '_initramfs/' ; then
|
|
||||||
initramfs=true
|
build_target $cfg_name
|
||||||
target_name=${target_name}_initramfs
|
|
||||||
fi
|
|
||||||
echo Start build for target $target_name "($board-$subtarget-$device)"
|
|
||||||
|
|
||||||
build_target $cfg
|
|
||||||
|
|
||||||
if [ ! -f $outdir/kernel-debug.tar.zst ]; then
|
if [ ! -f $outdir/kernel-debug.tar.zst ]; then
|
||||||
echo "ERROR: cannot build images for target $target_name"
|
echo "ERROR: cannot build images for target $target_name"
|
||||||
@@ -426,9 +357,6 @@ function build_config {
|
|||||||
|
|
||||||
if [ "$XTARGET" != "*" ]; then
|
if [ "$XTARGET" != "*" ]; then
|
||||||
TARGETCFG=$XDIR/$XTARGET
|
TARGETCFG=$XDIR/$XTARGET
|
||||||
if [ $BUILD_ONLY_INITRAMFS = true ]; then
|
|
||||||
TARGETCFG=$XDIR/_initramfs/$XTARGET
|
|
||||||
fi
|
|
||||||
XTARGET_EXT="${XTARGET##*.}"
|
XTARGET_EXT="${XTARGET##*.}"
|
||||||
[ $XTARGET_EXT != config ] && TARGETCFG=$TARGETCFG.config
|
[ $XTARGET_EXT != config ] && TARGETCFG=$TARGETCFG.config
|
||||||
[ ! -f $TARGETCFG ] && die "File '"`basename $TARGETCFG`"' not found!"
|
[ ! -f $TARGETCFG ] && die "File '"`basename $TARGETCFG`"' not found!"
|
||||||
@@ -440,12 +368,7 @@ if [ "$XTARGET" != "*" ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
XOUT=$XDIR/xout
|
XOUT=$XDIR/xout
|
||||||
|
CFG_LIST=$( find $XDIR/* -maxdepth 1 -name '[a-z0-9]*.config' )
|
||||||
if [ $BUILD_ONLY_INITRAMFS = true ]; then
|
|
||||||
CFG_LIST=$( find $XDIR/_initramfs/* -maxdepth 1 -name '[a-z0-9]*.config' )
|
|
||||||
else
|
|
||||||
CFG_LIST=$( find $XDIR/* -maxdepth 1 -name '[a-z0-9]*.config' )
|
|
||||||
fi
|
|
||||||
|
|
||||||
rm -rf $XOUT
|
rm -rf $XOUT
|
||||||
|
|
||||||
@@ -454,16 +377,35 @@ if [ -z "$CFG_LIST" ]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ $BUILD_ONLY_INITRAMFS = true ]; then
|
INITRAMFS_COUNT=0
|
||||||
echo "Start make initramfs configs!"
|
|
||||||
else
|
|
||||||
echo "Start make non initramfs configs!"
|
|
||||||
fi
|
|
||||||
|
|
||||||
clean_all
|
|
||||||
|
|
||||||
for CFG in $CFG_LIST; do
|
for CFG in $CFG_LIST; do
|
||||||
build_config $CFG
|
if [[ "$CFG" == *"_initramfs"* ]]; then
|
||||||
|
INITRAMFS_COUNT=$(( INITRAMFS_COUNT + 1 ))
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
|
if [ $INITRAMFS_COUNT = 0 ] && [ $BUILD_ONLY_INITRAMFS = true ]; then
|
||||||
|
echo "ERROR: Cannot found initramfs configs!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $INITRAMFS_COUNT -gt 0 ] && [ $BUILD_SKIP_INITRAMFS != true ]; then
|
||||||
|
echo "Start make initramfs configs!"
|
||||||
|
clean_all
|
||||||
|
for CFG in $CFG_LIST; do
|
||||||
|
[[ "$CFG" != *"_initramfs"* ]] && continue # process only initramfs configs
|
||||||
|
build_config $CFG
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $BUILD_ONLY_INITRAMFS != true ]; then
|
||||||
|
echo "Start make non initramfs configs!"
|
||||||
|
clean_all
|
||||||
|
for CFG in $CFG_LIST; do
|
||||||
|
[[ "$CFG" == *"_initramfs"* ]] && continue # skip initramfs configs
|
||||||
|
build_config $CFG
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
echo "All targets was builded!"
|
echo "All targets was builded!"
|
||||||
|
|
||||||
|
|||||||
@@ -4,8 +4,8 @@ SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
|
|||||||
export XDIR=$SCRIPT_DIR
|
export XDIR=$SCRIPT_DIR
|
||||||
export XADDONSDIR=$XDIR/package/addons
|
export XADDONSDIR=$XDIR/package/addons
|
||||||
FEEDSDIR=$XDIR/package/feeds
|
FEEDSDIR=$XDIR/package/feeds
|
||||||
ADDONSCFG=$XDIR/_cfginc/_addons.config
|
ADDONSCFG=$XDIR/_addons.config
|
||||||
ADDONSNSS=$XDIR/_cfginc/_addons_nss.config
|
ADDONSNSS=$XDIR/_addons_nss.config
|
||||||
|
|
||||||
. ./xcommon.sh
|
. ./xcommon.sh
|
||||||
|
|
||||||
|
|||||||
@@ -16,6 +16,7 @@ CONFIG_TARGET_mediatek_filogic_DEVICE_asus_zenwifi-bt8=y
|
|||||||
|
|
||||||
### Temp and sensors
|
### Temp and sensors
|
||||||
CONFIG_PACKAGE_lm-sensors=y
|
CONFIG_PACKAGE_lm-sensors=y
|
||||||
|
CONFIG_PACKAGE_lm-sensors-detect=y
|
||||||
CONFIG_PACKAGE_luci-app-temp-status=y
|
CONFIG_PACKAGE_luci-app-temp-status=y
|
||||||
CONFIG_PACKAGE_luci-i18n-temp-status-ru=y
|
CONFIG_PACKAGE_luci-i18n-temp-status-ru=y
|
||||||
CONFIG_PACKAGE_collectd-mod-sensors=y
|
CONFIG_PACKAGE_collectd-mod-sensors=y
|
||||||
|
|||||||
Reference in New Issue
Block a user