wz_user.sh 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552
  1. #!/bin/sh
  2. LOG_NAME=/opt/wz_mini/log/wz_user
  3. if [[ -e $LOG_NAME.log || -L $LOG_NAME.log ]] ; then
  4. i=0
  5. while [[ -e $LOG_NAME.log.$i || -L $LOG_NAME.log.$i ]] ; do
  6. let i++
  7. done
  8. mv $LOG_NAME.log $LOG_NAME.log.$i
  9. LOG_NAME=$LOG_NAME
  10. fi
  11. touch -- "$LOG_NAME".log
  12. exec 1> $LOG_NAME.log 2>&1
  13. set -x
  14. echo "welcome to wz_user.sh"
  15. echo "PID $$"
  16. if [[ -e /tmp/dbgflag ]];then
  17. echo "debug mode, disabled"
  18. exit 0
  19. fi
  20. export WZMINI_CFG=/opt/wz_mini/wz_mini.conf
  21. [ -f $WZMINI_CFG ] && source $WZMINI_CFG
  22. hostname_set() {
  23. echo "set hostname"
  24. hostname $HOSTNAME
  25. }
  26. first_run_check() {
  27. if [[ -e /opt/wz_mini/tmp/.run_mmc_firstrun ]]; then
  28. echo "run_mmc.sh already run once, exit."
  29. exit 0
  30. fi
  31. }
  32. wait_sdroot() {
  33. ##Stall execution if the micro-sd card isn't mounted yet, iCamera controls this internally.
  34. while true
  35. do
  36. if [[ -d /media/mmc/wz_mini ]] || [[ -d /media/mmcblk0p1/wz_mini ]]; then
  37. echo "sd card ready"
  38. break
  39. fi
  40. echo "sdcard not ready yet..."
  41. sleep 5
  42. done
  43. }
  44. store_mac() {
  45. echo "store original mac"
  46. cat /sys/class/net/wlan0/address | tr '[:lower:]' '[:upper:]' > /opt/wz_mini/tmp/wlan0_mac
  47. }
  48. wait_wlan() {
  49. ##Check if the driver has been loaded for the onboard wlan0, store the MAC.
  50. while true
  51. do
  52. if ifconfig wlan0 | grep "inet addr";
  53. then
  54. store_mac
  55. break
  56. elif [[ "$ENABLE_USB_ETH" == "true" || "$ENABLE_USB_DIRECT" == "true" ]]; then
  57. store_mac
  58. break
  59. fi
  60. echo " wlan0 not ready yet..."
  61. sleep 5
  62. done
  63. }
  64. rename_interface() {
  65. ##Fool iCamera by renaming the hardline interface to wlan0
  66. echo "renaming interfaces"
  67. ifconfig $1 down
  68. ifconfig wlan0 down
  69. /media/mmc/wz_mini/bin/busybox ip link set wlan0 name wlanold
  70. /media/mmc/wz_mini/bin/busybox ip addr flush dev wlanold
  71. /media/mmc/wz_mini/bin/busybox ip link set $1 name wlan0
  72. eth_wlan_up
  73. }
  74. eth_wlan_up() {
  75. ##Run DHCP client, and bind mount our fake wpa_cli.sh to fool iCamera
  76. ifconfig wlan0 up
  77. pkill udhcpc
  78. udhcpc -i wlan0 -x hostname:$HOSTNAME -p /var/run/udhcpc.pid -b
  79. if [[ "$V2" == "true" ]]; then
  80. mount -o bind /media/mmc/wz_mini/bin/wpa_cli.sh /system/bin/wpa_cli
  81. else
  82. mount -o bind /media/mmc/wz_mini/bin/wpa_cli.sh /bin/wpa_cli
  83. fi
  84. break
  85. }
  86. wpa_check() {
  87. #Check if wpa_supplicant has been created by iCamera
  88. if [[ -e /tmp/wpa_supplicant.conf ]]; then
  89. echo "wpa_supplicant.conf ready"
  90. wlanold_check $1
  91. else
  92. echo "wpa_supplicant.conf not ready, wait some time for creation."
  93. COUNT=0
  94. ATTEMPTS=15
  95. until [[ -e /tmp/wpa_supplicant.conf ]] || [[ $COUNT -eq $ATTEMPTS ]]; do
  96. echo -e "$(( COUNT++ ))... \c"
  97. sleep 5
  98. done
  99. [[ $COUNT -eq $ATTEMPTS ]] && echo "time exceeded waiting for iCamera, continue potentially broken condition without network." && wlanold_check $1
  100. fi
  101. }
  102. wlanold_check() {
  103. #Have we renamed interfaces yet?
  104. if [[ -d /sys/class/net/wlanold ]]; then
  105. echo "wlanold exist"
  106. eth_wlan_up
  107. else
  108. echo "wlanold doesn't exist"
  109. rename_interface $1
  110. fi
  111. }
  112. netloop() {
  113. ##While loop for check
  114. while true
  115. do
  116. wpa_check $1
  117. echo "wlan0 not ready yet..."
  118. sleep 5
  119. done
  120. }
  121. swap_enable() {
  122. if [[ -e /media/mmc/wz_mini/swap ]]; then
  123. echo "Swap exists, enable"
  124. swapon /media/mmc/wz_mini/swap
  125. else
  126. echo "Swap file missing!"
  127. fi
  128. }
  129. dmesg_log() {
  130. DMESG_LOG=/opt/wz_mini/log/dmesg
  131. if [[ -e $DMESG_LOG.log || -L $DMESG_LOG.log ]] ; then
  132. i=0
  133. while [[ -e $DMESG_LOG.log.$i || -L $DMESG_LOG.log.$i ]] ; do
  134. let i++
  135. done
  136. mv $DMESG_LOG.log $DMESG_LOG.log.$i
  137. DMESG_LOG=$DMESG_LOG
  138. fi
  139. touch -- "$DMESG_LOG".log
  140. dmesg > $DMESG_LOG.log 2>&1
  141. }
  142. first_run_check
  143. wait_sdroot
  144. wait_wlan
  145. if cat /params/config/.product_config | grep WYZEC1-JZ; then
  146. V2="true"
  147. KMOD_PATH="/opt/wz_mini/lib/modules/3.10.14_v2"
  148. else
  149. V2="false"
  150. KMOD_PATH="/opt/wz_mini/lib/modules/3.10.14__isvp_swan_1.0__"
  151. fi
  152. if [[ "$ENABLE_SWAP" == "true" ]]; then
  153. if cat /proc/swaps | grep "mini" ; then
  154. echo "Swap is already enabled"
  155. else
  156. echo "Swap not enabled, enabling"
  157. swap_enable
  158. fi
  159. fi
  160. if [[ "$ENABLE_IPV6" == "true" ]]; then
  161. echo "ipv6 enabled"
  162. else
  163. echo "ipv6 disabled"
  164. sysctl -w net.ipv6.conf.all.disable_ipv6=1
  165. fi
  166. if [[ "$ENABLE_NFSv4" == "true" ]]; then
  167. insmod $KMOD_PATH/kernel/lib/oid_registry.ko
  168. insmod $KMOD_PATH/kernel/net/dns_resolver/dns_resolver.ko
  169. insmod $KMOD_PATH/kernel/fs/nfs/nfsv4.ko
  170. insmod $KMOD_PATH/kernel/net/sunrpc/auth_gss/auth_rpcgss.ko
  171. echo nfsv4 enabled
  172. else
  173. echo nfsv4 disabled
  174. fi
  175. if [[ "$ENABLE_IPTABLES" == "true" ]]; then
  176. if [[ "$V2" == "true" ]]; then
  177. echo "v2 has iptables built in"
  178. else
  179. insmod /lib/modules/3.10.14__isvp_swan_1.0__/kernel/net/netfilter/x_tables.ko
  180. insmod /lib/modules/3.10.14__isvp_swan_1.0__/kernel/net/ipv4/netfilter/ip_tables.ko
  181. insmod /lib/modules/3.10.14__isvp_swan_1.0__/kernel/net/ipv4/netfilter/ipt_REJECT.ko
  182. insmod /lib/modules/3.10.14__isvp_swan_1.0__/kernel/net/ipv4/netfilter/iptable_filter.ko
  183. insmod /lib/modules/3.10.14__isvp_swan_1.0__/kernel/net/ipv4/netfilter/iptable_mangle.ko
  184. echo "iptables ipv4 enabled"
  185. fi
  186. if [[ "$ENABLE_IPV6" == "true" ]]; then
  187. insmod $KMOD_PATH/kernel/net/ipv6/netfilter/ip6_tables.ko
  188. insmod $KMOD_PATH/kernel/net/ipv6/netfilter/ip6t_REJECT.ko
  189. insmod $KMOD_PATH/kernel/net/ipv6/netfilter/ip6table_filter.ko
  190. insmod $KMOD_PATH/kernel/net/ipv6/netfilter/ip6table_mangle.ko
  191. echo "iptables ipv6 enabled"
  192. fi
  193. else
  194. echo "iptables disabled"
  195. fi
  196. if [[ "$ENABLE_USB_ETH" == "true" ]]; then
  197. insmod $KMOD_PATH/kernel/drivers/net/usb/usbnet.ko
  198. insmod $KMOD_PATH/kernel/drivers/net/usb/asix.ko
  199. if [[ "$ENABLE_SWAP" == "true" ]]; then
  200. echo "swap already enabled"
  201. else
  202. swap_enable
  203. fi
  204. netloop eth0
  205. else
  206. echo "usb ethernet disabled"
  207. fi
  208. if [[ "$ENABLE_USB_DIRECT" == "true" ]]; then
  209. host_macaddr=$(echo $HOSTNAME|md5sum|sed 's/^\(..\)\(..\)\(..\)\(..\)\(..\).*$/02:\1:\2:\3:\4:\5/')
  210. if [[ "$V2" == "true" ]]; then
  211. echo connect > /sys/devices/platform/jz-dwc2/dwc2/udc/dwc2/soft_connect
  212. sleep 1
  213. devmem 0x10000040 32 0x0b800096
  214. sleep 1
  215. devmem 0x13500000 32 0x001100cc
  216. else
  217. #Set dwc2 ID_PIN driver memory
  218. devmem 0x13500000 32 0x001100cc
  219. devmem 0x10000040 32 0x0b000096
  220. #wipe the bits to set the ID_PIN, only for the V3.
  221. devmem 0x10000040 32 0x0b000FFF
  222. fi
  223. if [[ "$V2" == "false" ]]; then
  224. insmod /opt/wz_mini/lib/modules/3.10.14__isvp_swan_1.0__/kernel/drivers/usb/gadget/u_ether.ko
  225. insmod /opt/wz_mini/lib/modules/3.10.14__isvp_swan_1.0__/kernel/drivers/usb/gadget/usb_f_ncm.ko
  226. fi
  227. insmod $KMOD_PATH/kernel/drivers/usb/gadget/libcomposite.ko
  228. insmod $KMOD_PATH/kernel/drivers/usb/gadget/g_ncm.ko iManufacturer=wz_mini_ncm host_addr=$host_macaddr dev_addr=$USB_DIRECT_MAC_ADDR
  229. sleep 1
  230. if [[ "$ENABLE_SWAP" == "true" ]]; then
  231. echo "swap already enabled"
  232. else
  233. swap_enable
  234. fi
  235. #loop begin
  236. while true
  237. do
  238. wpa_check usb0
  239. echo "wlan0 not ready yet..."
  240. sleep 1
  241. done
  242. else
  243. echo "usb direct disabled"
  244. fi
  245. if [[ "$ENABLE_USB_RNDIS" == "true" ]]; then
  246. insmod $KMOD_PATH/kernel/drivers/net/usb/usbnet.ko
  247. insmod $KMOD_PATH/kernel/drivers/net/usb/cdc_ether.ko
  248. insmod $KMOD_PATH/kernel/drivers/net/usb/rndis_host.ko
  249. sleep 1
  250. if [[ "$ENABLE_SWAP" == "true" ]]; then
  251. echo "swap already enabled"
  252. else
  253. swap_enable
  254. fi
  255. #loop begin
  256. while true
  257. do
  258. wpa_check usb0
  259. echo "wlan0 not ready yet..."
  260. sleep 1
  261. done
  262. else
  263. echo "usb direct disabled"
  264. fi
  265. if [[ "$ENABLE_WIREGUARD" == "true" ]]; then
  266. insmod $KMOD_PATH/kernel/net/ipv4/tunnel4.ko
  267. insmod $KMOD_PATH/kernel/net/ipv4/ip_tunnel.ko
  268. insmod $KMOD_PATH/kernel/net/wireguard/wireguard.ko
  269. if [[ "$WIREGUARD_IPV4" != "" ]]; then
  270. if [ -d /opt/wz_mini/etc/wireguard ]; then
  271. echo "wireguard dir exists"
  272. else
  273. mkdir -p /opt/wz_mini/etc/wireguard
  274. fi
  275. if [ ! -f /opt/wz_mini/etc/wireguard/privatekey ]; then
  276. (umask 277 && /media/mmc/wz_mini/bin/wg genkey | /media/mmc/wz_mini/bin/busybox tee /opt/wz_mini/etc/wireguard/privatekey | /media/mmc/wz_mini/bin/wg pubkey > /opt/wz_mini/etc/wireguard/publickey)
  277. fi
  278. /media/mmc/wz_mini/bin/busybox ip link add dev wg0 type wireguard
  279. /media/mmc/wz_mini/bin/busybox ip address add dev wg0 $WIREGUARD_IPV4
  280. /media/mmc/wz_mini/bin/wg set wg0 private-key /opt/wz_mini/etc/wireguard/privatekey
  281. /media/mmc/wz_mini/bin/busybox ip link set wg0 up
  282. fi
  283. if [[ "$WIREGUARD_PEER_PUBLIC_KEY" != "" ]] && [[ "$WIREGUARD_PEER_ALLOWED_IPS" != "" ]] && [[ "$WIREGUARD_PEER_ENDPOINT" != "" ]] && [[ "$WIREGUARD_PEER_KEEP_ALIVE" != "" ]]; then
  284. /media/mmc/wz_mini/bin/wg set wg0 peer $WIREGUARD_PEER_PUBLIC_KEY allowed-ips $WIREGUARD_PEER_ALLOWED_IPS endpoint $WIREGUARD_PEER_ENDPOINT persistent-keepalive $WIREGUARD_PEER_KEEP_ALIVE
  285. /media/mmc/wz_mini/bin/busybox ip route add $WIREGUARD_PEER_ALLOWED_IPS dev wg0
  286. fi
  287. else
  288. echo "wireguard disabled"
  289. fi
  290. if [[ "$ENABLE_CIFS" == "true" ]]; then
  291. insmod $KMOD_PATH/kernel/fs/cifs/cifs.ko
  292. else
  293. echo "cifs disabled"
  294. fi
  295. if [[ "$ENABLE_USB_STORAGE" == "true" ]]; then
  296. insmod $KMOD_PATH/kernel/drivers/scsi/scsi_mod.ko
  297. insmod $KMOD_PATH/kernel/drivers/scsi/sd_mod.ko
  298. insmod $KMOD_PATH/kernel/drivers/usb/storage/usb-storage.ko
  299. else
  300. echo "usb_storage disabled"
  301. fi
  302. if [[ "$ENABLE_EXT4" == "true" ]]; then
  303. if [[ "$V2" == "true" ]]; then
  304. insmod $KMOD_PATH/kernel/lib/crc16.ko
  305. fi
  306. insmod $KMOD_PATH/kernel/fs/jbd2/jbd2.ko
  307. insmod $KMOD_PATH/kernel/fs/mbcache.ko
  308. insmod $KMOD_PATH/kernel/fs/ext4/ext4.ko
  309. else
  310. echo "ext4 disabled"
  311. fi
  312. if [[ "$DISABLE_FW_UPGRADE" == "true" ]]; then
  313. mkdir /tmp/Upgrade
  314. mount -t tmpfs -o size=1,nr_inodes=1 none /tmp/Upgrade
  315. echo -e "127.0.0.1 localhost \n127.0.0.1 wyze-upgrade-service.wyzecam.com" > /opt/wz_mini/tmp/.storage/hosts
  316. mount --bind /opt/wz_mini/tmp/.storage/hosts /etc/hosts
  317. else
  318. mkdir /tmp/Upgrade
  319. /opt/wz_mini/bin/busybox inotifyd /opt/wz_mini/usr/bin/watch_up.sh /tmp:n &
  320. fi
  321. if [[ "$REMOTE_SPOTLIGHT" == "true" ]]; then
  322. /media/mmc/wz_mini/bin/socat pty,link=/dev/ttyUSB0,raw tcp:$REMOTE_SPOTLIGHT_HOST:9000 &
  323. echo "remote accessory enabled"
  324. else
  325. echo "remote accessory disabled"
  326. fi
  327. if [[ "$ENABLE_MP4_WRITE" == "true" ]]; then
  328. if [[ "$V2" == "true" ]]; then
  329. echo "mp4_write not supported on v2"
  330. else
  331. /opt/wz_mini/bin/cmd mp4write on
  332. echo "mp4_write enabled"
  333. fi
  334. else
  335. echo "mp4 write disabled"
  336. fi
  337. if [[ "$RTSP_HI_RES_ENABLED" == "true" ]]; then
  338. if [[ "$V2" == "true" ]]; then
  339. HI_VIDEO_DEV="/dev/video6"
  340. else
  341. HI_VIDEO_DEV="/dev/video1"
  342. fi
  343. if [[ "$ENABLE_SWAP" == "true" ]]; then
  344. echo "swap already enabled"
  345. else
  346. swap_enable
  347. fi
  348. if [[ "$RTSP_PASSWORD" = "" ]]; then
  349. RTSP_PASSWORD=$(cat /opt/wz_mini/tmp/wlan0_mac)
  350. fi
  351. /opt/wz_mini/bin/cmd video on
  352. if [[ "$RTSP_HI_RES_ENABLE_AUDIO" == "true" ]]; then
  353. /opt/wz_mini/bin/cmd audio on
  354. AUDIO_CH="-C 1"
  355. AUDIO_FMT="-a S16_LE"
  356. DEVICE1="$HI_VIDEO_DEV,hw:Loopback,0"
  357. else
  358. DEVICE1="$HI_VIDEO_DEV"
  359. echo "rtsp audio disabled"
  360. fi
  361. if [[ "$RTSP_HI_RES_ENC_PARAMETER" != "" ]]; then
  362. if [[ "$V2" == "true" ]]; then
  363. watch -n30 -t "/system/bin/impdbg --enc_rc_s 0:0:4:$RTSP_LOW_RES_ENC_PARAMETER" > /dev/null 2>&1 &
  364. else
  365. watch -n30 -t "/system/bin/impdbg --enc_rc_s 0:44:4:$RTSP_HI_RES_ENC_PARAMETER" > /dev/null 2>&1 &
  366. fi
  367. fi
  368. if [[ "$RTSP_HI_RES_MAX_BITRATE" != "" ]]; then
  369. if [[ "$V2" == "true" ]]; then
  370. watch -n30 -t "/system/bin/impdbg --enc_rc_s 0:28:4:$RTSP_LOW_RES_MAX_BITRATE" > /dev/null 2>&1 &
  371. else
  372. watch -n30 -t "/system/bin/impdbg --enc_rc_s 0:52:4:$RTSP_HI_RES_MAX_BITRATE" > /dev/null 2>&1 &
  373. fi
  374. fi
  375. if [[ "$RTSP_HI_RES_TARGET_BITRATE" != "" ]]; then
  376. if [[ "$V2" == "true" ]]; then
  377. echo "not supported on v2"
  378. else
  379. watch -n30 -t "/system/bin/impdbg --enc_rc_s 0:48:4:$RTSP_HI_RES_TARGET_BITRATE" > /dev/null 2>&1 &
  380. fi
  381. fi
  382. if [[ "$RTSP_HI_RES_FPS" != "" ]]; then
  383. if [[ "$V2" == "true" ]]; then
  384. watch -n30 -t "/system/bin/impdbg --enc_rc_s 0:8:4:$RTSP_HI_RES_FPS" > /dev/null 2>&1 &
  385. else
  386. watch -n30 -t "/system/bin/impdbg --enc_rc_s 0:80:4:$RTSP_HI_RES_FPS" > /dev/null 2>&1 &
  387. fi
  388. fi
  389. else
  390. echo "rtsp disabled"
  391. fi
  392. if [[ "$RTSP_LOW_RES_ENABLED" == "true" ]]; then
  393. if [[ "$V2" == "true" ]]; then
  394. LOW_VIDEO_DEV="/dev/video7"
  395. else
  396. LOW_VIDEO_DEV="/dev/video2"
  397. fi
  398. if [[ "$ENABLE_SWAP" == "true" ]]; then
  399. echo "swap already enabled"
  400. else
  401. swap_enable
  402. fi
  403. /opt/wz_mini/bin/cmd video on1
  404. if [[ "$RTSP_PASSWORD" = "" ]]; then
  405. RTSP_PASSWORD=$(cat /opt/wz_mini/tmp/wlan0_mac)
  406. fi
  407. if [[ "$RTSP_LOW_RES_ENABLE_AUDIO" == "true" ]]; then
  408. /opt/wz_mini/bin/cmd audio on1
  409. AUDIO_CH="-C 1"
  410. AUDIO_FMT="-a S16_LE"
  411. DEVICE2="$LOW_VIDEO_DEV,hw:Loopback,1"
  412. else
  413. DEVICE2="$LOW_VIDEO_DEV"
  414. echo "rtsp audio disabled"
  415. fi
  416. if [[ "$RTSP_LOW_RES_ENC_PARAMETER" != "" ]]; then
  417. if [[ "$V2" == "true" ]]; then
  418. watch -n30 -t "/system/bin/impdbg --enc_rc_s 1:0:4:$RTSP_LOW_RES_ENC_PARAMETER" > /dev/null 2>&1 &
  419. else
  420. watch -n30 -t "/system/bin/impdbg --enc_rc_s 1:44:4:$RTSP_LOW_RES_ENC_PARAMETER" > /dev/null 2>&1 &
  421. fi
  422. fi
  423. if [[ "$RTSP_LOW_RES_MAX_BITRATE" != "" ]]; then
  424. if [[ "$V2" == "true" ]]; then
  425. watch -n30 -t "/system/bin/impdbg --enc_rc_s 1:28:4:$RTSP_LOW_RES_MAX_BITRATE" > /dev/null 2>&1 &
  426. else
  427. watch -n30 -t "/system/bin/impdbg --enc_rc_s 1:52:4:$RTSP_LOW_RES_MAX_BITRATE" > /dev/null 2>&1 &
  428. fi
  429. fi
  430. if [[ "$RTSP_LOW_RES_TARGET_BITRATE" != "" ]]; then
  431. if [[ "$V2" == "true" ]]; then
  432. echo "not supported on v2"
  433. else
  434. watch -n30 -t "/system/bin/impdbg --enc_rc_s 1:48:4:$RTSP_LOW_RES_TARGET_BITRATE" > /dev/null 2>&1 &
  435. fi
  436. fi
  437. if [[ "$RTSP_LOW_RES_FPS" != "" ]]; then
  438. if [[ "$V2" == "true" ]]; then
  439. watch -n30 -t "/system/bin/impdbg --enc_rc_s 1:8:4:$RTSP_LOW_RES_FPS" > /dev/null 2>&1 &
  440. else
  441. watch -n30 -t "/system/bin/impdbg --enc_rc_s 1:80:4:$RTSP_LOW_RES_FPS" > /dev/null 2>&1 &
  442. fi
  443. fi
  444. else
  445. echo "rtsp disabled"
  446. fi
  447. if [[ "$RTSP_LOW_RES_ENABLED" == "true" ]] || [[ "$RTSP_HI_RES_ENABLED" == "true" ]]; then
  448. LD_LIBRARY_PATH=/media/mmc/wz_mini/lib /media/mmc/wz_mini/bin/v4l2rtspserver $AUDIO_CH $AUDIO_FMT -U $RTSP_LOGIN:$RTSP_PASSWORD -P $RTSP_PORT $DEVICE1 $DEVICE2 &
  449. fi
  450. hostname_set
  451. touch /opt/wz_mini/tmp/.run_mmc_firstrun
  452. pkill -f dumpload #Kill dumpload so it won't waste cpu or ram gathering cores when something crashes
  453. sysctl -w kernel.core_pattern='|/bin/false'
  454. dmesg_log
  455. sync;echo 3 > /proc/sys/vm/drop_caches
  456. if [ -f "$CUSTOM_SCRIPT_PATH" ]; then
  457. echo "starting custom script"
  458. $CUSTOM_SCRIPT_PATH &
  459. else
  460. echo "custom script not found"
  461. fi