run_mmc.sh 14 KB

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