wz_user.sh 14 KB

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