1 # SPDX-License-Identifier: GPL-2.0 << 2 # 1 # 3 # Makefile for the linux kernel. 2 # Makefile for the linux kernel. 4 # 3 # 5 4 6 extra-y += vmlinux.lds !! 5 extra-y := head.o init_task.o vmlinux.lds.s 7 << 8 obj-$(CONFIG_AMIGA) := head.o << 9 obj-$(CONFIG_ATARI) := head.o << 10 obj-$(CONFIG_MAC) := head.o << 11 obj-$(CONFIG_APOLLO) := head.o << 12 obj-$(CONFIG_VME) := head.o << 13 obj-$(CONFIG_HP300) := head.o << 14 obj-$(CONFIG_Q40) := head.o << 15 obj-$(CONFIG_SUN3X) := head.o << 16 obj-$(CONFIG_VIRT) := head.o << 17 obj-$(CONFIG_SUN3) := sun3-head.o << 18 << 19 obj-y += entry.o irq.o module.o process.o pt << 20 obj-y += setup.o signal.o sys_m68k.o syscall << 21 << 22 obj-$(CONFIG_MMU_MOTOROLA) += ints.o vectors.o << 23 obj-$(CONFIG_MMU_SUN3) += ints.o vectors.o << 24 obj-$(CONFIG_PCI) += pcibios.o << 25 << 26 obj-$(CONFIG_M68K_NONCOHERENT_DMA) += dma.o << 27 << 28 obj-$(CONFIG_KEXEC_CORE) += machine_kex << 29 obj-$(CONFIG_BOOTINFO_PROC) += bootinfo_pr << 30 obj-$(CONFIG_UBOOT) += uboot.o << 31 << 32 obj-$(CONFIG_EARLY_PRINTK) += early_print << 33 6 >> 7 obj-y := process.o semaphore.o signal.o entry.o traps.o irq.o vm86.o \ >> 8 ptrace.o i8259.o ioport.o ldt.o setup.o time.o sys_i386.o \ >> 9 pci-dma.o i386_ksyms.o i387.o dmi_scan.o bootflag.o \ >> 10 doublefault.o >> 11 >> 12 obj-y += cpu/ >> 13 obj-y += timers/ >> 14 obj-$(CONFIG_ACPI_BOOT) += acpi/ >> 15 obj-$(CONFIG_X86_BIOS_REBOOT) += reboot.o >> 16 obj-$(CONFIG_MCA) += mca.o >> 17 obj-$(CONFIG_X86_MSR) += msr.o >> 18 obj-$(CONFIG_X86_CPUID) += cpuid.o >> 19 obj-$(CONFIG_MICROCODE) += microcode.o >> 20 obj-$(CONFIG_APM) += apm.o >> 21 obj-$(CONFIG_X86_SMP) += smp.o smpboot.o >> 22 obj-$(CONFIG_X86_TRAMPOLINE) += trampoline.o >> 23 obj-$(CONFIG_X86_MPPARSE) += mpparse.o >> 24 obj-$(CONFIG_X86_LOCAL_APIC) += apic.o nmi.o >> 25 obj-$(CONFIG_X86_IO_APIC) += io_apic.o >> 26 obj-$(CONFIG_X86_NUMAQ) += numaq.o >> 27 obj-$(CONFIG_X86_SUMMIT) += summit.o >> 28 obj-$(CONFIG_EDD) += edd.o >> 29 obj-$(CONFIG_MODULES) += module.o >> 30 obj-y += sysenter.o vsyscall.o >> 31 obj-$(CONFIG_ACPI_SRAT) += srat.o >> 32 obj-$(CONFIG_HPET_TIMER) += time_hpet.o >> 33 >> 34 EXTRA_AFLAGS := -traditional >> 35 >> 36 obj-$(CONFIG_SCx200) += scx200.o >> 37 >> 38 # vsyscall.o contains the vsyscall DSO images as __initdata. >> 39 # We must build both images before we can assemble it. >> 40 # Note: kbuild does not track this dependency due to usage of .incbin >> 41 $(obj)/vsyscall.o: $(obj)/vsyscall-int80.so $(obj)/vsyscall-sysenter.so >> 42 targets += $(foreach F,int80 sysenter,vsyscall-$F.o vsyscall-$F.so) >> 43 >> 44 # The DSO images are built using a special linker script. >> 45 quiet_cmd_syscall = SYSCALL $@ >> 46 cmd_syscall = $(CC) -nostdlib $(SYSCFLAGS_$(@F)) \ >> 47 -Wl,-T,$(filter-out FORCE,$^) -o $@ >> 48 >> 49 vsyscall-flags = -shared -s -Wl,-soname=linux-gate.so.1 >> 50 SYSCFLAGS_vsyscall-sysenter.so = $(vsyscall-flags) >> 51 SYSCFLAGS_vsyscall-int80.so = $(vsyscall-flags) >> 52 >> 53 $(obj)/vsyscall-int80.so $(obj)/vsyscall-sysenter.so: \ >> 54 $(obj)/vsyscall-%.so: $(src)/vsyscall.lds $(obj)/vsyscall-%.o FORCE >> 55 $(call if_changed,syscall) >> 56 >> 57 # We also create a special relocatable object that should mirror the symbol >> 58 # table and layout of the linked DSO. With ld -R we can then refer to >> 59 # these symbols in the kernel code rather than hand-coded addresses. >> 60 extra-y += vsyscall-syms.o >> 61 $(obj)/built-in.o: $(obj)/vsyscall-syms.o >> 62 $(obj)/built-in.o: ld_flags += -R $(obj)/vsyscall-syms.o >> 63 >> 64 SYSCFLAGS_vsyscall-syms.o = -r >> 65 $(obj)/vsyscall-syms.o: $(src)/vsyscall.lds $(obj)/vsyscall-sysenter.o FORCE >> 66 $(call if_changed,syscall)
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.