run_mmc.sh 10 KB

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