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 notifier.o ksysfs.o
14 obj-
$(CONFIG_SYSCTL
) += sysctl_check.o
15 obj-
$(CONFIG_STACKTRACE
) += stacktrace.o
17 obj-
$(CONFIG_DEBUG_MUTEXES
) += mutex-debug.o
18 obj-
$(CONFIG_LOCKDEP
) += lockdep.o
19 ifeq ($(CONFIG_PROC_FS
),y
)
20 obj-
$(CONFIG_LOCKDEP
) += lockdep_proc.o
22 obj-
$(CONFIG_FUTEX
) += futex.o
23 ifeq ($(CONFIG_COMPAT
),y
)
24 obj-
$(CONFIG_FUTEX
) += futex_compat.o
26 obj-
$(CONFIG_RT_MUTEXES
) += rtmutex.o
27 obj-
$(CONFIG_DEBUG_RT_MUTEXES
) += rtmutex-debug.o
28 obj-
$(CONFIG_RT_MUTEX_TESTER
) += rtmutex-tester.o
29 obj-
$(CONFIG_GENERIC_ISA_DMA
) += dma.o
30 obj-
$(CONFIG_SMP
) += cpu.o spinlock.o
31 obj-
$(CONFIG_DEBUG_SPINLOCK
) += spinlock.o
32 obj-
$(CONFIG_PROVE_LOCKING
) += spinlock.o
33 obj-
$(CONFIG_UID16
) += uid16.o
34 obj-
$(CONFIG_MODULES
) += module.o
35 obj-
$(CONFIG_KALLSYMS
) += kallsyms.o
36 obj-
$(CONFIG_PM
) += power
/
37 obj-
$(CONFIG_BSD_PROCESS_ACCT
) += acct.o
38 obj-
$(CONFIG_KEXEC
) += kexec.o
39 obj-
$(CONFIG_BACKTRACE_SELF_TEST
) += backtracetest.o
40 obj-
$(CONFIG_COMPAT
) += compat.o
41 obj-
$(CONFIG_CGROUPS
) += cgroup.o
42 obj-
$(CONFIG_CGROUP_DEBUG
) += cgroup_debug.o
43 obj-
$(CONFIG_CPUSETS
) += cpuset.o
44 obj-
$(CONFIG_CGROUP_NS
) += ns_cgroup.o
45 obj-
$(CONFIG_IKCONFIG
) += configs.o
46 obj-
$(CONFIG_STOP_MACHINE
) += stop_machine.o
47 obj-
$(CONFIG_KPROBES_SANITY_TEST
) += test_kprobes.o
48 obj-
$(CONFIG_AUDIT
) += audit.o auditfilter.o
49 obj-
$(CONFIG_AUDITSYSCALL
) += auditsc.o
50 obj-
$(CONFIG_AUDIT_TREE
) += audit_tree.o
51 obj-
$(CONFIG_KPROBES
) += kprobes.o
52 obj-
$(CONFIG_DETECT_SOFTLOCKUP
) += softlockup.o
53 obj-
$(CONFIG_GENERIC_HARDIRQS
) += irq
/
54 obj-
$(CONFIG_SECCOMP
) += seccomp.o
55 obj-
$(CONFIG_RCU_TORTURE_TEST
) += rcutorture.o
56 obj-
$(CONFIG_CLASSIC_RCU
) += rcuclassic.o
57 obj-
$(CONFIG_PREEMPT_RCU
) += rcupreempt.o
58 ifeq ($(CONFIG_PREEMPT_RCU
),y
)
59 obj-
$(CONFIG_RCU_TRACE
) += rcupreempt_trace.o
61 obj-
$(CONFIG_RELAY
) += relay.o
62 obj-
$(CONFIG_SYSCTL
) += utsname_sysctl.o
63 obj-
$(CONFIG_TASK_DELAY_ACCT
) += delayacct.o
64 obj-
$(CONFIG_TASKSTATS
) += taskstats.o tsacct.o
65 obj-
$(CONFIG_MARKERS
) += marker.o
66 obj-
$(CONFIG_LATENCYTOP
) += latencytop.o
68 ifneq ($(CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER
),y
)
69 # According to Alan Modra <alan@linuxcare.com.au>, the -fno-omit-frame-pointer is
70 # needed for x86 only. Why this used to be enabled for all architectures is beyond
71 # me. I suspect most platforms don't need this, but until we know that for sure
72 # I turn this off for IA-64 only. Andreas Schwab says it's also needed on m68k
73 # to get a correct value for the wait-channel (WCHAN in ps). --davidm
74 CFLAGS_sched.o
:= $(PROFILING
) -fno-omit-frame-pointer
77 $(obj
)/configs.o
: $(obj
)/config_data.h
79 # config_data.h contains the same information as ikconfig.h but gzipped.
80 # Info from config_data can be extracted from /proc/config*
81 targets
+= config_data.gz
82 $(obj
)/config_data.gz
: .config FORCE
83 $(call if_changed
,gzip
)
85 quiet_cmd_ikconfiggz
= IKCFG
$@
86 cmd_ikconfiggz
= (echo
"static const char kernel_config_data[] = MAGIC_START"; cat
$< | scripts
/bin2c
; echo
"MAGIC_END;") > $@
87 targets
+= config_data.h
88 $(obj
)/config_data.h
: $(obj
)/config_data.gz FORCE
89 $(call if_changed
,ikconfiggz
)