]> git.lizzy.rs Git - plan9front.git/blob - sys/src/9/bcm64/mkfile
amd64: FP: always use enough to fit AVX state and align to 64 bytes
[plan9front.git] / sys / src / 9 / bcm64 / mkfile
1 CONF=pi3
2 CONFLIST=pi3 pi4
3
4 loadaddr=0xffffffffc0080000
5
6 objtype=arm64
7 </$objtype/mkfile
8 p=9
9
10 DEVS=`{rc ../port/mkdevlist $CONF}
11
12 PORT=\
13         alarm.$O\
14         alloc.$O\
15         allocb.$O\
16         auth.$O\
17         cache.$O\
18         chan.$O\
19         dev.$O\
20         edf.$O\
21         fault.$O\
22         mul64fract.$O\
23         page.$O\
24         parse.$O\
25         pgrp.$O\
26         portclock.$O\
27         print.$O\
28         proc.$O\
29         qio.$O\
30         qlock.$O\
31         rdb.$O\
32         rebootcmd.$O\
33         segment.$O\
34         syscallfmt.$O\
35         sysfile.$O\
36         sysproc.$O\
37         taslock.$O\
38         tod.$O\
39         xalloc.$O\
40         userinit.$O\
41
42 OBJ=\
43         l.$O\
44         cache.v8.$O\
45         bootargs.$O\
46         clock.$O\
47         fpu.$O\
48         main.$O\
49         mmu.$O\
50         sysreg.$O\
51         random.$O\
52         trap.$O\
53         $CONF.root.$O\
54         $CONF.rootc.$O\
55         $DEVS\
56         $PORT\
57
58 # HFILES=
59
60 LIB=\
61         /$objtype/lib/libmemlayer.a\
62         /$objtype/lib/libmemdraw.a\
63         /$objtype/lib/libdraw.a\
64         /$objtype/lib/libip.a\
65         /$objtype/lib/libsec.a\
66         /$objtype/lib/libmp.a\
67         /$objtype/lib/libc.a\
68         /$objtype/lib/libdtracy.a\
69
70 9:V: $p$CONF s$p$CONF
71
72 $p$CONF:DQ:     $OBJ $CONF.$O $LIB
73         echo '# linking raw kernel'     # H6: no headers, data segment aligned
74         $LD -s -l -o $target -H6 -R0x10000 -T$loadaddr $prereq
75
76 s$p$CONF:DQ:    $OBJ $CONF.$O $LIB
77         echo '# linking kernel with symbols'
78         $LD -l -o $target -R0x10000 -T$loadaddr $prereq
79         size $target
80
81 $p$CONF.gz:D:   $p$CONF
82         gzip -9 <$p$CONF >$target
83
84 $OBJ: $HFILES
85
86 install:V: /$objtype/$p$CONF
87
88 /$objtype/$p$CONF:D: $p$CONF s$p$CONF
89         cp -x $p$CONF s$p$CONF /$objtype/
90
91
92 REPCC=`{../port/mkfilelist ../bcm}
93 ^($REPCC)\.$O:R:        '../bcm/\1.c'
94         $CC $CFLAGS -I. -. ../bcm/$stem1.c
95
96 <../boot/bootmkfile
97 <../port/portmkfile
98 <|../port/mkbootrules $CONF
99
100 arch.$O clock.$O fpiarm.$O main.$O mmu.$O screen.$O syscall.$O trap.$O: \
101         /$objtype/include/ureg.h
102 trap.$O main.$O: /sys/include/tos.h
103 l.$O cache.v8.$O mmu.$O rebootcode.$O: mem.h
104 l.$O cache.v8.$O archbcm3.$O clock.$O fpu.$O trap.$O mmu.$O rebootcode.$O: sysreg.h
105 main.$O: rebootcode.i
106 pcibcm.$O: ../port/pci.h
107
108 devmouse.$O mouse.$O screen.$O: screen.h
109 usbdwc.$O: dwcotg.h ../port/usb.h
110
111 io.h:   ../bcm/io.h
112         touch $target
113 screen.h:D: ../bcm/screen.h
114         echo '#include "../bcm/screen.h"' > screen.h
115 dwcotg.h:D: ../bcm/dwcotg.h
116         echo '#include "../bcm/dwcotg.h"' > dwcotg.h
117
118 initcode.out:           init9.$O initcode.$O /$objtype/lib/libc.a
119         $LD -l -R1 -s -o $target $prereq
120
121 rebootcode.out:         rebootcode.$O cache.v8.$O
122         $LD -l -H6 -R1 -T0x1c00 -s -o $target $prereq
123
124 $CONF.clean:
125         rm -rf $p$CONF s$p$CONF errstr.h screen.h dwcotg.h $CONF.c boot$CONF.c