From 3e9e0044352449160133ab221c9828bfec84fb3e Mon Sep 17 00:00:00 2001
From: "Igor Zalatov (from Citadel PC)" <flyrouter@gmail.com>
Date: Sun, 31 Oct 2021 14:37:23 +0300
Subject: [PATCH] Add some novatek files

---
 .github/workflows/hi3516cv300_images.yml      | 129 ++++++++++++++++++
 .github/workflows/nt98566_images.yml          |   5 -
 ...516cv300_kernel-3.18.20_sdk-2.0.4.0.patch} |   0
 .../11_fix_yylloc_for_modern_computers.patch  |  11 ++
 br-ext-chip-novatek/Config.in                 |   1 +
 .../unknown_unknown_nt98562_openipc_defconfig |   2 +-
 .../unknown_unknown_nt98566_openipc_defconfig |   2 +-
 br-ext-chip-novatek/external.mk               |   1 +
 .../package/novatek-osdrv-nt9856x             |   1 +
 building.sh                                   |   4 +-
 .../package/novatek-osdrv-nt9856x/Config.in   |   6 +
 .../novatek-osdrv-nt9856x/files/kmod/.dot     |   0
 .../novatek-osdrv-nt9856x/files/lib/.dot      |   0
 .../files/script/S99novatek                   |  67 +++++++++
 .../files/script/ircut_demo                   |  85 ++++++++++++
 .../files/script/load_novatek                 |   2 +
 .../novatek-osdrv-nt9856x/files/sensor/.dot   |   0
 .../novatek-osdrv-nt9856x.mk                  |  35 +++++
 18 files changed, 342 insertions(+), 9 deletions(-)
 create mode 100644 .github/workflows/hi3516cv300_images.yml
 rename br-ext-chip-hisilicon/board/hi3516cv300/kernel/patches/{hi3516cv300_kernel-3.18.20_sdk-2.0.4.0.patch => 00_hi3516cv300_kernel-3.18.20_sdk-2.0.4.0.patch} (100%)
 create mode 100644 br-ext-chip-hisilicon/board/hi3516cv300/kernel/patches/11_fix_yylloc_for_modern_computers.patch
 create mode 120000 br-ext-chip-novatek/package/novatek-osdrv-nt9856x
 create mode 100644 general/package/novatek-osdrv-nt9856x/Config.in
 create mode 100644 general/package/novatek-osdrv-nt9856x/files/kmod/.dot
 create mode 100644 general/package/novatek-osdrv-nt9856x/files/lib/.dot
 create mode 100755 general/package/novatek-osdrv-nt9856x/files/script/S99novatek
 create mode 100755 general/package/novatek-osdrv-nt9856x/files/script/ircut_demo
 create mode 100755 general/package/novatek-osdrv-nt9856x/files/script/load_novatek
 create mode 100644 general/package/novatek-osdrv-nt9856x/files/sensor/.dot
 create mode 100644 general/package/novatek-osdrv-nt9856x/novatek-osdrv-nt9856x.mk

