distribution/packages/jelos/sources/scripts/runemu.sh

536 lines
15 KiB
Bash
Raw Normal View History

2022-02-05 14:23:32 +00:00
#!/bin/bash
# SPDX-License-Identifier: GPL-2.0-or-later
# Copyright (C) 2019-present Shanti Gilbert (https://github.com/shantigilbert)
# Copyright (C) 2020-present Fewtarius
# Source predefined functions and variables
. /etc/profile
. /etc/os-release
# Command line schema
# $1 = Game/Port
# $2 = Platform
# $3 = Core
# $4 = Emulator
### Define the variables used throughout the script
BTENABLED=$(get_setting bluetooth.enabled)
CFG="/storage/.emulationstation/es_settings.cfg"
VERBOSE=false
LOGSDIR="/var/log"
LOGFILE="exec.log"
TBASH="/usr/bin/bash"
RATMPCONF="/storage/.config/retroarch/retroarch.cfg"
RAAPPENDCONF="/tmp/raappend.cfg"
NETPLAY="No"
SHADERTMP="/tmp/shader"
OUTPUT_LOG="${LOGSDIR}/${LOGFILE}"
### Do not change the variables below as it may break things.
MYNAME=$(basename "$0")
### Enable logging
if [ "$(get_es_setting string LogLevel)" == "minimal" ]; then
LOG=false
else
LOG=true
2022-08-23 18:45:30 +00:00
VERBOSE=true
2022-02-05 14:23:32 +00:00
fi
arguments="$@"
PLATFORM="${arguments##*-P}" # read from -P onwards
PLATFORM="${PLATFORM%% *}" # until a space is found
CORE="${arguments##*--core=}" # read from --core= onwards
CORE="${CORE%% *}" # until a space is found
EMULATOR="${arguments##*--emulator=}" # read from --emulator= onwards
EMULATOR="${EMULATOR%% *}" # until a space is found
ROMNAME="$1"
BASEROMNAME=${ROMNAME##*/}
GAMEFOLDER="${ROMNAME//${BASEROMNAME}}"
### Determine if we're running a Libretro core and append the libretro suffix
if [[ $EMULATOR = "retroarch" ]]; then
2022-08-23 18:45:30 +00:00
EMU="${CORE}_libretro"
RETROARCH="yes"
2022-02-05 14:23:32 +00:00
elif [[ $EMULATOR = "mupen64plussa" ]]; then
2022-08-23 18:45:30 +00:00
EMU="M64P"
2022-02-05 14:23:32 +00:00
else
2022-08-23 18:45:30 +00:00
EMU="${CORE}"
2022-02-05 14:23:32 +00:00
fi
# freej2me needs the JDK to be downloaded on the first run
if [[ ${EMU} == "freej2me_libretro" ]]; then
/usr/bin/freej2me.sh
JAVA_HOME='/storage/jdk'
export JAVA_HOME
PATH="$JAVA_HOME/bin:$PATH"
export PATH
fi
# easyrpg needs runtime files to be downloaded on the first run
if [[ ${EMU} == "easyrpg_libretro" ]]; then
/usr/bin/easyrpg.sh
fi
### If we're running a port, assume it's libretro
### Re-evaluate as not all ports may be libretro cores
### perhaps rewrite to use ^ functionality
[[ ${PLATFORM} = "ports" ]] && RETROARCH="yes"
# check if we started as host for a game
if [[ "$arguments" == *"--host"* ]]; then
2022-08-23 18:45:30 +00:00
NETPLAY="${arguments##*--host}" # read from --host onwards
NETPLAY="${NETPLAY%%--nick*}" # until --nick is found
NETPLAY="--host $NETPLAY --nick"
2022-02-05 14:23:32 +00:00
fi
# check if we are trying to connect to a client on netplay
if [[ "$arguments" == *"--connect"* ]]; then
2022-08-23 18:45:30 +00:00
NETPLAY="${arguments##*--connect}" # read from --connect onwards
NETPLAY="${NETPLAY%%--nick*}" # until --nick is found
NETPLAY="--connect $NETPLAY --nick"
2022-02-05 14:23:32 +00:00
fi
### Offline all but the number of cores we need for this game if configured.
NUMCORES=$(get_setting "cores" "${PLATFORM}" "${ROMNAME##*/}")
2023-01-03 12:04:57 +00:00
if [ -n "${NUMCORES}" ] &&
[ ! ${NUMCORES} = "default" ]
then
onlinecores ${NUMCORES} 0
fi
2022-02-05 14:23:32 +00:00
### Set the performance mode
PERFORMANCE_MODE=$(get_setting "cpugovernor" "${PLATFORM}" "${ROMNAME##*/}")
2022-11-09 13:02:06 +00:00
if [ ! "${PERFORMANCE_MODE}" = "auto" ]
then
${PERFORMANCE_MODE}
fi
2022-02-05 14:23:32 +00:00
2022-04-02 14:15:12 +00:00
### We need the original system cooling profile later so get it now!
COOLINGPROFILE=$(get_setting cooling.profile)
2022-08-11 22:10:16 +00:00
if [ -e "/usr/bin/overclock" ]
then
2022-08-11 22:10:16 +00:00
### Set the overclock mode
OVERCLOCK=$(get_setting "overclock" "${PLATFORM}" "${ROMNAME##*/}")
if [ ! "${OVERCLOCK}" = "system" ]
then
2022-08-11 22:10:16 +00:00
if [ ! -z "${OVERCLOCK}" ] && [ -e "/usr/bin/overclock" ]
then
/usr/bin/overclock ${OVERCLOCK}
fi
fi
fi
2022-04-02 14:15:12 +00:00
if [ "${DEVICE_HAS_FAN}" = "true" ]
then
### Set any custom fan profile (make this better!)
GAMEFAN=$(get_setting "cooling.profile" "${PLATFORM}" "${ROMNAME##*/}")
if [ ! -z "${GAMEFAN}" ]
then
set_setting cooling.profile ${GAMEFAN}
systemctl restart fancontrol
fi
fi
2022-02-05 14:23:32 +00:00
# Disable netplay by default
set_setting "netplay.client.ip" "disable"
set_setting "netplay.client.port" "disable"
### Function Library
function log() {
2022-08-23 18:45:30 +00:00
if [ ${LOG} == true ]
then
if [[ ! -d "$LOGSDIR" ]]
then
mkdir -p "$LOGSDIR"
fi
echo "${MYNAME}: $1" 2>&1 | tee -a ${LOGSDIR}/${LOGFILE}
else
echo "${MYNAME}: $1"
fi
2022-02-05 14:23:32 +00:00
}
function loginit() {
2022-08-23 18:45:30 +00:00
if [ ${LOG} == true ]
then
if [ -e ${LOGSDIR}/${LOGFILE} ]
then
rm -f ${LOGSDIR}/${LOGFILE}
fi
cat <<EOF >${LOGSDIR}/${LOGFILE}
2022-02-05 14:23:32 +00:00
Emulation Run Log - Started at $(date)
ARG1: $1
ARG2: $2
ARG3: $3
ARG4: $4
ARGS: $*
PLATFORM: $PLATFORM
ROM NAME: ${ROMNAME}
BASE ROM NAME: ${ROMNAME##*/}
USING CONFIG: ${RATMPCONF}
USING APPENDCONFIG : ${RAAPPENDCONF}
EOF
2022-08-23 18:45:30 +00:00
else
log $0 "Emulation Run Log - Started at $(date)"
2022-08-23 18:45:30 +00:00
fi
2022-02-05 14:23:32 +00:00
}
function quit() {
$VERBOSE && log $0 "Cleaning up and exiting"
2022-08-23 18:45:30 +00:00
bluetooth enable
jslisten stop
clear_screen
DEVICE_CPU_GOVERNOR=$(get_setting system.cpugovernor)
${DEVICE_CPU_GOVERNOR}
set_audio default
exit $1
2022-02-05 14:23:32 +00:00
}
function clear_screen() {
$VERBOSE && log $0 "Clearing screen"
clear
2022-02-05 14:23:32 +00:00
}
function bluetooth() {
2022-08-23 18:45:30 +00:00
if [ "$1" == "disable" ]
then
$VERBOSE && log $0 "Disabling BT"
2022-08-23 18:45:30 +00:00
if [[ "$BTENABLED" == "1" ]]
then
NPID=$(pgrep -f batocera-bluetooth-agent)
if [[ ! -z "$NPID" ]]; then
kill "$NPID"
fi
fi
elif [ "$1" == "enable" ]
then
$VERBOSE && log $0 "Enabling BT"
2022-08-23 18:45:30 +00:00
if [[ "$BTENABLED" == "1" ]]
then
systemd-run batocera-bluetooth-agent
fi
fi
2022-02-05 14:23:32 +00:00
}
### Main Screen Turn On
loginit "$1" "$2" "$3" "$4"
clear_screen
bluetooth disable
jslisten stop
### Per emulator/core configurations
if [ -z ${RETROARCH} ]
then
$VERBOSE && log $0 "Configuring for a non-libretro emulator"
2022-08-23 18:45:30 +00:00
case ${PLATFORM} in
"setup")
RUNTHIS='${TBASH} "${ROMNAME}"'
;;
"nds")
jslisten set "drastic"
2022-10-21 19:56:51 +00:00
RUNTHIS='${TBASH} /usr/bin/start_drastic.sh "${ROMNAME}"'
2022-08-23 18:45:30 +00:00
;;
"solarus")
if [ "$EMU" = "solarus" ]
then
jslisten set "solarus-run"
RUNTHIS='${TBASH} /usr/bin/solarus.sh "${ROMNAME}"'
fi
;;
"n64")
jslisten set "mupen64plus"
if [ "$EMU" = "M64P" ]
then
RUNTHIS='${TBASH} /usr/bin/m64p.sh "${CORE}" "${ROMNAME}"'
fi
;;
"pc")
jslisten set "dosbox dosbox-x"
if [ "$EMU" = "DOSBOXSDL2" ]
then
RUNTHIS='${TBASH} /usr/bin/dosbox.start -conf "${GAMEFOLDER}dosbox-SDL2.conf"'
elif [ "$EMU" = "DOSBOX-X" ]
then
RUNTHIS='${TBASH} /usr/bin/dosbox-x.start -conf "${GAMEFOLDER}dosbox-SDL2.conf"'
fi
;;
"neocd")
jslisten set "retroarch"
if [ "$EMU" = "fbneo" ]
then
RUNTHIS='/usr/bin/retroarch -L /tmp/cores/fbneo_libretro.so --subsystem neocd --config ${RATMPCONF} --appendconfig ${RAAPPENDCONF} "${ROMNAME}"'
2022-08-23 18:45:30 +00:00
fi
;;
"psx")
2022-09-03 00:51:03 +00:00
jslisten set "duckstation-nogui"
2022-08-23 18:45:30 +00:00
if [ "$EMU" = "duckstationsa" ]; then
RUNTHIS='${TBASH} /usr/bin/start_duckstation.sh "${ROMNAME}"'
2022-08-23 18:45:30 +00:00
fi
2022-08-05 14:08:26 +00:00
;;
2022-09-05 12:03:17 +00:00
"ps2")
jslisten set "-9 pcsx2"
if [ "$EMU" = "pcsx2sa" ]; then
2022-09-05 12:03:17 +00:00
RUNTHIS='${TBASH} /usr/bin/start_pcsx2.sh "${ROMNAME}"'
fi
;;
2022-11-02 14:18:15 +00:00
"gamecube")
2022-09-03 01:06:59 +00:00
jslisten set "-9 dolphin-emu-nogui"
2022-11-02 14:18:15 +00:00
if [ "$EMU" = "dolphinsa-gc" ]; then
RUNTHIS='${TBASH} /usr/bin/start_dolphin_gc.sh "${ROMNAME}"'
2022-12-16 14:42:30 +00:00
elif [ "$EMU" = "primehack" ]; then
RUNTHIS='${TBASH} /usr/bin/start_primehack.sh "${ROMNAME}"'
2022-08-05 14:08:26 +00:00
fi
2022-09-05 18:43:19 +00:00
;;
2022-11-02 14:18:15 +00:00
"wii")
jslisten set "-9 dolphin-emu-nogui"
if [ "$EMU" = "dolphinsa-wii" ]; then
RUNTHIS='${TBASH} /usr/bin/start_dolphin_wii.sh "${ROMNAME}"'
2022-12-16 14:42:30 +00:00
elif [ "$EMU" = "primehack" ]; then
RUNTHIS='${TBASH} /usr/bin/start_primehack.sh "${ROMNAME}"'
2022-11-02 14:18:15 +00:00
fi
;;
"wiiu")
jslisten set "-9 cemu"
if [ "$EMU" = "cemu" ]; then
RUNTHIS='${TBASH} /usr/bin/start_cemu.sh "${ROMNAME}"'
fi
;;
"switch")
jslisten set "-9 yuzu-cmd"
if [ "$EMU" = "yuzu" ]; then
RUNTHIS='${TBASH} /usr/bin/start_yuzu.sh "${ROMNAME}"'
fi
;;
2023-01-02 16:49:21 +00:00
"3ds")
jslisten set "-9 citra"
if [ "$EMU" = "citrasa" ]; then
RUNTHIS='${TBASH} /usr/bin/start_citra.sh "${ROMNAME}"'
fi
;;
2022-08-23 18:45:30 +00:00
"mplayer")
jslisten set "mpv"
RUNTHIS='${TBASH} /usr/bin/mpv_video.sh "${ROMNAME}"'
;;
"shell")
RUNTHIS='${TBASH} "${ROMNAME}"'
;;
*)
jslisten set "${CORE}"
RUNTHIS='${TBASH} "start_${CORE}.sh" "${ROMNAME}"'
esac
2022-02-05 14:23:32 +00:00
else
$VERBOSE && log $0 "Configuring for a libretro core"
2022-08-23 18:45:30 +00:00
### Set jslisten to kill the appropriate retroarch
jslisten set "retroarch retroarch32"
2022-09-01 10:07:11 +00:00
RABIN="retroarch"
2022-08-23 18:45:30 +00:00
if [[ "${HW_ARCH}" =~ aarch64 ]]
then
### Check if we need retroarch 32 bits or 64 bits
if [[ "${CORE}" =~ pcsx_rearmed32 ]] || \
[[ "${CORE}" =~ gpsp ]] || \
[[ "${CORE}" =~ flycast32 ]]
then
export LIBGL_DRIVERS_PATH="/usr/lib32/dri"
2022-09-29 20:44:45 +00:00
export LD_LIBRARY_PATH="/usr/lib32"
export RABIN="retroarch32"
2022-08-23 18:45:30 +00:00
fi
fi
# Platform specific configurations
2022-02-05 14:23:32 +00:00
case ${PLATFORM} in
"doom")
2022-08-23 18:45:30 +00:00
# EXT can be wad, WAD, iwad, IWAD, pwad, PWAD or doom
EXT=${ROMNAME##*.}
# If its not a simple wad (extension .doom) read the file and parse the data
if [ ${EXT} == "doom" ]; then
dos2unix "${1}"
while IFS== read -r key value; do
if [ "$key" == "IWAD" ]; then
ROMNAME="$value"
2022-08-29 01:53:58 +00:00
fi
done < "${1}"
fi
;;
"quake")
2022-08-29 03:10:14 +00:00
# EXT can only by quake
2022-08-29 01:53:58 +00:00
EXT=${ROMNAME##*.}
# If its not a simple pak (extension .pak0) read the file and parse the data
if [ ${EXT} == "quake" ]; then
dos2unix "${1}"
while IFS== read -r key value; do
if [ "$key" == "PAK" ]; then
ROMNAME="$value"
2022-08-23 18:45:30 +00:00
fi
done < "${1}"
fi
2022-02-05 14:23:32 +00:00
;;
esac
2022-08-23 18:45:30 +00:00
if [[ "${CORE}" =~ "custom" ]]
then
RUNTHIS='${EMUPERF} /usr/bin/${RABIN} -L /storage/.config/retroarch/cores/${EMU}.so --config ${RATMPCONF} --appendconfig ${RAAPPENDCONF} "${ROMNAME}"'
else
RUNTHIS='${EMUPERF} /usr/bin/${RABIN} -L /tmp/cores/${EMU}.so --config ${RATMPCONF} --appendconfig ${RAAPPENDCONF} "${ROMNAME}"'
2022-08-23 18:45:30 +00:00
fi
CONTROLLERCONFIG="${arguments#*--controllers=*}"
if [[ "$arguments" == *"-state_slot"* ]]; then
CONTROLLERCONFIG="${CONTROLLERCONFIG%% -state_slot*}" # until -state is found
SNAPSHOT="${arguments#*-state_slot *}" # -state_slot x
SNAPSHOT="${SNAPSHOT%% -*}"
if [[ "$arguments" == *"-autosave"* ]]; then
CONTROLLERCONFIG="${CONTROLLERCONFIG%% -autosave*}" # until -autosave is found
AUTOSAVE="${arguments#*-autosave *}" # -autosave x
AUTOSAVE="${AUTOSAVE%% -*}"
else
AUTOSAVE=""
fi
else
CONTROLLERCONFIG="${CONTROLLERCONFIG%% --*}" # until a -- is found
SNAPSHOT=""
AUTOSAVE=""
fi
2022-02-05 14:23:32 +00:00
# CORE=${EMU%%_*}
2022-08-23 18:45:30 +00:00
### Configure netplay
if [[ ${NETPLAY} != "No" ]]; then
NETPLAY_NICK=$(get_setting netplay.nickname)
[[ -z "$NETPLAY_NICK" ]] && NETPLAY_NICK="${uuidgen | awk 'BEGIN {FS="-"} {print toupper($1)}'}"
set_setting netplay.nickname ${NETPLAY_NICK}
if [[ "${NETPLAY}" == *"connect"* ]]; then
NETPLAY_PORT="${arguments##*--port }" # read from -netplayport onwards
NETPLAY_PORT="${NETPLAY_PORT%% *}" # until a space is found
NETPLAY_IP="${arguments##*--connect }" # read from -netplayip onwards
NETPLAY_IP="${NETPLAY_IP%% *}" # until a space is found
set_setting "netplay.client.ip" "${NETPLAY_IP}"
set_setting "netplay.client.port" "${NETPLAY_PORT}"
RUNTHIS=$(echo ${RUNTHIS} | sed "s|--config|--connect ${NETPLAY_IP}\|${NETPLAY_PORT} --nick ${NETPLAY_NICK} --config|")
else
RUNTHIS=$(echo ${RUNTHIS} | sed "s|--config|${NETPLAY} --nick ${NETPLAY_NICK} --config|")
fi
fi
# Platform specific configurations
2022-02-05 14:23:32 +00:00
case ${PLATFORM} in
"atomiswave")
rm ${ROMNAME}.nvmem*
;;
"ports")
PORTCORE="${arguments##*-C}" # read from -C onwards
EMU="${PORTCORE%% *}_libretro" # until a space is found
PORTSCRIPT="${arguments##*-SC}" # read from -SC onwards
;;
"scummvm")
2022-08-23 18:45:30 +00:00
GAMEDIR=$(cat "${ROMNAME}" | awk 'BEGIN {FS="\""}; {print $2}')
cd "${GAMEDIR}"
RUNTHIS='${TBASH} /usr/bin/scummvm.start libretro .'
2022-02-05 14:23:32 +00:00
;;
esac
fi
if [ -e "${SHADERTMP}" ]
then
2022-08-23 18:45:30 +00:00
rm -f "${SHADERTMP}"
2022-02-05 14:23:32 +00:00
fi
if [[ ${PLATFORM} == "ports" ]]; then
2022-08-23 18:45:30 +00:00
(/usr/bin/setsettings.sh "${PLATFORM}" "${PORTSCRIPT}" "${CORE}" --controllers="${CONTROLLERCONFIG}" --autosave="${AUTOSAVE}" --snapshot="${SNAPSHOT}" >${SHADERTMP}) &
2022-02-05 14:23:32 +00:00
else
2022-08-23 18:45:30 +00:00
(/usr/bin/setsettings.sh "${PLATFORM}" "${ROMNAME}" "${CORE}" --controllers="${CONTROLLERCONFIG}" --autosave="${AUTOSAVE}" --snapshot="${SNAPSHOT}" >${SHADERTMP}) &
2022-02-05 14:23:32 +00:00
fi
SETSETTINGS_PID=$!
clear_screen
### Wait for background jobs to complete before continuing.
wait ${SETSETTINGS_PID} #Don't wait for show splash
### If setsettings wrote data in the background, grab it and assign it to SHADERSET
if [ -e "${SHADERTMP}" ]
then
2022-08-23 18:45:30 +00:00
SHADERSET=$(cat ${SHADERTMP})
rm -f ${SHADERTMP}
$VERBOSE && log $0 "Shader set to ${SHADERSET}"
2022-02-05 14:23:32 +00:00
fi
if [[ ${SHADERSET} != 0 ]]; then
2022-08-23 18:45:30 +00:00
RUNTHIS=$(echo ${RUNTHIS} | sed "s|--config|${SHADERSET} --config|")
2022-02-05 14:23:32 +00:00
fi
clear_screen
$VERBOSE && log $0 "executing game: ${ROMNAME}"
$VERBOSE && log $0 "script to execute: ${RUNTHIS}"
2022-02-05 14:23:32 +00:00
# If the rom is a shell script just execute it, useful for DOSBOX and ScummVM scan scripts
if [[ "${ROMNAME}" == *".sh" ]]; then
$VERBOSE && log $0 "Executing shell script ${ROMNAME}"
2022-08-23 18:45:30 +00:00
"${ROMNAME}" &>>${OUTPUT_LOG}
2022-02-05 14:23:32 +00:00
ret_error=$?
else
$VERBOSE && log $0 "Executing $(eval echo ${RUNTHIS})"
2022-08-23 18:45:30 +00:00
eval ${RUNTHIS} &>>${OUTPUT_LOG}
ret_error=$?
2022-02-05 14:23:32 +00:00
fi
clear_screen
### Reset the number of cores to use.
NUMCORES=$(get_setting "system.cores")
2023-01-03 10:55:36 +00:00
if [ -n "${NUMCORES}" ]
then
onlinecores ${NUMCORES} 0
else
onlinecores all 1
fi
### Restore the overclock mode
if [ -e "/usr/bin/overclock" ]
then
2022-08-23 18:45:30 +00:00
OVERCLOCK=$(get_setting "system.overclock")
if [ ! -z "${OVERCLOCK}" ]
then
/usr/bin/overclock ${OVERCLOCK}
if [ "${DEVICE_HAS_FAN}" = "true" ]
then
set_setting cooling.profile ${COOLINGPROFILE}
systemctl restart fancontrol
fi
fi
fi
### Backup save games
CLOUD_BACKUP=$(get_setting "cloud.backup")
if [ "${CLOUD_BACKUP}" = "1" ]
then
INETUP=$(/usr/bin/amionline >/dev/null 2>&1)
if [ $? == 0 ]
then
log $0 "backup saves to the cloud."
run /usr/bin/cloud_backup
fi
fi
$VERBOSE && log $0 "Checking errors: ${ret_error} "
2022-02-05 14:23:32 +00:00
if [ "${ret_error}" == "0" ]
then
2022-08-23 18:45:30 +00:00
quit 0
2022-02-05 14:23:32 +00:00
else
log $0 "exiting with $ret_error"
2022-08-23 18:45:30 +00:00
quit 1
2022-02-05 14:23:32 +00:00
fi