run_mmc.sh 12 KB

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