diff --git a/.github/workflows/hi3516cv300_images.yml b/.github/workflows/hi3516cv300_images.yml
new file mode 100644
index 00000000..1e91dc81
--- /dev/null
+++ b/.github/workflows/hi3516cv300_images.yml
@@ -0,0 +1,129 @@
+name: OpenIPC for Hi3516Cv300
+
+on:
+  workflow_dispatch:
+
+jobs:
+  build_core:
+    name: OpenIPC v2.1 for Hi3516Cv300
+    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 Hi3516Cv300 firmware
+        id: build-hi3516cv300-firmware
+        continue-on-error: true
+        run: |
+          ARCHIVE_FW="${GITHUB_WORKSPACE}/output/images/openipc.hi3516cv300-br.tgz"
+          echo "ARCHIVE_FW=$ARCHIVE_FW" >> $GITHUB_ENV
+          cd $GITHUB_WORKSPACE
+          make PLATFORM=hisilicon BOARD=unknown_unknown_hi3516cv300_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" >> $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" >> $GITHUB_ENV && exit 1
+          mv ${GITHUB_WORKSPACE}/output/images/uImage ${GITHUB_WORKSPACE}/output/images/uImage.hi3516cv300
+          mv ${GITHUB_WORKSPACE}/output/images/rootfs.squashfs ${GITHUB_WORKSPACE}/output/images/rootfs.squashfs.hi3516cv300
+          tar -C ${GITHUB_WORKSPACE}/output/images -cvzf $ARCHIVE_FW rootfs.squashfs.hi3516cv300 uImage.hi3516cv300
+
+      - name: Build Hi3516Cv300 SDK
+        id: build-hi3516cv300-sdk
+        continue-on-error: true
+        run: |
+          ARCHIVE_SDK="${GITHUB_WORKSPACE}/output/images/arm-openipc-linux-musleabi_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-hi3516cv300-firmware.outcome != 'success' || steps.build-hi3516cv300-sdk.outcome != 'success'
+        run: |
+          TG_OPTIONS="-s --connect-timeout 30 --max-time 30"
+          TG_NOTIFY="${TG_NOTIFY:=Warning, Buildroot compiling error... HI3516CV300}"
+          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.hi3516cv300-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-hi3516cv300-linux-musleabi_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/.github/workflows/nt98566_images.yml b/.github/workflows/nt98566_images.yml
index 14d53f82..d8cf7e02 100644
--- a/.github/workflows/nt98566_images.yml
+++ b/.github/workflows/nt98566_images.yml
@@ -1,11 +1,6 @@
 name: OpenIPC for NT98566
 
 on:
-  push:
-    branches:
-      - master
-    tags:
-      - "v*"
   workflow_dispatch:
 
 jobs:
diff --git a/br-ext-chip-hisilicon/board/hi3516cv300/kernel/patches/hi3516cv300_kernel-3.18.20_sdk-2.0.4.0.patch b/br-ext-chip-hisilicon/board/hi3516cv300/kernel/patches/00_hi3516cv300_kernel-3.18.20_sdk-2.0.4.0.patch
similarity index 100%
rename from br-ext-chip-hisilicon/board/hi3516cv300/kernel/patches/hi3516cv300_kernel-3.18.20_sdk-2.0.4.0.patch
rename to br-ext-chip-hisilicon/board/hi3516cv300/kernel/patches/00_hi3516cv300_kernel-3.18.20_sdk-2.0.4.0.patch
diff --git a/br-ext-chip-hisilicon/board/hi3516cv300/kernel/patches/11_fix_yylloc_for_modern_computers.patch b/br-ext-chip-hisilicon/board/hi3516cv300/kernel/patches/11_fix_yylloc_for_modern_computers.patch
new file mode 100644
index 00000000..b4e1d793
--- /dev/null
+++ b/br-ext-chip-hisilicon/board/hi3516cv300/kernel/patches/11_fix_yylloc_for_modern_computers.patch
@@ -0,0 +1,11 @@
+--- a/scripts/dtc/dtc-lexer.lex.c	2021-10-31 13:51:18.858858304 +0300
++++ b/scripts/dtc/dtc-lexer.lex.c	2021-10-31 13:54:53.017440216 +0300
+@@ -637,7 +637,7 @@
+ #include "srcpos.h"
+ #include "dtc-parser.tab.h"
+ 
+-YYLTYPE yylloc;
++extern YYLTYPE yylloc;
+ 
+ /* CAUTION: this will stop working if we ever use yyless() or yyunput() */
+ #define	YY_USER_ACTION \
diff --git a/br-ext-chip-novatek/Config.in b/br-ext-chip-novatek/Config.in
index e1bd48f7..bab39260 100644
--- a/br-ext-chip-novatek/Config.in
+++ b/br-ext-chip-novatek/Config.in
@@ -15,6 +15,7 @@ source "$BR2_EXTERNAL_NOVATEK_PATH/package/mbedtls-openipc/Config.in"
 source "$BR2_EXTERNAL_NOVATEK_PATH/package/microbe-web/Config.in"
 source "$BR2_EXTERNAL_NOVATEK_PATH/package/motors/Config.in"
 source "$BR2_EXTERNAL_NOVATEK_PATH/package/node-exporter/Config.in"
