Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
a91c4fb5
Commit
a91c4fb5
authored
Aug 16, 2004
by
Sam Ravnborg
Browse files
Options
Browse Files
Download
Plain Diff
Merge mars.ravnborg.org:/home/sam/bk/kbuild-mm2
into mars.ravnborg.org:/home/sam/bk/kbuild
parents
744dbb74
948a4d33
Changes
39
Show whitespace changes
Inline
Side-by-side
Showing
39 changed files
with
99 additions
and
53 deletions
+99
-53
Documentation/kbuild/makefiles.txt
Documentation/kbuild/makefiles.txt
+31
-0
Makefile
Makefile
+7
-7
arch/alpha/kernel/Makefile
arch/alpha/kernel/Makefile
+1
-1
arch/arm/Makefile
arch/arm/Makefile
+1
-1
arch/arm/kernel/Makefile
arch/arm/kernel/Makefile
+1
-1
arch/arm26/Makefile
arch/arm26/Makefile
+1
-1
arch/arm26/kernel/Makefile
arch/arm26/kernel/Makefile
+1
-1
arch/cris/Makefile
arch/cris/Makefile
+1
-1
arch/cris/kernel/Makefile
arch/cris/kernel/Makefile
+1
-1
arch/h8300/kernel/Makefile
arch/h8300/kernel/Makefile
+1
-1
arch/i386/kernel/Makefile
arch/i386/kernel/Makefile
+1
-1
arch/ia64/kernel/Makefile
arch/ia64/kernel/Makefile
+5
-5
arch/m68k/kernel/Makefile
arch/m68k/kernel/Makefile
+1
-1
arch/m68knommu/kernel/Makefile
arch/m68knommu/kernel/Makefile
+1
-1
arch/mips/Makefile
arch/mips/Makefile
+1
-1
arch/mips/kernel/Makefile
arch/mips/kernel/Makefile
+1
-1
arch/parisc/kernel/Makefile
arch/parisc/kernel/Makefile
+1
-1
arch/ppc/Makefile
arch/ppc/Makefile
+1
-1
arch/ppc/kernel/Makefile
arch/ppc/kernel/Makefile
+1
-1
arch/ppc64/kernel/Makefile
arch/ppc64/kernel/Makefile
+1
-1
arch/s390/kernel/Makefile
arch/s390/kernel/Makefile
+1
-1
arch/sh/Makefile
arch/sh/Makefile
+1
-1
arch/sh/boot/compressed/Makefile
arch/sh/boot/compressed/Makefile
+1
-1
arch/sh/kernel/Makefile
arch/sh/kernel/Makefile
+1
-1
arch/sh64/boot/compressed/Makefile
arch/sh64/boot/compressed/Makefile
+3
-3
arch/sparc/boot/Makefile
arch/sparc/boot/Makefile
+1
-1
arch/sparc/kernel/Makefile
arch/sparc/kernel/Makefile
+1
-1
arch/sparc64/Makefile
arch/sparc64/Makefile
+1
-1
arch/sparc64/kernel/Makefile
arch/sparc64/kernel/Makefile
+1
-1
arch/um/Makefile
arch/um/Makefile
+4
-4
arch/um/Makefile-skas
arch/um/Makefile-skas
+1
-1
arch/um/kernel/Makefile
arch/um/kernel/Makefile
+1
-1
arch/v850/kernel/Makefile
arch/v850/kernel/Makefile
+1
-1
arch/x86_64/kernel/Makefile
arch/x86_64/kernel/Makefile
+1
-1
arch/x86_64/kernel/Makefile-HEAD
arch/x86_64/kernel/Makefile-HEAD
+1
-1
scripts/Makefile.build
scripts/Makefile.build
+8
-0
scripts/Makefile.lib
scripts/Makefile.lib
+5
-0
scripts/Makefile.modpost
scripts/Makefile.modpost
+2
-1
scripts/mod/modpost.c
scripts/mod/modpost.c
+4
-3
No files found.
Documentation/kbuild/makefiles.txt
View file @
a91c4fb5
...
...
@@ -938,6 +938,37 @@ When kbuild executes the following steps are followed (roughly):
will be displayed with "make KBUILD_VERBOSE=0".
--- 6.8 Preprocessing linker scripts
When the vmlinux image is build the linker script:
arch/$(ARCH)/kernel/vmlinux.lds is used.
The script is a preprocessed variant of the file vmlinux.lds.S
located in the same directory.
kbuild knows .lds file and includes a rule *lds.S -> *lds.
Example:
#arch/i386/kernel/Makefile
always := vmlinux.lds
#Makefile
export CPPFLAGS_vmlinux.lds += -P -C -U$(ARCH)
The assigment to $(always) is used to tell kbuild to build the
target: vmlinux.lds.
The assignment to $(CPPFLAGS_vmlinux.lds) tell kbuild to use the
specified options when building the target vmlinux.lds.
When building the *.lds target kbuild used the variakles:
CPPFLAGS : Set in top-level Makefile
EXTRA_CPPFLAGS : May be set in the kbuild makefile
CPPFLAGS_$(@F) : Target specific flags.
Note that the full filename is used in this
assignment.
The kbuild infrastructure for *lds file are used in several
architecture specific files.
=== 7 Kbuild Variables
The top Makefile exports the following variables:
...
...
Makefile
View file @
a91c4fb5
...
...
@@ -545,7 +545,7 @@ endef
quiet_cmd_sysmap
=
SYSMAP
cmd_sysmap
=
$(CONFIG_SHELL)
$(srctree)
/scripts/mksysmap
LDFLAGS_vmlinux
+=
-T
arch
/
$(ARCH)
/kernel/vmlinux.lds
.s
LDFLAGS_vmlinux
+=
-T
arch
/
$(ARCH)
/kernel/vmlinux.lds
# Generate section listing all symbols and add it into vmlinux
# It's a three stage process:
...
...
@@ -591,13 +591,13 @@ cmd_kallsyms = $(NM) -n $< | $(KALLSYMS) $(foreach x,$(CONFIG_KALLSYMS_ALL),--al
.tmp_kallsyms%.S
:
.tmp_vmlinux% $(KALLSYMS)
$(
call
cmd,kallsyms
)
.tmp_vmlinux1
:
$(vmlinux-objs) arch/$(ARCH)/kernel/vmlinux.lds
.s
FORCE
.tmp_vmlinux1
:
$(vmlinux-objs) arch/$(ARCH)/kernel/vmlinux.lds FORCE
$(
call
if_changed_rule,vmlinux__
)
.tmp_vmlinux2
:
$(vmlinux-objs) .tmp_kallsyms1.o arch/$(ARCH)/kernel/vmlinux.lds
.s
FORCE
.tmp_vmlinux2
:
$(vmlinux-objs) .tmp_kallsyms1.o arch/$(ARCH)/kernel/vmlinux.lds FORCE
$(
call
if_changed_rule,vmlinux__
)
.tmp_vmlinux3
:
$(vmlinux-objs) .tmp_kallsyms2.o arch/$(ARCH)/kernel/vmlinux.lds
.s
FORCE
.tmp_vmlinux3
:
$(vmlinux-objs) .tmp_kallsyms2.o arch/$(ARCH)/kernel/vmlinux.lds FORCE
$(
call
if_changed_rule,vmlinux__
)
endif
...
...
@@ -618,13 +618,13 @@ define rule_vmlinux
$(rule_verify_kallsyms)
endef
vmlinux
:
$(vmlinux-objs) $(kallsyms.o) arch/$(ARCH)/kernel/vmlinux.lds
.s
FORCE
vmlinux
:
$(vmlinux-objs) $(kallsyms.o) arch/$(ARCH)/kernel/vmlinux.lds FORCE
$(
call
if_changed_rule,vmlinux
)
# The actual objects are generated when descending,
# make sure no implicit rule kicks in
$(sort $(vmlinux-objs)) arch/$(ARCH)/kernel/vmlinux.lds
.s
:
$(vmlinux-dirs) ;
$(sort $(vmlinux-objs)) arch/$(ARCH)/kernel/vmlinux.lds
:
$(vmlinux-dirs) ;
# Handle descending into subdirectories listed in $(vmlinux-dirs)
# Preset locale variables to speed up the build process. Limit locale
...
...
@@ -682,7 +682,7 @@ prepare-all: prepare0 prepare
# Leave this as default for preprocessing vmlinux.lds.S, which is now
# done in arch/$(ARCH)/kernel/Makefile
export
AFLAGS_vmlinux.lds.o
+=
-P
-C
-U
$(ARCH)
export
CPPFLAGS_vmlinux.lds
+=
-P
-C
-U
$(ARCH)
# Single targets
# ---------------------------------------------------------------------------
...
...
arch/alpha/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -2,7 +2,7 @@
# Makefile for the linux kernel.
#
extra-y
:=
head.o vmlinux.lds
.s
extra-y
:=
head.o vmlinux.lds
EXTRA_AFLAGS
:=
$(CFLAGS)
EXTRA_CFLAGS
:=
-Werror
-Wno-sign-compare
...
...
arch/arm/Makefile
View file @
a91c4fb5
...
...
@@ -9,7 +9,7 @@
LDFLAGS_vmlinux
:=
-p
--no-undefined
-X
LDFLAGS_BLOB
:=
--format
binary
AFLAGS_vmlinux.lds.o
=
-DTEXTADDR
=
$(TEXTADDR)
-DDATAADDR
=
$(DATAADDR)
CPPFLAGS_vmlinux.lds
=
-DTEXTADDR
=
$(TEXTADDR)
-DDATAADDR
=
$(DATAADDR)
OBJCOPYFLAGS
:=
-O
binary
-R
.note
-R
.comment
-S
GZFLAGS
:=
-9
#CFLAGS +=-pipe
...
...
arch/arm/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -26,7 +26,7 @@ endif
head-y
:=
head.o
obj-$(CONFIG_DEBUG_LL)
+=
debug.o
extra-y
:=
$
(
head-y
)
init_task.o vmlinux.lds
.s
extra-y
:=
$
(
head-y
)
init_task.o vmlinux.lds
# Spell out some dependencies that aren't automatically figured out
$(obj)/entry-armv.o
:
$(obj)/entry-header.S include/asm-arm/constants.h
...
...
arch/arm26/Makefile
View file @
a91c4fb5
...
...
@@ -9,7 +9,7 @@
LDFLAGS_vmlinux
:=
-p
-X
LDFLAGS_BLOB
:=
--format
binary
AFLAGS_vmlinux.lds.o
=
-DTEXTADDR
=
$(TEXTADDR)
-DDATAADDR
=
$(DATAADDR)
CPPFLAGS_vmlinux.lds
=
-DTEXTADDR
=
$(TEXTADDR)
-DDATAADDR
=
$(DATAADDR)
OBJCOPYFLAGS
:=
-O
binary
-R
.note
-R
.comment
-S
GZFLAGS
:=
-9
...
...
arch/arm26/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -14,5 +14,5 @@ obj-y := compat.o dma.o entry.o irq.o \
obj-$(CONFIG_FIQ)
+=
fiq.o
obj-$(CONFIG_MODULES)
+=
armksyms.o
extra-y
:=
init_task.o vmlinux.lds
.s
extra-y
:=
init_task.o vmlinux.lds
arch/cris/Makefile
View file @
a91c4fb5
...
...
@@ -29,7 +29,7 @@ LDFLAGS_BLOB := --format binary --oformat elf32-cris \
OBJCOPYFLAGS
:=
-O
binary
-R
.note
-R
.comment
-S
AFLAGS_vmlinux.lds.o
=
-DDRAM_VIRTUAL_BASE
=
0x
$(CONFIG_ETRAX_DRAM_VIRTUAL_BASE)
CPPFLAGS_vmlinux.lds
=
-DDRAM_VIRTUAL_BASE
=
0x
$(CONFIG_ETRAX_DRAM_VIRTUAL_BASE)
AFLAGS
+=
-mlinux
CFLAGS
:=
$(CFLAGS)
-mlinux
-march
=
$
(
arch-y
)
-pipe
...
...
arch/cris/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -3,7 +3,7 @@
# Makefile for the linux kernel.
#
extra-y
:=
vmlinux.lds
.s
extra-y
:=
vmlinux.lds
obj-y
:=
process.o traps.o irq.o ptrace.o setup.o
\
time.o sys_cris.o semaphore.o
...
...
arch/h8300/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -2,7 +2,7 @@
# Makefile for the linux kernel.
#
extra-y
:=
vmlinux.lds
.s
extra-y
:=
vmlinux.lds
obj-y
:=
process.o traps.o ptrace.o ints.o
\
sys_h8300.o time.o semaphore.o signal.o
\
...
...
arch/i386/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -2,7 +2,7 @@
# Makefile for the linux kernel.
#
extra-y
:=
head.o init_task.o vmlinux.lds
.s
extra-y
:=
head.o init_task.o vmlinux.lds
obj-y
:=
process.o semaphore.o signal.o entry.o traps.o irq.o vm86.o
\
ptrace.o i8259.o ioport.o ldt.o setup.o time.o sys_i386.o
\
...
...
arch/ia64/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -2,7 +2,7 @@
# Makefile for the linux kernel.
#
extra-y
:=
head.o init_task.o vmlinux.lds
.s
extra-y
:=
head.o init_task.o vmlinux.lds
obj-y
:=
acpi.o entry.o efi.o efi_stub.o gate-data.o fsys.o ia64_ksyms.o irq.o irq_ia64.o
\
irq_lsapic.o ivt.o machvec.o pal.o patch.o process.o perfmon.o ptrace.o sal.o
\
...
...
@@ -21,25 +21,25 @@ obj-$(CONFIG_IA64_CYCLONE) += cyclone.o
# The gate DSO image is built using a special linker script.
targets
+=
gate.so gate-syms.o
extra-y
+=
gate.so gate-syms.o gate.lds.
s gate.o
extra-y
:=
gate.so gate-syms.o gate.ld
s gate.o
# fp_emulate() expects f2-f5,f16-f31 to contain the user-level state.
CFLAGS_traps.o
+=
-mfixed-range
=
f2-f5,f16-f31
AFLAGS_gate.lds.o
+
=
-P
-C
-U
$(ARCH)
CPPFLAGS_gate.lds
:
=
-P
-C
-U
$(ARCH)
quiet_cmd_gate
=
GATE
$@
cmd_gate
=
$(CC)
-nostdlib
$
(
GATECFLAGS_
$
(
@F
))
-Wl
,-T,
$(
filter-out
FORCE,
$^
)
-o
$@
GATECFLAGS_gate.so
=
-shared
-s
-Wl
,-soname
=
linux-gate.so.1
$(obj)/gate.so
:
$(obj)/gate.lds
.s
$(obj)/gate.o FORCE
$(obj)/gate.so
:
$(obj)/gate.lds $(obj)/gate.o FORCE
$(
call
if_changed,gate
)
$(obj)/built-in.o
:
$(obj)/gate-syms.o
$(obj)/built-in.o
:
ld_flags += -R $(obj)/gate-syms.o
GATECFLAGS_gate-syms.o
=
-r
$(obj)/gate-syms.o
:
$(
src)/gate.lds.
s $(obj)/gate.o FORCE
$(obj)/gate-syms.o
:
$(
obj)/gate.ld
s $(obj)/gate.o FORCE
$(
call
if_changed,gate
)
# gate-data.o contains the gate DSO image as data in section .data.gate.
...
...
arch/m68k/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -7,7 +7,7 @@ ifndef CONFIG_SUN3
else
extra-y
:=
sun3-head.o
endif
extra-y
+=
vmlinux.lds
.s
extra-y
+=
vmlinux.lds
obj-y
:=
entry.o process.o traps.o ints.o signal.o ptrace.o
\
sys_m68k.o time.o semaphore.o setup.o m68k_ksyms.o
...
...
arch/m68knommu/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -2,7 +2,7 @@
# Makefile for arch/m68knommu/kernel.
#
extra-y
:=
vmlinux.lds
.s
extra-y
:=
vmlinux.lds
obj-y
+=
dma.o entry.o init_task.o m68k_ksyms.o process.o ptrace.o semaphore.o
\
setup.o signal.o syscalltable.o sys_m68k.o time.o traps.o
...
...
arch/mips/Makefile
View file @
a91c4fb5
...
...
@@ -643,7 +643,7 @@ endif
# none has been choosen above.
#
AFLAGS_vmlinux.lds.o
:=
\
CPPFLAGS_vmlinux.lds
:=
\
-D
"LOADADDR=
$
(load-y)"
\
-D
"JIFFIES=
$(JIFFIES)
"
\
-imacros
$(srctree)
/include/asm-
$(ARCH)
/sn/mapped_kernel.h
...
...
arch/mips/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -2,7 +2,7 @@
# Makefile for the Linux/MIPS kernel.
#
extra-y
:=
head.o init_task.o vmlinux.lds
.s
extra-y
:=
head.o init_task.o vmlinux.lds
obj-y
+=
cpu-probe.o branch.o entry.o genex.o irq.o process.o
\
ptrace.o reset.o semaphore.o setup.o signal.o syscall.o
\
...
...
arch/parisc/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -4,7 +4,7 @@
head-y
:=
head.o
head-$(CONFIG_PARISC64)
:=
head64.o
extra-y
:=
init_task.o
$
(
head-y
)
vmlinux.lds
.s
extra-y
:=
init_task.o
$
(
head-y
)
vmlinux.lds
AFLAGS_entry.o
:=
-traditional
AFLAGS_pacache.o
:=
-traditional
...
...
arch/ppc/Makefile
View file @
a91c4fb5
...
...
@@ -70,7 +70,7 @@ BOOT_TARGETS = zImage zImage.initrd znetboot znetboot.initrd vmlinux.sm
all
:
zImage
AFLAGS_vmlinux.lds.o
:=
-Upowerpc
CPPFLAGS_vmlinux.lds
:=
-Upowerpc
# All the instructions talk about "make bzImage".
bzImage
:
zImage
...
...
arch/ppc/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -9,7 +9,7 @@ extra-$(CONFIG_E500) := head_e500.o
extra-$(CONFIG_8xx)
:=
head_8xx.o
extra-$(CONFIG_6xx)
+=
idle_6xx.o
extra-$(CONFIG_POWER4)
+=
idle_power4.o
extra-y
+=
vmlinux.lds
.s
extra-y
+=
vmlinux.lds
obj-y
:=
entry.o traps.o irq.o idle.o time.o misc.o
\
process.o signal.o ptrace.o align.o
\
...
...
arch/ppc64/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -3,7 +3,7 @@
#
EXTRA_CFLAGS
+=
-mno-minimal-toc
extra-y
:=
head.o vmlinux.lds
.s
extra-y
:=
head.o vmlinux.lds
obj-y
:=
setup.o entry.o traps.o irq.o idle.o dma.o
\
time.o process.o signal.o syscalls.o misc.o ptrace.o
\
...
...
arch/s390/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -10,7 +10,7 @@ obj-y := bitmap.o traps.o time.o process.o \
extra-$(CONFIG_ARCH_S390_31)
+=
head.o
extra-$(CONFIG_ARCH_S390X)
+=
head64.o
extra-y
+=
init_task.o vmlinux.lds
.s
extra-y
+=
init_task.o vmlinux.lds
obj-$(CONFIG_MODULES)
+=
s390_ksyms.o module.o
obj-$(CONFIG_SMP)
+=
smp.o
...
...
arch/sh/Makefile
View file @
a91c4fb5
...
...
@@ -122,7 +122,7 @@ drivers-$(CONFIG_OPROFILE) += arch/sh/oprofile/
boot
:=
arch
/sh/boot
AFLAGS_vmlinux.lds.o
:=
-traditional
CPPFLAGS_vmlinux.lds
:=
-traditional
prepare
:
target_links
...
...
arch/sh/boot/compressed/Makefile
View file @
a91c4fb5
...
...
@@ -22,7 +22,7 @@ CONFIG_MEMORY_START ?= 0x0c000000
CONFIG_BOOT_LINK_OFFSET
?=
0x00800000
IMAGE_OFFSET
:=
$(
shell
printf
"0x%8x"
$$
[
0x80000000+
$(CONFIG_MEMORY_START)
+
$(CONFIG_BOOT_LINK_OFFSET)
]
)
LDFLAGS_vmlinux
:=
-Ttext
$(IMAGE_OFFSET)
-e
startup
-T
$(obj)
/../../kernel/vmlinux.lds
.s
LDFLAGS_vmlinux
:=
-Ttext
$(IMAGE_OFFSET)
-e
startup
-T
$(obj)
/../../kernel/vmlinux.lds
$(obj)/vmlinux
:
$(OBJECTS) $(obj)/piggy.o FORCE
$(
call
if_changed,ld
)
...
...
arch/sh/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -2,7 +2,7 @@
# Makefile for the Linux/SuperH kernel.
#
extra-y
:=
head.o init_task.o vmlinux.lds
.s
extra-y
:=
head.o init_task.o vmlinux.lds
obj-y
:=
process.o signal.o entry.o traps.o irq.o
\
ptrace.o setup.o time.o sys_sh.o semaphore.o
\
...
...
arch/sh64/boot/compressed/Makefile
View file @
a91c4fb5
...
...
@@ -12,7 +12,7 @@
#
targets
:=
vmlinux vmlinux.bin vmlinux.bin.gz
\
head.o misc.o cache.o piggy.o vmlinux.lds
.o
head.o misc.o cache.o piggy.o vmlinux.lds
EXTRA_AFLAGS
:=
-traditional
...
...
@@ -25,7 +25,7 @@ OBJECTS := $(obj)/head.o $(obj)/misc.o $(obj)/cache.o
ZIMAGE_OFFSET
=
$(
shell
printf
"0x%8x"
$$
[
$(CONFIG_MEMORY_START)
+0x400000+0x10000]
)
LDFLAGS_vmlinux
:=
-Ttext
$(ZIMAGE_OFFSET)
-e
startup
\
-T
$(obj)
/../../kernel/vmlinux.lds
.s
\
-T
$(obj)
/../../kernel/vmlinux.lds
\
--no-warn-mismatch
$(obj)/vmlinux
:
$(OBJECTS) $(obj)/piggy.o FORCE
...
...
@@ -41,6 +41,6 @@ $(obj)/vmlinux.bin.gz: $(obj)/vmlinux.bin FORCE
LDFLAGS_piggy.o
:=
-r
--format
binary
--oformat
elf32-sh64-linux
-T
OBJCOPYFLAGS
+=
-R
.empty_zero_page
$(obj)/piggy.o
:
$(obj)/vmlinux.lds
.s
$(obj)/vmlinux.bin.gz FORCE
$(obj)/piggy.o
:
$(obj)/vmlinux.lds $(obj)/vmlinux.bin.gz FORCE
$(
call
if_changed,ld
)
arch/sparc/boot/Makefile
View file @
a91c4fb5
...
...
@@ -37,7 +37,7 @@ endef
BTOBJS
:=
$(HEAD_Y)
$(INIT_Y)
BTLIBS
:=
$(CORE_Y)
$(LIBS_Y)
$(DRIVERS_Y)
$(NET_Y)
LDFLAGS_image
:=
-T
arch
/sparc/kernel/vmlinux.lds
.s
$(BTOBJS)
\
LDFLAGS_image
:=
-T
arch
/sparc/kernel/vmlinux.lds
$(BTOBJS)
\
--start-group
$(BTLIBS)
--end-group
\
$(kallsyms.o)
$(obj)
/btfix.o
...
...
arch/sparc/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -2,7 +2,7 @@
# Makefile for the linux kernel.
#
extra-y
:=
head.o init_task.o vmlinux.lds
.s
extra-y
:=
head.o init_task.o vmlinux.lds
EXTRA_AFLAGS
:=
-ansi
...
...
arch/sparc64/Makefile
View file @
a91c4fb5
...
...
@@ -10,7 +10,7 @@
CHECK
:=
$(CHECK)
-D__sparc__
=
1
-D__sparc_v9__
=
1
AFLAGS_vmlinux.lds.o
+=
-Usparc
CPPFLAGS_vmlinux.lds
+=
-Usparc
CC
:=
$(
shell
if
$(CC)
-m64
-S
-o
/dev/null
-xc
/dev/null
>
/dev/null 2>&1
;
then
echo
$(CC)
;
else
echo
sparc64-linux-gcc
;
fi
)
...
...
arch/sparc64/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -5,7 +5,7 @@
EXTRA_AFLAGS
:=
-ansi
EXTRA_CFLAGS
:=
-Werror
extra-y
:=
head.o init_task.o vmlinux.lds
.s
extra-y
:=
head.o init_task.o vmlinux.lds
obj-y
:=
process.o setup.o cpu.o idprom.o
\
traps.o devices.o auxio.o
\
...
...
arch/um/Makefile
View file @
a91c4fb5
...
...
@@ -77,7 +77,7 @@ vmlinux: $(ARCH_DIR)/main.o
# CONFIG_MODE_SKAS + CONFIG_STATIC_LINK case.
LINK_TT
=
-static
LD_SCRIPT_TT
:=
uml.lds
.s
LD_SCRIPT_TT
:=
uml.lds
ifeq
($(CONFIG_STATIC_LINK),y)
LINK-y
+=
$(LINK_TT)
...
...
@@ -98,12 +98,12 @@ CPP_MODE_TT := $(shell [ "$(CONFIG_MODE_TT)" = "y" ] && echo -DMODE_TT)
CONFIG_KERNEL_STACK_ORDER
?=
2
STACK_SIZE
:=
$(
shell
echo
$$
[
4096
*
(
1 <<
$(CONFIG_KERNEL_STACK_ORDER)
)
]
)
AFLAGS_vmlinux.lds.o
=
-U
$(SUBARCH)
\
CPPFLAGS_vmlinux.lds
=
-U
$(SUBARCH)
\
-DSTART
=
$$
((
$(TOP_ADDR)
-
$(SIZE)
))
-DELF_ARCH
=
$(ELF_ARCH)
\
-DELF_FORMAT
=
\"
$(ELF_FORMAT)
\"
$(CPP_MODE_TT)
\
-DKERNEL_STACK_SIZE
=
$(STACK_SIZE)
AFLAGS_$(LD_SCRIPT-y
:
.s=).o = $(AFLAGS_vmlinux.lds.o
) -P -C -Uum
CPPFLAGS_$(LD_SCRIPT-y)
=
$(CPPFLAGS_vmlinux.lds
)
-P
-C
-Uum
LD_SCRIPT-y
:=
$(ARCH_DIR)
/
$
(
LD_SCRIPT-y
)
...
...
@@ -122,7 +122,7 @@ USER_CFLAGS := $(patsubst -D__KERNEL__,,$(USER_CFLAGS)) $(ARCH_INCLUDE) \
# To get a definition of F_SETSIG
USER_CFLAGS
+=
-D_GNU_SOURCE
CLEAN_FILES
+=
linux x.i gmon.out
$(ARCH_DIR)
/uml.lds
.s
\
CLEAN_FILES
+=
linux x.i gmon.out
$(ARCH_DIR)
/uml.lds
\
$(ARCH_DIR)
/dyn_link.ld.s
$(GEN_HEADERS)
$(ARCH_DIR)/main.o
:
$(ARCH_DIR)/main.c
...
...
arch/um/Makefile-skas
View file @
a91c4fb5
...
...
@@ -12,7 +12,7 @@ LINK-$(CONFIG_GPROF) += $(PROFILE)
MODE_INCLUDE += -I$(TOPDIR)/$(ARCH_DIR)/kernel/skas/include
LINK_SKAS = -Wl,-rpath,/lib
LD_SCRIPT_SKAS = dyn.lds
.s
LD_SCRIPT_SKAS = dyn.lds
GEN_HEADERS += $(ARCH_DIR)/kernel/skas/include/skas_ptregs.h
...
...
arch/um/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -3,7 +3,7 @@
# Licensed under the GPL
#
extra-y
:=
vmlinux.lds
.s
extra-y
:=
vmlinux.lds
obj-y
=
checksum.o config.o exec_kern.o exitcode.o frame_kern.o frame.o
\
helper.o init_task.o irq.o irq_user.o ksyms.o mem.o mem_user.o
\
...
...
arch/v850/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -9,7 +9,7 @@
# for more details.
#
extra-y
:=
head.o init_task.o vmlinux.lds
.s
extra-y
:=
head.o init_task.o vmlinux.lds
obj-y
+=
intv.o entry.o process.o syscalls.o time.o semaphore.o setup.o
\
signal.o irq.o mach.o ptrace.o bug.o
...
...
arch/x86_64/kernel/Makefile
View file @
a91c4fb5
...
...
@@ -2,7 +2,7 @@
# Makefile for the linux kernel.
#
extra-y
:=
head.o head64.o init_task.o vmlinux.lds
.s
extra-y
:=
head.o head64.o init_task.o vmlinux.lds
EXTRA_AFLAGS
:=
-traditional
obj-y
:=
process.o semaphore.o signal.o entry.o traps.o irq.o
\
ptrace.o i8259.o ioport.o ldt.o setup.o time.o sys_x86_64.o
\
...
...
arch/x86_64/kernel/Makefile-HEAD
View file @
a91c4fb5
...
...
@@ -2,7 +2,7 @@
# Makefile for the linux kernel.
#
extra-y := head.o head64.o init_task.o vmlinux.lds
.s
extra-y := head.o head64.o init_task.o vmlinux.lds
EXTRA_AFLAGS := -traditional
obj-y := process.o semaphore.o signal.o entry.o traps.o irq.o \
ptrace.o i8259.o ioport.o ldt.o setup.o time.o sys_x86_64.o \
...
...
scripts/Makefile.build
View file @
a91c4fb5
...
...
@@ -219,6 +219,14 @@ cmd_as_o_S = $(CC) $(a_flags) -c -o $@ $<
targets
+=
$
(
real-objs-y
)
$
(
real-objs-m
)
$
(
lib-y
)
targets
+=
$
(
extra-y
)
$(MAKECMDGOALS)
$(always)
# Linker scripts preprocessor (.lds.S -> .lds)
# ---------------------------------------------------------------------------
quiet_cmd_cpp_lds_S
=
LDS
$@
cmd_cpp_lds_S
=
$(CPP)
$(cpp_flags)
-D__ASSEMBLY__
-o
$@
$<
%.lds
:
%.lds.S FORCE
$(
call
if_changed_dep,cpp_lds_S
)
# Build the compiled-in targets
# ---------------------------------------------------------------------------
...
...
scripts/Makefile.lib
View file @
a91c4fb5
...
...
@@ -100,6 +100,7 @@ modname_flags = $(if $(filter 1,$(words $(modname))),-DKBUILD_MODNAME=$(subst $
_c_flags
=
$(CFLAGS)
$(EXTRA_CFLAGS)
$
(
CFLAGS_
$
(
*
F
)
.o
)
_a_flags
=
$(AFLAGS)
$(EXTRA_AFLAGS)
$
(
AFLAGS_
$
(
*
F
)
.o
)
_cpp_flags
=
$(CPPFLAGS)
$(EXTRA_CPPFLAGS)
$
(
CPPFLAGS_
$
(
@F
))
# If building the kernel in a separate objtree expand all occurrences
# of -Idir to -I$(srctree)/dir except for absolute paths (starting with '/').
...
...
@@ -107,6 +108,7 @@ _a_flags = $(AFLAGS) $(EXTRA_AFLAGS) $(AFLAGS_$(*F).o)
ifeq
($(KBUILD_SRC),)
__c_flags
=
$(_c_flags)
__a_flags
=
$(_a_flags)
__cpp_flags
=
$(_cpp_flags)
else
# Prefix -I with $(srctree) if it is not an absolute path
...
...
@@ -120,6 +122,7 @@ flags = $(foreach o,$($(1)),$(if $(filter -I%,$(o)),$(call addtree,$(o)),$(o)))
# FIXME: Replace both with specific CFLAGS* statements in the makefiles
__c_flags
=
$(
call
addtree,-I
$(obj)
)
$(
call
flags,_c_flags
)
__a_flags
=
$(
call
flags,_a_flags
)
__cpp_flags
=
$(
call
flags,_cpp_flags
)
endif
c_flags
=
-Wp
,-MD,
$(depfile)
$(NOSTDINC_FLAGS)
$(CPPFLAGS)
\
...
...
@@ -129,6 +132,8 @@ c_flags = -Wp,-MD,$(depfile) $(NOSTDINC_FLAGS) $(CPPFLAGS) \
a_flags
=
-Wp
,-MD,
$(depfile)
$(NOSTDINC_FLAGS)
$(CPPFLAGS)
\
$(__a_flags)
$(modkern_aflags)
cpp_flags
=
-Wp
,-MD,
$(depfile)
$(NOSTDINC_FLAGS)
$(__cpp_flags)
ld_flags
=
$(LDFLAGS)
$(EXTRA_LDFLAGS)
# Finds the multi-part object the current object will be linked into
...
...
scripts/Makefile.modpost
View file @
a91c4fb5
...
...
@@ -51,6 +51,7 @@ _modpost: $(modules)
# Includes step 3,4
quiet_cmd_modpost
=
MODPOST
cmd_modpost
=
scripts/mod/modpost
\
$(
if
$(CONFIG_MODVERSIONS)
,-m
)
\
$(
if
$(KBUILD_EXTMOD)
,-i,-o
)
$(symverfile)
\
$(
filter-out
FORCE,
$^
)
...
...
scripts/mod/modpost.c
View file @
a91c4fb5
...
...
@@ -343,7 +343,6 @@ handle_modversions(struct module *mod, struct elf_info *info,
crc
=
(
unsigned
int
)
sym
->
st_value
;
add_exported_symbol
(
symname
+
strlen
(
CRC_PFX
),
mod
,
&
crc
);
modversions
=
1
;
}
break
;
case
SHN_UNDEF
:
...
...
@@ -649,7 +648,6 @@ read_dump(const char *fname)
if
(
!
(
mod
=
find_module
(
modname
)))
{
if
(
is_vmlinux
(
modname
))
{
modversions
=
1
;
have_vmlinux
=
1
;
}
mod
=
new_module
(
NOFAIL
(
strdup
(
modname
)));
...
...
@@ -696,11 +694,14 @@ main(int argc, char **argv)
char
*
dump_read
=
NULL
,
*
dump_write
=
NULL
;
int
opt
;
while
((
opt
=
getopt
(
argc
,
argv
,
"i:o:"
))
!=
-
1
)
{
while
((
opt
=
getopt
(
argc
,
argv
,
"i:
m
o:"
))
!=
-
1
)
{
switch
(
opt
)
{
case
'i'
:
dump_read
=
optarg
;
break
;
case
'm'
:
modversions
=
1
;
break
;
case
'o'
:
dump_write
=
optarg
;
break
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment