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 9 44 ifdef CONFIG_DYNAMIC_FTRACE !! 10 # We are not yet configured - so test on arch 45 KBUILD_CPPFLAGS += -DCC_USING_PATCHABLE_FUNCTI !! 11 ifeq ($(ARCH),sparc) 46 CC_FLAGS_FTRACE := -fpatchable-function-entry= !! 12 KBUILD_DEFCONFIG := sparc32_defconfig >> 13 else >> 14 KBUILD_DEFCONFIG := sparc64_defconfig 47 endif 15 endif 48 16 49 ifdef CONFIG_64BIT !! 17 ifeq ($(CONFIG_SPARC32),y) 50 tool-archpref = $(64bit-tool-archpre !! 18 ##### 51 UTS_MACHINE := loongarch64 !! 19 # sparc32 52 endif !! 20 # 53 21 54 ifneq ($(SUBARCH),$(ARCH)) !! 22 CHECKFLAGS += -D__sparc__ 55 ifeq ($(CROSS_COMPILE),) !! 23 LDFLAGS := -m elf32_sparc 56 CROSS_COMPILE := $(call cc-cross-prefix, $ !! 24 export BITS := 32 57 endif !! 25 UTS_MACHINE := sparc 58 endif << 59 26 60 ifdef CONFIG_64BIT !! 27 # We are adding -Wa,-Av8 to KBUILD_CFLAGS to deal with a specs bug in some 61 ld-emul = $(64bit-emul) !! 28 # versions of gcc. Some gcc versions won't pass -Av8 to binutils when you 62 cflags-y += -mabi=lp64s !! 29 # give -mcpu=v8. This silently worked with older bintutils versions but 63 endif !! 30 # does not any more. >> 31 KBUILD_CFLAGS += -m32 -mcpu=v8 -pipe -mno-fpu -fcall-used-g5 -fcall-used-g7 >> 32 KBUILD_CFLAGS += -Wa,-Av8 64 33 65 cflags-y += -pipe $(CC_ !! 34 KBUILD_AFLAGS += -m32 -Wa,-Av8 66 LDFLAGS_vmlinux += -static -n << 67 35 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 36 else 91 cflags-y += $(call cc-o !! 37 ##### 92 KBUILD_AFLAGS_KERNEL += -Wa,-mla-gl !! 38 # sparc64 93 KBUILD_CFLAGS_KERNEL += -Wa,-mla-gl !! 39 # 94 KBUILD_AFLAGS_MODULE += -Wa,-mla-gl << 95 KBUILD_CFLAGS_MODULE += -fplt -Wa,- << 96 endif << 97 << 98 KBUILD_AFLAGS += $(call cc-o << 99 KBUILD_CFLAGS += $(call cc-o << 100 KBUILD_AFLAGS += $(call cc-o << 101 KBUILD_CFLAGS += $(call cc-o << 102 40 103 ifdef CONFIG_OBJTOOL !! 41 CHECKFLAGS += -D__sparc__ -D__sparc_v9__ -D__arch64__ -m64 104 KBUILD_CFLAGS += -fno-jump-t !! 42 LDFLAGS := -m elf64_sparc 105 endif !! 43 export BITS := 64 >> 44 UTS_MACHINE := sparc64 106 45 107 KBUILD_RUSTFLAGS += --target=lo !! 46 KBUILD_CFLAGS += -m64 -pipe -mno-fpu -mcpu=ultrasparc -mcmodel=medlow 108 KBUILD_RUSTFLAGS_KERNEL += -Zdirect-ac !! 47 KBUILD_CFLAGS += -ffixed-g4 -ffixed-g5 -fcall-used-g7 -Wno-sign-compare 109 KBUILD_RUSTFLAGS_MODULE += -Zdirect-ac !! 48 KBUILD_CFLAGS += -Wa,--undeclared-regs 110 !! 49 KBUILD_CFLAGS += $(call cc-option,-mtune=ultrasparc3) 111 ifeq ($(CONFIG_RELOCATABLE),y) !! 50 KBUILD_AFLAGS += -m64 -mcpu=ultrasparc -Wa,--undeclared-regs 112 KBUILD_CFLAGS_KERNEL += -fPIE << 113 KBUILD_RUSTFLAGS_KERNEL += -Crelocatio << 114 LDFLAGS_vmlinux += -static -pi << 115 endif << 116 51 117 cflags-y += $(call cc-option, -mno-check-zero- !! 52 ifeq ($(CONFIG_MCOUNT),y) 118 !! 53 KBUILD_CFLAGS += -pg 119 ifndef CONFIG_KASAN << 120 cflags-y += -fno-builtin-memcpy -fno-builtin-m << 121 endif 54 endif 122 55 123 load-y = 0x9000000000200000 << 124 bootvars-y = VMLINUX_LOAD_ADDRESS=$(load- << 125 << 126 drivers-$(CONFIG_PCI) += arch/loonga << 127 << 128 KBUILD_AFLAGS += $(cflags-y) << 129 KBUILD_CFLAGS += $(cflags-y) << 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 56 endif 145 57 146 KBUILD_CFLAGS += -isystem $(shell $(CC) -print !! 58 head-y := arch/sparc/kernel/head_$(BITS).o 147 59 148 KBUILD_LDFLAGS += -m $(ld-emul) !! 60 # See arch/sparc/Kbuild for the core part of the kernel >> 61 core-y += arch/sparc/ 149 62 150 ifdef need-compiler !! 63 libs-y += arch/sparc/prom/ 151 CHECKFLAGS += $(shell $(CC) $(KBUILD_CPPFLAGS) !! 64 libs-y += arch/sparc/lib/ 152 grep -E -vw '__GNUC_(MINOR_|PATCHLEVEL << 153 sed -e "s/^\#define /-D'/" -e "s/ /'=' << 154 endif << 155 65 156 libs-y += arch/loongarch/lib/ !! 66 drivers-$(CONFIG_PM) += arch/sparc/power/ 157 libs-$(CONFIG_EFI_STUB) += $(objtree)/drivers/ !! 67 drivers-$(CONFIG_OPROFILE) += arch/sparc/oprofile/ 158 68 159 drivers-y += arch/loongarch/cryp !! 69 boot := arch/sparc/boot 160 70 161 # suspend and hibernation support !! 71 # Default target 162 drivers-$(CONFIG_PM) += arch/loongarch/powe !! 72 all: zImage 163 73 164 ifeq ($(KBUILD_EXTMOD),) !! 74 image zImage uImage tftpboot.img vmlinux.aout: vmlinux 165 prepare: vdso_prepare !! 75 $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@ 166 vdso_prepare: prepare0 << 167 $(Q)$(MAKE) $(build)=arch/loongarch/vd << 168 endif << 169 76 170 vdso-install-y += arch/loongarch/vdso/vdso.so. !! 77 install: 171 !! 78 $(Q)$(MAKE) $(build)=$(boot) $@ 172 all: $(notdir $(KBUILD_IMAGE)) $(KBUILD_DTB << 173 << 174 vmlinuz.efi: vmlinux.efi << 175 79 176 vmlinux.elf vmlinux.efi vmlinuz.efi: vmlinux !! 80 archclean: 177 $(Q)$(MAKE) $(build)=$(boot) $(bootvar !! 81 $(Q)$(MAKE) $(clean)=$(boot) 178 82 179 install: !! 83 # This is the image used for packaging 180 $(Q)install -D -m 755 $(KBUILD_IMAGE) !! 84 KBUILD_IMAGE := $(boot)/zImage 181 $(Q)install -D -m 644 .config $(INSTAL << 182 $(Q)install -D -m 644 System.map $(INS << 183 85 >> 86 # Don't use tabs in echo arguments. >> 87 ifeq ($(ARCH),sparc) 184 define archhelp 88 define archhelp 185 echo ' install - install !! 89 echo '* image - kernel image ($(boot)/image)' 186 echo !! 90 echo '* zImage - stripped kernel image ($(boot)/zImage)' >> 91 echo ' uImage - U-Boot SPARC32 Image (only for LEON)' >> 92 echo ' tftpboot.img - image prepared for tftp' 187 endef 93 endef >> 94 else >> 95 define archhelp >> 96 echo '* vmlinux - standard sparc64 kernel' >> 97 echo '* zImage - stripped and compressed sparc64 kernel ($(boot)/zImage)' >> 98 echo ' vmlinux.aout - a.out kernel for sparc64' >> 99 echo ' tftpboot.img - image prepared for tftp' >> 100 endef >> 101 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.