#!/bin/sh

MODDIR=/lib/modules
echo "init frontpanel"
insmod $MODDIR/aotom.ko
insmod $MODDIR/simu_button.ko
if [ -e $MODDIR/encrypt.ko ]; then
	insmod $MODDIR/encrypt.ko
fi

if [ -e /var/etc/.firstboot ]; then
   echo "WAIT RUN" >/dev/vfd
   echo "WAIT 1st start"
   rm /var/etc/.firstboot
   sleep 1
   touch /dev/.devfsd
fi

/etc/init.d/mountvirtfs start

/etc/init.d/portmap start

insmod $MODDIR/e2_proc.ko

if [ ! -e /var/etc/.firstboot ]; then

   echo "Starting DEBUG Interface"
   /etc/init.d/mountall start
   /etc/init.d/hostname start

   echo "starting telnetd"
   /usr/sbin/telnetd -l /bin/login

   echo "init stmfb"
   insmod $MODDIR/stmcore-display-sti7105.ko

   if  grep -q "config.av.videoport=Scart" /etc/enigma2/settings; then
     insmod $MODDIR/stmfb.ko display0=720x576i-32@50:15m:pal:yuv:yuv;#SCART
   else
     insmod $MODDIR/stmfb.ko display0=1280x720-32@50:15m:pal:yuv:yuv;#HDMI
   fi

   echo "LOADING MODULES"   
   echo " TRIPLEX" > /dev/vfd
   
   # turn off power led
   fp_control -l 0 0

   echo "load a firmware"
   if [ -e /boot/audio_dts.elf ]; then
       /bin/ustslave /dev/st231-1 /boot/audio_dts.elf
   else
       /bin/ustslave /dev/st231-1 /boot/audio.elf
   fi
   echo "load v firmware"
   /bin/ustslave /dev/st231-0 /boot/video.elf

   echo "init embx"
   insmod $MODDIR/embxshell.ko
   insmod $MODDIR/embxmailbox.ko mailbox0=0xfe211000:136:set2 mailbox1=0xfe212000:0 ;
   insmod $MODDIR/embxshm.ko mailbox0=shm:0:7:0x60000000:0:256:256:0:512:0x40000000:0x10000000 ;
   insmod $MODDIR/mme_host.ko transport0=shm

   echo "init AVS"
   insmod $MODDIR/avs.ko type=avs_pio #type=spark_avs #type=stv6417

   player=`cat /proc/stb/player/version`
   player=`cat /proc/stb/player/version | awk '{ print substr( $0, length($0) - 2, length($0) ) }'`
   echo "init player $player"

   insmod $MODDIR/mmelog.ko
   insmod $MODDIR/ksound.ko
   insmod $MODDIR/p2div64.ko
   insmod $MODDIR/stm_v4l2.ko
#   if [ $player -gt 131 ]; then
#      insmod $MODDIR/stmvout.ko
#      insmod $MODDIR/stmvbi.ko
#   fi
   insmod $MODDIR/pseudocard.ko

   tuner=`cat /var/config/tuner.conf`
   insmod $MODDIR/spark7162.ko $tuner

   if [ $player -gt 131 ]; then
      if [ -e $MODDIR/pti_fta.ko ]; then
      	insmod $MODDIR/pti_fta.ko
      else
	insmod $MODDIR/pti.ko waitMS=20 videoMem=4096
      fi
      insmod $MODDIR/stm_monitor.ko
      insmod $MODDIR/stmsysfs.ko
      insmod $MODDIR/stmdvb.ko
      #/etc/init.d/stmdvb_check
   else
      insmod $MODDIR/pti.ko
      #insmod $MODDIR/stmdvb.ko
      /etc/init.d/stmdvb_check
      insmod $MODDIR/stm_monitor.ko
   fi	
   insmod $MODDIR/player2.ko discardlateframe=0
   insmod $MODDIR/sth264pp.ko
   insmod $MODDIR/stmalloc.ko
   insmod $MODDIR/platform.ko
   insmod $MODDIR/silencegen.ko

   insmod $MODDIR/bpamem.ko
   mknod /dev/bpamem c 153 0

   showiframe -p /boot/bootlogo.mvi &
   stfbcontrol a 0

   echo "init lircd"
   /usr/bin/lircd

   mknod /dev/rc c 147 1

   major=$(awk "\$2==\"sparkid\" {print \$1}" /proc/devices)
   rm -f /dev/sparkid
   mknod /dev/sparkid c $major 0 

   /bin/evremote2 spark 100 &
   #/bin/evremote2 10 120 &

   # timefix e2
   # date -s "121220001970"

   stfbcontrol a 255

   /etc/init.d/mountall start
   /etc/init.d/hostname start

   echo "starting telnetd"
   /usr/sbin/telnetd -l /bin/login
   /etc/init.d/vsftpd start
   /usr/sbin/inetd

   NFS=$(grep -c 'nfs' /proc/cmdline)
   if [ "$NFS" -eq "1" ]; then 
      echo "Booting from nfs, don't set network" 
   else 
   #Network & restore backup management
    if [ -e /var/etc/1stboot ]; then
	echo "detected 1stboot - no network configured"
	BACKUP=`findfs LABEL=RECOVERY`
	if [ -n "$BACKUP" ]; then
		mount $BACKUP /hdd
		if [ -e /hdd/backup/autorestore.sh ]; then
			echo "Autorestore" > /dev/vfd
			echo "Autorestore"
			/hdd/backup/autorestore.sh
		fi
		umount /hdd
	fi  
    else
       if [ -e /etc/network/interfaces ]; then
        . /var/config/wlan.conf
        if [ $wlan == off ]; then
            /etc/init.d/networking start &
        else
            insmod /lib/modules/$wlan''.ko
            echo "$wlan driver loaded"
            /etc/init.d/networking restart &
        fi
       fi
    fi
   fi

   #init rc.modules
   /var/config/rc.modules

   #init rc.local
   /var/config/rc.local

   until false
   do
	  python /usr/lib/enigma2/python/Plugins/Extensions/PKT/progress 60 MINI &
      echo "starting e2->"
      /usr/local/bin/enigma2.sh
      rtv=$?
      cp /tmp/reference.dat /var/bin
      echo "e2 ended <- RTV: " $rtv
      case "$rtv" in
		0) echo "0"
		   echo "E2 ERROR"
      		   init 6;;
		1) echo "1"
		   echo "SHUTDOWN"
		   fp_control -i 46 0
		   init 0;;
		2) echo "2"
		   echo "REBOOT"
		   echo Reboot > /dev/vfd
		   init 6;;
		3) echo "3"
		   echo "E2 RESTART"
		   echo Restart > /dev/vfd
		   echo "0" > /proc/progress
		   showiframe -p /boot/bootlogo.mvi &;;
		*) echo "*"
		   echo "ERROR"
		   echo "0" > /proc/progress
		   showiframe -p /boot/bootlogo.mvi &;;
      esac
   done 
fi

#never reached
echo "REBOOT" > /dev/vfd
echo "REBOOT SPARK"
reboot -f
