summaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
Diffstat (limited to 'include')
-rw-r--r--include/rom.sh431
1 files changed, 324 insertions, 107 deletions
diff --git a/include/rom.sh b/include/rom.sh
index a4fa37a2..e93a6723 100644
--- a/include/rom.sh
+++ b/include/rom.sh
@@ -9,18 +9,27 @@ grubdata="config/data/grub"
buildser()
{
- [ "$1" = "pico" ] && x_ cmake -DPICO_BOARD="$2" \
- -DPICO_SDK_PATH="$picosdk" -B "$sersrc/build" "$sersrc" && \
- x_ cmake --build "$sersrc/build"
- [ "$1" = "stm32" ] && x_ make -C "$sersrc" libopencm3-just-make \
- BOARD=$2 && x_ make -C "$sersrc" BOARD=$2
+ if [ "$1" = "pico" ]
+ then
+ x_ cmake -DPICO_BOARD="$2" \
+ -DPICO_SDK_PATH="$picosdk" -B "$sersrc/build" "$sersrc" && \
+ x_ cmake --build "$sersrc/build"
+ elif [ "$1" = "stm32" ]
+ then
+ x_ make -C "$sersrc" libopencm3-just-make \
+ BOARD=$2 && x_ make -C "$sersrc" BOARD=$2
+ fi
+
x_ mkdir -p "bin/serprog_$1"
x_ mv "$serx" "bin/serprog_$1/serprog_$2.${serx##*.}"
}
copyps1bios()
{
- [ "$dry" = ":" ] && return 0; :
+ if [ "$dry" = ":" ]
+ then
+ return 0
+ fi
remkdir "bin/playstation"
x_ cp src/pcsx-redux/src/mips/openbios/openbios.bin bin/playstation
@@ -28,6 +37,7 @@ copyps1bios()
printf "MIT License\n\nCopyright (c) 2019-2025 PCSX-Redux authors\n\n" \
> bin/playstation/COPYING.txt || \
err "can't write PCSX Redux copyright info" "copyps1bios" "$@"
+
x_ cat config/snippet/mit >>bin/playstation/COPYING.txt || \
err "can't copy MIT license snippet" "copyps1bios" "$@"
}
@@ -35,9 +45,13 @@ copyps1bios()
mkpayload_grub()
{
eval "`setvars "" grub_modules grub_install_modules`"
+
$dry eval "`setcfg "$grubdata/module/$tree"`"
- $dry x_ rm -f "$srcdir/grub.elf"; $dry \
- x_ "$srcdir/grub-mkstandalone" --grub-mkimage="$srcdir/grub-mkimage" \
+
+ $dry x_ rm -f "$srcdir/grub.elf"
+
+ $dry x_ "$srcdir/grub-mkstandalone" \
+ --grub-mkimage="$srcdir/grub-mkimage" \
-O i386-coreboot -o "$srcdir/grub.elf" -d "${srcdir}/grub-core/" \
--fonts= --themes= --locales= --modules="$grub_modules" \
--install-modules="$grub_install_modules" \
@@ -47,55 +61,96 @@ mkpayload_grub()
corebootpremake()
{
- [ "$XBMK_RELEASE" = "y" ] && [ "$release" = "n" ] && return 0; :
+ if [ "$XBMK_RELEASE" = "y" ] && [ "$release" = "n" ]
+ then
+ return 0
+ fi
$dry cook_coreboot_config
fx_ check_coreboot_util printf "cbfstool\nifdtool\n"
+
printf "%s\n" "${version%%-*}" > "$srcdir/.coreboot-version" || \
err "!mk $srcdir .coreboot-version" "corebootpremake" "$@"
- [ -z "$mode" ] && [ "$target" != "$tree" ] && \
- x_ ./mk download "$target"; :
+
+ if [ -z "$mode" ] && [ "$target" != "$tree" ]
+ then
+ x_ ./mk download "$target"
+ fi
}
cook_coreboot_config()
{
- [ -n "$mode" ] || [ ! -f "$srcdir/.config" ] || printf \
- "CONFIG_CCACHE=y\n" >> "$srcdir/.config" || \
- err "can't cook config in '$srcdir'" "cook_coreboot_config" "$@"; :
+ if [ -z "$mode" ] && [ -f "$srcdir/.config" ]
+ then
+ printf "CONFIG_CCACHE=y\n" >> "$srcdir/.config" || \
+ err "can't cook '$srcdir'" "cook_coreboot_config" "$@"
+ fi
}
check_coreboot_util()
{
- [ "$badhash" = "y" ] && x_ rm -f "elf/coreboot/$tree/$1"
- e "elf/coreboot/$tree/$1" f && return 0
+ if [ "$badhash" = "y" ]
+ then
+ x_ rm -f "elf/coreboot/$tree/$1"
+ fi
+ if e "elf/coreboot/$tree/$1" f
+ then
+ return 0
+ fi
utilelfdir="elf/coreboot/$tree"
utilsrcdir="src/coreboot/$tree/util/$1"
- utilmode="" && [ -n "$mode" ] && utilmode="clean"
+ utilmode=""
+ if [ -n "$mode" ]
+ then
+ utilmode="clean"
+ fi
+
x_ make -C "$utilsrcdir" $utilmode -j$XBMK_THREADS $makeargs
- [ -n "$mode" ] && x_ rm -Rf "$utilelfdir" && return 0
- [ -z "$mode" ] || return 0
- [ -f "$utilelfdir/$1" ] && return 0
+
+ if [ -n "$mode" ]
+ then
+ x_ rm -Rf "$utilelfdir" # TODO: is this needed?
+ return 0
+ fi
+ if [ -n "$mode" ] || [ -f "$utilelfdir/$1" ]
+ then
+ return 0
+ fi
x_ mkdir -p "$utilelfdir"
x_ cp "$utilsrcdir/$1" "$utilelfdir"
- [ "$1" = "cbfstool" ] && x_ cp "$utilsrcdir/rmodtool" "$utilelfdir"; :
+
+ if [ "$1" = "cbfstool" ]
+ then
+ x_ cp "$utilsrcdir/rmodtool" "$utilelfdir"
+ fi
}
coreboot_pad_one_byte()
{
- [ "$XBMK_RELEASE" = "y" ] && [ "$release" = "n" ] && return 0; :
+ # TODO: why is this if block here? can i remove it?
+ if [ "$XBMK_RELEASE" = "y" ] && [ "$release" = "n" ]
+ then
+ return 0
+ fi
+
$dry pad_one_byte "$srcdir/build/coreboot.rom"
}
mkcorebootbin()
{
- [ "$XBMK_RELEASE" = "y" ] && [ "$release" = "n" ] && return 0; :
+ if [ "$XBMK_RELEASE" = "y" ] && [ "$release" = "n" ]
+ then
+ return 0
+ fi
- $dry fx_ check_coreboot_util printf "cbfstool\nifdtool\n"
+ $dry check_coreboot_util cbfstool
+ $dry check_coreboot_util ifdtool
- for y in "$target_dir/config"/*; do
+ for y in "$target_dir/config"/*
+ do
defconfig="$y"
mkcorebootbin_real
done
@@ -105,119 +160,231 @@ mkcorebootbin()
mkcorebootbin_real()
{
- [ "$target" = "$tree" ] && return 0
+ if [ "$target" = "$tree" ]
+ then
+ return 0
+ fi
tmprom="$xbtmp/coreboot.rom"
initmode="${defconfig##*/}"
displaymode="${initmode##*_}"
- [ "$displaymode" = "$initmode" ] && displaymode="" # "normal" config
+ if [ "$displaymode" = "$initmode" ]
+ then
+ displaymode="" # blank it for "normal" configs
+ fi
initmode="${initmode%%_*}"
cbfstool="elf/coreboot/$tree/cbfstool"
elfrom="elf/coreboot/$tree/$target/$initmode"
- [ -n "$displaymode" ] && elfrom="${elfrom}_$displaymode"
+ if [ -n "$displaymode" ]
+ then
+ elfrom="${elfrom}_$displaymode"
+ fi
elfrom="$elfrom/coreboot.rom"
$dry x_ cp "$elfrom" "$tmprom"
$dry unpad_one_byte "$tmprom"
- [ -z "$payload_uboot" ] || [ "$payload_uboot" = "amd64" ] || \
- [ "$payload_uboot" = "i386" ] || [ "$payload_uboot" = "arm64" ] \
- || err "'$target' defines bad u-boot type '$payload_uboot'" \
- "mkcorebootbin_real" "$@"
+ if [ -n "$payload_uboot" ] && [ "$payload_uboot" != "amd64" ] && \
+ [ "$payload_uboot" != "i386" ] && [ "$payload_uboot" != "arm64" ]
+ then
+ err "'$target' defines bad u-boot type '$payload_uboot'" \
+ "mkcorebootbin_real" "$@"
+ fi
- [ -z "$payload_uboot" ] || [ "$payload_uboot" = "arm64" ] || \
+ if [ -n "$payload_uboot" ] && [ "$payload_uboot" != "arm64" ]
+ then
payload_seabios="y"
+ fi
- [ -n "$uboot_config" ] || uboot_config="default"
- [ "$payload_grub" = "y" ] && payload_seabios="y"
- [ "$payload_seabios" = "y" ] && [ "$payload_uboot" = "arm64" ] && \
- $dry err "$target: U-Boot(arm64) and SeaBIOS/GRUB both enabled." \
- "mkcorebootbin_real" "$@"
+ if [ -z "$uboot_config" ]
+ then
+ uboot_config="default"
+ fi
+ if [ "$payload_grub" = "y" ]
+ then
+ payload_seabios="y"
+ fi
+ if [ "$payload_seabios" = "y" ] && [ "$payload_uboot" = "arm64" ]
+ then
+ $dry err "$target: U-Boot(arm) and SeaBIOS/GRUB both enabled" \
+ "mkcorebootbin_real" "$@"
+ fi
- [ -z "$grub_scan_disk" ] && grub_scan_disk="nvme ahci ata"
+ if [ -z "$grub_scan_disk" ]
+ then
+ grub_scan_disk="nvme ahci ata"
+ fi
- [ -n "$grubtree" ] || grubtree="default"
+ if [ -z "$grubtree" ]
+ then
+ grubtree="default"
+ fi
grubelf="elf/grub/$grubtree/$grubtree/payload/grub.elf"
- [ "$payload_memtest" = "y" ] || payload_memtest="n"
- [ "$(uname -m)" = "x86_64" ] || payload_memtest="n"
+ if [ "$payload_memtest" != "y" ]
+ then
+ payload_memtest="n"
+ fi
+ if [ "$(uname -m)" != "x86_64" ]
+ then
+ payload_memtest="n"
+ fi
- [ "$payload_grubsea" = "y" ] && [ "$initmode" = "normal" ] && \
- payload_grubsea="n"
- [ "$payload_grub" = "y" ] || payload_grubsea="n"
+ if [ "$payload_grubsea" = "y" ] && [ "$initmode" = "normal" ]
+ then
+ payload_grubsea="n"
+ fi
+ if [ "$payload_grub" != "y" ]
+ then
+ payload_grubsea="n"
+ fi
- if $dry grep "CONFIG_PAYLOAD_NONE=y" "$defconfig"; then
- [ "$payload_seabios" = "y" ] && pname="seabios" && \
- $dry add_seabios
- [ "$payload_uboot" = "arm64" ] && pname="uboot" && \
- $dry add_uboot; :
+ if $dry grep "CONFIG_PAYLOAD_NONE=y" "$defconfig"
+ then
+ if [ "$payload_seabios" = "y" ]
+ then
+ pname="seabios"
+ $dry add_seabios
+ fi
+ if [ "$payload_uboot" = "arm64" ]
+ then
+ pname="uboot"
+ $dry add_uboot
+ fi
else
pname="custom"
$dry cprom
fi; :
}
+# in our design, SeaBIOS is also responsible for starting either
+# a GRUB or U-Boot payload. this is because SeaBIOS is generally
+# a more reliable codebase, so it's less likely to cause a brick
+# during testing and development, or user configuration. if one
+# of the u-boot or grub payloads fails, the user still has a
+# functional SeaBIOS setup to fall back on. watch:
+
add_seabios()
{
- [ -z "$payload_uboot" ] || [ "$payload_uboot" = "arm64" ] || \
- $dry add_uboot
+ if [ -n "$payload_uboot" ] && [ "$payload_uboot" != "arm64" ]
+ then
+ # we must add u-boot first, because it's added as a flat
+ # binary at a specific offset for secondary program loader
+
+ $dry add_uboot
+ fi
_seabioself="elf/seabios/default/default/$initmode/bios.bin.elf"
- _seaname="fallback/payload" && [ "$payload_grubsea" = "y" ] && \
- _seaname="seabios.elf"
+ _seaname="fallback/payload"
+ if [ "$payload_grubsea" = "y" ]
+ then
+ _seaname="seabios.elf"
+ fi
cbfs "$tmprom" "$_seabioself" "$_seaname"
+
x_ "$cbfstool" "$tmprom" add-int -i 3000 -n etc/ps2-keyboard-spinup
- _z="2" && [ "$initmode" = "vgarom" ] && _z="0"
- x_ "$cbfstool" "$tmprom" add-int -i $_z -n etc/pci-optionrom-exec
+ opexec="2"
+ if [ "$initmode" = "vgarom" ]
+ then
+ opexec="0"
+ fi
+ x_ "$cbfstool" "$tmprom" add-int -i $opexec -n etc/pci-optionrom-exec
+
x_ "$cbfstool" "$tmprom" add-int -i 0 -n etc/optionroms-checksum
- [ "$initmode" = "libgfxinit" ] && \
- cbfs "$tmprom" "$seavgabiosrom" vgaroms/seavgabios.bin raw
+ if [ "$initmode" = "libgfxinit" ]
+ then
+ cbfs "$tmprom" "$seavgabiosrom" vgaroms/seavgabios.bin raw
+ fi
+
+ if [ "$payload_memtest" = "y" ]
+ then
+ # because why not have memtest?
+
+ cbfs "$tmprom" \
+ "elf/memtest86plus/memtest.bin" img/memtest
+ fi
+
+ if [ "$payload_grub" = "y" ]
+ then
+ add_grub
+ fi
+
+ if [ "$payload_grubsea" != "y" ]
+ then
+ # ROM image where SeaBIOS doesn't load grub/u-boot first.
+ # U-Boot/GRUB available in ESC menu if enabled for the board
+
+ cprom
+ fi
- [ "$payload_memtest" = "y" ] && cbfs "$tmprom" \
- "elf/memtest86plus/memtest.bin" img/memtest
+ # now make "SeaUBoot" and "SeaGRUB" images, where SeaBIOS auto-loads
+ # SeaBIOS or U-Boot first; users can bypass this by pressing ESC
+ # in the SeaBIOS menu, to boot devices using SeaBIOS itself instead
- [ "$payload_grub" = "y" ] && add_grub
+ if [ "$payload_uboot" = "amd64" ] && \
+ [ "$displaymode" != "txtmode" ] && \
+ [ "$initmode" != "normal" ] && [ "$payload_grubsea" != "y" ]
+ then
+ pname="seauboot"
+ cprom "seauboot"
+ fi
- [ "$payload_grubsea" != "y" ] && cprom
- [ "$payload_uboot" = "amd64" ] && [ "$displaymode" != "txtmode" ] && \
- [ "$initmode" != "normal" ] && [ "$payload_grubsea" != "y" ] && \
- pname="seauboot" && cprom "seauboot"
- [ "$payload_grub" = "y" ] && pname="seagrub" && mkseagrub; :
+ if [ "$payload_grub" = "y" ]
+ then
+ pname="seagrub"
+ mkseagrub
+ fi
}
add_grub()
{
- _grubname="img/grub2" && [ "$payload_grubsea" = "y" ] && \
- _grubname="fallback/payload"
+ # path in CBFS for the GRUB payload
+ _grubname="img/grub2"
+ if [ "$payload_grubsea" = "y" ]
+ then
+ _grubname="fallback/payload"
+ fi
+
cbfs "$tmprom" "$grubelf" "$_grubname"
+
printf "set grub_scan_disk=\"%s\"\n" "$grub_scan_disk" \
> "$xbtmp/tmpcfg" || \
err "$target: !insert scandisk" "add_grub" "$@"
+
cbfs "$tmprom" "$xbtmp/tmpcfg" scan.cfg raw
- [ "$initmode" != "normal" ] && [ "$displaymode" != "txtmode" ] && \
- cbfs "$tmprom" "$grubdata/background/background1280x800.png" \
- "background.png" raw; :
+
+ if [ "$initmode" != "normal" ] && [ "$displaymode" != "txtmode" ]
+ then
+ cbfs "$tmprom" "$grubdata/background/background1280x800.png" \
+ "background.png" raw
+ fi
}
mkseagrub()
{
- [ "$payload_grubsea" = "y" ] && pname="grub"
- [ "$payload_grubsea" = "y" ] || \
- cbfs "$tmprom" "$grubdata/bootorder" bootorder raw
+ if [ "$payload_grubsea" = "y" ]
+ then
+ pname="grub"
+ else
+ cbfs "$tmprom" "$grubdata/bootorder" bootorder raw
+ fi
+
fx_ cprom x_ find "$grubdata/keymap" -type f -name "*.gkb"
}
add_uboot()
{
- if [ "$displaymode" = "txtmode" ]; then
+ if [ "$displaymode" = "txtmode" ]
+ then
printf "cb/%s: Cannot use U-Boot in text mode\n" \
"$target" 1>&2
return 0
- elif [ "$initmode" = "normal" ]; then
+ elif [ "$initmode" = "normal" ]
+ then
printf "cb/%s: Cannot use U-Boot in normal initmode\n" \
"$target" 1>&2
return 0
@@ -231,71 +398,121 @@ add_uboot()
ubpath="fallback/payload"
ubtree="default"
ubtarget="$target"
+
# override for x86/x86_64 targets:
- if [ -n "$payload_uboot" ] && [ "$payload_uboot" != "arm64" ]; then
+ if [ -n "$payload_uboot" ] && [ "$payload_uboot" != "arm64" ]
+ then
ubcbfsargs="-l 0x1110000 -e 0x1110000" # 64-bit and 32-bit
- # on 64-bit, 0x1120000 is the SPL, and stub before that
+ # on 64-bit, 0x1120000 is the SPL, with a stub that
+ # loads it, located at 0x1110000
+
ubpath="img/u-boot" # 64-bit
ubtree="x86_64"
ubtarget="amd64coreboot"
- [ "$payload_uboot" = "i386" ] && ubpath="u-boot" # 32-bit
- [ "$payload_uboot" = "i386" ] && ubtree="x86"
- [ "$payload_uboot" = "i386" ] && ubtarget="i386coreboot"; :
+
+ if [ "$payload_uboot" = "i386" ]
+ then
+ ubpath="u-boot" # 32-bit
+ ubtree="x86"
+ ubtarget="i386coreboot"; :
+ fi
fi
ubdir="elf/u-boot/$ubtree/$ubtarget/$uboot_config"
# aarch64 targets:
- ubootelf="$ubdir/u-boot.elf" && [ ! -f "$ubootelf" ] && \
- ubootelf="$ubdir/u-boot"
+ ubootelf="$ubdir/u-boot.elf"
+ if [ ! -f "$ubootelf" ]
+ then
+ ubootelf="$ubdir/u-boot"
+ fi
+
# override for x86/x86_64 targets:
- [ "$payload_uboot" = "i386" ] && ubootelf="$ubdir/u-boot-dtb.bin"
- [ "$payload_uboot" = "amd64" ] && \
- ubootelf="$ubdir/u-boot-x86-with-spl.bin" # EFI-compatible
+ if [ "$payload_uboot" = "i386" ]
+ then
+ ubootelf="$ubdir/u-boot-dtb.bin"
+ elif [ "$payload_uboot" = "amd64" ]
+ then
+ ubootelf="$ubdir/u-boot-x86-with-spl.bin" # EFI-compatible
+ fi
cbfs "$tmprom" "$ubootelf" "$ubpath" $ubcbfsargs
- [ "$payload_seabios" = "y" ] || cprom; :
+ if [ "$payload_seabios" != "y" ]
+ then
+ cprom
+ fi
}
+# prepare the final image in bin/ for user installation:
+
cprom()
{
cpcmd="cp"
- tmpnew=""; newrom="bin/$target/${pname}_${target}_$initmode.rom"
- [ -n "$displaymode" ] && newrom="${newrom%.rom}_$displaymode.rom"
- [ $# -gt 0 ] && [ "${1%.gkb}" != "$1" ] && tmpnew="${1##*/}" && \
- newrom="${newrom%.rom}_${tmpnew%.gkb}.rom"
+ tmpnew=""
+ newrom="bin/$target/${pname}_${target}_$initmode.rom"
+
+ if [ -n "$displaymode" ]
+ then
+ newrom="${newrom%.rom}_$displaymode.rom"
+ fi
+
+ if [ $# -gt 0 ] && [ "${1%.gkb}" != "$1" ]
+ then
+ tmpnew="${1##*/}"
+ newrom="${newrom%.rom}_${tmpnew%.gkb}.rom"
+ fi
irom="$tmprom"
- [ $# -lt 1 ] || irom="$(mktemp || err "!mk irom, $(echo "$@")")" || \
- err "can't copy rom" "cprom" "$@"
- [ $# -gt 0 ] && x_ cp "$tmprom" "$irom" && cpcmd="mv"
- [ $# -gt 0 ] && [ "${1%.gkb}" != "$1" ] && \
- cbfs "$irom" "$grubdata/keymap/$tmpnew" keymap.gkb raw
- [ $# -gt 0 ] && [ "$1" = "seauboot" ] && \
- cbfs "$irom" "$grubdata/bootorder_uboot" bootorder raw; :
+ if [ $# -gt 0 ]
+ then
+ irom="$(mktemp || err "!mk irom, $(echo "$@")")" || \
+ err "can't copy rom" "cprom" "$@"
+
+ x_ cp "$tmprom" "$irom" && cpcmd="mv"
+
+ if [ "${1%.gkb}" != "$1" ]
+ then
+ cbfs "$irom" "$grubdata/keymap/$tmpnew" keymap.gkb raw
+ elif [ "$1" = "seauboot" ]
+ then
+ cbfs "$irom" "$grubdata/bootorder_uboot" bootorder raw
+ fi
+ fi
printf "Creating new %s image: '%s'\n" "$projectname" "$newrom"
+
x_ mkdir -p "bin/$target"
x_ $cpcmd "$irom" "$newrom"
}
cbfs()
{
- ccmd="add-payload" && [ $# -gt 3 ] && [ $# -lt 5 ] && ccmd="add"
- lzma="-c lzma" && [ $# -gt 3 ] && [ $# -lt 5 ] && lzma="-t $4"
-
- [ $# -gt 4 ] && [ "$5" = "0x1110000" ] && \
- ccmd="add-flat-binary" && \
- lzma="-c lzma -l 0x1110000 -e 0x1110000"
+ ccmd="add-payload"
+ lzma="-c lzma"
+
+ if [ $# -gt 3 ] && [ $# -lt 5 ]
+ then
+ ccmd="add"
+ lzma="-t $4"
+ elif [ $# -gt 4 ] && [ "$5" = "0x1110000" ]
+ then
+ ccmd="add-flat-binary" && \
+ lzma="-c lzma -l 0x1110000 -e 0x1110000"
+ fi
x_ "$cbfstool" "$1" $ccmd -f "$2" -n "$3" $lzma
}
+# for release files:
+
mkcoreboottar()
{
- [ "$target" != "$tree" ] && [ "$XBMK_RELEASE" = "y" ] && \
- [ "$release" != "n" ] && $dry mkrom_tarball "bin/$target" && \
- $dry x_ ./mk inject "bin/${relname}_${target}.tar.xz" nuke; :
+ if [ "$target" != "$tree" ] && [ "$XBMK_RELEASE" = "y" ] && \
+ [ "$release" != "n" ]
+ then
+ $dry mkrom_tarball "bin/$target" && \
+ $dry x_ ./mk inject "bin/${relname}_${target}.tar.xz" nuke; :
+ fi
}