1 # SPDX-License-Identifier: GPL-2.0 << 2 # 1 # 3 # Author: Huacai Chen <chenhuacai@loongson.cn> !! 2 # sparc/Makefile 4 # Copyright (C) 2020-2022 Loongson Technology << 5 << 6 boot := arch/loongarch/boot << 7 << 8 KBUILD_DEFCONFIG := loongson3_defconfig << 9 KBUILD_DTBS := dtbs << 10 << 11 image-name-y := vmlinux << 12 image-name-$(CONFIG_EFI_ZBOOT) := vmlinuz << 13 << 14 ifndef CONFIG_EFI_STUB << 15 KBUILD_IMAGE := $(boot)/vmlinux.elf << 16 else << 17 KBUILD_IMAGE := $(boot)/$(image-name-y).efi << 18 endif << 19 << 20 # 3 # 21 # Select the object file format to substitute !! 4 # Makefile for the architecture dependent flags and dependencies on the >> 5 # Sparc and sparc64. 22 # 6 # 23 64bit-tool-archpref = loongarch64 !! 7 # Copyright (C) 1994,1996,1998 David S. Miller (davem@caip.rutgers.edu) 24 32bit-bfd = elf32-loongarch !! 8 # Copyright (C) 1998 Jakub Jelinek (jj@ultra.linux.cz) 25 64bit-bfd = elf64-loongarch << 26 32bit-emul = elf32loongarch << 27 64bit-emul = elf64loongarch << 28 << 29 CC_FLAGS_FPU := -mfpu=64 << 30 CC_FLAGS_NO_FPU := -msoft-float << 31 << 32 ifdef CONFIG_UNWINDER_ORC << 33 orc_hash_h := arch/$(SRCARCH)/include/generate << 34 orc_hash_sh := $(srctree)/scripts/orc_hash.sh << 35 targets += $(orc_hash_h) << 36 quiet_cmd_orc_hash = GEN $@ << 37 cmd_orc_hash = mkdir -p $(dir $@); \ << 38 $(CONFIG_SHELL) $(orc_has << 39 $(orc_hash_h): $(srctree)/arch/loongarch/inclu << 40 $(call if_changed,orc_hash) << 41 archprepare: $(orc_hash_h) << 42 endif << 43 << 44 ifdef CONFIG_DYNAMIC_FTRACE << 45 KBUILD_CPPFLAGS += -DCC_USING_PATCHABLE_FUNCTI << 46 CC_FLAGS_FTRACE := -fpatchable-function-entry= << 47 endif << 48 << 49 ifdef CONFIG_64BIT << 50 tool-archpref = $(64bit-tool-archpre << 51 UTS_MACHINE := loongarch64 << 52 endif << 53 << 54 ifneq ($(SUBARCH),$(ARCH)) << 55 ifeq ($(CROSS_COMPILE),) << 56 CROSS_COMPILE := $(call cc-cross-prefix, $ << 57 endif << 58 endif << 59 9 60 ifdef CONFIG_64BIT !! 10 # We are not yet configured - so test on arch 61 ld-emul = $(64bit-emul) !! 11 ifeq ($(ARCH),sparc) 62 cflags-y += -mabi=lp64s !! 12 KBUILD_DEFCONFIG := sparc32_defconfig 63 endif << 64 << 65 cflags-y += -pipe $(CC_ << 66 LDFLAGS_vmlinux += -static -n << 67 << 68 # When the assembler supports explicit relocat << 69 # GCC may have -mexplicit-relocs off by defaul << 70 # assembler, so we force it via an option. << 71 # << 72 # When the assembler does not supports explici << 73 # it. Disable it if the compiler supports it. << 74 # << 75 # The combination of a "new" assembler and "ol << 76 # the rarity of this combo and the extra compl << 77 # Either upgrade the compiler or downgrade the << 78 # out if it is the case (by probing for the mo << 79 # compilers in this case would have support). << 80 # << 81 # Also, -mdirect-extern-access is useful in ca << 82 # relocs, for avoiding unnecessary GOT accesse << 83 # support though. << 84 ifdef CONFIG_AS_HAS_EXPLICIT_RELOCS << 85 cflags-y += $(call cc-o << 86 KBUILD_CFLAGS_KERNEL += $(call cc-o << 87 KBUILD_CFLAGS_KERNEL += $(call cc-o << 88 KBUILD_AFLAGS_MODULE += $(call cc-o << 89 KBUILD_CFLAGS_MODULE += $(call cc-o << 90 else 13 else 91 cflags-y += $(call cc-o !! 14 KBUILD_DEFCONFIG := sparc64_defconfig 92 KBUILD_AFLAGS_KERNEL += -Wa,-mla-gl << 93 KBUILD_CFLAGS_KERNEL += -Wa,-mla-gl << 94 KBUILD_AFLAGS_MODULE += -Wa,-mla-gl << 95 KBUILD_CFLAGS_MODULE += -fplt -Wa,- << 96 endif 15 endif 97 16 98 KBUILD_AFLAGS += $(call cc-o !! 17 ifeq ($(CONFIG_SPARC32),y) 99 KBUILD_CFLAGS += $(call cc-o !! 18 ##### 100 KBUILD_AFLAGS += $(call cc-o !! 19 # sparc32 101 KBUILD_CFLAGS += $(call cc-o !! 20 # 102 21 103 ifdef CONFIG_OBJTOOL !! 22 CHECKFLAGS += -D__sparc__ 104 KBUILD_CFLAGS += -fno-jump-t !! 23 LDFLAGS := -m elf32_sparc 105 endif !! 24 export BITS := 32 >> 25 UTS_MACHINE := sparc 106 26 107 KBUILD_RUSTFLAGS += --target=lo !! 27 KBUILD_CFLAGS += -m32 -mcpu=v8 -pipe -mno-fpu -fcall-used-g5 -fcall-used-g7 108 KBUILD_RUSTFLAGS_KERNEL += -Zdirect-ac !! 28 KBUILD_AFLAGS += -m32 -Wa,-Av8 109 KBUILD_RUSTFLAGS_MODULE += -Zdirect-ac << 110 << 111 ifeq ($(CONFIG_RELOCATABLE),y) << 112 KBUILD_CFLAGS_KERNEL += -fPIE << 113 KBUILD_RUSTFLAGS_KERNEL += -Crelocatio << 114 LDFLAGS_vmlinux += -static -pi << 115 endif << 116 29 117 cflags-y += $(call cc-option, -mno-check-zero- !! 30 else 118 !! 31 ##### 119 ifndef CONFIG_KASAN !! 32 # sparc64 120 cflags-y += -fno-builtin-memcpy -fno-builtin-m !! 33 # 121 endif << 122 34 123 load-y = 0x9000000000200000 !! 35 CHECKFLAGS += -D__sparc__ -D__sparc_v9__ -D__arch64__ -m64 124 bootvars-y = VMLINUX_LOAD_ADDRESS=$(load- !! 36 LDFLAGS := -m elf64_sparc >> 37 export BITS := 64 >> 38 UTS_MACHINE := sparc64 125 39 126 drivers-$(CONFIG_PCI) += arch/loonga !! 40 KBUILD_CFLAGS += -m64 -pipe -mno-fpu -mcpu=ultrasparc -mcmodel=medlow >> 41 KBUILD_CFLAGS += -ffixed-g4 -ffixed-g5 -fcall-used-g7 -Wno-sign-compare >> 42 KBUILD_CFLAGS += -Wa,--undeclared-regs >> 43 KBUILD_CFLAGS += $(call cc-option,-mtune=ultrasparc3) >> 44 KBUILD_AFLAGS += -m64 -mcpu=ultrasparc -Wa,--undeclared-regs 127 45 128 KBUILD_AFLAGS += $(cflags-y) !! 46 ifeq ($(CONFIG_MCOUNT),y) 129 KBUILD_CFLAGS += $(cflags-y) !! 47 KBUILD_CFLAGS += -pg 130 KBUILD_CPPFLAGS += -DVMLINUX_LOAD_ADDRESS=$(lo << 131 << 132 # This is required to get dwarf unwinding tabl << 133 # instead of .eh_frame so we don't discard the << 134 KBUILD_CFLAGS += -fno-asynchronous-unwind-tabl << 135 << 136 ifdef CONFIG_ARCH_STRICT_ALIGN << 137 # Don't emit unaligned accesses. << 138 # Not all LoongArch cores support unaligned ac << 139 # rely on others to provide emulation for thes << 140 KBUILD_CFLAGS += $(call cc-option,-mstrict-ali << 141 else << 142 # Optimise for performance on hardware support << 143 KBUILD_CFLAGS += $(call cc-option,-mno-strict- << 144 endif 48 endif 145 49 146 KBUILD_CFLAGS += -isystem $(shell $(CC) -print << 147 << 148 KBUILD_LDFLAGS += -m $(ld-emul) << 149 << 150 ifdef need-compiler << 151 CHECKFLAGS += $(shell $(CC) $(KBUILD_CPPFLAGS) << 152 grep -E -vw '__GNUC_(MINOR_|PATCHLEVEL << 153 sed -e "s/^\#define /-D'/" -e "s/ /'=' << 154 endif 50 endif 155 51 156 libs-y += arch/loongarch/lib/ !! 52 head-y := arch/sparc/kernel/head_$(BITS).o 157 libs-$(CONFIG_EFI_STUB) += $(objtree)/drivers/ << 158 53 159 drivers-y += arch/loongarch/cryp !! 54 # See arch/sparc/Kbuild for the core part of the kernel >> 55 core-y += arch/sparc/ 160 56 161 # suspend and hibernation support !! 57 libs-y += arch/sparc/prom/ 162 drivers-$(CONFIG_PM) += arch/loongarch/powe !! 58 libs-y += arch/sparc/lib/ 163 59 164 ifeq ($(KBUILD_EXTMOD),) !! 60 drivers-$(CONFIG_PM) += arch/sparc/power/ 165 prepare: vdso_prepare !! 61 drivers-$(CONFIG_OPROFILE) += arch/sparc/oprofile/ 166 vdso_prepare: prepare0 << 167 $(Q)$(MAKE) $(build)=arch/loongarch/vd << 168 endif << 169 62 170 vdso-install-y += arch/loongarch/vdso/vdso.so. !! 63 boot := arch/sparc/boot 171 64 172 all: $(notdir $(KBUILD_IMAGE)) $(KBUILD_DTB !! 65 # Default target >> 66 all: zImage 173 67 174 vmlinuz.efi: vmlinux.efi !! 68 image zImage uImage tftpboot.img vmlinux.aout: vmlinux >> 69 $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@ 175 70 176 vmlinux.elf vmlinux.efi vmlinuz.efi: vmlinux !! 71 archclean: 177 $(Q)$(MAKE) $(build)=$(boot) $(bootvar !! 72 $(Q)$(MAKE) $(clean)=$(boot) 178 73 179 install: !! 74 # This is the image used for packaging 180 $(Q)install -D -m 755 $(KBUILD_IMAGE) !! 75 KBUILD_IMAGE := $(boot)/zImage 181 $(Q)install -D -m 644 .config $(INSTAL << 182 $(Q)install -D -m 644 System.map $(INS << 183 76 >> 77 # Don't use tabs in echo arguments. >> 78 ifeq ($(ARCH),sparc) 184 define archhelp 79 define archhelp 185 echo ' install - install !! 80 echo '* image - kernel image ($(boot)/image)' 186 echo !! 81 echo '* zImage - stripped kernel image ($(boot)/zImage)' >> 82 echo ' uImage - U-Boot SPARC32 Image (only for LEON)' >> 83 echo ' tftpboot.img - image prepared for tftp' 187 endef 84 endef >> 85 else >> 86 define archhelp >> 87 echo '* vmlinux - standard sparc64 kernel' >> 88 echo '* zImage - stripped and compressed sparc64 kernel ($(boot)/zImage)' >> 89 echo ' vmlinux.aout - a.out kernel for sparc64' >> 90 echo ' tftpboot.img - image prepared for tftp' >> 91 endef >> 92 endif
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.