3 #/etc/sudoers needs to be adjusted if you touch any of the sudo lines
5 # look at the comments in the CLOSE_X part, adjust
6 #use "lsof /usr/lib/libX11.so.6 | awk '{print $1}'| sort | uniq > whitelist" with nothing running to generate the whitelist
8 #todo - no proper order
9 #validate params better
10 #make uid/pnd_name mandatory (and rename var, its confusing!)
11 #find a clean way of shutting down x without a fixed dm, mabye avoid nohup usage somehow
12 #add options to just mount iso without union and to mount the union later
14 #SCRIPT_DIR=$(echo $(dirname $(which $0))|sed 's#^\.#'"$(pwd)"'#')
15 #. $SCRIPT_DIR/pnd_loging
16 #PND_LogDateFormat=PND_Time
18 PND_MOUNT_DIR="/mnt/pnd"
19 UNION_MOUNT_DIR="/mnt/utmp"
20 CPUSPEEDSCRIPT=/usr/pandora/scripts/op_cpuspeed.sh
22 #=============================================================================
27 if [ $(ps -o tty,pid 2>/dev/null|grep $$|awk 'BEGIN{R=0}/pts/{R=1}END{print R}') -eq 1 ];then
29 exec 3>&1 # duplicate stdout so we can still write to screen after the log redirect
32 echo "======================================================================================="
33 for v in $PND_HEADER;do
34 printf "%-15s : %s\n" "$v" "$(eval "echo \${$v:-'<unset>'}")"
36 echo "======================================================================================="
41 awk 'BEGIN{R=0}END{exit R}
42 /cannot open display/||/unary operator expected/||/No such file or directory/||/command not found/{R=R+1}
44 !/gpg-error/&&/ERROR/||/FAILED/{R=R+1}
45 {IGNORECASE=0}' < "$PND_LOG"
51 RC=$(( $RC + $? )) # trying to find error in the logs
53 echo "======================================================================================="
54 echo "Return code is : $RC"
60 export PND_TASK_NAME="$*"
61 echo "[ START ]--- $PND_TASK_NAME ----------"
62 if [ $PND_isInteractive -eq 1 ];then
63 printf "$PND_TASK_NAME" >&3
80 printf "[%7s]--- $PND_TASK_NAME ----------\n" "$STATUS"
81 if [ $PND_isInteractive -eq 1 ];then
82 printf "\r%s\033[70G[$COLOR%7s\033[m]\n" "$PND_TASK_NAME" "$STATUS" >&3
89 [ $# -gt 0 ]||return 1
91 local l_name=${2:-"Wait succes of $1"}
93 local l_sleep=${4:-10}
96 while [ $C -lt $l_cnt ] && ! eval $l_test;do
97 sleep $l_sleep;C=$(($C + 1));
105 PID=$(pidof -o %PPID -x "$1") # get pid of app
106 while [ -n "$PID" ]; do
108 test $l_sleep -lt 10 && l_sleep=$(($l_sleep + 1))
109 PID=$(pidof -o %PPID -x "$1")
116 if [ $PND_ISEXEC -eq 0 ];then
120 export PND_INTERACTIVE=2
122 RES=$(( $? + $PND_ERRORS ))
123 echo "<result>$RES</result>"
128 if echo "$line"|grep -q "<result>.*</result>";then
129 return $(( $(echo $line|sed 's/<[^>]*>//g') + $PND_ERRORS ))
130 elif ! echo "$line"| $(eval $PND_OUT_CHECK); then
142 #=============================================================================
148 pnd_run.sh -p file.pnd -e cmd [-a args] [-b pndid] [-s path] [-c speed] [-d [path]] [-x] [-m] [-u] [-- more_args]
149 -p file.pnd : Specify the pnd file to execute
150 -e cmd : Command to run
151 -a args : Arguments to the command
152 -b pndid : name of the directory mount-point ($UNION_MOUNT_DIR/pndid) (Default: name of the pnd file)
153 -s path : Directory in the union to start the command from
154 -o speed : Set the CPU speed
155 -d [path] : Use path as source of the overlay. (Default: pandora/appdata/pndid)
156 -x : Stop X before starting the apps
157 -m : Only mount the pnd, dont run it (-e become optional)
158 -u : Only umount the pnd, dont run it (-e become optional)
160 If '--' is specified, all subsequent arguments are passed through to the command
161 (useful if you want to pass quotes and weird chars to the command)
166 for p in $(fuser -m $1 2>/dev/null);do ps hf $p;done
170 #=============================================================================
171 # CPU speed functions
173 cat /proc/pandora/cpu_mhz_max
178 if ! [ -f "$CPUSPEED_FILE" ] && [ ! -z "$PND_CPUSPEED" ]; then
179 if [ ${PND_CPUSPEED} -gt $(PND_getCPUSpeed) ]; then
180 CURRENTSPEED=$(PND_getCPUSpeed)
181 case "$(zenity --title="set cpu speed" --height=350 --list --column "id" --column "Please select" --hide-column=1 \
182 --text="$PND_NAME suggests to set the cpu speed to $PND_CPUSPEED MHz to make it run properly.\n\n Do you want to change the cpu speed? (current speed: $(PND_getCPUSpeed) MHz)\n\nWarning: Setting the clock speed above 600MHz can be unstable and it NOT recommended!" \
183 "yes" "Yes, set it to $PND_CPUSPEED MHz" \
184 "custom" "Yes, select custom value" \
185 "yessave" "Yes, set it to $PND_CPUSPEED MHz and don't ask again" \
186 "customsave" "Yes, set it to custom speed and don't ask again" \
187 "no" "No, don't change the speed" \
188 "nosave" "No, don't chage the speed and don't ask again")" in
190 sudo $CPUSPEEDSCRIPT $PND_CPUSPEED
197 zenity --info --title="Note" --text="Speed saved.\n\nTo re-enable this dialogue, please delete the file\n$CPUSPEED_FILE"
198 PND_getCPUSpeed > $CPUSPEED_FILE
201 zenity --info --title="Note" --text="Speed saved.\n\nTo re-enable this dialogue, please delete the file\n$CPUSPEED_FILE"
202 sudo $CPUSPEEDSCRIPT $PND_CPUSPEED
203 PND_getCPUSpeed > $CPUSPEED_FILE
207 zenity --info --title="Note" --text="Speed will not be changed.\n\nTo re-enable this dialogue, please delete the file\n$CPUSPEED_FILE"
208 echo 9999 > $CPUSPEED_FILE
210 *) unset CURRENTSPEED;;
213 elif [ "$PND_CPUSPEED" -lt "1500" ]; then
214 CURRENTSPEED=$(PND_getCPUSpeed)
215 echo Setting to CPU-Speed $PND_CPUSPEED MHz
216 sudo $CPUSPEEDSCRIPT $PND_CPUSPEED
220 PND_resetCPUSpeed() {
221 if [ ! -z "$CURRENTSPEED" ]; then
222 sudo $CPUSPEEDSCRIPT $CURRENTSPEED
226 #=============================================================================
227 # X management functions
230 if [ $CLOSE_X ]; then #the app doesnt want x to run, so we kill it and restart it once the app quits
231 if [ ! $(pidof X) ]; then
234 applist=$(lsof /usr/lib/libX11.so.6 | awk '{print $1}'| sort | uniq)
235 whitelist=$(cat ~/pndtest/whitelist) #adjust this to a fixed whitelist, maybe in the config dir
236 filteredlist=$(echo -e "$applist\n\n$whitelist\n\n$whitelist" | sort | uniq -u) #whitelist appended two times so those items are always removed
237 if [ ${#filteredlist} -ge 1 ]; then
238 message=$(echo -e "The following applications are still running, are you sure you want to close x? \n$filteredlist")
239 echo -e "?ae[34me[30m?"
240 xmessage -center "$message", -buttons yes,no
241 if [ $? = 102 ]; then
244 sudo /etc/init.d/slim-init stop
247 echo -e "?ae[34me[30m?"
248 xmessage -center "killing x, nothing of value will be lost", -buttons ok,cancel
249 if [ $? = 102 ]; then
252 # close x now, do we want to use slim stop or just kill x?
253 sudo /etc/init.d/slim-init stop
261 if [ $CLOSE_X ]; then #restart x if it was killed
262 # We need to wait a bit, doing it nicely ;)
264 sudo /etc/init.d/slim-init start
269 #=============================================================================
270 # (u)Mounting functions
274 echo "Loopback devices :"
275 sudo /sbin/losetup -a
276 echo "Are mounted on :"
278 echo "For these Union :"
283 mount | grep -q "on $UNION_MOUNT_DIR/${PND_NAME} type aufs"
287 mount |grep -v aufs | grep -q "on $PND_MOUNT_DIR/${PND_NAME} type" || \
288 mount |grep -v aufs | grep -q "on $UNION_MOUNT_DIR/${PND_NAME} type"
292 [ -z "$(list_using_fs "$PND_MOUNT_DIR/$PND_NAME")" ]
295 noMoreProcessUnion() {
296 [ -z "$(list_using_fs "$UNION_MOUNT_DIR/$PND_NAME")" ]
300 MOUNT_TARGET="${1:-$PND_MOUNT_DIR}"
301 if ! is_pnd_mounted;then
302 #check if pnd is already attached to loop
303 LOOP=$(/sbin/losetup -a | grep "$PND" | tail -n1 | awk -F: '{print $1}')
304 #check if the loop device is already mounted
305 if ! [ -z "$LOOP" ];then
306 echo "Found a loop ($LOOP), using it"
307 loopmountedon=$( mount | grep "$(mount | grep "$LOOP" | awk '{print $3}')" | grep utmp | awk '{print $3}' )
311 if [ ! "$loopmountedon" ]; then #check if the pnd is already attached to some loop device but not used
314 if [ ! "$LOOP" ]; then
315 FREELOOP=$(/sbin/losetup -f) #get first free loop device
316 if [ ! "$FREELOOP" ]; then # no free loop device, create a new one
317 #find a free loop device and use it
318 usedminor=$(/sbin/losetup -a | tail -n1|sed 's/.*loop\(.*\)\: .*/\1/')
319 #usedminor=${usedminor:9:1}
320 freeminor=$(($usedminor+1))
321 echo "Creating a new device : mknod -m777 /dev/loop$freeminor b 7 $freeminor"
322 mknod -m777 /dev/loop$freeminor b 7 $freeminor
323 FREELOOP=/dev/loop$freeminor
330 /sbin/losetup -r $FREELOOP "$PND" #attach the pnd to the loop device
331 mntline="mount -o ro" #setup the mountline for later
335 #we bind the folder, now it can be treated in a unified way
336 #ATENTION: -o ro doesnt work for --bind at least on 25, on 26 its possible using remount, may have changed on 27
337 mntline="mount --bind -o ro"
341 /sbin/losetup -r $FREELOOP "$PND" #attach the pnd to the loop device
342 mntline="mount -t squashfs -o ro"
346 echo "ERROR Unknown filesystem type : $PND_FSTYPE"
349 echo "Mounting : $mntline \"$mntdev\" \"$MOUNT_TARGET/${PND_NAME}\""
350 $mntline "$mntdev" "$MOUNT_TARGET/${PND_NAME}" #mount the pnd/folder
352 if ! is_pnd_mounted ;then
354 echo "WARNING : mount faild, re-tring"
356 $mntline "$mntdev" "$MOUNT_TARGET/${PND_NAME}" #mount the pnd/folder
357 if ! is_pnd_mounted ;then
358 echo "ERROR The PND File-system is not mounted !"
363 else #the pnd is already mounted but a mount was requested with a different basename/uid, just link it there
364 echo WARNING $LOOP already mounted on $loopmountedon skipping losetup - putting link to old mount
366 rmdir "$UNION_MOUNT_DIR/$PND_NAME"
367 ln -s $loopmountedon "$UNION_MOUNT_DIR/$PND_NAME"
371 # For backward compatibility
372 if [[ "$MOUNT_TARGET" != "$PND_MOUNT_DIR" ]];then
373 if [ -h "$PND_MOUNT_DIR/$PND_NAME" ];then
374 rm "$PND_MOUNT_DIR/$PND_NAME"
376 rmdir "$PND_MOUNT_DIR/$PND_NAME"
378 if [ ! -e "$PND_MOUNT_DIR/$PND_NAME" ];then
379 ln -s "$MOUNT_TARGET/$PND_NAME" "$PND_MOUNT_DIR/$PND_NAME"
385 if [ $(id -u) -ne 0 ];then
386 sudo /usr/pandora/scripts/pnd_run.sh -m -p "$PND" -b "$PND_NAME"
387 if ! is_union_mounted;then
388 echo "ERROR: The Union File-system is not mounted !"
394 #create mountpoints, check if they exist already first to avoid annoying error messages
395 if ! [ -d "$PND_MOUNT_DIR/${PND_NAME}" ]; then
396 mkdir -p "$PND_MOUNT_DIR/${PND_NAME}" #mountpoint for iso, ro
398 #writeable dir for union
399 if ! [ -d "${APPDATADIR}" ]; then
400 mkdir -p "${APPDATADIR}"
401 chmod -R a+xrw "${APPDATADIR}" 2>/dev/null
403 # create the union mountpoint
404 if ! [ -d "$UNION_MOUNT_DIR/${PND_NAME}" ]; then
405 mkdir -p "$UNION_MOUNT_DIR/${PND_NAME}" # union over the two
407 #is the union already mounted? if not mount evrything, else launch the stuff
408 if ! is_union_mounted;then
409 if ! is_pnd_mounted;then
410 mountPnd "$UNION_MOUNT_DIR"|| return 2; # quit mounting the union if the PND first didnt mount
412 echo "WARNING The PND is already mounted, using it"
415 RO=0;for o in $(mount|awk '$3=="'$MOUNTPOINT'"{print $6}'|sed 's/.*(//;s/)$//;s/,/ /g');do [[ $o = "ro" ]]&& RO=1;done
416 if [ $RO -eq 1 ];then
417 echo "WARNING SD-Card is mounted Read-only !! Trying to remount RW"
418 mount -oremount,rw $MOUNTPOINT
421 if [[ "$APPDD_FSTYPE" = "vfat" ]]; then # use noplink on fat, dont on other fs's
422 #append is fucking dirty, need to clean that up
423 MOUNT_CMD="mount -t aufs -o exec,noplink,dirs=\"${APPDATADIR}=rw+nolwh\":\"$PND_MOUNT_DIR/$PND_NAME=rr$append\" none \"$UNION_MOUNT_DIR/$PND_NAME\""
425 MOUNT_CMD="mount -t aufs -o exec,dirs=\"${APPDATADIR}=rw+nolwh\":\"$PND_MOUNT_DIR/$PND_NAME=rr$append\" none \"$UNION_MOUNT_DIR/$PND_NAME\""
427 echo "Mounting the Union FS : $MOUNT_CMD"
430 if ! is_union_mounted;then
432 echo "WARNING : mount faild, re-tring"
435 if ! is_union_mounted;then
436 echo "ERROR: The Union File-system is not mounted !"
442 echo "WARNING Union already mounted, using it"
448 #delete folders created by aufs if empty
449 rmdir -rf "${APPDATADIR}/.wh..wh.plnk" 2>/dev/null
450 rmdir -rf "${APPDATADIR}/.wh..wh..tmp" 2>/dev/null
451 rmdir "${APPDATADIR}/.wh..wh.orph" 2>/dev/null
452 rm "${APPDATADIR}/.aufs.xino" 2>/dev/null
454 #delete appdata folder and ancestors if _empty_
455 rmdir -p "${APPDATADIR}" 2>/dev/null
457 # Clean the loopback device
458 if [ $PND_FSTYPE = ISO ] || [ $PND_FSTYPE = Squashfs ]; then # check if we where running an iso, clean up loop device if we did
459 LOOP=$(/sbin/losetup -a | grep "$(basename $PND)" | tail -n1 | awk -F: '{print $1}')
460 /sbin/losetup -d $LOOP
463 /sbin/losetup -a|cut -d':' -f 1|while read l;do
464 if ! mount|grep -q $l;then
465 echo "WARNING Found $l loop as unused. flushing"
474 MOUNT_TARGET="${1:-$PND_MOUNT_DIR}"
475 if is_pnd_mounted;then
476 PND_WaitFor noMoreProcessPnd "Waiting the PND mount dir to be free"
477 umount "$MOUNT_TARGET/$PND_NAME"
479 if is_pnd_mounted; then
480 echo WARNING umount PND failed, didnt clean up. Process still using this FS :
481 list_using_fs "$MOUNT_TARGET/$PND_NAME"
484 # removing the now useless mountpoint
485 if [ -d "$MOUNT_TARGET/$PND_NAME" ];then
486 rmdir "$MOUNT_TARGET/$PND_NAME"
488 if [ -h "$PND_MOUNT_DIR/$PND_NAME" ];then
489 rm "$PND_MOUNT_DIR/$PND_NAME"
492 # All went well, cleaning
499 if [ $(id -u) -ne 0 ];then
500 sudo /usr/pandora/scripts/pnd_run.sh -u -p "$PND" -b "$PND_NAME"
504 # Make sure the Union FS is unmounted
506 if is_union_mounted;then
507 PND_WaitFor noMoreProcessUnion "Waiting the Union to be available"
508 umount "$UNION_MOUNT_DIR/$PND_NAME" #umount union
510 if is_union_mounted; then
511 echo "WARNING umount UNION failed, didnt clean up. Process still using this FS :"
512 list_using_fs "$UNION_MOUNT_DIR/$PND_NAME"
515 # the Union is umounted, removing the now empty mountpoint
516 if [[ "$PND_MOUNT_DIR" != "$UNION_MOUNT_DIR" ]];then
517 if [ -d "$UNION_MOUNT_DIR/$PND_NAME" ];then
518 rmdir "$UNION_MOUNT_DIR/$PND_NAME"
519 elif [ -e "$UNION_MOUNT_DIR/$PND_NAME" ];then
520 rm "$UNION_MOUNT_DIR/$PND_NAME" >/dev/null 2>&1 # as it might be a symlink
523 # Try umounting the PND
524 umountPnd $UNION_MOUNT_DIR
530 #=============================================================================
531 # Create the condition to run an app, run it and wait for it's end
533 cd "$UNION_MOUNT_DIR/$PND_NAME" # cd to union mount
534 if [ "$STARTDIR" ] && [ -d "$STARTDIR" ]; then
535 cd "$STARTDIR"; # cd to folder specified by the optional arg -s
538 echo "$EXENAME" | grep -q "^\.\/" && DOTSLASH="true"
540 # now set up the env for the PND, don't run any tools after this point
541 # because PATH and LD_LIBRARY_PATH may be different and incompatible
543 if [ -d "$UNION_MOUNT_DIR/$PND_NAME/lib" ];then
544 export LD_LIBRARY_PATH="$UNION_MOUNT_DIR/$PND_NAME/lib:${LD_LIBRARY_PATH:-"/usr/lib:/lib"}"
546 export LD_LIBRARY_PATH="$UNION_MOUNT_DIR/$PND_NAME:${LD_LIBRARY_PATH:-"/usr/lib:/lib"}"
550 if [ -d "$UNION_MOUNT_DIR/$PND_NAME/bin" ];then
551 export PATH="$UNION_MOUNT_DIR/$PND_NAME/bin:${PATH:-"/usr/bin:/bin:/usr/local/bin"}"
554 if [ -d "$UNION_MOUNT_DIR/$PND_NAME/share" ];then
555 export XDG_DATA_DIRS="$UNION_MOUNT_DIR/$PND_NAME/share:$XDG_DATA_DIRS:/usr/share"
558 export REAL_HOME="$HOME"
559 export HOME="$UNION_MOUNT_DIR/$PND_NAME"
560 export XDG_CONFIG_HOME="$HOME"
561 export XDG_DATA_HOME="$HOME"
562 export XDG_CACHE_HOME="$HOME"
564 if [ "$DOTSLASH" = "true" ]; then
565 "$EXENAME" $ARGUMENTS "$@"
567 "./$EXENAME" $ARGUMENTS "$@"
571 #the app could have exited now, OR it went into bg, we still need to wait in that case till it really quits!
572 LD_LIBRARY_PATH= PATH="$REAL_PATH" PND_WaitForExit "$EXENAME"
574 # clean up to avoid any effects of the .pnd on the remaining parts of this script
575 unset LD_LIBRARY_PATH
576 export HOME="$REAL_HOME"
578 export PATH="$REAL_PATH"
580 # ... the rest should not matter
595 PND_BeginTask "Mount the PND"
599 zenity --warning --title="Mounting the PND failed" --text="Mounting the PND failed. The application wont start. Please have a look at $PND_LOG"
602 if [ -e /proc/pandora/cpu_mhz_max ] && [ ! -z "$PND_CPUSPEED" ];then
603 PND_BeginTask "Set CPU speed"
607 if [ $CLOSE_X ]; then
608 PND_BeginTask "Closing X"
613 old_fb0_geometry=$(fbset -fb /dev/fb0 -s | grep geometry | awk '{print $2, $3, $4, $5, $6}')
614 if [ -e "${APPDATADIR}/PND_pre_script.sh" ]; then
615 PND_BeginTask "Starting user configured pre-script"
616 . ${APPDATADIR}/PND_pre_script.sh # Sourcing so it can shared vars with post-script ;)
620 PND_BeginTask "Starting the application ( $EXENAME $ARGUMENTS "$@")"
624 if [ -e "${APPDATADIR}/PND_post_script.sh" ]; then
625 PND_BeginTask "Starting user configured post-script"
626 . ${APPDATADIR}/PND_post_script.sh
630 if [ $CLOSE_X ]; then
631 PND_BeginTask "Restarting X"
635 if [ ! -z "$CURRENTSPEED" ]; then
636 PND_BeginTask "Reset CPU speed to $CURRENTSPEED"
640 PND_BeginTask "Restoring the frame buffer status"
641 ofbset -fb /dev/fb0 -pos 0 0
642 fbset -fb /dev/fb0 -g $old_fb0_geometry
643 old_res=$(echo $old_fb0_geometry | awk '{print $1, $2}')
644 ofbset -fb /dev/fb0 -size $old_res -en 1
645 if ! lsof /dev/fb1 > /dev/null; then
646 ofbset -fb /dev/fb1 -mem 0 -size 0 0 -en 0
650 running_pnd_count=$(ps ax | grep "pnd_run.s[h]" | wc -l)
651 # restore settings if we are the last exiting pnd
652 # compare with 2 because one is used by subshell where "ps ax | ..." runs
653 if [ "$running_pnd_count" -eq "2" ]; then
654 PND_BeginTask "Restoring nub mode"
655 sed -n '1p' /etc/pandora/conf/nubs.state > /proc/pandora/nub0/mode
656 sed -n '7p' /etc/pandora/conf/nubs.state > /proc/pandora/nub1/mode
660 PND_BeginTask "uMount the PND"
667 ######################################################################################
668 #### Parsing the arguments :
670 if [ "$#" -lt 1 ]; then
676 while [ "$#" -gt 0 ];do
677 if [ "$1" == "--" ]; then
682 if [ "$#" -gt 1 ] && ( [[ "$(echo $2|cut -c 1)" != "-" ]] || [[ "$1" = "-a" ]] );then
689 -c) PND_CPUSPEED="$2";;
690 -d) APPDATASET=1;APPDATADIR="$2";;
692 *) echo "ERROR while parsing arguments: \"$1 $2\" is not a valid argument";
697 else # there's no $2 or it's an argument
703 *) echo "ERROR while parsing arguments: \"$1\" is not a valid argument";
712 if test -z "$PND"; then
713 echo "ERROR: pnd file provided (-p)"
718 # getting the real full path to the file
719 PND="$(readlink -f $PND)"
721 #PND_NAME really should be something sensible and somewhat unique
722 #if -b is set use that as pnd_name, else generate it from PND
723 #get basename (strip extension if file) for union mountpoints etc, maybe this should be changed to something specified inside the xml
724 #this should probably be changed to .... something more sensible
725 #currently only everything up to the first '.' inside the filenames is used.
726 PND_NAME="${PND_NAME:-"$(basename $PND | cut -d'.' -f1)"}"
728 PND_LOG="/tmp/pndrun_${PND_NAME}.out"
729 PND_HEADER="PND PND_FSTYPE APPDATADIR APPDD_FSTYPE PND_CPUSPEED EXENAME ARGUMENTS"
731 if [ ! -e "$PND" ]; then #check if theres a pnd suplied, need to clean that up a bit more
732 echo "ERROR: selected PND($PND) file does not exist!"
737 if [ ! "$EXENAME" ] && [[ "$ACTION" = "run" ]]; then
738 echo "ERROR: no executable name provided! (-e)"
743 PND_FSTYPE=$(file -b "$PND" | awk '{ print $1 }') # is -p a zip/iso or folder?
744 MOUNTPOINT=$(df "$PND" | tail -1|awk '{print $6}') # find out on which mountpoint the pnd is
745 if [ $(df "$PND"|wc -l) -eq 1 ];then # this is actually a bug in busybox
747 elif [ ! -d "$MOUNTPOINT" ]; then
750 [ ! -z $APPDATASET ] || [ -z ${MOUNTPOINT} ] && APPDATADIR=${APPDATADIR:-$(dirname $PND)/$PND_NAME}
751 APPDATADIR=${APPDATADIR:-${MOUNTPOINT}/pandora/appdata/${PND_NAME}}
752 APPDD_FSTYPE=$(cat /proc/mounts | awk '$2=="'${MOUNTPOINT}'"{print $3}' | head -1)
753 CPUSPEED_FILE=${MOUNTPOINT}/pandora/appdata/${PND_NAME}/cpuspeed
754 if [ -f "$CPUSPEED_FILE" ]; then
755 PND_CPUSPEED=$(cat "$CPUSPEED_FILE")
757 export APPDATADIR PND PND_NAME
759 #Only logging when running
760 if [[ "$ACTION" == "run" ]];then
763 if [ $CLOSE_X ]; then