+source "$BR2_EXTERNAL_NOVATEK_PATH/package/novatek-osdrv-nt9856x/Config.in"
 source "$BR2_EXTERNAL_NOVATEK_PATH/package/opus-openipc/Config.in"
 source "$BR2_EXTERNAL_NOVATEK_PATH/package/uacme-openipc/Config.in"
 source "$BR2_EXTERNAL_NOVATEK_PATH/package/vtund-openipc/Config.in"
diff --git a/br-ext-chip-novatek/configs/unknown_unknown_nt98562_openipc_defconfig b/br-ext-chip-novatek/configs/unknown_unknown_nt98562_openipc_defconfig
index a7f5fa79..ce3aebce 100644
--- a/br-ext-chip-novatek/configs/unknown_unknown_nt98562_openipc_defconfig
+++ b/br-ext-chip-novatek/configs/unknown_unknown_nt98562_openipc_defconfig
@@ -52,7 +52,7 @@ BR2_PACKAGE_DROPBEAR=y
 # BR2_PACKAGE_FDK_AAC_OPENIPC is not set
 BR2_PACKAGE_FWPRINTENV_OPENIPC=y
 BR2_PACKAGE_HASERL=y
-# BR2_PACKAGE_NOVATEK_OSDRV_NT9856X is not set
+BR2_PACKAGE_NOVATEK_OSDRV_NT9856X=y
 BR2_PACKAGE_IPCTOOL=y
 BR2_PACKAGE_JSON_C=y
 BR2_PACKAGE_LAME_OPENIPC=y
diff --git a/br-ext-chip-novatek/configs/unknown_unknown_nt98566_openipc_defconfig b/br-ext-chip-novatek/configs/unknown_unknown_nt98566_openipc_defconfig
index aa57a5ab..f102cdaa 100644
--- a/br-ext-chip-novatek/configs/unknown_unknown_nt98566_openipc_defconfig
+++ b/br-ext-chip-novatek/configs/unknown_unknown_nt98566_openipc_defconfig
@@ -52,7 +52,7 @@ BR2_PACKAGE_DROPBEAR=y
 # BR2_PACKAGE_FDK_AAC_OPENIPC is not set
 BR2_PACKAGE_FWPRINTENV_OPENIPC=y
 BR2_PACKAGE_HASERL=y
-# BR2_PACKAGE_NOVATEK_OSDRV_NT9856X is not set
+BR2_PACKAGE_NOVATEK_OSDRV_NT9856X=y
 BR2_PACKAGE_IPCTOOL=y
 BR2_PACKAGE_JSON_C=y
 BR2_PACKAGE_LAME_OPENIPC=y
diff --git a/br-ext-chip-novatek/external.mk b/br-ext-chip-novatek/external.mk
index 754df39b..be9b615b 100644
--- a/br-ext-chip-novatek/external.mk
+++ b/br-ext-chip-novatek/external.mk
@@ -15,6 +15,7 @@ include $(BR2_EXTERNAL_NOVATEK_PATH)/package/mbedtls-openipc/mbedtls-openipc.mk
 include $(BR2_EXTERNAL_NOVATEK_PATH)/package/microbe-web/microbe-web.mk
 include $(BR2_EXTERNAL_NOVATEK_PATH)/package/motors/motors.mk
 include $(BR2_EXTERNAL_NOVATEK_PATH)/package/node-exporter/node-exporter.mk
+include $(BR2_EXTERNAL_NOVATEK_PATH)/package/novatek-osdrv-nt9856x/novatek-osdrv-nt9856x.mk
 include $(BR2_EXTERNAL_NOVATEK_PATH)/package/opus-openipc/opus-openipc.mk
 include $(BR2_EXTERNAL_NOVATEK_PATH)/package/uacme-openipc/uacme-openipc.mk
 include $(BR2_EXTERNAL_NOVATEK_PATH)/package/vtund-openipc/vtund-openipc.mk
