From f916fc19834cc3568eae8954001e9077779bf7f6 Mon Sep 17 00:00:00 2001 From: "Igor Zalatov (from Citadel PC)" Date: Sat, 25 Jun 2022 15:28:07 +0300 Subject: [PATCH] Update msc313e/msc316dc project --- .github/workflows/msc316dc_images.yml | 139 ++++++++++++++++++ .../infinity3/kernel/msc316dc.generic.config | 1 + .../unknown_unknown_msc313e_unknown/config | 10 ++ .../kernel/.gitkeep | 0 .../config | 2 +- .../kernel/.gitkeep | 0 ...unknown_unknown_msc316dc_openipc_defconfig | 99 +++++++++++++ building.sh | 6 + docs/index.md | 12 +- 9 files changed, 263 insertions(+), 6 deletions(-) create mode 100644 .github/workflows/msc316dc_images.yml create mode 120000 br-ext-chip-sigmastar/board/infinity3/kernel/msc316dc.generic.config create mode 100644 br-ext-chip-sigmastar/board/unknown_unknown_msc313e_unknown/config rename br-ext-chip-sigmastar/board/{unknown_unknown_ssc313e_unknown => unknown_unknown_msc313e_unknown}/kernel/.gitkeep (100%) rename br-ext-chip-sigmastar/board/{unknown_unknown_ssc313e_unknown => unknown_unknown_msc316dc_unknown}/config (90%) create mode 100644 br-ext-chip-sigmastar/board/unknown_unknown_msc316dc_unknown/kernel/.gitkeep create mode 100644 br-ext-chip-sigmastar/configs/unknown_unknown_msc316dc_openipc_defconfig diff --git a/.github/workflows/msc316dc_images.yml b/.github/workflows/msc316dc_images.yml new file mode 100644 index 00000000..f482d76c --- /dev/null +++ b/.github/workflows/msc316dc_images.yml @@ -0,0 +1,139 @@ +name: "MSC316DC" + +on: + push: + branches: + - production + tags: + - "v*" + schedule: + - cron: "00 01 * * *" + workflow_dispatch: + +jobs: + build_core: + name: OpenIPC firmware for MSC316DC + runs-on: ubuntu-18.04 + + steps: + + - name: Checkout + id: checkout + uses: actions/checkout@v2 + + - name: Install build dependencies + id: install + run: | + make install-deps + mkdir -p tmp + + - name: Free disk space + id: freshing + run: | + sudo swapoff -a + sudo rm -f /swapfile + sudo apt clean + docker rmi $(docker image ls -aq) + df -h + + - name: Prepare buildroot + id: prepare + run: | + HEAD_TAG=$(git tag --points-at HEAD) + GIT_HASH=$(git rev-parse --short $GITHUB_SHA) + BRANCH_NAME=$(echo $GITHUB_REF | cut -d'/' -f 3) + if [ -z "$HEAD_TAG" ]; then + TAG_NAME="latest" + RELEASE_NAME="Development Build" + PRERELEASE=true + else + TAG_NAME=${{ github.ref }} + RELEASE_NAME="Release ${{ github.ref }}" + PRERELEASE=false + fi + echo "GIT_HASH=$GIT_HASH" >> $GITHUB_ENV + echo "TAG_NAME=$TAG_NAME" >> $GITHUB_ENV + echo "RELEASE_NAME=$RELEASE_NAME" >> $GITHUB_ENV + echo "PRERELEASE=$PRERELEASE" >> $GITHUB_ENV + echo "BRANCH_NAME=$BRANCH_NAME" >> $GITHUB_ENV + cd $GITHUB_WORKSPACE + make prepare + + - name: Build MSC316DC firmware + id: build-msc316dc-firmware + continue-on-error: true + run: | + ARCHIVE_FW="${GITHUB_WORKSPACE}/output/images/openipc.msc316dc-br.tgz" + echo "ARCHIVE_FW=$ARCHIVE_FW" >> $GITHUB_ENV + cd $GITHUB_WORKSPACE + make PLATFORM=sigmastar BOARD=unknown_unknown_msc316dc_openipc all + [[ $(stat --printf="%s" ${GITHUB_WORKSPACE}/output/images/uImage) -gt 2097152 ]] && echo "TG_NOTIFY=Warning, kernel size exceeded : $(stat --printf="%s" ${GITHUB_WORKSPACE}/output/images/uImage) vs 2097152... MSC316DC" >> $GITHUB_ENV && exit 1 + [[ $(stat --printf="%s" ${GITHUB_WORKSPACE}/output/images/rootfs.squashfs) -gt 5242880 ]] && echo "TG_NOTIFY=Warning, rootfs size exceeded - $(stat --printf="%s" ${GITHUB_WORKSPACE}/output/images/rootfs.squashfs) vs 5242880... MSC316DC" >> $GITHUB_ENV && exit 1 + cd ${GITHUB_WORKSPACE}/output/images + mv uImage uImage.msc316dc + mv rootfs.squashfs rootfs.squashfs.msc316dc + md5sum rootfs.squashfs.msc316dc > rootfs.squashfs.msc316dc.md5sum + md5sum uImage.msc316dc > uImage.msc316dc.md5sum + tar -cvzf $ARCHIVE_FW *msc316dc* + + - name: Build MSC316DC SDK + id: build-msc316dc-sdk + continue-on-error: true + run: | + ARCHIVE_SDK="${GITHUB_WORKSPACE}/output/images/arm-openipc-linux-musleabihf_sdk-buildroot.tar.gz" + echo "ARCHIVE_SDK=$ARCHIVE_SDK" >> $GITHUB_ENV + cd $GITHUB_WORKSPACE/output + make sdk + + - name: Send warning message to telegram channel + env: + TG_TOKEN: ${{ secrets.TELEGRAM_TOKEN_BOT_OPENIPC }} + TG_CHANNEL: ${{ secrets.TELEGRAM_CHANNEL_OPENIPC_DEV }} + if: steps.build-msc316dc-firmware.outcome != 'success' || steps.build-msc316dc-sdk.outcome != 'success' + run: | + TG_OPTIONS="-s --connect-timeout 30 --max-time 30" + TG_NOTIFY="${TG_NOTIFY:=Warning, Buildroot compiling error... MSC316DC}" + TG_HEADER=$(echo -e "\r\n$TG_NOTIFY \r\n\r\nCommit: $GIT_HASH \r\nBranch: $BRANCH_NAME \r\nTag: $TAG_NAME \r\n\r\n\xE2\x9A\xA0 GitHub Actions") + curl $TG_OPTIONS -H "Content-Type: multipart/form-data" -X POST https://api.telegram.org/bot$TG_TOKEN/sendMessage \ + -F chat_id=$TG_CHANNEL -F text="$TG_HEADER" + + - name: Create release + uses: actions/create-release@v1 + continue-on-error: true + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + tag_name: ${{ env.TAG_NAME }} + release_name: ${{ env.RELEASE_NAME }} + draft: false + prerelease: ${{ env.PRERELEASE }} + + - name: Upload FW to release + uses: svenstaro/upload-release-action@v2 + continue-on-error: true + with: + repo_token: ${{ secrets.GITHUB_TOKEN }} + file: ${{ env.ARCHIVE_FW }} + asset_name: "openipc.msc316dc-br.tgz" + tag: ${{ env.TAG_NAME }} + overwrite: true + + - name: Upload SDK to release + uses: svenstaro/upload-release-action@v2 + continue-on-error: true + with: + repo_token: ${{ secrets.GITHUB_TOKEN }} + file: ${{ env.ARCHIVE_SDK }} + asset_name: "arm-openipc-msc316dc-linux-musleabihf_sdk-buildroot.tar.gz" + tag: ${{ env.TAG_NAME }} + overwrite: true + + - name: Send binary file to telegram channel + env: + TG_TOKEN: ${{ secrets.TELEGRAM_TOKEN_BOT_OPENIPC }} + TG_CHANNEL: ${{ secrets.TELEGRAM_CHANNEL_OPENIPC_DEV }} + run: | + TG_OPTIONS="-s --connect-timeout 30 --max-time 30" + TG_HEADER=$(echo -e "\r\nCommit: $GIT_HASH \r\nBranch: $BRANCH_NAME \r\nTag: $TAG_NAME \r\n\r\n\xE2\x9C\x85 GitHub Actions") + curl $TG_OPTIONS -H "Content-Type: multipart/form-data" -X POST https://api.telegram.org/bot$TG_TOKEN/sendDocument \ + -F chat_id=$TG_CHANNEL -F document="@$ARCHIVE_FW" -F caption="$TG_HEADER" diff --git a/br-ext-chip-sigmastar/board/infinity3/kernel/msc316dc.generic.config b/br-ext-chip-sigmastar/board/infinity3/kernel/msc316dc.generic.config new file mode 120000 index 00000000..0fc5930c --- /dev/null +++ b/br-ext-chip-sigmastar/board/infinity3/kernel/msc316dc.generic.config @@ -0,0 +1 @@ +msc313e.generic.config \ No newline at end of file diff --git a/br-ext-chip-sigmastar/board/unknown_unknown_msc313e_unknown/config b/br-ext-chip-sigmastar/board/unknown_unknown_msc313e_unknown/config new file mode 100644 index 00000000..83d7e395 --- /dev/null +++ b/br-ext-chip-sigmastar/board/unknown_unknown_msc313e_unknown/config @@ -0,0 +1,10 @@ +VENDOR=unknown +MODEL=unknown +FAMILY=infinity3 +CHIP=ssc313e +RAM_SIZE=64M +RAM_LINUX_SIZE=32M +RAM_MPP_SIZE=32M +ROM_SIZE=? +CMOS=unknown +UBOOT_SIZE=? diff --git a/br-ext-chip-sigmastar/board/unknown_unknown_ssc313e_unknown/kernel/.gitkeep b/br-ext-chip-sigmastar/board/unknown_unknown_msc313e_unknown/kernel/.gitkeep similarity index 100% rename from br-ext-chip-sigmastar/board/unknown_unknown_ssc313e_unknown/kernel/.gitkeep rename to br-ext-chip-sigmastar/board/unknown_unknown_msc313e_unknown/kernel/.gitkeep diff --git a/br-ext-chip-sigmastar/board/unknown_unknown_ssc313e_unknown/config b/br-ext-chip-sigmastar/board/unknown_unknown_msc316dc_unknown/config similarity index 90% rename from br-ext-chip-sigmastar/board/unknown_unknown_ssc313e_unknown/config rename to br-ext-chip-sigmastar/board/unknown_unknown_msc316dc_unknown/config index f12c3b04..7a32a3b5 100644 --- a/br-ext-chip-sigmastar/board/unknown_unknown_ssc313e_unknown/config +++ b/br-ext-chip-sigmastar/board/unknown_unknown_msc316dc_unknown/config @@ -1,7 +1,7 @@ VENDOR=unknown MODEL=unknown FAMILY=infinity3 -CHIP=ssc313e +CHIP=msc316dc RAM_SIZE=128M RAM_LINUX_SIZE=64M RAM_MPP_SIZE=64M diff --git a/br-ext-chip-sigmastar/board/unknown_unknown_msc316dc_unknown/kernel/.gitkeep b/br-ext-chip-sigmastar/board/unknown_unknown_msc316dc_unknown/kernel/.gitkeep new file mode 100644 index 00000000..e69de29b diff --git a/br-ext-chip-sigmastar/configs/unknown_unknown_msc316dc_openipc_defconfig b/br-ext-chip-sigmastar/configs/unknown_unknown_msc316dc_openipc_defconfig new file mode 100644 index 00000000..668f94f3 --- /dev/null +++ b/br-ext-chip-sigmastar/configs/unknown_unknown_msc316dc_openipc_defconfig @@ -0,0 +1,99 @@ +# Architecture +BR2_arm=y +BR2_cortex_a7=y +BR2_ARM_EABIHF=y +BR2_ARM_FPU_NEON_VFPV4=y +BR2_ARM_INSTRUCTIONS_THUMB2=y +BR2_KERNEL_HEADERS_VERSION=y +BR2_DEFAULT_KERNEL_VERSION="3.18.30" +BR2_PACKAGE_HOST_LINUX_HEADERS_CUSTOM_3_18=y + +# Toolchain +BR2_PER_PACKAGE_DIRECTORIES=y +BR2_GCC_VERSION_7_X=y +# BR2_TOOLCHAIN_USES_UCLIBC is not set +# BR2_TOOLCHAIN_BUILDROOT_UCLIBC is not set +# BR2_TOOLCHAIN_BUILDROOT_LIBC="uclibc" +BR2_TOOLCHAIN_USES_MUSL=y +BR2_TOOLCHAIN_BUILDROOT_MUSL=y +BR2_TOOLCHAIN_BUILDROOT_LIBC="musl" +BR2_TOOLCHAIN_BUILDROOT_CXX=y +# BR2_TOOLCHAIN_BUILDROOT_LOCALE is not set +BR2_TOOLCHAIN_BUILDROOT_USE_SSP=y + +# Kernel +BR2_LINUX_KERNEL=y +BR2_LINUX_KERNEL_CUSTOM_VERSION=y +BR2_LINUX_KERNEL_CUSTOM_VERSION_VALUE="3.18.30" +BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG=y +BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE="$(BR2_EXTERNAL_SIGMASTAR_PATH)/board/infinity3/kernel/msc316dc.generic.config" +BR2_LINUX_KERNEL_UIMAGE=y +BR2_LINUX_KERNEL_XZ=y +BR2_LINUX_KERNEL_EXT_SIGMASTAR_PATCHER=y +BR2_LINUX_KERNEL_EXT_SIGMASTAR_PATCHER_LIST="$(BR2_EXTERNAL_SIGMASTAR_PATH)/board/infinity3/kernel/patches/ $(BR2_EXTERNAL_SIGMASTAR_PATH)/board/infinity3/kernel/overlay" + +# Filesystem +# BR2_TARGET_TZ_INFO is not set +BR2_TARGET_ROOTFS_CPIO=y +BR2_TARGET_ROOTFS_SQUASHFS=y +BR2_TARGET_ROOTFS_SQUASHFS4_XZ=y +BR2_ROOTFS_OVERLAY="$(TOPDIR)/../general/overlay" +BR2_ROOTFS_POST_BUILD_SCRIPT="$(TOPDIR)/../scripts/executing_commands_for_$(BR2_TOOLCHAIN_BUILDROOT_LIBC).sh" + +# OpenIPC configuration +BR2_TOOLCHAIN_BUILDROOT_VENDOR="openipc" +BR2_TARGET_GENERIC_ISSUE="Welcome to OpenIPC v2.2" +BR2_TARGET_GENERIC_HOSTNAME="openipc-msc316dc" +BR2_GLOBAL_PATCH_DIR="$(TOPDIR)/../general/package/all-patches" + +# OpenIPC packages +BR2_PACKAGE_BUSYBOX_CONFIG="$(TOPDIR)/../general/package/busybox/busybox.config" +BR2_PACKAGE_DROPBEAR_OPENIPC=y +# BR2_PACKAGE_FDK_AAC_OPENIPC is not set +BR2_PACKAGE_FWPRINTENV_OPENIPC=y +BR2_PACKAGE_HASERL=y +BR2_PACKAGE_IPCTOOL=y +BR2_PACKAGE_JSON_C=y +BR2_PACKAGE_LAME_OPENIPC=y +BR2_PACKAGE_LIBCURL_OPENIPC=y +BR2_PACKAGE_LIBCURL_OPENIPC_CURL=y +# BR2_PACKAGE_LIBCURL_OPENIPC_VERBOSE is not set +# BR2_PACKAGE_LIBCURL_OPENIPC_PROXY_SUPPORT is not set +# BR2_PACKAGE_LIBCURL_OPENIPC_COOKIES_SUPPORT is not set +# BR2_PACKAGE_LIBCURL_OPENIPC_EXTRA_PROTOCOLS_FEATURES is not set +BR2_PACKAGE_LIBCURL_OPENIPC_MBEDTLS=y +BR2_PACKAGE_LIBEVENT_OPENIPC=y +BR2_PACKAGE_LIBEVENT_OPENIPC_REMOVE_PYSCRIPT=y +BR2_PACKAGE_LIBOGG_OPENIPC=y +BR2_PACKAGE_LIBWEBSOCKETS_OPENIPC=y +BR2_PACKAGE_LIBYAML=y +BR2_PACKAGE_MAJESTIC_FONTS=y +# BR2_PACKAGE_MAJESTIC_MSC313E=y +BR2_PACKAGE_MBEDTLS_OPENIPC=y +# BR2_PACKAGE_MBEDTLS_OPENIPC_PROGRAMS is not set +# BR2_PACKAGE_MBEDTLS_OPENIPC_COMPRESSION is not set +BR2_PACKAGE_MICROBE_WEB=y +# BR2_PACKAGE_MINI_SNMPD is not set +BR2_PACKAGE_MOTORS=y +BR2_PACKAGE_OPUS_OPENIPC=y +BR2_PACKAGE_OPUS_OPENIPC_FIXED_POINT=y +BR2_PACKAGE_SIGMASTAR_OSDRV_MSC313E=y +# BR2_PACKAGE_SSHPASS is not set +BR2_PACKAGE_UACME_OPENIPC=y +BR2_PACKAGE_VTUND_OPENIPC=y +BR2_PACKAGE_YAML_CLI=y + +# WiFi +BR2_PACKAGE_WIRELESS_TOOLS=y +BR2_PACKAGE_WPA_SUPPLICANT=y +BR2_PACKAGE_WPA_SUPPLICANT_CLI=y +BR2_PACKAGE_WPA_SUPPLICANT_NL80211=y +BR2_PACKAGE_WPA_SUPPLICANT_PASSPHRASE=y +BR2_PACKAGE_LINUX_FIRMWARE_OPENIPC=y +BR2_PACKAGE_LINUX_FIRMWARE_OPENIPC_MT7601U=y +# BR2_PACKAGE_RTL8188EU is not set +# BR2_PACKAGE_RTL8192EU_OPENIPC is not set + +# WIREGUARD +BR2_PACKAGE_WIREGUARD_LINUX_COMPAT=y +BR2_PACKAGE_WIREGUARD_TOOLS=y diff --git a/building.sh b/building.sh index 96db9960..5d18e4f4 100755 --- a/building.sh +++ b/building.sh @@ -437,6 +437,11 @@ msc313e() { fresh && make PLATFORM=sigmastar BOARD=unknown_unknown_${soc}_openipc all && rename } +msc316dc() { + soc="msc316dc" + fresh && make PLATFORM=sigmastar BOARD=unknown_unknown_${soc}_openipc all && rename +} + ################################################################################# rv1109() { @@ -673,6 +678,7 @@ xm550() { ####### # # msc313e # OpenIPC +# msc316dc # OpenIPC # # ssc325 # OpenIPC # diff --git a/docs/index.md b/docs/index.md index f2406ac8..0793ef7e 100644 --- a/docs/index.md +++ b/docs/index.md @@ -80,8 +80,8 @@ _**NB!** Downloads are for research only, without any guarantee._ | Ingenic T20
![T20][T20] |
![sMVP] | | [⬇][fwT20] | + | | | | | Ingenic T21
![T21][T21] |
![sMVP] | | [⬇][fwT21] | + | | | | | Ingenic T31
![T31][T31] |
![sMVP] | | [⬇][fwT31] | + | | | | -| MStar MSC313E
![MSC313E][MSC313E] |
![sRnD] | | | | | | | -| MStar MSC316D
![MSC316D][MSC316D] |
![sRnD] | | | | | | | +| MStar MSC313E
![MSC313E][MSC313E] |
![sWIP] | [⬇][bootMSC313E] | [⬇][fwMSC313E] | | | | | +| MStar MSC316D
![MSC316DC][MSC316DC] |
![sWIP] | | [⬇][fwMSC316DC] | | | | | | Novatek NT98562
![NT98562][NT98562] |
![sWIP] | | [⬇][fwNT98562] | | | | | | Novatek NT98566
![NT98566][NT98566] |
![sWIP] | | [⬇][fwNT98566] | | | | | | SigmaStar SSC325
![SSC325][SSC325] |
![sRnD] | | [⬇][fwSSC325] | | | | | @@ -200,8 +200,8 @@ Thank you. [Hi3518Ev200]: https://github.com/OpenIPC/firmware/actions/workflows/hi3518ev200_images.yml/badge.svg [Hi3518Ev300]: https://github.com/OpenIPC/firmware/actions/workflows/hi3518ev300_images.yml/badge.svg [Hi3519v101]: https://github.com/OpenIPC/firmware/actions/workflows/hi3519v101_images.yml/badge.svg -[MSC313E]: https://img.shields.io/static/v1?label=MSC313E&message=%20&logo=github -[MSC316D]: https://img.shields.io/static/v1?label=MSC316D&message=%20&logo=github +[MSC313E]: https://github.com/OpenIPC/firmware/actions/workflows/msc313e_images.yml/badge.svg +[MSC316DC]: https://github.com/OpenIPC/firmware/actions/workflows/msc316dc_images.yml/badge.svg [NT98562]: https://github.com/OpenIPC/firmware/actions/workflows/nt98562_images.yml/badge.svg [NT98566]: https://github.com/OpenIPC/firmware/actions/workflows/nt98566_images.yml/badge.svg [SSC325]: https://github.com/OpenIPC/firmware/actions/workflows/ssc325_images.yml/badge.svg @@ -240,6 +240,8 @@ Thank you. [bootHi3518Ev200]: https://github.com/OpenIPC/firmware/releases/download/latest/u-boot-hi3518ev200-universal.bin [bootHi3518Ev300]: https://github.com/OpenIPC/firmware/releases/download/latest/u-boot-hi3518ev300-universal.bin [bootHi3519v101]: https://github.com/OpenIPC/firmware/releases/download/latest/u-boot-hi3519v101-universal.bin +[bootMSC313E]: https://github.com/OpenIPC/firmware/releases/download/latest/u-boot-msc313e-universal.bin +[bootMSC316DC]: https://github.com/OpenIPC/firmware/releases/download/latest/u-boot-msc316dc-universal.bin [fwAmbaS2L]: https://github.com/OpenIPC/firmware/releases/download/latest/openipc.ambarella-s2l-br.tgz @@ -287,7 +289,7 @@ Thank you. [fwHi3518Ev300]: https://github.com/OpenIPC/firmware/releases/download/latest/openipc.hi3518ev300-br.tgz [fwHi3519v101]: https://github.com/OpenIPC/firmware/releases/download/latest/openipc.hi3519v101-br.tgz [fwMSC313E]: https://github.com/OpenIPC/firmware/releases/download/latest/openipc.msc313e-br.tgz -[fwMSC316D]: https://github.com/OpenIPC/firmware/releases/download/latest/openipc.msc316d-br.tgz +[fwMSC316DC]: https://github.com/OpenIPC/firmware/releases/download/latest/openipc.msc316dc-br.tgz [fwNT98562]: https://github.com/OpenIPC/firmware/releases/download/latest/openipc.nt98562-br.tgz [fwNT98566]: https://github.com/OpenIPC/firmware/releases/download/latest/openipc.nt98566-br.tgz [fwSSC325]: https://github.com/OpenIPC/firmware/releases/download/latest/openipc.ssc325-br.tgz