[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Minios-devel] [UNIKRAFT PATCH v3 1/4] build: make all linker scripts preprocessable
This will allow to apply some code de-duplication, and makes build system a little bit homogeneous against linker scripts Signed-off-by: Yuri Volchkov <yuri.volchkov@xxxxxxxxx> --- plat/kvm/Linker.uk | 4 ++-- plat/kvm/Makefile.uk | 3 ++- plat/kvm/x86/{link64.lds => link64.lds.S} | 0 plat/xen/Linker.uk | 13 ++----------- plat/xen/Makefile.uk | 3 +++ plat/xen/arm/{link32.lds => link32.lds.S} | 0 plat/xen/x86/{link64.lds => link64.lds.S} | 0 7 files changed, 9 insertions(+), 14 deletions(-) rename plat/kvm/x86/{link64.lds => link64.lds.S} (100%) rename plat/xen/arm/{link32.lds => link32.lds.S} (100%) rename plat/xen/x86/{link64.lds => link64.lds.S} (100%) diff --git a/plat/kvm/Linker.uk b/plat/kvm/Linker.uk index 52ae61b9..8ed25260 100644 --- a/plat/kvm/Linker.uk +++ b/plat/kvm/Linker.uk @@ -1,11 +1,11 @@ ifeq (x86_64,$(CONFIG_UK_ARCH)) -KVM_LDSCRIPT := $(CONFIG_UK_BASE)/plat/kvm/x86/link64.lds KVM_LDFLAGS-y += -Wl,-m,elf_x86_64 else ifeq (arm64,$(CONFIG_UK_ARCH)) KVM_LDFLAGS-y += -Wl,-m,aarch64elf -KVM_LDSCRIPT := $(call src2lds,libkvmplat,$(KVM_LDSCRIPT_SRC)) endif +KVM_LDSCRIPT := $(call src2lds,libkvmplat,$(KVM_LDSCRIPT_SRC-y)) + ## ## Link image ## diff --git a/plat/kvm/Makefile.uk b/plat/kvm/Makefile.uk index b9a93a11..633348ab 100644 --- a/plat/kvm/Makefile.uk +++ b/plat/kvm/Makefile.uk @@ -26,6 +26,7 @@ LIBKVMPLAT_CXXFLAGS += -DKVMPLAT ## ## Architecture library definitions for x86_64 ## +KVM_LDSCRIPT_SRC-$(CONFIG_ARCH_X86_64) := $(CONFIG_UK_BASE)/plat/kvm/x86/link64.lds.S LIBKVMPLAT_SRCS-$(CONFIG_ARCH_X86_64) += $(UK_PLAT_COMMON_BASE)/x86/trace.c|common LIBKVMPLAT_SRCS-$(CONFIG_ARCH_X86_64) += $(UK_PLAT_COMMON_BASE)/x86/traps.c|common LIBKVMPLAT_TRAPS_COMMON_FLAGS += $(NO_X86_EXTREGS_FLAGS) @@ -59,7 +60,6 @@ KVM_LDSCRIPT_SRC := $(CONFIG_UK_BASE)/plat/kvm/arm/link64.lds.S ifeq ($(findstring y,$(CONFIG_KVM_KERNEL_SERIAL_CONSOLE) $(CONFIG_KVM_DEBUG_SERIAL_CONSOLE)),y) LIBKVMPLAT_SRCS-$(CONFIG_ARCH_ARM_64) += $(UK_PLAT_COMMON_BASE)/arm/pl011.c|common endif -LIBKVMPLAT_SRCS-$(CONFIG_ARCH_ARM_64) += $(KVM_LDSCRIPT_SRC) LIBKVMPLAT_SRCS-$(CONFIG_ARCH_ARM_64) += $(UK_PLAT_COMMON_BASE)/arm/cpu_native.c|common LIBKVMPLAT_SRCS-$(CONFIG_ARCH_ARM_64) += $(UK_PLAT_COMMON_BASE)/arm/cache64.S|common LIBKVMPLAT_SRCS-$(CONFIG_ARCH_ARM_64) += $(UK_PLAT_COMMON_BASE)/arm/psci_arm64.S|common @@ -78,6 +78,7 @@ LIBKVMPLAT_SRCS-y += $(LIBKVMPLAT_BASE)/irq.c LIBKVMPLAT_SRCS-y += $(LIBKVMPLAT_BASE)/io.c LIBKVMPLAT_SRCS-y += $(UK_PLAT_COMMON_BASE)/lcpu.c|common LIBKVMPLAT_SRCS-y += $(UK_PLAT_COMMON_BASE)/memory.c|common +LIBKVMPLAT_SRCS-y += $(KVM_LDSCRIPT_SRC-y) ## ## PCI library definitions diff --git a/plat/kvm/x86/link64.lds b/plat/kvm/x86/link64.lds.S similarity index 100% rename from plat/kvm/x86/link64.lds rename to plat/kvm/x86/link64.lds.S diff --git a/plat/xen/Linker.uk b/plat/xen/Linker.uk index 5f39de1a..bcbdc00f 100644 --- a/plat/xen/Linker.uk +++ b/plat/xen/Linker.uk @@ -1,17 +1,8 @@ ifeq (x86_64,$(CONFIG_UK_ARCH)) -XEN_LDSCRIPT := $(CONFIG_UK_BASE)/plat/xen/x86/link64.lds XEN_LDFLAGS-y += -Wl,-m,elf_x86_64 endif -ifeq (x86_32,$(CONFIG_UK_ARCH)) -XEN_LDSCRIPT := $(CONFIG_UK_BASE)/plat/xen/x86/link32.lds -XEN_LDFLAGS-y += -Wl,-m,elf_x86_32 -endif -ifeq (arm_64,$(CONFIG_UK_ARCH)) -XEN_LDSCRIPT := $(CONFIG_UK_BASE)/plat/xen/arm/link64.lds -endif -ifeq (arm,$(CONFIG_UK_ARCH)) -XEN_LDSCRIPT := $(CONFIG_UK_BASE)/plat/xen/arm/link32.lds -endif + +XEN_LDSCRIPT := $(call src2lds,libxenplat,$(XEN_LDSCRIPT_SRC-y)) ## ## Link image diff --git a/plat/xen/Makefile.uk b/plat/xen/Makefile.uk index 3642c5b2..69b10efc 100644 --- a/plat/xen/Makefile.uk +++ b/plat/xen/Makefile.uk @@ -31,6 +31,7 @@ LIBXENPLAT_SRCS-y += $(LIBXENPLAT_BASE)/io.c LIBXENPLAT_SRCS-y += $(UK_PLAT_COMMON_BASE)/lcpu.c|common LIBXENPLAT_SRCS-y += $(UK_PLAT_COMMON_BASE)/memory.c|common +XEN_LDSCRIPT_SRC-$(CONFIG_ARCH_X86_64) := $(CONFIG_UK_BASE)/plat/xen/x86/link64.lds.S LIBXENPLAT_SRCS-$(CONFIG_ARCH_X86_64) += $(UK_PLAT_COMMON_BASE)/x86/trace.c|common LIBXENPLAT_SRCS-$(CONFIG_ARCH_X86_64) += $(UK_PLAT_COMMON_BASE)/x86/traps.c|common LIBXENPLAT_SRCS-$(CONFIG_ARCH_X86_64) += $(UK_PLAT_COMMON_BASE)/x86/cpu_features.c|common @@ -55,6 +56,7 @@ LIBXENPLAT_SRCS-$(CONFIG_ARCH_X86_64) += $(UK_PLAT_COMMON_BASE)/x86/cpu_native.c LIBXENPLAT_SRCS-$(CONFIG_ARCH_ARM_32) += $(UK_PLAT_COMMON_BASE)/arm/cpu_native.c endif +XEN_LDSCRIPT_SRC-$(CONFIG_ARCH_ARM_32) := $(CONFIG_UK_BASE)/plat/xen/arm/link32.lds.S LIBXENPLAT_SRCS-$(CONFIG_ARCH_ARM_32) += $(LIBXENPLAT_BASE)/arm/setup.c LIBXENPLAT_SRCS-$(CONFIG_ARCH_ARM_32) += $(LIBXENPLAT_BASE)/arm/traps.c LIBXENPLAT_SRCS-$(CONFIG_ARCH_ARM_32) += $(LIBXENPLAT_BASE)/arm/entry32.S @@ -79,6 +81,7 @@ LIBXENPLAT_SRCS-y += $(LIBXENPLAT_BASE)/emg_console.c endif LIBXENPLAT_SRCS-y += $(LIBXENPLAT_BASE)/shutdown.c LIBXENPLAT_SRCS-y += $(LIBXENPLAT_BASE)/events.c +LIBXENPLAT_SRCS-y += $(XEN_LDSCRIPT_SRC-y) ifeq ($(CONFIG_XEN_GNTTAB),y) LIBXENPLAT_SRCS-y += $(LIBXENPLAT_BASE)/gnttab.c diff --git a/plat/xen/arm/link32.lds b/plat/xen/arm/link32.lds.S similarity index 100% rename from plat/xen/arm/link32.lds rename to plat/xen/arm/link32.lds.S diff --git a/plat/xen/x86/link64.lds b/plat/xen/x86/link64.lds.S similarity index 100% rename from plat/xen/x86/link64.lds rename to plat/xen/x86/link64.lds.S -- 2.19.2 _______________________________________________ Minios-devel mailing list Minios-devel@xxxxxxxxxxxxxxxxxxxx https://lists.xenproject.org/mailman/listinfo/minios-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |