rom.sh 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276
  1. # SPDX-License-Identifier: GPL-3.0-or-later
  2. # Copyright (c) 2014-2016,2020-2021,2023-2025 Leah Rowe <leah@libreboot.org>
  3. # Copyright (c) 2021-2022 Ferass El Hafidi <vitali64pmemail@protonmail.com>
  4. # Copyright (c) 2022 Caleb La Grange <thonkpeasant@protonmail.com>
  5. # Copyright (c) 2022-2023 Alper Nebi Yasak <alpernebiyasak@gmail.com>
  6. # Copyright (c) 2023-2024 Riku Viitanen <riku.viitanen@protonmail.com>
  7. grubdata="config/data/grub"
  8. mkserprog()
  9. {
  10. [ "$_f" = "-d" ] && return 0 # dry run
  11. basename -as .h "$serdir/"*.h > "$xbmktmp/ser" || \
  12. $err "!mk $1 $xbmktmp"
  13. while read -r sertarget; do
  14. [ "$1" = "pico" ] && x_ cmake -DPICO_BOARD="$sertarget" \
  15. -DPICO_SDK_PATH="$picosdk" -B "$sersrc/build" "$sersrc" \
  16. && x_ cmake --build "$sersrc/build"
  17. [ "$1" = "stm32" ] && x_ make -C "$sersrc" \
  18. libopencm3-just-make BOARD=$sertarget && x_ make -C \
  19. "$sersrc" BOARD=$sertarget
  20. x_ mkdir -p "bin/serprog_$1"
  21. x_ mv "$serx" "bin/serprog_$1/serprog_$sertarget.${serx##*.}"
  22. done < "$xbmktmp/ser"
  23. [ "$XBMK_RELEASE" = "y" ] && mkrom_tarball "bin/serprog_$1"; :
  24. }
  25. copyps1bios()
  26. {
  27. x_ rm -Rf bin/playstation
  28. x_ mkdir -p bin/playstation
  29. x_ cp src/pcsx-redux/src/mips/openbios/openbios.bin bin/playstation
  30. printf "MIT License\n\nCopyright (c) 2019-2024 PCSX-Redux authors\n\n" \
  31. > bin/playstation/COPYING.txt || $err "!pcsx-redux copyright"
  32. cat config/snippet/mit >>bin/playstation/COPYING.txt || $err "!pcsx MIT"
  33. }
  34. mkpayload_grub()
  35. {
  36. eval "`setvars "" grub_modules grub_install_modules`"
  37. $dry eval "`setcfg "$grubdata/module/$tree"`"
  38. $dry x_ rm -f "$srcdir/grub.elf"; $dry \
  39. x_ "$srcdir/grub-mkstandalone" --grub-mkimage="$srcdir/grub-mkimage" \
  40. -O i386-coreboot -o "$srcdir/grub.elf" -d "${srcdir}/grub-core/" \
  41. --fonts= --themes= --locales= --modules="$grub_modules" \
  42. --install-modules="$grub_install_modules" \
  43. "/boot/grub/grub_default.cfg=${srcdir}/.config" \
  44. "/boot/grub/grub.cfg=$grubdata/memdisk.cfg"; :
  45. }
  46. mkvendorfiles()
  47. {
  48. [ -z "$mode" ] && $dry cook_coreboot_config
  49. check_coreboot_utils "$tree"
  50. printf "%s\n" "${version%%-*}" > "$srcdir/.coreboot-version" || \
  51. $err "!mk $srcdir .coreboot-version"; :
  52. }
  53. cook_coreboot_config()
  54. {
  55. [ -f "$srcdir/.config" ] || return 0
  56. printf "CONFIG_CCACHE=y\n" >> "$srcdir/.config" || \
  57. $err "$srcdir/.config: Could not enable ccache"
  58. make -C "$srcdir" oldconfig || $err "Could not cook $srcdir/.config"; :
  59. }
  60. check_coreboot_utils()
  61. {
  62. for util in cbfstool ifdtool; do
  63. [ "$badhash" = "y" ] && x_ rm -f "elf/$util/$1/$util"
  64. e "elf/$util/$1/$util" f && continue
  65. utilelfdir="elf/$util/$1"
  66. utilsrcdir="src/coreboot/$1/util/$util"
  67. utilmode="" && [ -n "$mode" ] && utilmode="clean"
  68. x_ make -C "$utilsrcdir" $utilmode -j$XBMK_THREADS $makeargs
  69. if [ -z "$mode" ] && [ ! -f "$utilelfdir/$util" ]; then
  70. x_ mkdir -p "$utilelfdir"
  71. x_ cp "$utilsrcdir/$util" "$utilelfdir"
  72. [ "$util" = "cbfstool" ] || continue
  73. x_ cp "$utilsrcdir/rmodtool" "$utilelfdir"
  74. elif [ -n "$mode" ]; then
  75. x_ rm -Rf "$utilelfdir"
  76. fi; :
  77. done; :
  78. }
  79. mkcorebootbin()
  80. {
  81. [ "$target" = "$tree" ] && return 0
  82. tmprom="$xbmktmp/coreboot.rom"
  83. $dry x_ cp "$srcdir/build/coreboot.rom" "$tmprom"
  84. initmode="${defconfig##*/}"
  85. displaymode="${initmode##*_}"
  86. [ "$displaymode" = "$initmode" ] && displaymode="" # "normal" config
  87. initmode="${initmode%%_*}"
  88. cbfstool="elf/cbfstool/$tree/cbfstool"
  89. [ "$payload_uboot_i386" = "y" ] && \
  90. [ "$payload_uboot_amd64" = "y" ] && \
  91. $err "'$target' enables 32- and 64-bit x86 U-Boot"
  92. if [ "$payload_uboot_i386" = "y" ] || \
  93. [ "$payload_uboot_amd64" = "y" ]; then
  94. printf "'%s' has x86 U-Boot; assuming SeaBIOS=y\n" \
  95. "$target" 1>&2
  96. payload_seabios="y"
  97. fi
  98. [ -n "$uboot_config" ] || uboot_config="default"
  99. [ "$payload_uboot" = "y" ] || payload_seabios="y"
  100. [ "$payload_grub" = "y" ] && payload_seabios="y"
  101. [ "$payload_seabios" = "y" ] && [ "$payload_uboot" = "y" ] && \
  102. $dry $err "$target: U-Boot(arm64) and SeaBIOS/GRUB both enabled."
  103. [ -z "$grub_scan_disk" ] && grub_scan_disk="nvme ahci ata"
  104. [ -n "$grubtree" ] || grubtree="default"
  105. grubelf="elf/grub/$grubtree/payload/grub.elf"
  106. [ "$payload_memtest" = "y" ] || payload_memtest="n"
  107. [ "$(uname -m)" = "x86_64" ] || payload_memtest="n"
  108. [ "$payload_grubsea" = "y" ] && [ "$initmode" = "normal" ] && \
  109. payload_grubsea="n"
  110. [ "$payload_grub" = "y" ] || payload_grubsea="n"
  111. if $dry grep "CONFIG_PAYLOAD_NONE=y" "$defconfig"; then
  112. [ "$payload_seabios" = "y" ] && pname="seabios" && \
  113. $dry add_seabios
  114. [ "$payload_uboot" = "y" ] && pname="uboot" && $dry add_uboot
  115. else
  116. pname="custom"
  117. $dry cprom
  118. fi; :
  119. }
  120. add_seabios()
  121. {
  122. if [ "$payload_uboot_i386" = "y" ] || \
  123. [ "$payload_uboot_amd64" = "y" ]; then
  124. $dry add_uboot
  125. fi
  126. _seabioself="elf/seabios/default/$initmode/bios.bin.elf"
  127. _seaname="fallback/payload" && [ "$payload_grubsea" = "y" ] && \
  128. _seaname="seabios.elf"
  129. cbfs "$tmprom" "$_seabioself" "$_seaname"
  130. x_ "$cbfstool" "$tmprom" add-int -i 3000 -n etc/ps2-keyboard-spinup
  131. _z="2" && [ "$initmode" = "vgarom" ] && _z="0"
  132. x_ "$cbfstool" "$tmprom" add-int -i $_z -n etc/pci-optionrom-exec
  133. x_ "$cbfstool" "$tmprom" add-int -i 0 -n etc/optionroms-checksum
  134. [ "$initmode" = "libgfxinit" ] && \
  135. cbfs "$tmprom" "$seavgabiosrom" vgaroms/seavgabios.bin raw
  136. [ "$payload_memtest" = "y" ] && cbfs "$tmprom" \
  137. "elf/memtest86plus/memtest.bin" img/memtest
  138. [ "$payload_grub" = "y" ] && add_grub
  139. [ "$payload_grubsea" != "y" ] && cprom
  140. [ "$payload_uboot_amd64" = "y" ] && [ "$displaymode" != "txtmode" ] && \
  141. [ "$initmode" != "normal" ] && [ "$payload_grubsea" != "y" ] && \
  142. pname="seauboot" && cprom "seauboot"
  143. [ "$payload_grub" = "y" ] && pname="seagrub" && mkseagrub; :
  144. }
  145. add_grub()
  146. {
  147. _grubname="img/grub2" && [ "$payload_grubsea" = "y" ] && \
  148. _grubname="fallback/payload"
  149. cbfs "$tmprom" "$grubelf" "$_grubname"
  150. printf "set grub_scan_disk=\"%s\"\n" "$grub_scan_disk" \
  151. > "$xbmktmp/tmpcfg" || $err "$target: !insert scandisk"
  152. cbfs "$tmprom" "$xbmktmp/tmpcfg" scan.cfg raw
  153. [ "$initmode" != "normal" ] && [ "$displaymode" != "txtmode" ] && \
  154. cbfs "$tmprom" "$grubdata/background/background1280x800.png" \
  155. "background.png" raw; :
  156. }
  157. mkseagrub()
  158. {
  159. [ "$payload_grubsea" = "y" ] && pname="grub"
  160. [ "$payload_grubsea" = "y" ] || \
  161. cbfs "$tmprom" "$grubdata/bootorder" bootorder raw
  162. for keymap in config/data/grub/keymap/*.gkb; do
  163. [ -f "$keymap" ] && cprom "${keymap##*/}"; :
  164. done; :
  165. }
  166. add_uboot()
  167. {
  168. if [ "$displaymode" = "txtmode" ]; then
  169. printf "cb/%s: Cannot use U-Boot in text mode\n" \
  170. "$target" 1>&2
  171. return 0
  172. elif [ "$initmode" = "normal" ]; then
  173. printf "cb/%s: Cannot use U-Boot in normal initmode\n" \
  174. "$target" 1>&2
  175. return 0
  176. fi
  177. # TODO: re-work to allow each coreboot target to say which ub tree
  178. # instead of hardcoding as in the current logic below:
  179. # aarch64 targets:
  180. ubcbfsargs=""
  181. ubpath="fallback/payload"
  182. ubtarget="$target"
  183. # override for x86/x86_64 targets:
  184. if [ "$payload_uboot_i386" = "y" ] || \
  185. [ "$payload_uboot_amd64" = "y" ]; then
  186. ubcbfsargs="-l 0x1110000 -e 0x1110000" # 64-bit and 32-bit
  187. # on 64-bit, 0x1120000 is the SPL, and stub before that
  188. ubpath="img/u-boot" # 64-bit
  189. ubtarget="amd64coreboot"
  190. [ "$payload_uboot_i386" = "y" ] && ubpath="u-boot" # 32-bit
  191. [ "$payload_uboot_i386" = "y" ] && ubtarget="i386coreboot"; :
  192. fi
  193. ubdir="elf/u-boot/$ubtarget/$uboot_config"
  194. # aarch64 targets:
  195. ubootelf="$ubdir/u-boot.elf" && [ ! -f "$ubootelf" ] && \
  196. ubootelf="$ubdir/u-boot"
  197. # override for x86/x86_64 targets:
  198. [ "$payload_uboot_i386" = "y" ] && ubootelf="$ubdir/u-boot-dtb.bin"
  199. [ "$payload_uboot_amd64" = "y" ] && \
  200. ubootelf="$ubdir/u-boot-x86-with-spl.bin" # EFI-compatible
  201. cbfs "$tmprom" "$ubootelf" "$ubpath" $ubcbfsargs
  202. [ "$payload_seabios" = "y" ] || cprom; :
  203. }
  204. cprom()
  205. {
  206. newrom="bin/$target/${pname}_${target}_$initmode.rom"
  207. [ -n "$displaymode" ] && newrom="${newrom%.rom}_$displaymode.rom"
  208. [ $# -gt 0 ] && [ "$1" != "seauboot" ] && \
  209. newrom="${newrom%.rom}_${1%.gkb}.rom"
  210. x_ mkdir -p "bin/$target"
  211. x_ cp "$tmprom" "$newrom" && [ $# -gt 0 ] && [ "$1" != "seauboot" ] && \
  212. cbfs "$newrom" "config/data/grub/keymap/$1" keymap.gkb raw
  213. [ $# -gt 0 ] && [ "$1" = "seauboot" ] && \
  214. cbfs "$newrom" "config/data/grub/bootorder_uboot" bootorder raw; :
  215. }
  216. cbfs()
  217. {
  218. ccmd="add-payload" && [ $# -gt 3 ] && [ $# -lt 5 ] && ccmd="add"
  219. lzma="-c lzma" && [ $# -gt 3 ] && [ $# -lt 5 ] && lzma="-t $4"
  220. [ $# -gt 4 ] && [ "$5" = "0x1110000" ] && \
  221. ccmd="add-flat-binary" && \
  222. lzma="-c lzma -l 0x1110000 -e 0x1110000"
  223. x_ "$cbfstool" "$1" $ccmd -f "$2" -n "$3" $lzma
  224. }
  225. mkcoreboottar()
  226. {
  227. [ "$target" = "$tree" ] && return 0
  228. [ "$XBMK_RELEASE" = "y" ] || return 0
  229. [ "$release" != "n" ] || return 0
  230. $dry mkrom_tarball "bin/$target"; :
  231. }