mirror of
https://review.haiku-os.org/haiku
synced 2025-01-18 12:38:51 +01:00
u-boot: Fix after multi-loader changes
* Move MMU image to a real image define vs being crammed into the u-boot bootloader Jamfile * ARM not working yet, but better! * x86 still builds Change-Id: I3fb873dbac06fe2db893915b667bf3ce1df44686
This commit is contained in:
parent
59bba8b9ec
commit
dd45d433ed
1
Jamfile
1
Jamfile
@ -118,6 +118,7 @@ include [ FDirName $(HAIKU_BUILD_RULES_DIR) images FloppyBootImage ] ;
|
||||
include [ FDirName $(HAIKU_BUILD_RULES_DIR) images CDBootImage ] ;
|
||||
include [ FDirName $(HAIKU_BUILD_RULES_DIR) images HaikuCD ] ;
|
||||
include [ FDirName $(HAIKU_BUILD_RULES_DIR) images AnybootImage ] ;
|
||||
include [ FDirName $(HAIKU_BUILD_RULES_DIR) images MMCImage ] ;
|
||||
|
||||
# Check whether all requested optional packages do actually exist.
|
||||
local package ;
|
||||
|
@ -241,6 +241,7 @@ rule KernelArchitectureSetup architecture
|
||||
case ppc :
|
||||
HAIKU_KERNEL_PLATFORM ?= openfirmware ;
|
||||
HAIKU_BOOT_TARGETS += openfirmware ;
|
||||
|
||||
HAIKU_BOOT_FLOPPY_IMAGE_SIZE = 1440 ; # in kB
|
||||
# offset in floppy image (>= sizeof(haiku_loader))
|
||||
HAIKU_BOOT_ARCHIVE_IMAGE_OFFSET = 384 ; # in kB
|
||||
@ -258,6 +259,16 @@ rule KernelArchitectureSetup architecture
|
||||
HAIKU_BOOT_ARCHIVE_IMAGE_OFFSET = 192 ; # in kB - unused yet
|
||||
HAIKU_BOOT_LOADER_BASE ?= 0x1000000 ;
|
||||
|
||||
# Modern u-boot fill in sane addresses for us.
|
||||
# We only need to fill in the FDT dtb
|
||||
HAIKU_MMC_UBOOT_SCRIPT = "\
|
||||
test -e mmc 0 uEnv.txt && fatload mmc 0 ${scriptaddr} uEnv.txt && env import -t ${scriptaddr} ${filesize} \
|
||||
fatload mmc 0 ${kernel_addr_r} haiku_loader.u-boot \
|
||||
fatload mmc 0 ${ramdisk_addr_r} haiku-floppyboot.tgz.u-boot \
|
||||
fatload mmc 0 ${fdt_addr_r} ${dtb} \
|
||||
fdt addr ${fdt_addr_r} \
|
||||
bootm ${kernel_addr_r} ${ramdisk_addr_r} ${fdt_addr_r}" ;
|
||||
|
||||
case arm64 :
|
||||
HAIKU_BOOT_PLATFORM ?= efi ;
|
||||
|
||||
|
@ -56,6 +56,15 @@ HAIKU_INSTALL_TARGETS_VAR on $(HAIKU_CD_BOOT_IMAGE_CONTAINER_NAME)
|
||||
HAIKU_CONTAINER_SYSTEM_DIR_TOKENS on $(HAIKU_CD_BOOT_IMAGE_CONTAINER_NAME)
|
||||
= system ;
|
||||
|
||||
# boot MMC image
|
||||
HAIKU_MMC_BOOT_IMAGE_CONTAINER_NAME = haiku-boot-mmc-container ;
|
||||
HAIKU_CONTAINER_GRIST on $(HAIKU_MMC_BOOT_IMAGE_CONTAINER_NAME) = MMCImage ;
|
||||
# HAIKU_INCLUDE_IN_CONTAINER_VAR -- update only mode not supported
|
||||
HAIKU_INSTALL_TARGETS_VAR on $(HAIKU_MMC_BOOT_IMAGE_CONTAINER_NAME)
|
||||
= HAIKU_MMC_BOOT_IMAGE_INSTALL_TARGETS ;
|
||||
HAIKU_CONTAINER_SYSTEM_DIR_TOKENS on $(HAIKU_MMC_BOOT_IMAGE_CONTAINER_NAME)
|
||||
= system ;
|
||||
|
||||
# Haiku image/install defaults
|
||||
HAIKU_DEFAULT_IMAGE_NAME = haiku.image ;
|
||||
HAIKU_DEFAULT_IMAGE_DIR = $(HAIKU_OUTPUT_DIR) ;
|
||||
@ -75,7 +84,8 @@ HAIKU_DEFAULT_ANYBOOT_DIR = $(HAIKU_OUTPUT_DIR) ;
|
||||
HAIKU_DEFAULT_ANYBOOT_LABEL ?= Haiku ;
|
||||
|
||||
# Haiku MMC defaults
|
||||
HAIKU_DEFAULT_MMC_IMAGE_NAME = haiku-mmc.image ;
|
||||
#HAIKU_DEFAULT_MMC_NAME = haiku-$(TARGET_KERNEL_ARCH).mmc ;
|
||||
HAIKU_DEFAULT_MMC_NAME = haiku.mmc ;
|
||||
HAIKU_DEFAULT_MMC_DIR = $(HAIKU_OUTPUT_DIR) ;
|
||||
HAIKU_DEFAULT_MMC_LABEL ?= Haiku ;
|
||||
|
||||
|
63
build/jam/images/MMCImage
Normal file
63
build/jam/images/MMCImage
Normal file
@ -0,0 +1,63 @@
|
||||
# Set anyboot file name and directory defaults.
|
||||
HAIKU_MMC_NAME ?= $(HAIKU_DEFAULT_MMC_NAME) ;
|
||||
HAIKU_MMC_DIR ?= $(HAIKU_DEFAULT_MMC_DIR) ;
|
||||
HAIKU_MMC = $(HAIKU_MMC_NAME) ;
|
||||
HAIKU_MMC_LABEL ?= $(HAIKU_DEFAULT_MMC_LABEL) ;
|
||||
|
||||
# SD/mmc image rule
|
||||
# requires mtools package on linux
|
||||
rule BuildUBootSDImage image : files
|
||||
{
|
||||
Depends $(image) : $(files) $(TARGET_DEVICE_TREES) ;
|
||||
SDIMAGE_BLOCK_SIZE on $(image) = 1048576 ; # 1MiB
|
||||
SDIMAGE_MTOOLS_H on $(image) = 255 ;
|
||||
SDIMAGE_MTOOLS_S on $(image) = 63 ;
|
||||
SDIMAGE_MTOOLS_C on $(image) = 8 ;
|
||||
SDIMAGE_SIZE on $(image) = $(HAIKU_BOOT_SDIMAGE_SIZE) ;
|
||||
SDIMAGE_BEGIN on $(image) = $(HAIKU_BOOT_SDIMAGE_BEGIN:E=63) ;
|
||||
BuildUBootSDImage1 $(image) : $(files) ;
|
||||
}
|
||||
|
||||
actions BuildUBootSDImage1
|
||||
{
|
||||
$(RM) $(1)
|
||||
$(RM) $(1).mtools
|
||||
|
||||
# make an empty image
|
||||
dd of=$(1) \
|
||||
if=/dev/zero \
|
||||
bs=$(SDIMAGE_BLOCK_SIZE) \
|
||||
count=$(SDIMAGE_SIZE)
|
||||
# generate mtools config
|
||||
echo 'drive i: file="$(1)" partition=1 cylinders=$(SDIMAGE_MTOOLS_C)
|
||||
heads=$(SDIMAGE_MTOOLS_H) sectors=$(SDIMAGE_MTOOLS_S)
|
||||
mformat_only' > $(1).mtools
|
||||
# partition it
|
||||
MTOOLSRC=$(1).mtools mpartition -b$(SDIMAGE_BEGIN) -cI -T 0xc i:
|
||||
# format the image
|
||||
MTOOLSRC=$(1).mtools mformat -L 32 -v "HAIKU" i:
|
||||
|
||||
# generate u-boot environment variables
|
||||
echo '$(HAIKU_BOARD_SDIMAGE_UBOOT_UENV)' > uEnv.txt
|
||||
# populate
|
||||
MTOOLSRC=$(1).mtools mcopy $(2[1-]) i:
|
||||
MTOOLSRC=$(1).mtools mcopy uEnv.txt i:
|
||||
# populate fdts
|
||||
MTOOLSRC=$(1).mtools mmd i:\fdt
|
||||
MTOOLSRC=$(1).mtools mcopy $(TARGET_DEVICE_TREES[1-]) i:\fdt\
|
||||
# list content
|
||||
MTOOLSRC=$(1).mtools mdir i:
|
||||
MTOOLSRC=$(1).mtools mdir i:\fdt
|
||||
# cleanup
|
||||
$(RM) $(1).mtools
|
||||
$(RM) uEnv.txt
|
||||
# Add haiku bootstrap partition to MMC image
|
||||
#cat $(2[0]) >> $(1)
|
||||
}
|
||||
|
||||
# SD/mmc image targets
|
||||
BuildUBootSDImage $(HAIKU_MMC_NAME) :
|
||||
$(HAIKU_IMAGE) haiku_loader.u-boot haiku-floppyboot.tgz.u-boot boot.scr ;
|
||||
#BlessSDImage haiku-$(TARGET_KERNEL_ARCH).mmc ;
|
||||
NotFile haiku-mmc-image ;
|
||||
Depends haiku-mmc-image : $(HAIKU_MMC_NAME) ;
|
@ -4,6 +4,9 @@ DEFINES += _BOOT_MODE ;
|
||||
|
||||
UsePrivateHeaders [ FDirName libroot locale ] ;
|
||||
|
||||
#
|
||||
# Coff haiku_loader creation
|
||||
#
|
||||
rule BuildCoffLoader {
|
||||
local coffLoader = $(1) ;
|
||||
local bootLoader = $(2) ;
|
||||
@ -29,6 +32,10 @@ actions BuildCoffLoader bind HACK_COFF {
|
||||
$(HACK_COFF) $(1)
|
||||
}
|
||||
|
||||
|
||||
#
|
||||
# BIOS haiku_loader creation
|
||||
#
|
||||
rule BuildBiosLoader {
|
||||
local haikuLoader = $(1) ;
|
||||
local bootLoader = $(2) ;
|
||||
@ -48,6 +55,10 @@ actions BuildBiosLoader {
|
||||
$(TARGET_OBJCOPY_$(TARGET_PACKAGING_ARCH)) -O binary $(2) $(1)
|
||||
}
|
||||
|
||||
|
||||
#
|
||||
# EFI loader creation
|
||||
#
|
||||
rule BuildEFILoader {
|
||||
local efiLoader = $(1) ;
|
||||
local bootLoader = $(2) ;
|
||||
@ -62,6 +73,44 @@ actions BuildEFILoader {
|
||||
-j .rel -j .rela -j .reloc --target=efi-app-x86_64 $(2) $(1)
|
||||
}
|
||||
|
||||
|
||||
#
|
||||
# U-boot image creation
|
||||
#
|
||||
rule BuildUImage image : data : args
|
||||
{
|
||||
Depends $(image) : $(data) ;
|
||||
LocalClean clean : $(image) ;
|
||||
MKIMAGE_ARGS on $(image) = $(args) ;
|
||||
colon on $(image) = ":" ;
|
||||
local files = $(data:G=) ;
|
||||
BuildUImage1 $(image) : $(data) ;
|
||||
}
|
||||
|
||||
actions BuildUImage1
|
||||
{
|
||||
mkimage $(MKIMAGE_ARGS) -d $(>:J=$(colon)) $(<)
|
||||
}
|
||||
|
||||
rule BuildUImageScript script : content
|
||||
{
|
||||
LocalClean clean : $(script) ;
|
||||
SCRIPTCONTENT on $(script) = $(content) ;
|
||||
SCRIPTNAME on $(script) = $(script) ;
|
||||
FAKEOS on $(script) = "linux" ;
|
||||
BuildUImageScript1 $(script) : $(content) ;
|
||||
}
|
||||
|
||||
actions BuildUImageScript1
|
||||
{
|
||||
rm -f $(<) $(<).txt
|
||||
echo '$(SCRIPTCONTENT)' > $(<).txt
|
||||
mkimage -A $(TARGET_ARCH) -O $(FAKEOS) -T script -C none -n $(SCRIPTNAME) \
|
||||
-d $(<).txt $(<)
|
||||
rm -f $(<).txt
|
||||
}
|
||||
|
||||
|
||||
local extraSources = ;
|
||||
if $(TARGET_GCC_VERSION_$(TARGET_PACKAGING_ARCH)[1]) = 2 {
|
||||
extraSources += atomic.S ;
|
||||
@ -151,12 +200,34 @@ for platform in [ MultiBootSubDirSetup ] {
|
||||
: $(ldflags)
|
||||
;
|
||||
|
||||
BuildCoffLoader boot_loader_$(TARGET_BOOT_PLATFORM)_coff : boot_loader_$(TARGET_BOOT_PLATFORM) ;
|
||||
|
||||
if $(TARGET_BOOT_PLATFORM) != efi {
|
||||
BuildBiosLoader haiku_loader.$(TARGET_BOOT_PLATFORM) : boot_loader_$(TARGET_BOOT_PLATFORM) ;
|
||||
} else {
|
||||
BuildEFILoader haiku_loader.$(TARGET_BOOT_PLATFORM) : boot_loader_$(TARGET_BOOT_PLATFORM) ;
|
||||
switch $(TARGET_BOOT_PLATFORM) {
|
||||
case efi :
|
||||
BuildEFILoader haiku_loader.$(TARGET_BOOT_PLATFORM) : boot_loader_$(TARGET_BOOT_PLATFORM) ;
|
||||
|
||||
case bios_ia32 :
|
||||
BuildBiosLoader haiku_loader.$(TARGET_BOOT_PLATFORM) : boot_loader_$(TARGET_BOOT_PLATFORM) ;
|
||||
|
||||
case pxe_ia32 :
|
||||
BuildBiosLoader haiku_loader.$(TARGET_BOOT_PLATFORM) : boot_loader_$(TARGET_BOOT_PLATFORM) ;
|
||||
|
||||
case openfirmware :
|
||||
BuildCoffLoader haiku_loader.$(TARGET_BOOT_PLATFORM) : boot_loader_$(TARGET_BOOT_PLATFORM) ;
|
||||
|
||||
case u-boot :
|
||||
local loader_entry = `printf \"obase=16;ibase=16;10 + %x\\n\" $(HAIKU_BOOT_LOADER_BASE)|bc` ;
|
||||
BuildUImage haiku_loader.$(TARGET_BOOT_PLATFORM) : boot_loader_$(TARGET_BOOT_PLATFORM)
|
||||
:
|
||||
-A $(TARGET_ARCH) -O linux -T kernel -C none
|
||||
-a $(HAIKU_BOOT_LOADER_BASE) -e $(loader_entry)
|
||||
-n 'Haiku $(TARGET_KERNEL_ARCH) loader' ;
|
||||
BuildUImage haiku-floppyboot.tgz.$(TARGET_BOOT_PLATFORM) : haiku-floppyboot.tgz :
|
||||
-A $(TARGET_ARCH) -O linux -T ramdisk -C none
|
||||
-n 'Haiku $(TARGET_KERNEL_ARCH) floppyboot' ;
|
||||
BuildUImageScript boot.scr : $(HAIKU_MMC_UBOOT_SCRIPT) ;
|
||||
|
||||
case * :
|
||||
Exit "Currently unsupported haiku_loader:" $(TARGET_BOOT_PLATFORM) ;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -15,263 +15,57 @@ UsePrivateHeaders [ FDirName storage ] ;
|
||||
UsePrivateHeaders [ FDirName kernel arch generic ] ;
|
||||
|
||||
{
|
||||
local defines = _BOOT_MODE ;
|
||||
local defines = _BOOT_MODE ;
|
||||
|
||||
defines = [ FDefines $(defines) ] ;
|
||||
SubDirCcFlags $(defines) -g3 -O0 ;
|
||||
SubDirC++Flags $(defines) -fno-rtti -g3 -O0 ;
|
||||
defines = [ FDefines $(defines) ] ;
|
||||
SubDirCcFlags $(defines) -g3 -O0 ;
|
||||
SubDirC++Flags $(defines) -fno-rtti -g3 -O0 ;
|
||||
}
|
||||
|
||||
# we fake NetBSD since we don't have an OS ID yet for uimage,
|
||||
# and we also fake a netbsd loader anyway.
|
||||
local uImageFakeOS = "netbsd" ;
|
||||
|
||||
# Modern u-boot fill in sane addresses for us.
|
||||
# We only need to fill in the FDT dtb
|
||||
HAIKU_MMC_UBOOT_SCRIPT = "\
|
||||
test -e mmc 0 uEnv.txt && fatload mmc 0 ${scriptaddr} uEnv.txt && env import -t ${scriptaddr} ${filesize} \
|
||||
fatload mmc 0 ${kernel_addr_r} haiku_loader.ub \
|
||||
fatload mmc 0 ${ramdisk_addr_r} haiku-floppyboot.tgz.ub \
|
||||
fatload mmc 0 ${fdt_addr_r} ${dtb} \
|
||||
fdt addr ${fdt_addr_r} \
|
||||
bootm ${kernel_addr_r} ${ramdisk_addr_r} ${fdt_addr_r}" ;
|
||||
|
||||
SEARCH_SOURCE += [ FDirName $(HAIKU_TOP) src add-ons accelerants common ] ;
|
||||
|
||||
# First build the non arch dependent parts
|
||||
BootMergeObject boot_platform_u-boot_common.o :
|
||||
start.cpp
|
||||
debug.cpp
|
||||
console.cpp
|
||||
serial.cpp
|
||||
devices.cpp
|
||||
keyboard.cpp
|
||||
menu.cpp
|
||||
cpu.cpp
|
||||
uimage.cpp
|
||||
video.cpp
|
||||
openfirmware.cpp
|
||||
$(genericPlatformSources)
|
||||
:
|
||||
:
|
||||
boot_platform_generic.a
|
||||
boot_fdt.a
|
||||
;
|
||||
|
||||
BootMergeObject boot_platform_u-boot.o :
|
||||
: :
|
||||
# must come first to have _start_* at correct locations
|
||||
boot_platform_u-boot_$(TARGET_ARCH).o
|
||||
boot_platform_u-boot_common.o
|
||||
;
|
||||
|
||||
# TODO: handle flash and SD images as Container stuff ?
|
||||
|
||||
# bootable flash image
|
||||
rule BuildUBootFlashImage image : haikuLoader : parts
|
||||
{
|
||||
Depends $(image) : $(haikuLoader) ;
|
||||
#Depends $(image) : $(archive) ;
|
||||
Depends $(image) : $(parts) ;
|
||||
LocalClean clean : $(image) ;
|
||||
FLASH_IMAGE_BLOCK_SIZE on $(image) = 1024 ;
|
||||
FLASH_IMAGE_BLOCK_COUNT on $(image) = 32768 ;
|
||||
#FLASH_IMAGE_UBOOT_OFFSET on $(image) = 0 ;
|
||||
FLASH_IMAGE_LOADER_OFFSET on $(image) = 248 ;
|
||||
|
||||
# add u-boot
|
||||
FLASH_OFFSET on $(haikuLoader) = $(FLASH_IMAGE_LOADER_OFFSET) ;
|
||||
local offsets = ;
|
||||
for dep in $(haikuLoader) $(parts) {
|
||||
offsets += [ on $(dep) return $(FLASH_OFFSET) ] ;
|
||||
}
|
||||
FLASH_OFFSETS on $(image) = $(offsets) ;
|
||||
|
||||
# create empty image
|
||||
BuildUBootFlashImage1 $(image) : $(haikuLoader) $(parts) ;
|
||||
}
|
||||
|
||||
|
||||
actions BuildUBootFlashImage1
|
||||
{
|
||||
$(RM) $(<)
|
||||
|
||||
# make an empty image
|
||||
dd of=$(<) \
|
||||
if=/dev/zero \
|
||||
bs=$(FLASH_IMAGE_BLOCK_SIZE) \
|
||||
count=$(FLASH_IMAGE_BLOCK_COUNT)
|
||||
|
||||
# add binaries
|
||||
# ugly HACK
|
||||
FLASH_OFFSETS=" $(FLASH_OFFSETS) "
|
||||
FLASH_OFFSETS=${FLASH_OFFSETS# }
|
||||
for b in $(>) ; do
|
||||
s="${FLASH_OFFSETS%% *}"
|
||||
FLASH_OFFSETS="${FLASH_OFFSETS#* }"
|
||||
dd of=$(<) \
|
||||
if=$b \
|
||||
bs=$(FLASH_IMAGE_BLOCK_SIZE) \
|
||||
conv=notrunc seek=$s
|
||||
done
|
||||
}
|
||||
|
||||
# uImage
|
||||
rule BuildUImage image : data : args
|
||||
{
|
||||
Depends $(image) : $(data) ;
|
||||
LocalClean clean : $(image) ;
|
||||
MKIMAGE_ARGS on $(image) = $(args) ;
|
||||
colon on $(image) = ":" ;
|
||||
local files = $(data:G=) ;
|
||||
BuildUImage1 $(image) : $(data) ;
|
||||
}
|
||||
|
||||
actions BuildUImage1
|
||||
{
|
||||
mkimage $(MKIMAGE_ARGS) -d $(>:J=$(colon)) $(<)
|
||||
}
|
||||
|
||||
rule BuildUImageScript script : content
|
||||
{
|
||||
LocalClean clean : $(script) ;
|
||||
SCRIPTCONTENT on $(script) = $(content) ;
|
||||
SCRIPTNAME on $(script) = $(script) ;
|
||||
FAKEOS on $(script) = $(uImageFakeOS) ;
|
||||
BuildUImageScript1 $(script) : $(content) ;
|
||||
}
|
||||
|
||||
actions BuildUImageScript1
|
||||
{
|
||||
rm -f $(<) $(<).txt
|
||||
echo '$(SCRIPTCONTENT)' > $(<).txt
|
||||
mkimage -A $(TARGET_ARCH) -O $(FAKEOS) -T script -C none -n $(SCRIPTNAME) \
|
||||
-d $(<).txt $(<)
|
||||
rm -f $(<).txt
|
||||
}
|
||||
|
||||
# SD/mmc image rule
|
||||
# requires mtools package on linux
|
||||
rule BuildUBootSDImage image : files
|
||||
{
|
||||
Depends $(image) : $(files) $(TARGET_DEVICE_TREES) ;
|
||||
SDIMAGE_BLOCK_SIZE on $(image) = 1048576 ; # 1MiB
|
||||
SDIMAGE_MTOOLS_H on $(image) = 255 ;
|
||||
SDIMAGE_MTOOLS_S on $(image) = 63 ;
|
||||
SDIMAGE_MTOOLS_C on $(image) = 8 ;
|
||||
SDIMAGE_SIZE on $(image) = $(HAIKU_BOOT_SDIMAGE_SIZE) ;
|
||||
SDIMAGE_BEGIN on $(image) = $(HAIKU_BOOT_SDIMAGE_BEGIN:E=63) ;
|
||||
BuildUBootSDImage1 $(image) : $(files) ;
|
||||
}
|
||||
|
||||
actions BuildUBootSDImage1
|
||||
{
|
||||
$(RM) $(1)
|
||||
$(RM) $(1).mtools
|
||||
|
||||
# make an empty image
|
||||
dd of=$(1) \
|
||||
if=/dev/zero \
|
||||
bs=$(SDIMAGE_BLOCK_SIZE) \
|
||||
count=$(SDIMAGE_SIZE)
|
||||
# generate mtools config
|
||||
echo 'drive i: file="$(1)" partition=1 cylinders=$(SDIMAGE_MTOOLS_C)
|
||||
heads=$(SDIMAGE_MTOOLS_H) sectors=$(SDIMAGE_MTOOLS_S)
|
||||
mformat_only' > $(1).mtools
|
||||
# partition it
|
||||
MTOOLSRC=$(1).mtools mpartition -b$(SDIMAGE_BEGIN) -cI -T 0xc i:
|
||||
# format the image
|
||||
MTOOLSRC=$(1).mtools mformat -L 32 -v "HAIKU" i:
|
||||
|
||||
# generate u-boot environment variables
|
||||
echo '$(HAIKU_BOARD_SDIMAGE_UBOOT_UENV)' > uEnv.txt
|
||||
# populate
|
||||
MTOOLSRC=$(1).mtools mcopy $(2[1-]) i:
|
||||
MTOOLSRC=$(1).mtools mcopy uEnv.txt i:
|
||||
# populate fdts
|
||||
MTOOLSRC=$(1).mtools mmd i:\fdt
|
||||
MTOOLSRC=$(1).mtools mcopy $(TARGET_DEVICE_TREES[1-]) i:\fdt\
|
||||
# list content
|
||||
MTOOLSRC=$(1).mtools mdir i:
|
||||
MTOOLSRC=$(1).mtools mdir i:\fdt
|
||||
# cleanup
|
||||
$(RM) $(1).mtools
|
||||
$(RM) uEnv.txt
|
||||
# Add haiku bootstrap partition to MMC image
|
||||
#cat $(2[0]) >> $(1)
|
||||
}
|
||||
|
||||
|
||||
rule BlessSDImage image
|
||||
{
|
||||
# "Blesses" SD cards by writing out data to a fixed point outside of the
|
||||
# filesystem. Handy if your board needs an SPL or boot0 at a fixed point.
|
||||
if $(HAIKU_BOARD_SDIMAGE_BOOT0_FILE) {
|
||||
Depends $(image) : $(HAIKU_BOARD_SDIMAGE_BOOT0_FILE) ;
|
||||
}
|
||||
|
||||
if $(HAIKU_BOARD_SDIMAGE_BOOT1_FILE) {
|
||||
Depends $(image) : $(HAIKU_BOARD_SDIMAGE_BOOT1_FILE) ;
|
||||
}
|
||||
|
||||
BlessSDImage1 $(image) : $(HAIKU_BOARD_SDIMAGE_BOOT0_FILE) $(HAIKU_BOARD_SDIMAGE_BOOT1_FILE) ;
|
||||
}
|
||||
|
||||
|
||||
actions BlessSDImage1 bind HAIKU_BOARD_SDIMAGE_BOOT0_SEEK HAIKU_BOARD_SDIMAGE_BOOT1_SEEK
|
||||
{
|
||||
if [ $(HAIKU_BOARD_SDIMAGE_BOOT0_SEEK:E=-1) -ge 0 ]; then
|
||||
dd if=$(2[1]) of=$(1) bs=1 seek=$(HAIKU_BOARD_SDIMAGE_BOOT0_SEEK) conv=notrunc
|
||||
fi
|
||||
|
||||
if [ $(HAIKU_BOARD_SDIMAGE_BOOT1_SEEK:E=-1) -ge 0 ]; then
|
||||
dd if=$(2[2]) of=$(1) bs=1 seek=$(HAIKU_BOARD_SDIMAGE_BOOT1_SEEK) conv=notrunc
|
||||
fi
|
||||
}
|
||||
|
||||
HAIKU_BOOT_LOADER_ENTRY_LINUX = `printf \"obase=16;ibase=16;10 + %x\\n\" $(HAIKU_BOOT_LOADER_BASE)|bc` ;
|
||||
|
||||
# uimage targets
|
||||
BuildUImage haiku-floppyboot.tgz.ub : haiku-floppyboot.tgz :
|
||||
-A $(TARGET_ARCH) -O linux -T ramdisk -C none
|
||||
-n 'Haiku $(TARGET_KERNEL_ARCH) floppyboot' ;
|
||||
|
||||
BuildUImage haiku_loader.ub : haiku_loader :
|
||||
-A $(TARGET_ARCH) -O linux -T kernel -C none
|
||||
-a $(HAIKU_BOOT_LOADER_BASE) -e $(HAIKU_BOOT_LOADER_ENTRY_LINUX)
|
||||
-n 'Haiku $(TARGET_KERNEL_ARCH) loader' ;
|
||||
|
||||
BuildUImageScript boot.scr : $(HAIKU_MMC_UBOOT_SCRIPT) ;
|
||||
|
||||
# flash image targets
|
||||
|
||||
BuildUBootFlashImage haiku-$(TARGET_KERNEL_ARCH)_flash_image_raw.img : haiku_loader :
|
||||
$(FLASH_IMAGE_PARTS) ;
|
||||
NotFile haiku-flash-image ;
|
||||
Depends haiku-flash-image : haiku-$(TARGET_KERNEL_ARCH)_flash_image_raw.img ;
|
||||
|
||||
#BuildUBootFlashImage haiku-$(TARGET_KERNEL_ARCH)_flash_image_elf.img : boot_loader_u-boot :
|
||||
# $(FLASH_IMAGE_PARTS) ;
|
||||
#NotFile haiku-flash-elf-image ;
|
||||
#Depends haiku-flash-elf-image : haiku-$(TARGET_KERNEL_ARCH)_flash_image_elf.img ;
|
||||
|
||||
BuildUBootFlashImage haiku-$(TARGET_KERNEL_ARCH)_flash_image_uimage.img : haiku_loader.ub :
|
||||
$(FLASH_IMAGE_PARTS) ;
|
||||
NotFile haiku-flash-uimage ;
|
||||
Depends haiku-flash-uimage : haiku-$(TARGET_KERNEL_ARCH)_flash_image_uimage.img ;
|
||||
|
||||
# SD/mmc image targets
|
||||
BuildUBootSDImage haiku-$(TARGET_KERNEL_ARCH).mmc :
|
||||
$(HAIKU_IMAGE) haiku_loader.ub haiku-floppyboot.tgz.ub boot.scr ;
|
||||
BlessSDImage haiku-$(TARGET_KERNEL_ARCH).mmc ;
|
||||
NotFile haiku-mmc-image ;
|
||||
Depends haiku-mmc-image : haiku-$(TARGET_KERNEL_ARCH).mmc ;
|
||||
|
||||
SEARCH on [ FGristFiles $(genericPlatformSources) ]
|
||||
= [ FDirName $(HAIKU_TOP) src system boot platform generic ] ;
|
||||
= [ FDirName $(HAIKU_TOP) src system boot platform generic ] ;
|
||||
|
||||
local platform ;
|
||||
for platform in [ MultiBootSubDirSetup u-boot ] {
|
||||
on $(platform) {
|
||||
|
||||
local kernelPlatformSources =
|
||||
openfirmware.cpp ;
|
||||
|
||||
SEARCH on [ FGristFiles $(kernelPlatformSources) ]
|
||||
= [ FDirName $(HAIKU_TOP) src system kernel platform u-boot ] ;
|
||||
|
||||
# First build the non arch dependent parts
|
||||
BootMergeObject boot_platform_u-boot_common.o :
|
||||
start.cpp
|
||||
debug.cpp
|
||||
console.cpp
|
||||
serial.cpp
|
||||
devices.cpp
|
||||
keyboard.cpp
|
||||
menu.cpp
|
||||
cpu.cpp
|
||||
uimage.cpp
|
||||
video.cpp
|
||||
$(kernelPlatformSources)
|
||||
$(genericPlatformSources)
|
||||
:
|
||||
:
|
||||
boot_platform_generic.a
|
||||
boot_fdt.a
|
||||
;
|
||||
|
||||
BootMergeObject boot_platform_u-boot.o :
|
||||
: :
|
||||
# must come first to have _start_* at correct locations
|
||||
boot_platform_u-boot_$(TARGET_ARCH).o
|
||||
boot_platform_u-boot_common.o
|
||||
;
|
||||
}
|
||||
}
|
||||
|
||||
SEARCH on [ FGristFiles openfirmware.cpp ]
|
||||
= [ FDirName $(HAIKU_TOP) src system kernel platform u-boot ] ;
|
||||
|
||||
# Tell the build system to where stage1.bin can be found, so it can be used
|
||||
# elsewhere.
|
||||
|
Loading…
Reference in New Issue
Block a user