2017-09-23 22:53:10 -04:00
|
|
|
|
2017-09-20 17:47:48 -04:00
|
|
|
# Targets specific for the NERF firmware
|
|
|
|
#
|
|
|
|
|
|
|
|
# this assumes that we've already made the edk2 things, via
|
|
|
|
# edk2.intermediate or something like that.
|
|
|
|
EDK2_DIR := $(build)/$(edk2_dir)/BaseTools/BinWrappers/PosixLike
|
|
|
|
|
|
|
|
|
2017-09-23 22:53:10 -04:00
|
|
|
# build/edk2-UDK2017/Build/MdeModule/DEBUG_GCC5/X64/MdeModulePkg/Core/Dxe/DxeMain/OUTPUT
|
|
|
|
# wtf edk2 doesn't hve a way to turn the inf file into an executable?
|
|
|
|
# this build system sucks
|
2017-09-20 17:47:48 -04:00
|
|
|
|
2017-09-23 22:53:10 -04:00
|
|
|
RuntimeArchProtocolGuid := { 0xb7dfb4e1, 0x052f, 0x449f, { 0x87, 0xbe, 0x98, 0x18, 0xfc, 0x91, 0xb7, 0x33 }}
|
|
|
|
AcpiTableProtocolGuid := { 0xFFE06BDD, 0x6107, 0x46A6, { 0x7B, 0xB2, 0x5A, 0x9C, 0x7E, 0xC5, 0x27, 0x5C }}
|
2017-10-19 15:59:13 -04:00
|
|
|
SmbiosProtocolGuid := {0x3583ff6, 0xcb36, 0x4940, { 0x94, 0x7e, 0xb9, 0xb3, 0x9f, 0x4a, 0xfa, 0xf7}}
|
|
|
|
VariableArchProtocolGuid := { 0x1E5668E2, 0x8481, 0x11D4, { 0xBC, 0xF1, 0x00, 0x80, 0xC7, 0x3C, 0x88, 0x81 }}
|
2017-09-20 17:47:48 -04:00
|
|
|
|
|
|
|
|
2017-09-23 22:53:10 -04:00
|
|
|
dxe-y += DxeCore
|
|
|
|
DxeCore-filetype := EFI_FV_FILETYPE_DXE_CORE
|
|
|
|
DxeCore-guid := D6A2CB7F-6A18-4E2F-B43B-9920A733700A
|
2017-10-19 15:59:13 -04:00
|
|
|
#DxeCore-align := 1K
|
2017-09-23 22:53:10 -04:00
|
|
|
|
|
|
|
dxe-y += RuntimeDxe
|
|
|
|
RuntimeDxe-depex := TRUE
|
|
|
|
RuntimeDxe-guid := B601F8C4-43B7-4784-95B1-F4226CB40CEE
|
|
|
|
|
|
|
|
dxe-y += AcpiTableDxe
|
|
|
|
AcpiTableDxe-guid := 9622E42C-8E38-4a08-9E8F-54F784652F6B
|
|
|
|
AcpiTableDxe-depex := $(RuntimeArchProtocolGuid)
|
|
|
|
|
|
|
|
dxe-y += AcpiPlatform
|
|
|
|
AcpiPlatform-guid := cb933912-df8f-4305-b1f9-7b44fa11395c
|
|
|
|
AcpiPlatform-depex := $(RuntimeArchProtocolGuid) AND $(AcpiTableProtocolGuid)
|
|
|
|
|
2017-10-19 15:59:13 -04:00
|
|
|
dxe-y += SmbiosDxe
|
|
|
|
SmbiosDxe-guid := F9D88642-0737-49BC-81B5-6889CD57D9EA
|
|
|
|
SmbiosDxe-depex := $(RuntimeArchProtocolGuid)
|
|
|
|
|
|
|
|
# the VariableStore doesn't work with most vendor firmwares for some reason.
|
|
|
|
# instead we link in the EmuRuntimeDxe, which avoids the
|
|
|
|
dxe-n += VariableRuntimeDxe
|
|
|
|
VariableRuntimeDxe-guid := CBD2E4D5-7068-4FF5-B462-9822B4AD8D60
|
|
|
|
VariableRuntimeDxe-depex := $(RuntimeArchProtocolGuid)
|
|
|
|
dxe-y += EmuVariableRuntimeDxe
|
|
|
|
EmuVariableRuntimeDxe-guid := CBD2E4D5-7068-4FF5-B462-9822B4AD8D60
|
|
|
|
EmuVariableRuntimeDxe-depex := $(RuntimeArchProtocolGuid)
|
|
|
|
|
|
|
|
|
2017-09-25 15:21:16 -04:00
|
|
|
#dxe-y += Acpi-data
|
|
|
|
Acpi-data-file := /dev/null
|
|
|
|
Acpi-data-guid := 7E374E25-8E01-4FEE-87F2-390C23C606CD
|
|
|
|
Acpi-data-filetype := EFI_FV_FILETYPE_FREEFORM
|
|
|
|
Acpi-data-sectiontype := EFI_SECTION_RAW
|
2017-10-05 15:10:34 -04:00
|
|
|
Acpi-data.ffs: $(sort blobs/$(BOARD)/acpi/*)
|
2017-09-25 15:21:16 -04:00
|
|
|
for file in $^; do \
|
|
|
|
$(EDK2_DIR)/GenSec \
|
|
|
|
-s EFI_SECTION_RAW \
|
|
|
|
-o `basename $$file`.sec $$file; \
|
|
|
|
done
|
|
|
|
$(EDK2_DIR)/GenFfs \
|
|
|
|
-t EFI_FV_FILETYPE_FREEFORM \
|
|
|
|
-g $(Acpi-data-guid) \
|
|
|
|
-o $@ \
|
|
|
|
$(foreach f,$^,-i $(notdir $f).sec)
|
|
|
|
|
2017-09-23 22:53:10 -04:00
|
|
|
|
|
|
|
dxe-y += Linux
|
|
|
|
Linux-file := $(build)/$(linux_dir)/arch/x86/boot/bzImage
|
|
|
|
Linux-version := $(linux-version)
|
|
|
|
Linux-guid := DECAFBAD-6548-6461-732d-2f2d4e455246
|
2017-10-19 15:59:13 -04:00
|
|
|
Linux-depex := \
|
|
|
|
$(RuntimeArchProtocolGuid) \
|
|
|
|
AND $(AcpiTableProtocolGuid) \
|
|
|
|
AND $(SmbiosProtocolGuid) \
|
|
|
|
AND $(VariableArchProtocolGuid) \
|
2017-09-23 22:53:10 -04:00
|
|
|
|
|
|
|
|
|
|
|
dxe-y += Initrd
|
|
|
|
Initrd-file := initrd.cpio.xz
|
|
|
|
Initrd-filetype := EFI_FV_FILETYPE_FREEFORM
|
|
|
|
Initrd-guid := 74696e69-6472-632e-7069-6f2f62696f73
|
|
|
|
Initrd-sectiontype := EFI_SECTION_RAW
|
2017-09-20 17:47:48 -04:00
|
|
|
|
2017-09-23 22:53:10 -04:00
|
|
|
#$(build)/$(linux_dir)/arch/x86/boot/bzImage: linux.intermediate
|
|
|
|
|
|
|
|
%.dep:
|
|
|
|
$(EDK2_DIR)/GenDepex \
|
|
|
|
-t DXE_DRIVER \
|
|
|
|
-o $@ \
|
|
|
|
-e '$($*-depex)'
|
|
|
|
|
|
|
|
%.dep.sec: %.dep
|
2017-09-20 17:47:48 -04:00
|
|
|
$(EDK2_DIR)/GenSec \
|
|
|
|
-S EFI_SECTION_DXE_DEPEX \
|
|
|
|
-o $@ \
|
2017-09-23 22:53:10 -04:00
|
|
|
$<
|
2017-09-20 17:47:48 -04:00
|
|
|
|
2017-09-23 22:53:10 -04:00
|
|
|
%.name.sec:
|
|
|
|
$(EDK2_DIR)/GenSec \
|
|
|
|
-S EFI_SECTION_USER_INTERFACE \
|
|
|
|
-o "$@" \
|
|
|
|
-n "$*"
|
2017-09-20 17:47:48 -04:00
|
|
|
|
2017-09-23 22:53:10 -04:00
|
|
|
%.ver.sec:
|
2017-09-20 17:47:48 -04:00
|
|
|
$(EDK2_DIR)/GenSec \
|
2017-09-23 22:53:10 -04:00
|
|
|
-S EFI_SECTION_VERSION \
|
|
|
|
-o "$@" \
|
|
|
|
-n "$(or $($*-version),1.0)"
|
|
|
|
|
2017-09-20 17:47:48 -04:00
|
|
|
|
2017-09-23 22:53:10 -04:00
|
|
|
define build-ffs =
|
2017-10-19 15:59:13 -04:00
|
|
|
$1.ffs: \
|
|
|
|
$1.name.sec \
|
|
|
|
$1.ver.sec \
|
2017-09-23 22:53:10 -04:00
|
|
|
$(if $($1-depex),$1.dep.sec) \
|
2017-10-19 15:59:13 -04:00
|
|
|
$1.file.sec \
|
2017-09-20 17:47:48 -04:00
|
|
|
|
|
|
|
$(EDK2_DIR)/GenFfs \
|
2017-09-23 22:53:10 -04:00
|
|
|
-t $(or $($1-filetype),EFI_FV_FILETYPE_DRIVER) \
|
|
|
|
-g $($1-guid) \
|
2017-10-20 16:20:51 -04:00
|
|
|
--align $(or $($1-align),4K) \
|
2017-09-23 22:53:10 -04:00
|
|
|
-o $$@ \
|
2017-10-19 15:59:13 -04:00
|
|
|
$$(addprefix -i ,$$^) \
|
2017-09-20 17:47:48 -04:00
|
|
|
|
2017-09-23 22:53:10 -04:00
|
|
|
$1.file.sec: \
|
|
|
|
$(or $($1-file),$(build)/$(edk2_dir)/Build/MdeModule/DEBUG_GCC5/X64/$1.efi)
|
2017-09-20 17:47:48 -04:00
|
|
|
|
2017-09-23 22:53:10 -04:00
|
|
|
$(EDK2_DIR)/GenSec \
|
|
|
|
-S $(or $($1-sectiontype),EFI_SECTION_PE32) \
|
|
|
|
-o $$@ \
|
|
|
|
$$^
|
|
|
|
|
|
|
|
# add a dependency on the edk2 module if we are picking up an
|
|
|
|
# edk2 build DXEexecutable.
|
|
|
|
ifndef $($1-file)
|
|
|
|
$(build)/$(edk2_dir)/Build/MdeModule/DEBUG_GCC5/X64/$1.efi: edk2.intermediate
|
|
|
|
endif
|
|
|
|
|
|
|
|
endef
|
|
|
|
|
|
|
|
# For everything that we will include in our DXE filesystem, we
|
|
|
|
# have to instatiate targets for the ffs and file sections.
|
|
|
|
# If there is no DEPEX defined, do not create a depex file dependency
|
|
|
|
$(call map,build-ffs,$(dxe-y))
|
|
|
|
|
|
|
|
$(build)/$(linux_dir)/arch/x86/boot/bzImage: linux.intermediate
|
2017-09-20 17:47:48 -04:00
|
|
|
|
|
|
|
|
2017-09-22 15:13:41 -04:00
|
|
|
# Generate a firmware file with a well known guid
|
|
|
|
|
2017-09-20 18:59:24 -04:00
|
|
|
# If you have to fit within the normal UEFI image, the volume is
|
|
|
|
# limited to 0x47 blocks.
|
|
|
|
#
|
|
|
|
# But you can also replace the entire region from 0x310000
|
|
|
|
# up to PEI at 0xE40000, which leaves us almost 11 MB of space.
|
2017-10-05 15:10:34 -04:00
|
|
|
#
|
|
|
|
# x3550m5 -- pei starts at 0xb00000, bios is from 0x1000 == 0xaff
|
2017-09-25 15:21:16 -04:00
|
|
|
nerf.vol: $(addsuffix .ffs,$(dxe-y)) Acpi-data.ffs # blobs/r630/acpi-data.ffs.uncompressed
|
2017-09-20 17:47:48 -04:00
|
|
|
$(EDK2_DIR)/GenFv \
|
2017-10-05 15:10:34 -04:00
|
|
|
--numberblock $$[$(NERF_SIZE)/0x1000] \
|
|
|
|
--blocksize 0x1000 \
|
2017-09-20 17:47:48 -04:00
|
|
|
--FvNameGuid 4652454e-482f-6165-6473-2f4c696e7578 \
|
|
|
|
-o $@ \
|
2017-09-21 09:34:16 -04:00
|
|
|
$(addprefix -f ,$^)
|
2017-09-21 10:24:16 -04:00
|
|
|
@head -2 $@.txt
|
|
|
|
-$(RM) $@.txt $@.map
|
2017-09-20 17:47:48 -04:00
|
|
|
|
2017-09-22 16:20:58 -04:00
|
|
|
# You must provide your own r630.rom as input for the ME and PEI sections.
|
2017-09-21 10:24:16 -04:00
|
|
|
# the ifd is only the first 64k, but we take all the way to the ME region
|
|
|
|
# and unlock the IFD (from coreboot) to allow flashrom to write to the ROM.
|
|
|
|
# ifdtool -u blobs/r630/ifd.bin && mv blobs/r630/ifd.bin.new blobs/r630/ifd.bin
|
2017-10-05 15:10:34 -04:00
|
|
|
blobs/$(BOARD)/me.bin: blobs/$(BOARD)/$(BOARD).rom
|
|
|
|
dd < $< bs=$$[0x10000] skip=$$[$(ME_OFFSET)/0x10000] count=$$[$(ME_SIZE)/0x10000] > $@
|
|
|
|
blobs/$(BOARD)/pei.bin: blobs/$(BOARD)/$(BOARD).rom
|
|
|
|
dd < $< bs=$$[0x10000] skip=$$[$(PEI_OFFSET)/0x10000] count=$$[$(PEI_SIZE)/0x10000] > $@
|
|
|
|
|
|
|
|
nerf-$(BOARD).rom: \
|
|
|
|
blobs/$(BOARD)/ifd.bin \
|
|
|
|
blobs/$(BOARD)/me.bin \
|
2017-09-21 10:24:16 -04:00
|
|
|
nerf.vol \
|
2017-10-05 15:10:34 -04:00
|
|
|
blobs/$(BOARD)/pei.bin \
|
2017-09-21 10:24:16 -04:00
|
|
|
|
|
|
|
cat $^ > $@
|
|
|
|
@if [ `stat -c'%s' $@` -ne 16777216 ]; then \
|
|
|
|
echo -n >&2 "$@ SHOULD BE 16MB. size "; \
|
|
|
|
stat -c'%s' $@ >&2 ; \
|
|
|
|
mv $@ $@.bad; \
|
|
|
|
exit 1; \
|
|
|
|
fi
|
2017-09-20 18:59:24 -04:00
|
|
|
|
2017-09-23 22:53:10 -04:00
|
|
|
#
|
|
|
|
# Generate a compressed section
|
|
|
|
# LZMA guid is EE4E5898-3914-4259-9D6E-DC7BD79403CF
|
|
|
|
# Embedded filesystem is 8C8CE578-8A3D-4F1C-9935-896185C32DD3
|
|
|
|
#
|
2017-10-05 15:10:34 -04:00
|
|
|
acpi-lz.ffs: blobs/$(BOARD)/acpi-data.ffs
|
2017-09-23 22:53:10 -04:00
|
|
|
$(EDK2_DIR)/GenFfs \
|
|
|
|
-t EFI_FV_FILETYPE_FIRMWARE_VOLUME_IMAGE \
|
|
|
|
-g 8C8CE578-8A3D-4F1C-9935-896185C32DD3 \
|
|
|
|
-o $<.ffs.fv \
|
|
|
|
-a 16 \
|
|
|
|
-i $<
|
|
|
|
$(EDK2_DIR)/LzmaCompress \
|
|
|
|
-e \
|
|
|
|
-q \
|
|
|
|
-o $<.fv.lz \
|
|
|
|
$<.fv
|
|
|
|
$(EDK2_DIR)/GenSec \
|
|
|
|
-s EFI_SECTION_GUID_DEFINED \
|
|
|
|
-g EE4E5898-3914-4259-9D6E-DC7BD79403CF \
|
|
|
|
-r PROCESSING_REQUIRED \
|
|
|
|
-o $<.fv.lz.sec \
|
|
|
|
$<.fv.lz
|
|
|
|
$(EDK2_DIR)/GenFfs \
|
|
|
|
-t EFI_FV_FILETYPE_FIRMWARE_VOLUME_IMAGE \
|
|
|
|
-g 8C8CE578-8A3D-4F1C-9935-896185C32DD3 \
|
|
|
|
-i $<.fv.lz.sec \
|
|
|
|
-o $@
|
2017-09-20 17:47:48 -04:00
|
|
|
|
|
|
|
|
2017-11-20 17:28:35 -05:00
|
|
|
nerf.intermediate: edk2.intermediate nerf-$(BOARD).rom
|