]> git.plutz.net Git - blast/blobdiff - retropie.mk
retropie config, some config fixes
[blast] / retropie.mk
index da650d0f275bb0907064e7e3e03a0b9124f2667c..c23e85c334f15955c40e741f680302640e8d8f34 100644 (file)
@@ -4,18 +4,20 @@
 raspi=retropie.img
 
 ## Image size in MB. Needs to be able to hold all software.
-imagesize=3072
+# imagesize=3072
+imagesize=2048
 
 ## Additional packages
-packages=chromium-browser,ssh,lsb-release
-packages=supertuxkart/buster,libc-bin/buster,libc6/buster,libopenal1/buster,locales/buster
+# packages:=chromium-browser,ssh,lsb-release
+# packages=supertuxkart/buster,libc-bin/buster,libc6/buster,libopenal1/buster,locales/buster
+packages=ssh lsb-release bison bluetooth build-essential cmake dialog fbi fbset flex g++ gcc git libasound2-dev libavcodec-dev libavdevice-dev libavformat-dev libcurl4-openssl-dev libfreeimage-dev libfreetype6-dev libgles2-mesa-dev libraspberrypi-dev libsdl2-2.0-0 libsdl2-dev libsm-dev libudev-dev libusb-1.0-0-dev libvlccore-dev libvlc-dev libx11-xcb-dev libxkbcommon-dev mc python-dbus python-gobject python-pyudev rapidjson-dev samba vlc xmlstarlet omxplayer insserv libfftw3-single3 alsa-utils
 
 ## Debian release, so far only stretch has been tested
 release=stretch
 
 ## Comma separated list of config modules from modules/ directory
-modules=approx,nodm,xfce,autoresize,display_ws5inch
-approxhost := localhost:9999
+modules=approx,autoresize,display_ws5inch # nodm,xfce
+approxhost := localhost:9999
 
 ## Hostname for the generated machine
 hostname=retropie
@@ -26,7 +28,7 @@ rootpass=root
 ## The corresponding .pub file for the given rootkey will be applied as
 ## SSH login file for the root user.
 ## If the pub file is not found, a new key pair will be generated
-rootkey=image_ssh
+rootkey=image_ssh
 
 ## Comma separated list of users to be set up.
 ## User logins will start out with an empty password
@@ -36,7 +38,7 @@ users=rpi
 
 ## Wifi configuration, if a Wifi password is given, WPA encryption will be used
 ## without the password, the system will try to connect to an open wifi
-wifi=berlin.freifunk.net
+wifi=berlin.freifunk.net
 # wifi=MyWiFi
 # wifipass=P4ssW0rD
 
@@ -44,7 +46,8 @@ wifi=berlin.freifunk.net
 timezone=Europe/Berlin
 
 ## Comma separated list of locales, first one will become default locale
-locales=de_DE.UTF-8,en_US.UTF-8
+# locales=de_DE.UTF-8,en_US.UTF-8
+locales=en_US.UTF-8
 
 ## If nodm is installed, you can choose a user to login automatically
 ## If no user is given here, then nodm will default to root
@@ -61,36 +64,30 @@ nodm_user=rpi
 ## See modules/approx.mk if you need more flexibility
 # approx=http://localhost:9000/debian
 
-define stk_config :=
-<?xml version="1.0"?>
-<stkconfig version="8" >
-    <Video
-        width="1920"
-        height="1080"
-        fullscreen="true"
-        show_fps="true"
-        max_fps="60"
-        enable_high_definition_textures="0"
-        max_texture_size="128"
-    >
-    </Video>
-    <everything_unlocked value="true" />
+CFGROOT := img_mount/
 
-</stkconfig>
-
-endef
-export stk_config
-
-${CFGROOT}/etc/xdg/.config/supertuxkart/0.8.2/config.xml: ${CFGROOT}
-       mkdir -p "$${CFGROOT}"/etc/xdg/.config/supertuxkart/0.8.2/
-       printf  '%s\n' "$${stk_config}" >"$${CFGROOT}"/etc/xdg/.config/supertuxkart/0.8.2/config.xml
-
-# _config: ${CFGROOT}/etc/xdg/.config/supertuxkart/0.8.2/config.xml
+_target: ${CFGROOT}/opt/RetroPie-Setup/ ${CFGROOT}/etc/sudoers.d/nopassword _vc4driver _groups _autologin
 
 RetroPie-Setup/:
        [ ! -d "$@" ] && git clone --depth=1 https://github.com/RetroPie/RetroPie-Setup.git
 
-${FGROOT}/opt/RetroPie-Setup/: RetroPie-Setup/
+${CFGROOT}/opt/RetroPie-Setup/: RetroPie-Setup/ ${CFGROOT} | _config
        cp -au "$<" "$@"
 
-_config: ${FGROOT}/opt/RetroPie-Setup/
+_vc4driver: ${CFGROOT} | _config
+       sed -Ei 's;^ *dtoverlay=vc4-fkms-v3d;# &;' ${CFGROOT}/boot/config.txt
+
+${CFGROOT}/etc/sudoers.d/nopassword: ${CFGROOT}
+       printf '%%sudo ALL=NOPASSWD: ALL\n' >"$@"
+       chmod 440 "$@"
+
+_groups: _users
+       chroot "$${CFGROOT}" adduser rpi sudo
+       chroot "$${CFGROOT}" adduser rpi input
+       chroot "$${CFGROOT}" adduser rpi video
+
+_autologin: ${CFGROOT}/etc/systemd/system/getty@tty1.service.d/override.conf ${CFGROOT}
+${CFGROOT}/etc/systemd/system/getty@tty1.service.d/override.conf:
+       mkdir -p ${CFGROOT}/etc/systemd/system/getty@tty1.service.d/
+       printf '[Service]\nExecStart=\nExecStart=-/sbin/agetty --autologin %s --noclear %%I $$TERM' \
+               rpi >$@