| ifeq ($(CONFIG_ARCH_ROMSTAGE_X86_32)$(CONFIG_ARCH_ROMSTAGE_X86_64),y) |
| romstage-$(CONFIG_CACHE_AS_RAM) += car.c |
| endif |
| |
| subdirs-$(CONFIG_PARALLEL_MP) += name |
| ramstage-$(CONFIG_PARALLEL_MP) += mp_init.c |
| ramstage-$(CONFIG_MIRROR_PAYLOAD_TO_RAM_BEFORE_LOADING) += mirror_payload.c |
| |
| additional-dirs += $(obj)/cpu/x86 |
| |
| SIPI_ELF=$(obj)/cpu/x86/sipi_vector.elf |
| SIPI_RMOD=$(SIPI_ELF).rmod |
| SIPI_BIN=$(SIPI_ELF:.elf=) |
| SIPI_DOTO=$(SIPI_ELF:.elf=.o) |
| |
| ifeq ($(CONFIG_PARALLEL_MP),y) |
| ramstage-srcs += $(SIPI_BIN).manual |
| endif |
| rmodules_$(ARCH-ramstage-y)-$(CONFIG_PARALLEL_MP) += sipi_vector.S |
| |
| $(SIPI_DOTO): $(call src-to-obj,rmodules_$(ARCH-ramstage-y),src/cpu/x86/sipi_vector.S) |
| $(CC_rmodules_$(ARCH-ramstage-y)) $(CFLAGS_rmodules_$(ARCH-ramstage-y)) -nostdlib -r -o $@ $^ |
| |
| ifeq ($(CONFIG_ARCH_RAMSTAGE_X86_32),y) |
| $(eval $(call rmodule_link,$(SIPI_ELF), $(SIPI_DOTO), 0,x86_32)) |
| else |
| $(eval $(call rmodule_link,$(SIPI_ELF), $(SIPI_DOTO), 0,x86_64)) |
| endif |
| |
| $(SIPI_BIN): $(SIPI_RMOD) |
| $(OBJCOPY_ramstage) -O binary $< $@ |
| |
| $(call src-to-obj,ramstage,$(SIPI_BIN).manual): $(SIPI_BIN) |
| @printf " OBJCOPY $(subst $(obj)/,,$(@))\n" |
| cd $(dir $<); $(OBJCOPY_rmodules_$(ARCH-ramstage-y)) -I binary $(notdir $<) $(target-objcopy) $(abspath $@) |