summaryrefslogtreecommitdiffstats
path: root/src/arch/ia64/Makefile
blob: 42e0b47bead0efacaf2f6c39c331d6ab2a0372ad (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
ARCH_FORMAT=	elf64-ia64-little

LCONFIG+=	


BUILD_EFIS=	$(patsubst %.img, %.efi, $(IMGS)) $(patsubst %.img, %.zefi, $(IMGS))

START=	$(BIN)/start.o $(BIN)/reloc.o 
#START+=	$(BIN)/efi_main.o

SRCS+=	arch/ia64/prefix/efi_prefix.S arch/ia64/prefix/unnrv2b.S
SRCS+=	arch/ia64/core/__call.S 
SRCS+=	arch/ia64/core/ia64_timer.c
SRCS+=	arch/ia64/core/idiv32.S
SRCS+=	arch/ia64/core/idiv64.S
SRCS+=	arch/ia64/core/longjmp.S
SRCS+=	arch/ia64/core/memmove.S
SRCS+=	arch/ia64/core/memset.S
SRCS+=	arch/ia64/core/pal.c
SRCS+=	arch/ia64/core/pci_io.c
SRCS+=	arch/ia64/core/reloc.S
SRCS+=	arch/ia64/core/relocate_to.S
SRCS+=	arch/ia64/core/sal.c
SRCS+=	arch/ia64/core/setjmp.S
SRCS+=	arch/ia64/core/start.S
SRCS+=	arch/ia64/core/efi.c

ROMLIMIT:=3276800

include		$(BIN)/Roms

# We need allefis because $(IMGS) is not defined until
# the Makefile fragment "Roms" is read.
allefis:	$(BUILD_EFIS)


#BOBJS+=		$(BIN)/acpi.o 
BOBJS+=		$(BIN)/sal.o $(BIN)/pal.o 
BOBJS+=		$(BIN)/efi.o
BOBJS+=		$(BIN)/memset.o $(BIN)/memmove.o
BOBJS+=		$(BIN)/setjmp.o $(BIN)/longjmp.o
BOBJS+=		$(BIN)/relocate_to.o $(BIN)/__call.o
BOBJS+=		$(BIN)/pci_io.o $(BIN)/ia64_timer.o
BOBJS+=		$(BIN)/__divdi3.o $(BIN)/__udivdi3.o $(BIN)/__moddi3.o $(BIN)/__umoddi3.o
BOBJS+=		$(BIN)/__divsi3.o $(BIN)/__udivsi3.o $(BIN)/__modsi3.o $(BIN)/__umodsi3.o


# IA64 Division routines
$(BIN)/__divdi3.o:	arch/ia64/core/idiv64.S
	$(CPP) $(CFLAGS) -DASSEMBLY $< | $(AS) $(ASFLAGS) -o $@

$(BIN)/__udivdi3.o:	arch/ia64/core/idiv64.S
	$(CPP) $(CFLAGS) -DASSEMBLY -DUNSIGNED $< | $(AS) $(ASFLAGS) -o $@

$(BIN)/__moddi3.o:	arch/ia64/core/idiv64.S
	$(CPP) $(CFLAGS) -DASSEMBLY -DMODULO $< | $(AS) $(ASFLAGS) -o $@

$(BIN)/__umoddi3.o:	arch/ia64/core/idiv64.S
	$(CPP) $(CFLAGS) -DASSEMBLY -DUNSIGNED -DMODULO $< | $(AS) $(ASFLAGS) -o $@

$(BIN)/__divsi3.o:	arch/ia64/core/idiv32.S
	$(CPP) $(CFLAGS) -DASSEMBLY $< | $(AS) $(ASFLAGS) -o $@

$(BIN)/__udivsi3.o:	arch/ia64/core/idiv32.S
	$(CPP) $(CFLAGS) -DASSEMBLY -DUNSIGNED $< | $(AS) $(ASFLAGS) -o $@

$(BIN)/__modsi3.o:	arch/ia64/core/idiv32.S
	$(CPP) $(CFLAGS) -DASSEMBLY -DMODULO $< | $(AS) $(ASFLAGS) -o $@

$(BIN)/__umodsi3.o:	arch/ia64/core/idiv32.S
	$(CPP) $(CFLAGS) -DASSEMBLY -DUNSIGNED -DMODULO $< | $(AS) $(ASFLAGS) -o $@



# Utilities
$(BIN)/nrv2b:	util/nrv2b.c
	$(HOST_CC) -O2 -DENCODE -DDECODE -DMAIN -DVERBOSE -DNDEBUG -DBITSIZE=64 -DENDIAN=0 -o $@ $<

# Pattern Rules

# General for compiling assembly source files
$(BIN)/%.o:	arch/ia64/core/%.c $(MAKEDEPS)
	$(CC) $(CFLAGS) -o $@ -c $<

$(BIN)/%.o:	arch/ia64/prefix/%.S $(MAKEDEPS)
	$(CPP) $(CFLAGS) -DASSEMBLY $< | $(AS) $(ASFLAGS) -o $@

$(BIN)/%.o:	arch/ia64/core/%.S $(MAKEDEPS)
	$(CPP) $(CFLAGS) -DASSEMBLY $< | $(AS) $(ASFLAGS) -o $@

$(BIN)/%.o:	$(BIN)/%.s
	$(AS)	$(ASFLAGS) -o $@ $<

# General rules for bootable images

# Rules for nrv2b compressed images
$(BIN)/unnrv2b.tmp:	$(BIN)/unnrv2b.o arch/ia64/prefix/unnrv2b.lds $(MAKEDEPS)
	$(LD) -T arch/ia64/prefix/unnrv2b.lds $< -o $@

$(BIN)/unnrv2b: $(BIN)/unnrv2b.tmp $(MAKEDEPS)
	$(OBJCOPY) -O binary $< $@

$(BIN)/%.zimg: $(BIN)/%.z $(BIN)/unnrv2b arch/ia64/prefix/apply_unnrv2b_prefix.pl $(MAKEDEPS)
	$(PERL) arch/ia64/prefix/apply_unnrv2b_prefix.pl $(BIN)/unnrv2b $< > $@

# Placeholder; add no extra symbols to %.sym
$(BIN)/%.zsym: $(BIN)/%.sym $(MAKEDEPS)
	cp -f $< $@

# rules to generate efi loadable image
SUFFIXES += efi zefi
$(BIN)/efi_prefix.tmp:	$(BIN)/efi_prefix.o arch/ia64/prefix/efi_prefix.lds $(MAKEDEPS)
	$(LD) -T arch/ia64/prefix/efi_prefix.lds $< -o $@

$(BIN)/efi_prefix: $(BIN)/efi_prefix.tmp  $(MAKEDEPS)
	$(OBJCOPY) -O binary $< $@

$(BIN)/%.efi:	$(BIN)/%.img $(BIN)/%.tmp $(BIN)/efi_prefix arch/ia64/prefix/apply_efi_prefix.pl $(MAKEDEPS)
	@$(SIZE) $(BIN)/$(*).tmp | (read l1; read d1 d2 bss rest ; echo $$bss )
	$(PERL)	arch/ia64/prefix/apply_efi_prefix.pl $(BIN)/efi_prefix $< `$(SIZE) $(BIN)/$(*).tmp | (read l1; read d1 d2 bss rest ; echo $$bss )` > $@

$(BIN)/%.zefi: $(BIN)/%.zimg $(BIN)/%.tmp $(BIN)/efi_prefix arch/ia64/prefix/apply_efi_prefix.pl $(MAKEDEPS)
	@$(SIZE) $(BIN)/$(*).tmp | (read l1; read d1 d2 d3 size rest ; echo $$size )
	$(PERL)	arch/ia64/prefix/apply_efi_prefix.pl $(BIN)/efi_prefix $< `$(SIZE) $(BIN)/$(*).tmp | (read l1; read d1 d2 d3 size rest ; echo $$size )` > $@