#!/bin/sh

#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"
    echo 1 > /proc/sys/kernel/panic
    echo 0 > /sys/module/restart/parameters/download_mode
else
    echo "default process for crash: download"
fi

mkdir -p /usr/zte_web/web/zte_log
#date -s "2012-04-01 00:00:00"
#zte_fota

# Enable AR9344 power
echo 4 > /sys/class/gpio/export
echo out > /sys/class/gpio/gpio4/direction
echo 0 > /sys/class/gpio/gpio4/value

#################### 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 "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

#################### 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 &
atfwd_daemon &
zte_fota_vd &

#####################For CS voice#####################
mkdir /data
rm /data/alsaucm_test
alsaucm_test 1>/data/voice.log 2>&1 &
sleep 1
echo "open snd_soc_msm_2x" > /data/alsaucm_test
echo "set _verb Voice Call" > /data/alsaucm_test
echo "set _enadev Auxpcm Rx" > /data/alsaucm_test
echo "set _enadev Auxpcm Tx" > /data/alsaucm_test
sleep 3
aplay -D hw:0,2 -P 1>>/data/voice.log 2>&1 &
#sleep 1
arec -D hw:0,2 -P -R 8000 -C 1 1>>/data/voice.log 2>&1 &
#sleep 1
echo "volume volume 60" > /data/alsaucm_test
#sleep 1
zte_topsw_csphone &

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