#!/bin/sh

#####changed by huangmin for modem mode when modem crash, 2013.07.11 begin
#####changed by huangmin for log print, 2013.07.18 begin
if [ -f /usr/zte/zte_conf/config/crash_reboot.flg ]; then
	#reboot instead of turn to download mode when kernel panic
	if [ x`cat /sys/class/android_usb/android0/download` = x"NORMAL" ]; then
		echo "default process for crash: reboot" > /tmp/crash_mode.log
		echo 1 > /proc/sys/kernel/panic
		echo 0 > /sys/module/restart/parameters/download_mode
	else
		echo "default process for crash: download" > /tmp/crash_mode.log
	fi
else
	echo "default process for crash--no crash_reboot.flg: download" > /tmp/crash_mode.log
fi
#####changed by huangmin for log print, 2013.07.18 end
#####changed by huangmin for modem mode when modem crash, 2013.07.11 end

date -s "2012-04-01 00:00:00"
#zte_fota

#################### Factory Restore Function Begin ######################
factory_restore()
{
	echo "start restore configs." >> /tmp/restore.log
	#restore nvconfig
	#rm /usr/zte/zte_conf/config/userseting_nvconfig.txt || echo "can not remove userseting_nvconfig.txt" >> /tmp/restore.log
	#restore dnsmasq
	rm /usr/zte/zte_conf/config/dnsmasq.conf || echo "can not remove /usr/zte/zte_conf/config/dnsmasq.conf" >> /tmp/restore.log
	cp /usr/zte_web/web/copy/etc/dnsmasq.conf /usr/zte/zte_conf/config/dnsmasq.conf || echo "can not copy /usr/zte_web/web/copy/etc/dnsmasq.conf" >> /tmp/restore.log
	#restore xxx
	rm /etc/factory_restore || echo "fatal error: can not remove flag /etc/factory_restore" >> /tmp/restore.log
	echo "restore configs finished." >> /tmp/restore.log
}

factory_restore_probe()
{
	if [ -f /etc/factory_restore ]; then
		echo "need restore configs..." >> /tmp/restore.log
		factory_restore
	else
	    echo "no need restore configs." >> /tmp/restore.log
	fi
}

userdata_restore_probe()
{
	#check if restore ztedata
	if [ -f /etc/userdata_restore_flag ]; then
		rm /etc/userdata_restore_flag || echo "fatal error: can not remove /etc/userdata_restore_flag" >> /tmp/restore.log
		echo "need restore userdata..." >> /tmp/restore.log
		######## restore sms and phonebook here ########
		rm /usr/zte/web/sms_db/sms.db || echo "can not remove /usr/zte/web/sms_db/sms.db" >> /tmp/restore.log
		rm /usr/zte/web/pbm_db/pbm.db || echo "can not remove /usr/zte/web/pbm_db/pbm.db" >> /tmp/restore.log
		######## restore userdata here ########
		echo "restore userdata finished." >> /tmp/restore.log
	else
		echo "no need restore userdata." >> /tmp/restore.log
	fi
}
### this must be the first to run ###
echo 0 >/sys/module/pm_8x60/modes/cpu0/power_collapse/idle_enabled
echo 0 >/sys/module/pm_8x60/modes/cpu0/power_collapse/suspend_enabled
echo "checking for restore..." > /tmp/restore.log
echo "start time: `date`" >> /tmp/restore.log
userdata_restore_probe
factory_restore_probe
echo "end time  : `date`" >> /tmp/restore.log

################### cfg init ###########################################
insmod /usr/lib/modules/3.4.0+/kernel/drivers/cfg/cfg.ko
mknod /dev/flash0 c 200 0
mknod /dev/flash1 c 200 1
nvram

#Start ZTE syslog
zte_syslog_start()
{
  syslog_mode=`cfg get syslog_mode`

  if [ $syslog_mode = 0 ]; then
    syslog_path=`cfg get syslog_path`
    syslog_level=`cfg get syslog_level`
    syslog_size=`cfg get syslog_size`
    /usr/zte/zte_conf/scripts/zte_syslog.sh -L -o $syslog_path -l $syslog_level -s $syslog_size
  else
    if [ $syslog_mode = 1 ]; then
      syslog_host_ip=`cfg get syslog_host_ip` 
      /usr/zte/zte_conf/scripts/zte_syslog.sh -R $syslog_host_ip
    else
      /usr/zte/zte_conf/scripts/zte_syslog.sh -L
    fi
fi
}
zte_syslog_start

#################### Factory Restore Function End ######################
set_passwd()
{
	echo "root:zte9x15" > /tmp/tmppw
	chpasswd < /tmp/tmppw
	rm -rf /tmp/tmppw
}
set_passwd
#start up telnetd for debug use
# telnetd
#################### Add zte programs below ####################
ifconfig lo up
zte_usb_ctl &

#cfg will start zte_topsw_daemon
zte_topsw_cfg &
zte_topsw_sleep &
#zte_fota_vd &
updater standalone &
zte_dm &

sh /usr/ui/startdui.sh
#protect the adbd daemon,if daemon is not running,run it###
start-stop-daemon -S -b -a /sbin/adbd
