2 # Makefile for the linux kernel.
5 obj-y
= sched.o fork.o exec_domain.o panic.o printk.o profile.o \
6 exit.o itimer.o time.o softirq.o resource.o \
7 sysctl.o capability.o ptrace.o timer.o user.o user_namespace.o \
8 signal.o sys.o kmod.o workqueue.o pid.o \
9 rcupdate.o extable.o params.o posix-timers.o \
10 kthread.o wait.o kfifo.o sys_ni.o posix-cpu-timers.o mutex.o \
11 hrtimer.o rwsem.o latency.o nsproxy.o srcu.o \
12 utsname.o sysctl_check.o notifier.o
14 obj-
$(CONFIG_STACKTRACE
) += stacktrace.o
16 obj-
$(CONFIG_DEBUG_MUTEXES
) += mutex-debug.o
17 obj-
$(CONFIG_LOCKDEP
) += lockdep.o
18 ifeq ($(CONFIG_PROC_FS
),y
)
19 obj-
$(CONFIG_LOCKDEP
) += lockdep_proc.o
21 obj-
$(CONFIG_FUTEX
) += futex.o
22 ifeq ($(CONFIG_COMPAT
),y
)
23 obj-
$(CONFIG_FUTEX
) += futex_compat.o
25 obj-
$(CONFIG_RT_MUTEXES
) += rtmutex.o
26 obj-
$(CONFIG_DEBUG_RT_MUTEXES
) += rtmutex-debug.o
27 obj-
$(CONFIG_RT_MUTEX_TESTER
) += rtmutex-tester.o
28 obj-
$(CONFIG_GENERIC_ISA_DMA
) += dma.o
29 obj-
$(CONFIG_SMP
) += cpu.o spinlock.o
30 obj-
$(CONFIG_DEBUG_SPINLOCK
) += spinlock.o
31 obj-
$(CONFIG_PROVE_LOCKING
) += spinlock.o
32 obj-
$(CONFIG_UID16
) += uid16.o
33 obj-
$(CONFIG_MODULES
) += module.o
34 obj-
$(CONFIG_KALLSYMS
) += kallsyms.o
35 obj-
$(CONFIG_PM
) += power
/
36 obj-
$(CONFIG_BSD_PROCESS_ACCT
) += acct.o
37 obj-
$(CONFIG_KEXEC
) += kexec.o
38 obj-
$(CONFIG_COMPAT
) += compat.o
39 obj-
$(CONFIG_CGROUPS
) += cgroup.o
40 obj-
$(CONFIG_CGROUP_DEBUG
) += cgroup_debug.o
41 obj-
$(CONFIG_CPUSETS
) += cpuset.o
42 obj-
$(CONFIG_CGROUP_CPUACCT
) += cpu_acct.o
43 obj-
$(CONFIG_CGROUP_NS
) += ns_cgroup.o
44 obj-
$(CONFIG_IKCONFIG
) += configs.o
45 obj-
$(CONFIG_STOP_MACHINE
) += stop_machine.o
46 obj-
$(CONFIG_AUDIT
) += audit.o auditfilter.o
47 obj-
$(CONFIG_AUDITSYSCALL
) += auditsc.o
48 obj-
$(CONFIG_KPROBES
) += kprobes.o
49 obj-
$(CONFIG_SYSFS
) += ksysfs.o
50 obj-
$(CONFIG_DETECT_SOFTLOCKUP
) += softlockup.o
51 obj-
$(CONFIG_GENERIC_HARDIRQS
) += irq
/
52 obj-
$(CONFIG_SECCOMP
) += seccomp.o
53 obj-
$(CONFIG_RCU_TORTURE_TEST
) += rcutorture.o
54 obj-
$(CONFIG_RELAY
) += relay.o
55 obj-
$(CONFIG_SYSCTL
) += utsname_sysctl.o
56 obj-
$(CONFIG_TASK_DELAY_ACCT
) += delayacct.o
57 obj-
$(CONFIG_TASKSTATS
) += taskstats.o tsacct.o
58 obj-
$(CONFIG_MARKERS
) += marker.o
60 ifneq ($(CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER
),y
)
61 # According to Alan Modra <alan@linuxcare.com.au>, the -fno-omit-frame-pointer is
62 # needed for x86 only. Why this used to be enabled for all architectures is beyond
63 # me. I suspect most platforms don't need this, but until we know that for sure
64 # I turn this off for IA-64 only. Andreas Schwab says it's also needed on m68k
65 # to get a correct value for the wait-channel (WCHAN in ps). --davidm
66 CFLAGS_sched.o
:= $(PROFILING
) -fno-omit-frame-pointer
69 $(obj
)/configs.o
: $(obj
)/config_data.h
71 # config_data.h contains the same information as ikconfig.h but gzipped.
72 # Info from config_data can be extracted from /proc/config*
73 targets
+= config_data.gz
74 $(obj
)/config_data.gz
: .config FORCE
75 $(call if_changed
,gzip
)
77 quiet_cmd_ikconfiggz
= IKCFG
$@
78 cmd_ikconfiggz
= (echo
"static const char kernel_config_data[] = MAGIC_START"; cat
$< | scripts
/bin2c
; echo
"MAGIC_END;") > $@
79 targets
+= config_data.h
80 $(obj
)/config_data.h
: $(obj
)/config_data.gz FORCE
81 $(call if_changed
,ikconfiggz
)