]> git.lizzy.rs Git - plan9front.git/blob - sys/src/9/bcm/mkfile
devarch: restrict i/o port access to 64K, disallow msr 32-bit wrap arround (thanks...
[plan9front.git] / sys / src / 9 / bcm / mkfile
1 CONF=pif
2 CONFLIST=pif picpuf
3 EXTRACOPIES=
4 #EXTRACOPIES=''piestand lookout boundary # bovril
5
6 loadaddr=0x80008000
7
8 objtype=arm
9 </$objtype/mkfile
10 p=9
11
12 DEVS=`{rc ../port/mkdevlist $CONF}
13
14 PORT=\
15         alarm.$O\
16         alloc.$O\
17         allocb.$O\
18         auth.$O\
19         cache.$O\
20         chan.$O\
21         dev.$O\
22         edf.$O\
23         fault.$O\
24         mul64fract.$O\
25         page.$O\
26         parse.$O\
27         pgrp.$O\
28         portclock.$O\
29         print.$O\
30         proc.$O\
31         qio.$O\
32         qlock.$O\
33         rdb.$O\
34         rebootcmd.$O\
35         segment.$O\
36         syscallfmt.$O\
37         sysfile.$O\
38         sysproc.$O\
39         taslock.$O\
40         tod.$O\
41         xalloc.$O\
42
43 OBJ=\
44         l.$O\
45         lexception.$O\
46         lproc.$O\
47         arch.$O\
48         clock.$O\
49         fpi.$O\
50         fpiarm.$O\
51         fpimem.$O\
52         main.$O\
53         mmu.$O\
54         random.$O\
55         syscall.$O\
56         trap.$O\
57         $CONF.root.$O\
58         $CONF.rootc.$O\
59         $DEVS\
60         $PORT\
61
62 # HFILES=
63
64 LIB=\
65         /$objtype/lib/libmemlayer.a\
66         /$objtype/lib/libmemdraw.a\
67         /$objtype/lib/libdraw.a\
68         /$objtype/lib/libip.a\
69         /$objtype/lib/libsec.a\
70         /$objtype/lib/libmp.a\
71         /$objtype/lib/libc.a\
72
73 9:V: $p$CONF s$p$CONF
74
75 $p$CONF:DQ:     $CONF.c $OBJ $LIB mkfile
76         $CC $CFLAGS '-DKERNDATE='`{date -n} $CONF.c
77         echo '# linking raw kernel'     # H6: no headers, data segment aligned
78         $LD -l -o $target -H6 -R4096 -T$loadaddr $OBJ $CONF.$O $LIB
79
80 s$p$CONF:DQ:    $CONF.$O $OBJ $LIB
81         echo '# linking kernel with symbols'
82         $LD -l -o $target -R4096 -T$loadaddr $OBJ $CONF.$O $LIB
83         size $target
84
85 $p$CONF.gz:D:   $p$CONF
86         gzip -9 <$p$CONF >$target
87
88 $OBJ: $HFILES
89
90 install:V: /$objtype/$p$CONF
91
92 /$objtype/$p$CONF:D: $p$CONF s$p$CONF
93         cp -x $p$CONF s$p$CONF /$objtype/ &
94         for(i in $EXTRACOPIES)
95                 { 9fs $i && cp $p$CONF s$p$CONF /n/$i/$objtype && echo -n $i... & }
96         wait
97         echo
98         touch $target
99
100 <../boot/bootmkfile
101 <../port/portmkfile
102 <|../port/mkbootrules $CONF
103
104 arch.$O clock.$O fpiarm.$O main.$O mmu.$O screen.$O syscall.$O trap.$O: \
105         /$objtype/include/ureg.h
106
107 archbcm.$O: ../port/flashif.h
108 fpi.$O fpiarm.$O fpimem.$O: fpi.h
109 l.$O lexception.$O lproc.$O mmu.$O: arm.s mem.h
110 main.$O: errstr.h init.h reboot.h
111 devmouse.$O mouse.$O screen.$O: screen.h
112 devusb.$O: ../port/usb.h
113
114 init.h:D:       ../port/initcode.c init9.s
115         $CC ../port/initcode.c
116         $AS init9.s
117         $LD -l -R1 -s -o init.out init9.$O initcode.$O /$objtype/lib/libc.a
118         {echo 'uchar initcode[]={'
119          xd -1x <init.out |
120                 sed -e 's/^[0-9a-f]+ //' -e 's/ ([0-9a-f][0-9a-f])/0x\1,/g'
121          echo '};'} > init.h
122
123 reboot.h:D:     rebootcode.s arm.s arm.h mem.h
124         $AS rebootcode.s
125         # -lc is only for memmove.  -T arg is PADDR(REBOOTADDR)
126         $LD -l -s -T0x3400 -R4 -o reboot.out rebootcode.$O -lc
127         {echo 'uchar rebootcode[]={'
128          xd -1x reboot.out |
129                 sed -e '1,2d' -e 's/^[0-9a-f]+ //' -e 's/ ([0-9a-f][0-9a-f])/0x\1,/g'
130          echo '};'} > reboot.h
131 errstr.h:D:     ../port/mkerrstr ../port/error.h
132         rc ../port/mkerrstr > errstr.h
133
134 $CONF.clean:
135         rm -rf $p$CONF s$p$CONF errstr.h reboot.h $CONF.c boot$CONF.c