diff options
-rwxr-xr-x | script/build/boot/roms_helper | 71 | ||||
-rwxr-xr-x | script/handle/make/config | 58 |
2 files changed, 65 insertions, 64 deletions
diff --git a/script/build/boot/roms_helper b/script/build/boot/roms_helper index 64de5843..bd94a4b8 100755 --- a/script/build/boot/roms_helper +++ b/script/build/boot/roms_helper @@ -44,7 +44,6 @@ keyboard_layouts="" grub_scan_disk="undefined" tree="undefined" -romtype="normal" # optional parameter in target.cfg. "normal" is default arch="undefined" # Disable all payloads by default. @@ -332,7 +331,7 @@ build_seabios_roms() newrompath="${newrompath}${displaymode}.rom" fi - moverom "${t}" "${newrompath}" "${romtype}" || \ + moverom "${t}" "${newrompath}" || \ err "build_roms: cannot copy rom" rm -f "${t}" || err "cannot rm ${t}" fi @@ -418,7 +417,7 @@ build_grub_roms() { newrompath="${newrompath}${initmode}_${displaymode}_" newrompath="${newrompath}${keymap}.rom" fi - moverom "${tmpgrubrom}" "${newrompath}" "${romtype}" || \ + moverom "${tmpgrubrom}" "${newrompath}" || \ err "build_grub_roms, moverom" rm -f "${tmpgrubrom}" || err "rm tmpgrubrom, build_grub_roms" done @@ -494,7 +493,7 @@ build_uboot_roms() newrompath="${romdir}/uboot_payload_${board}_${initmode}_${displaymode}.rom" [ "${initmode}" = "normal" ] && \ newrompath="${romdir}/uboot_payload_${board}_${initmode}.rom" - moverom "${tmprom}" "${newrompath}" "${romtype}" || \ + moverom "${tmprom}" "${newrompath}" || \ err "build_roms: moverom fail (u-boot)" rm -f "${tmprom}" || \ err "build_roms: cannot rm u-boot rom" @@ -529,68 +528,14 @@ mkUbootRom() { # it is assumed that no other work will be done on the ROM # after calling this function. therefore this function is "final" moverom() { - rompath="$1" - newrompath="$2" - cuttype="$3" - + rompath="${1}" + newrompath="${2}" [ "${blobs_required}" = "n" ] && \ newrompath="${newrompath%.rom}_noblobs.rom" printf "\nCreating new ROM image: %s\n" "${newrompath}" - if [ "${cuttype}" = "4MiB IFD BIOS region" ]; then - dd if="${rompath}" of="${newrompath}" bs=1 \ - skip=$(($(stat -c %s "${rompath}") - 0x400000)) \ - count=4194304 || err "moverom: cannot cut 4MB section" - else - cp "${rompath}" "${newrompath}" || \ - err "moverom: can't copy rom" - fi - - # pike2008 cards cause a system hang when loading option roms in seabios - # if there is an empty option rom in cbfs, no option rom will be loaded - if [ "${cuttype}" = "d8d16sas" ]; then - emptyrom=$(mktemp -t coreboot_rom.XXXXXXXXXX) - rm -f "${emptyrom}" || err "cannot remove fake oprom" - touch "${emptyrom}" || err "cannot create fake oprom" - for deviceID in "0072" "3050"; do - "${cbfstool}" "${newrompath}" add -f "${emptyrom}" \ - -n "pci1000,${deviceID}.rom" -t raw || \ - err "moverom: cannot insert fake pike2008 rom" - done - rm -f "${emptyrom}" || \ - err "moverom: cannot remove pike2008 rom" - fi - - for romsize in 4 8 16; do - ifddir="descriptors/ich9m" - for bs in "4" "12"; do - ifdgbe="${ifddir}/ich9fdnogbe_${romsize}m.bin" - cmpstr="${romsize}MiB ICH9 IFD NOGBE NOR flash" - if [ "${bs}" = "12" ]; then - cmpstr="${romsize}MiB ICH9 IFD NOR flash" - ifdgbe="${ifddir}/ich9fdgbe_${romsize}m.bin" - fi - [ "${cuttype}" = "${cmpstr}" ] || continue - [ -f "${ifdgbe}" ] || ./build descriptors ich9m || \ - err "moverom: cannot create ich9m ifd" - dd if="${ifdgbe}" of="${newrompath}" bs=${bs}k count=1 \ - conv=notrunc || err "moverom: cant insert ich9m ifd" - done - - done - - if [ "${cuttype}" = "i945 laptop" ]; then - dd if="${newrompath}" of=top64k.bin bs=1 \ - skip=$(($(stat -c %s "${newrompath}") - 0x10000)) \ - count=64k || \ - err "moverom: cannot copy boot block from i945 rom" - dd if=top64k.bin of="${newrompath}" bs=1 \ - seek=$(($(stat -c %s "${newrompath}") - 0x20000)) \ - count=64k conv=notrunc || \ - err "moverom: cannot copy boot block into i945 rom" - rm -f top64k.bin || err "moverom: can't remove top64k.bin" - fi + cp "${rompath}" "${newrompath}" || err "moverom: can't copy rom" if [ "${microcode_required}" = "n" ]; then _newrom_b="${newrompath%.rom}_nomicrocode.rom" @@ -598,10 +543,8 @@ moverom() { err "moverom: cp \"${newrompath}\" \"${_newrom_b}\"" microcode_present="y" "${cbfstool}" "${_newrom_b}" remove -n \ - cpu_microcode_blob.bin || microcode_present="n" + cpu_microcode_blob.bin 2>/dev/null || microcode_present="n" if [ "${microcode_present}" = "n" ]; then - rm -f "${_newrom_b}" || \ - err "cannot remove ${_newrom_b}" printf "REMARK: '%s' already lacks microcode\n" \ "${newrompath}" printf "Renaming default ROM file instead.\n" diff --git a/script/handle/make/config b/script/handle/make/config index 0c60285f..5af7e9e7 100755 --- a/script/handle/make/config +++ b/script/handle/make/config @@ -41,6 +41,7 @@ elfdir="" listfile="" mode="" project="" +romtype="" target="" target_dir="" tree="" @@ -123,6 +124,7 @@ handle_dependencies() tree="undefined" arch="undefined" + romtype="normal" [ ! -f "${target_dir}/target.cfg" ] && \ fail "handle_dependencies: ${target_dir}: missing target.cfg" @@ -238,6 +240,11 @@ run_make_command() copy_elf() { + if [ "${project}" = "coreboot" ]; then + modify_coreboot_rom || \ + err "copy_elf: cannot prepare coreboot image" + fi + for f in $(cat "${listfile}"); do [ ! -f "${codedir}/$f" ] || \ cp "${codedir}/${f}" "${dest_dir}/" || \ @@ -248,6 +255,57 @@ copy_elf() fail "copy_elf: clean: ${codedir} (${project}/${target})" } +modify_coreboot_rom() +{ + rompath="${codedir}/build/coreboot.rom" + [ -f "${rompath}" ] || \ + err "modify_coreboot_rom: does not exist: ${rompath}" + tmprom="$(mktemp -t rom.XXXXXXXXXX)" + rm -f "${tmprom}" || \ + err "modify_coreboot_rom prep: cannot remove tmprom" + + if [ "${romtype}" = "d8d16sas" ]; then + # pike2008 roms hang seabios. an empty rom will override + # the built-in one, thus disabling all execution of it + touch "${tmprom}" || \ + err "modify_coreboot_rom: cannot create fake oprom" + for deviceID in "0072" "3050"; do + "${cbfstool}" "${rompath}" add -f "${tmprom}" \ + -n "pci1000,${deviceID}.rom" -t raw || \ + err "modify_coreboot_rom: can't insert fake rom" + done + elif [ "${romtype}" = "i945 laptop" ]; then + # for bucts-based installation method from factory bios + dd if="${rompath}" of="${tmprom}" bs=1 \ + skip=$(($(stat -c %s "${rompath}") - 0x10000)) \ + count=64k || \ + err "modify_coreboot_rom: can't read i945 bootblock" + dd if="${tmprom}" of="${rompath}" bs=1 \ + seek=$(($(stat -c %s "${rompath}") - 0x20000)) \ + count=64k conv=notrunc || \ + err "modify_coreboot_rom: can't write i945 bootblock" + fi + for romsize in 4 8 16; do + ifddir="descriptors/ich9m" + for bs in "4" "12"; do + ifdgbe="${ifddir}/ich9fdnogbe_${romsize}m.bin" + cmpstr="${romsize}MiB ICH9 IFD NOGBE NOR flash" + if [ "${bs}" = "12" ]; then + cmpstr="${romsize}MiB ICH9 IFD NOR flash" + ifdgbe="${ifddir}/ich9fdgbe_${romsize}m.bin" + fi + [ "${romtype}" = "${cmpstr}" ] || continue + [ -f "${ifdgbe}" ] || ./build descriptors ich9m || \ + err "modify_coreboot_rom: can't create ich9m ifd" + dd if="${ifdgbe}" of="${rompath}" bs=${bs}k count=1 \ + conv=notrunc || \ + err "modify_coreboot_rom: can't insert ich9m ifd" + done + done + rm -f "${tmprom}" || \ + err "modify_coreboot_rom: cannot remove tmprom" +} + fail() { [ -z "${codedir}" ] || ./handle make file -c "${codedir}" || : |