diff --git a/br-ext-chip-novatek/package/novatek-osdrv-nt9856x b/br-ext-chip-novatek/package/novatek-osdrv-nt9856x
new file mode 120000
index 00000000..e29eff01
--- /dev/null
+++ b/br-ext-chip-novatek/package/novatek-osdrv-nt9856x
@@ -0,0 +1 @@
+../../general/package/novatek-osdrv-nt9856x
\ No newline at end of file
diff --git a/building.sh b/building.sh
index efb96b07..cec2352f 100755
--- a/building.sh
+++ b/building.sh
@@ -257,8 +257,8 @@ xm550() {
 #
 # hi3516cv100                   # testing..
 # hi3516cv200                   # testing..
-hi3518ev200                   # testing..
-# hi3516cv300                   # testind..
+# hi3518ev200                   # testing..
+hi3516cv300                   # testind..
 # hi3516cv500                   # testind..
 #
 # hi3516dv300                   # testind..
diff --git a/general/package/novatek-osdrv-nt9856x/Config.in b/general/package/novatek-osdrv-nt9856x/Config.in
new file mode 100644
index 00000000..fb53c80a
--- /dev/null
+++ b/general/package/novatek-osdrv-nt9856x/Config.in
@@ -0,0 +1,6 @@
+config BR2_PACKAGE_NOVATEK_OSDRV_NT9856X
+	bool "novatek-osdrv-nt9856x"
+	help
+	  novatek-osdrv-nt9856x - Novatek kernel modules and libs
+
+	  https://openipc.org
diff --git a/general/package/novatek-osdrv-nt9856x/files/kmod/.dot b/general/package/novatek-osdrv-nt9856x/files/kmod/.dot
new file mode 100644
index 00000000..e69de29b
diff --git a/general/package/novatek-osdrv-nt9856x/files/lib/.dot b/general/package/novatek-osdrv-nt9856x/files/lib/.dot
new file mode 100644
index 00000000..e69de29b
diff --git a/general/package/novatek-osdrv-nt9856x/files/script/S99novatek b/general/package/novatek-osdrv-nt9856x/files/script/S99novatek
new file mode 100755
index 00000000..344d03f6
--- /dev/null
+++ b/general/package/novatek-osdrv-nt9856x/files/script/S99novatek
@@ -0,0 +1,67 @@
+#!/bin/sh
+
+DAEMON="majestic"
+PIDFILE="/var/run/$DAEMON.pid"
+
+DAEMON_ARGS=""
+
+# shellcheck source=/dev/null
+[ -r "/etc/default/$DAEMON" ] && . "/etc/default/$DAEMON"
+
+# The daemon does not create a pidfile, and use "-m" to instruct start-stop-daemon to create one.
+start() {
+	#logger -s -p daemon.info -t novatek "Check MAC for Novatek devices"
+	#if [ "$(fw_printenv -n ethaddr)" = "D0:22:12:88:88:88" ]; then
+	#	logger -s -p daemon.info -t novatek "The eth0 interface has a lousy MAC, let's try to change it.."
+	#else
+	#	logger -s -p daemon.info -t novatek "The eth0 interface has a correct MAC - $(fw_printenv -n ethaddr)"
+	#fi
+	#
+	logger -s -p daemon.info -t novatek "Loading of kernel modules and initialization of the video system has started"
+	export TZ=$(cat /etc/TZ)
+	load_novatek -i
+	#
+	printf 'Starting %s: ' "$DAEMON"
+	[ -f /usr/bin/$DAEMON ] || echo -en "DISABLED, "
+	# shellcheck disable=SC2086 # we need the word splitting
+	start-stop-daemon -b -m -S -q -p "$PIDFILE" -x "/usr/bin/$DAEMON" \
+		-- $DAEMON_ARGS
+	status=$?
+	if [ "$status" -eq 0 ]; then
+		echo "OK"
+	else
+		echo "FAIL"
+	fi
+	return "$status"
+}
+
+stop() {
+	printf 'Stopping %s: ' "$DAEMON"
+	[ -f /usr/bin/$DAEMON ] || echo -en "DISABLED, "
+	start-stop-daemon -K -q -p "$PIDFILE"
+	status=$?
+	if [ "$status" -eq 0 ]; then
+		rm -f "$PIDFILE"
+		echo "OK"
+	else
+		echo "FAIL"
+	fi
+	return "$status"
+}
+
+restart() {
+	stop
+	sleep 1
+	start
+}
+
+case "$1" in
+	start|stop|restart)
+		"$1";;
+	reload)
+		# Restart, since there is no true "reload" feature.
+		restart;;
+	*)
+		echo "Usage: $0 {start|stop|restart|reload}"
+		exit 1
+esac
diff --git a/general/package/novatek-osdrv-nt9856x/files/script/ircut_demo b/general/package/novatek-osdrv-nt9856x/files/script/ircut_demo
new file mode 100755
index 00000000..e66f7747
--- /dev/null
+++ b/general/package/novatek-osdrv-nt9856x/files/script/ircut_demo
@@ -0,0 +1,85 @@
+#!/bin/sh
+
+
+# DAY mode
+ir_cut_enable() {
+  # Pin_mux
+  [ ! -d /sys/class/gpio/gpio$gpio_0 ] && echo "$gpio_0" >/sys/class/gpio/export
+  [ ! -d /sys/class/gpio/gpio$gpio_1 ] && echo "$gpio_1" >/sys/class/gpio/export
+
+  # Dir
+  echo "out" >/sys/class/gpio/gpio$gpio_0/direction
+  echo "out" >/sys/class/gpio/gpio$gpio_1/direction
+
+  # Data, gpio_1: 0, gpio_0: 1  (day mode)
+  echo "1" >/sys/class/gpio/gpio$gpio_0/value
+  echo "0" >/sys/class/gpio/gpio$gpio_1/value
+
+  # Sleep 1s
+  sleep 1
+
+  # Back to original
+  echo "0" >/sys/class/gpio/gpio$gpio_0/value
+  echo "0" >/sys/class/gpio/gpio$gpio_1/value
+}
+
+
+# NIGHT mode
+ir_cut_disable() {
+  # Pin_mux
+  [ ! -d /sys/class/gpio/gpio$gpio_0 ] && echo "$gpio_0" >/sys/class/gpio/export
+  [ ! -d /sys/class/gpio/gpio$gpio_1 ] && echo "$gpio_1" >/sys/class/gpio/export
+
+  # Dir
+  echo "out" >/sys/class/gpio/gpio$gpio_0/direction
+  echo "out" >/sys/class/gpio/gpio$gpio_1/direction
+
+  # Data, gpio_1: 1, gpio_0: 0  (night mode)
+  echo "0" >/sys/class/gpio/gpio$gpio_0/value
+  echo "1" >/sys/class/gpio/gpio$gpio_1/value
+
+  # Sleep 1s
+  sleep 1
+
+  # Back to original
+  echo "0" >/sys/class/gpio/gpio$gpio_0/value
+  echo "0" >/sys/class/gpio/gpio$gpio_1/value
+}
+
+
+gpio_0=0
+gpio_1=0
+
+
+if [ $# -lt 2 ]; then
+  echo "Usage: ircut_demo <vendor> <mode>"
+  echo "For example:"
+  echo "NIGHT : ircut_demo anjoy 1"
+else
+  if [ $1 = "anjoy" ]; then
+    gpio_0=78
+    gpio_1=79
+  elif [ $1 = "brovotech" ]; then
+    gpio_0=78
+    gpio_1=79
+  elif [ $1 = "gospell" ]; then
+    gpio_0=78
+    gpio_1=79
+  elif [ $1 = "uniview" ]; then
+    gpio_0=78
+    gpio_1=79
+  else
+    echo -e "Wrong vendor name: $1\nPlease select: anjoy, brovotech, gospell, uniview"
+    exit
+  fi
+
+  if [ $2 -eq 0 ]; then
+    echo "DAY mode, ir_cut on"
+    ir_cut_enable >/dev/null
+  elif [ $2 -eq 1 ]; then
+    echo "NIGHT mode, ir_cut off"
+    ir_cut_disable >/dev/null
+  else
+    echo "Invalid mode, please slect 0 or 1"
+  fi
+fi
diff --git a/general/package/novatek-osdrv-nt9856x/files/script/load_novatek b/general/package/novatek-osdrv-nt9856x/files/script/load_novatek
new file mode 100755
index 00000000..13f47935
--- /dev/null
+++ b/general/package/novatek-osdrv-nt9856x/files/script/load_novatek
@@ -0,0 +1,2 @@
+#!/bin/sh
+
diff --git a/general/package/novatek-osdrv-nt9856x/files/sensor/.dot b/general/package/novatek-osdrv-nt9856x/files/sensor/.dot
new file mode 100644
index 00000000..e69de29b
diff --git a/general/package/novatek-osdrv-nt9856x/novatek-osdrv-nt9856x.mk b/general/package/novatek-osdrv-nt9856x/novatek-osdrv-nt9856x.mk
new file mode 100644
index 00000000..8779e49c
--- /dev/null
+++ b/general/package/novatek-osdrv-nt9856x/novatek-osdrv-nt9856x.mk
@@ -0,0 +1,35 @@
+################################################################################
+#
+# novatek-osdrv-nt9856x
+#
+################################################################################
+
+NOVATEK_OSDRV_NT9856X_VERSION =
+NOVATEK_OSDRV_NT9856X_SITE =
+NOVATEK_OSDRV_NT9856X_LICENSE = MIT
+NOVATEK_OSDRV_NT9856X_LICENSE_FILES = LICENSE
+
+
+define NOVATEK_OSDRV_NT9856X_INSTALL_TARGET_CMDS
+	$(INSTALL) -m 755 -d $(TARGET_DIR)/etc/init.d
+	$(INSTALL) -m 755 -t $(TARGET_DIR)/etc/init.d $(BR2_EXTERNAL_NOVATEK_PATH)/package/novatek-osdrv-nt9856x/files/script/S99novatek
+
+	$(INSTALL) -m 755 -d $(TARGET_DIR)/lib/modules/4.19.91/novatek
+	#$(INSTALL) -m 644 -t $(TARGET_DIR)/lib/modules/4.19.91/novatek $(BR2_EXTERNAL_NOVATEK_PATH)/package/novatek-osdrv-nt9856x/files/kmod/*.ko
+	#$(INSTALL) -m 644 -t $(TARGET_DIR)/lib/modules/4.19.91/novatek $(BR2_EXTERNAL_NOVATEK_PATH)/package/novatek-osdrv-nt9856x/files/kmod/mhal.ko
+
+	$(INSTALL) -m 755 -d $(TARGET_DIR)/usr/bin
+	#$(INSTALL) -m 755 -t $(TARGET_DIR)/usr/bin $(BR2_EXTERNAL_NOVATEK_PATH)/package/novatek-osdrv-nt9856x/files/script/load*
+	#$(INSTALL) -m 755 -t $(TARGET_DIR)/usr/bin $(BR2_EXTERNAL_NOVATEK_PATH)/package/novatek-osdrv-nt9856x/files/script/ircut_demo
+
+	$(INSTALL) -m 755 -d $(TARGET_DIR)/usr/lib/fonts
+	$(INSTALL) -m 644 -t $(TARGET_DIR)/usr/lib/fonts $(BR2_EXTERNAL_NOVATEK_PATH)/package/novatek-osdrv-nt9856x/files/fonts/*.bin
+
+	$(INSTALL) -m 755 -d $(TARGET_DIR)/usr/lib
+	# Minimalism for sample_venc_jpeg
+	#$(INSTALL) -m 644 -t $(TARGET_DIR)/usr/lib/ $(BR2_EXTERNAL_NOVATEK_PATH)/package/novatek-osdrv-nt9856x/files/lib/libmi_sys.so
+	# Maximum for demo software
+	#$(INSTALL) -m 644 -t $(TARGET_DIR)/usr/lib/ $(BR2_EXTERNAL_NOVATEK_PATH)/package/novatek-osdrv-nt9856x/files/lib/libmi_common.so
+endef
+
+$(eval $(generic-package))