run_mmc.sh 12 KB

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