View Chinese description | 查看中文说明
unifreq/openwrt_packit is an OpenWrt packaging script repository developed by Flippy
. It supports Allwinner (VPlus), Rockchip (BeikeYun, Chainedbox-L1-Pro, FastRhino-R66S/R68S, Radxa-5B/E25, Watermelon-pi, etc.), and Amlogic S9xxx series models such as S905x3, S905x2, S922x, S905x, S905d, S905, S912, etc.
This Actions uses his packaging scripts without any modification, only developed into a smart Action application, making the use of github Actions for packaging simpler and more personalized.
This Actions can be used by referencing it in the .github/workflows/*.yml
cloud compilation script, for example packaging-openwrt.yml. The code is as follows:
- name: Package OpenWrt Firmware
uses: ophub/flippy-openwrt-actions@main
env:
OPENWRT_ARMVIRT: openwrt/bin/targets/*/*/*.tar.gz
PACKAGE_SOC: all
KERNEL_VERSION_NAME: 6.1.1_5.15.1
KERNEL_AUTO_LATEST: true
Based on the latest kernel packaging scripts released by Flippy
, optional parameter configurations have been made for Packaging Files
, make.env
, Select Kernel Version
, Select Box SoC
, and so on.
Parameter | Default | Description |
---|---|---|
OPENWRT_ARMVIRT | None | Required. Set the file path for openwrt-armvirt-64-default-rootfs.tar.gz . You can use a relative path such as openwrt/bin/targets/*/*/*.tar.gz or a web file download link such as https://github.com/*/releases/*/*.tar.gz |
SCRIPT_REPO_URL | unifreq/openwrt_packit | Set <owner>/<repo> of the packaging script source repository |
SCRIPT_REPO_BRANCH | master | Set the branch of the packaging script source repository |
KERNEL_REPO_URL | breakings/OpenWrt | Set <owner>/<repo> of the kernel download repository, it downloads from the kernel Releases maintained by breakings by default. |
KERNEL_VERSION_NAME | 6.1.1_5.15.1 | Set the Kernel version, you can check and select a specific one. You can specify a single kernel such as 6.1.1 , or select multiple kernels connected with _ like 6.1.1_5.15.1 |
KERNEL_AUTO_LATEST | true | Set whether to automatically adopt the latest version kernel of the same series. When set to true , it will automatically look for whether there is an updated version of the kernel specified in KERNEL_VERSION_NAME , such as 6.1.1 , in the kernel library, and if there is an updated version, it will automatically replace it with the latest version. When set to false , it will compile the specified version kernel. |
PACKAGE_SOC | all | Set the SOC of the package box, the default is all to package all boxes, you can specify a single box like s905x3 , or select multiple boxes connected with _ like s905x3_s905d . The SoC codes for each box are: vplus , cm3 , jp-tvbox , beikeyun , l1pro , rock5b , r66s , r68s , e25 , photonicat , watermelon-pi , zcube1-max , ht2 , h28k , h66k , h68k , h69k , h69k-max , h88k , h88k-v3 , s905 , s905d , s905x2 , s905x3 , s912 , s922x , s922x-n2 , qemu , diy . Note: s922x-n2 is s922x-odroid-n2 , diy is a custom box. |
GZIP_IMGS | auto | Set the format of the file compression after packaging, optional values are .gz (default) / .xz / .zip / .zst / .7z |
SELECT_PACKITPATH | openwrt_packit | Set the name of the packaging directory under /opt |
SELECT_OUTPUTPATH | output | Set the name of the firmware output directory in the ${SELECT_PACKITPATH} directory |
SCRIPT_VPLUS | mk_h6_vplus.sh | Set the script filename for packaging h6 vplus |
SCRIPT_CM3 | mk_rk3566_radxa-cm3-rpi-cm4-io.sh | Set the script filename for packaging rk3566 radxa-cm3-rpi-cm4-io |
SCRIPT_HT2 | mk_rk3528_ht2.sh | Set the script filename for packaging rk3528 ht2 |
SCRIPT_H28K | mk_rk3528_h28k.sh | Set the script filename for packaging rk3528 h28k |
SCRIPT_H66K | mk_rk3568_h66k.sh | Set the script filename for packaging rk3568 h66k |
SCRIPT_H68K | mk_rk3568_h68k.sh | Set the script filename for packaging rk3568 h68k |
SCRIPT_H69K | mk_rk3568_h69k.sh | Set the script filename for packaging rk3568 h69k |
SCRIPT_H88K | mk_rk3588_h88k.sh | Set the script filename for packaging rk3588 h88k/ak88 |
SCRIPT_H88KV3 | mk_rk3588_h88k-v3.sh | Set the script filename for packaging rk3588 h88k-v3 |
SCRIPT_JPTVBOX | mk_rk3566_jp-tvbox.sh | Set the script filename for packaging rk3566 jp-tvbox |
SCRIPT_BEIKEYUN | mk_rk3328_beikeyun.sh | Set the script filename for packaging rk3328 beikeyun |
SCRIPT_L1PRO | mk_rk3328_l1pro.sh | Set the script filename for packaging rk3328 l1pro |
SCRIPT_ZCUBE1MAX | mk_rk3399_zcube1-max.sh | Set the script filename for packaging rk3399 zcube1-max |
SCRIPT_ROCK5B | mk_rk3588_rock5b.sh | Set the script filename for packaging rk3588 rock5b |
SCRIPT_R66S | mk_rk3568_r66s.sh | Set the script filename for packaging rk3568 r66s |
SCRIPT_R68S | mk_rk3568_r68s.sh | Set the script filename for packaging rk3568 r68s |
SCRIPT_E25 | mk_rk3568_e25.sh | Set the script filename for packaging rk3568 e25 |
SCRIPT_PHOTONICAT | mk_rk3568_photonicat.sh | Set the script filename for packaging rk3568 photonicat |
SCRIPT_WATERMELONPI | mk_rk3568_watermelon-pi.sh | Set the script filename for packaging rk3568 watermelon-pi |
SCRIPT_S905 | mk_s905_mxqpro+.sh | Set the script filename for packaging s905 mxqpro+ |
SCRIPT_S905D | mk_s905d_n1.sh | Set the script filename for packaging s905d n1 |
SCRIPT_S905X2 | mk_s905x2_x96max.sh | Set the script filename for packaging s905x2 x96max |
SCRIPT_S905X3 | mk_s905x3_multi.sh | Set the script filename for packaging s905x3 multi |
SCRIPT_S912 | mk_s912_zyxq.sh | Set the script filename for packaging s912 zyxq |
SCRIPT_S922X | mk_s922x_gtking.sh | Set the script filename for packaging s922x gtking |
SCRIPT_S922X_N2 | mk_s922x_odroid-n2.sh | Set the script filename for packaging s922x odroid-n2 |
SCRIPT_QEMU | mk_qemu-aarch64_img.sh | Set the script filename for packaging qemu |
SCRIPT_DIY | mk_diy.sh | Set the script filename for packaging diy custom |
SCRIPT_DIY_PATH | None | Set the source path for SCRIPT_DIY . It can be a URL like https://weburl/mydiyfile or a relative path in your repository like script/mk_s905w.sh |
WHOAMI | flippy | Set the value for WHOAMI in make.env |
OPENWRT_VER | auto | Set the value for OPENWRT_VER in make.env . By default, auto will inherit the value from the file. When set to other parameters, it will replace the original parameter with the custom parameter |
SW_FLOWOFFLOAD | 1 | Set the value for SW_FLOWOFFLOAD in make.env |
HW_FLOWOFFLOAD | 0 | Set the value for HW_FLOWOFFLOAD in make.env |
SFE_FLOW | 1 | Set the value for SFE_FLOW in make.env |
ENABLE_WIFI_K504 | 1 | Set the value for ENABLE_WIFI_K504 in make.env |
ENABLE_WIFI_K510 | 1 | Set the value for ENABLE_WIFI_K510 in make.env |
DISTRIB_REVISION | R$(date +%m.%d) | Set the value for DISTRIB_REVISION in make.env |
DISTRIB_DESCRIPTION | OpenWrt | Set the value for DISTRIB_DESCRIPTION in make.env |
💡 In general, using the default parameters is sufficient, but you can configure them according to your needs. For instance, if Flippy renames the packaging script making the original default script file unfindable, or if the firmware version number in make.env is not updated, you can use optional parameters for real-time specification and personalized configuration.
According to the standard of github.com, 3 environment variables have been output for use in subsequent compilation steps. Since github.com recently changed the settings of fork repositories, read-write permissions for Workflow are turned off by default. Therefore, ${{ secrets.GITHUB_TOKEN }}
and ${{ secrets.GH_TOKEN }}
need to be added to the repository and the Workflow read-write permissions
need to be set to upload to Releases
. For details, see User Manual.
Parameter | Default Value | Description |
---|---|---|
${{ env.PACKAGED_OUTPUTPATH }} | /opt/openwrt_packit/output | Path of the folder containing the packaged firmware |
${{ env.PACKAGED_OUTPUTDATE }} | 07.15.1058 | Packaging date |
${{ env.PACKAGED_STATUS }} | success / failure | Packaging status. Success / Failure |
The flippy-openwrt-actions © OPHUB is licensed under GPL-2.0