From e128c1b695ae665c5919c8aa1f9012f4c1ca2670 Mon Sep 17 00:00:00 2001 From: "Signor Pellegrino (from Citadel PC)" Date: Tue, 3 Dec 2024 00:19:30 +0300 Subject: [PATCH] Add openipc-thinker-aio profile --- .github/workflows/master.yml | 3 +- .../ssc338q_fpv_openipc-thinker-aio_defconfig | 73 +++++++++++++++++++ .../overlay/usr/share/openipc/customizer.sh | 6 ++ .../files/script/load_sigmastar | 72 ++++++++++++++++++ .../general/scripts/excludes/ssc338q_fpv.list | 12 +++ 5 files changed, 165 insertions(+), 1 deletion(-) create mode 100644 devices/ssc338q_fpv_openipc-thinker-aio/br-ext-chip-sigmastar/configs/ssc338q_fpv_openipc-thinker-aio_defconfig create mode 100644 devices/ssc338q_fpv_openipc-thinker-aio/general/overlay/usr/share/openipc/customizer.sh create mode 100755 devices/ssc338q_fpv_openipc-thinker-aio/general/package/sigmastar-osdrv-infinity6e/files/script/load_sigmastar create mode 100644 devices/ssc338q_fpv_openipc-thinker-aio/general/scripts/excludes/ssc338q_fpv.list diff --git a/.github/workflows/master.yml b/.github/workflows/master.yml index 140c4b2..b05b019 100644 --- a/.github/workflows/master.yml +++ b/.github/workflows/master.yml @@ -56,8 +56,9 @@ jobs: - ssc337de_ultimate_foscam-x5 - ssc338q_fpv_caddx-fly - ssc338q_fpv_emax-wyvern-link - - ssc338q_fpv_openipc-urllc-aio - ssc338q_fpv_openipc-mario-aio + - ssc338q_fpv_openipc-thinker-aio + - ssc338q_fpv_openipc-urllc-aio - ssc338q_fpv_runcam-wifilink - t10_lite_hb-wifi-z6 - t10_lite_jvs-ingt10-gqs60ep diff --git a/devices/ssc338q_fpv_openipc-thinker-aio/br-ext-chip-sigmastar/configs/ssc338q_fpv_openipc-thinker-aio_defconfig b/devices/ssc338q_fpv_openipc-thinker-aio/br-ext-chip-sigmastar/configs/ssc338q_fpv_openipc-thinker-aio_defconfig new file mode 100644 index 0000000..0e32127 --- /dev/null +++ b/devices/ssc338q_fpv_openipc-thinker-aio/br-ext-chip-sigmastar/configs/ssc338q_fpv_openipc-thinker-aio_defconfig @@ -0,0 +1,73 @@ +# Architecture +BR2_arm=y +BR2_cortex_a7=y +BR2_ARM_FPU_NEON_VFPV4=y +BR2_ARM_INSTRUCTIONS_THUMB2=y + +# Toolchain +BR2_TOOLCHAIN_EXTERNAL=y +BR2_TOOLCHAIN_EXTERNAL_CUSTOM=y +BR2_TOOLCHAIN_EXTERNAL_DOWNLOAD=y +BR2_TOOLCHAIN_EXTERNAL_URL="https://github.com/openipc/firmware/releases/download/$(OPENIPC_TOOLCHAIN).tgz" +BR2_TOOLCHAIN_EXTERNAL_CUSTOM_PREFIX="arm-openipc-linux-gnueabihf" +BR2_TOOLCHAIN_EXTERNAL_HEADERS_4_9=y +BR2_TOOLCHAIN_EXTERNAL_CUSTOM_GLIBC=y +# BR2_TOOLCHAIN_EXTERNAL_INET_RPC is not set +BR2_TOOLCHAIN_EXTERNAL_CXX=y + +# Kernel +BR2_LINUX_KERNEL=y +BR2_LINUX_KERNEL_CUSTOM_TARBALL=y +BR2_LINUX_KERNEL_CUSTOM_TARBALL_LOCATION="https://github.com/openipc/linux/archive/$(OPENIPC_KERNEL).tar.gz" +BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG=y +BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE="$(EXTERNAL_VENDOR)/board/$(OPENIPC_SOC_FAMILY)/infinity6e-ssc012b.config" +BR2_LINUX_KERNEL_UIMAGE=y +BR2_LINUX_KERNEL_XZ=y + +# Filesystem +BR2_PACKAGE_BUSYBOX_CONFIG="$(BR2_EXTERNAL)/package/busybox/busybox.config" +BR2_PACKAGE_EXFATPROGS=y +BR2_PACKAGE_UBOOT_TOOLS=y +BR2_PACKAGE_ZLIB=y +# BR2_PACKAGE_IFUPDOWN_SCRIPTS is not set +BR2_PACKAGE_WIRELESS_TOOLS=y +BR2_PACKAGE_WPA_SUPPLICANT=y +BR2_PACKAGE_WPA_SUPPLICANT_AP_SUPPORT=y +BR2_PACKAGE_WPA_SUPPLICANT_CLI=y +BR2_PACKAGE_WPA_SUPPLICANT_PASSPHRASE=y +BR2_TARGET_ROOTFS_CPIO=y +BR2_TARGET_ROOTFS_SQUASHFS=y +BR2_TARGET_ROOTFS_SQUASHFS4_XZ=y + +# OpenIPC +BR2_OPENIPC_SOC_VENDOR="sigmastar" +BR2_OPENIPC_SOC_MODEL="ssc338q" +BR2_OPENIPC_SOC_FAMILY="infinity6e" +BR2_OPENIPC_VARIANT="fpv" +BR2_OPENIPC_FLASH_SIZE="16" + +# Packages +BR2_PACKAGE_DROPBEAR_OPENIPC=y +BR2_PACKAGE_EXFAT_OPENIPC=y +BR2_PACKAGE_IPCTOOL=y +BR2_PACKAGE_JSONFILTER=y +BR2_PACKAGE_LIBCURL_OPENIPC=y +BR2_PACKAGE_LIBCURL_OPENIPC_CURL=y +# 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_LIBOGG_OPENIPC=y +BR2_PACKAGE_MAJESTIC_FONTS=y +BR2_PACKAGE_MAJESTIC_WEBUI=y +BR2_PACKAGE_MAJESTIC=y +BR2_PACKAGE_MAVFWD=y +BR2_PACKAGE_MBEDTLS_OPENIPC=y +BR2_PACKAGE_MSPOSD=y +BR2_PACKAGE_OPUS_OPENIPC=y +BR2_PACKAGE_OPUS_OPENIPC_FIXED_POINT=y +BR2_PACKAGE_RTL8733BU_OPENIPC=y +BR2_PACKAGE_RTL8812AU_OPENIPC=y +BR2_PACKAGE_SIGMASTAR_OSDRV_INFINITY6E=y +BR2_PACKAGE_VTUND_OPENIPC=y +BR2_PACKAGE_WIFIBROADCAST=y +BR2_PACKAGE_YAML_CLI=y diff --git a/devices/ssc338q_fpv_openipc-thinker-aio/general/overlay/usr/share/openipc/customizer.sh b/devices/ssc338q_fpv_openipc-thinker-aio/general/overlay/usr/share/openipc/customizer.sh new file mode 100644 index 0000000..23be532 --- /dev/null +++ b/devices/ssc338q_fpv_openipc-thinker-aio/general/overlay/usr/share/openipc/customizer.sh @@ -0,0 +1,6 @@ +#!/bin/sh + +# Set custom upgrade url +fw_setenv upgrade 'https://github.com/OpenIPC/builder/releases/download/latest/ssc338q_fpv_openipc-thinker-aio-nor.tgz' + +exit 0 diff --git a/devices/ssc338q_fpv_openipc-thinker-aio/general/package/sigmastar-osdrv-infinity6e/files/script/load_sigmastar b/devices/ssc338q_fpv_openipc-thinker-aio/general/package/sigmastar-osdrv-infinity6e/files/script/load_sigmastar new file mode 100755 index 0000000..28e528c --- /dev/null +++ b/devices/ssc338q_fpv_openipc-thinker-aio/general/package/sigmastar-osdrv-infinity6e/files/script/load_sigmastar @@ -0,0 +1,72 @@ +#!/bin/sh +# +# OpenIPC.org | 2024 +# + +MODULE=/lib/modules/4.9.84/sigmastar + +detect_sensor() { + insmod $MODULE/sensor_config.ko + if [ -e /dev/srcfg ]; then + echo srcfg 0 1 0 0 0 0 > /dev/srcfg + rmmod sensor_config + fi + SENSOR=$(ipcinfo -s) +} + +set_sensor() { + case $SENSOR in + imx307|imx335|imx347|imx415) + insmod $MODULE/sensor_${SENSOR}_mipi.ko chmap=1 + ;; + *) + echo -e "\n\e[1;31mUNSUPPORTED sensor - $SENSOR\e[0m\n" | logger -s -t OpenIPC + ;; + esac +} + +insert_ko() { + insmod $MODULE/mhal.ko + insmod $MODULE/mi_common.ko + insmod $MODULE/mi_sys.ko cmdQBufSize=768 logBufSize=256 + insmod $MODULE/mi_rgn.ko + insmod $MODULE/mi_ldc.ko + insmod $MODULE/mi_ai.ko + insmod $MODULE/mi_ao.ko + insmod $MODULE/mi_mipitx.ko + insmod $MODULE/mi_sensor.ko + insmod $MODULE/mi_shadow.ko + insmod $MODULE/mi_divp.ko + insmod $MODULE/mi_vif.ko + insmod $MODULE/mi_vpe.ko + insmod $MODULE/mi_venc.ko fw_path=/etc/firmware/chagall.bin + + MAJOR=$(awk '$2=="mi_poll" {print $1}' /proc/devices) + mknod /dev/mi_poll c "$MAJOR" 0 + echo isproot /etc/firmware > /dev/ispmid +} + +if [ ! -e /sys/module/mi_common ]; then + insert_ko +fi + +echo -e "\n\e[1;33mAutodetect sensor\e[0m\n" | logger -s -t OpenIPC +detect_sensor + +if [ -z "$SENSOR" ]; then + echo -e "\n\e[1;31mSensor parameter MISSING\e[0m\n" | logger -s -t OpenIPC + exit 1 +fi + +DRIVER=$(ls /sys/module | grep $SENSOR) +if [ -n "$DRIVER" ]; then + rmmod $DRIVER +fi + +echo -e "\n\e[1;32mSensor assigned - $SENSOR\e[0m\n" | logger -s -t OpenIPC +set_sensor + +# Custom settings +gpio set 29 + +exit 0 diff --git a/devices/ssc338q_fpv_openipc-thinker-aio/general/scripts/excludes/ssc338q_fpv.list b/devices/ssc338q_fpv_openipc-thinker-aio/general/scripts/excludes/ssc338q_fpv.list new file mode 100644 index 0000000..44fee48 --- /dev/null +++ b/devices/ssc338q_fpv_openipc-thinker-aio/general/scripts/excludes/ssc338q_fpv.list @@ -0,0 +1,12 @@ +/etc/sensors/gc2053.bin +/etc/sensors/gc4653.bin +/etc/sensors/sc501ai.bin +/lib/modules/4.9.84/kernel/fs/lockd/*.ko +/lib/modules/4.9.84/kernel/fs/nfs/*.ko +/lib/modules/4.9.84/kernel/fs/nfs_common/*.ko +/lib/modules/4.9.84/kernel/net/sunrpc/*.ko +/lib/modules/4.9.84/sigmastar/sensor_gc2053_mipi.ko +/lib/modules/4.9.84/sigmastar/sensor_gc4653_mipi.ko +/lib/modules/4.9.84/sigmastar/sensor_os04c10_mipi.ko +/lib/modules/4.9.84/sigmastar/sensor_sc501ai_mipi.ko +/lib/modules/4.9.84/sigmastar/sensor_sc8235_mipi.ko