source: soft/giet_vm/Makefile @ 366

Last change on this file since 366 was 366, checked in by cfuguet, 10 years ago

giet_boot: using boot_entry instead of boot_init as entry point

File size: 18.0 KB
Line 
1-include build.mk
2
3export # export all variable to sub-Makefile
4CC = mipsel-unknown-elf-gcc
5AS = mipsel-unknown-elf-as
6LD = mipsel-unknown-elf-ld
7DU = mipsel-unknown-elf-objdump
8
9ARCH ?= ../tsar-trunk-svn-2013/platforms/tsar_generic_iob
10X    ?= 2
11Y    ?= 2
12P    ?= 2
13APP  ?= convol
14
15.PHONY: map.bin
16
17### FAT parameters definition for Disk image
18### sector_size          = 512
19### partition_begin_lba  = 300
20### sector_per_cluster   = 8
21### partition sectors    = 524832
22
23### Objects to be linked for kernel.elf
24KERNEL_OBJS  = build/common/utils.o       \
25               build/common/vmem.o        \
26               build/fat32/fat32.o        \
27               build/drivers/dma_driver.o \
28               build/drivers/cma_driver.o \
29               build/drivers/fbf_driver.o \
30               build/drivers/xcu_driver.o \
31               build/drivers/icu_driver.o \
32               build/drivers/ioc_driver.o \
33               build/drivers/bdv_driver.o \
34               build/drivers/hba_driver.o \
35               build/drivers/sdc_driver.o \
36               build/drivers/spi_driver.o \
37               build/drivers/rdk_driver.o \
38               build/drivers/iob_driver.o \
39               build/drivers/mmc_driver.o \
40               build/drivers/mwr_driver.o \
41               build/drivers/nic_driver.o \
42               build/drivers/tim_driver.o \
43               build/drivers/tty_driver.o \
44               build/drivers/pic_driver.o \
45               build/kernel/giet.o        \
46               build/kernel/switch.o      \
47               build/kernel/ctx_handler.o \
48               build/kernel/exc_handler.o \
49               build/kernel/sys_handler.o \
50               build/kernel/irq_handler.o \
51               build/kernel/kernel_init.o
52
53### Objects to be linked for boot.elf
54BOOT_OBJS    = build/common/utils.o       \
55               build/common/vmem.o        \
56               build/fat32/fat32.o        \
57               build/drivers/dma_driver.o \
58               build/drivers/tty_driver.o \
59               build/drivers/pic_driver.o \
60               build/drivers/xcu_driver.o \
61               build/drivers/ioc_driver.o \
62               build/drivers/iob_driver.o \
63               build/drivers/bdv_driver.o \
64               build/drivers/sdc_driver.o \
65               build/drivers/spi_driver.o \
66               build/drivers/rdk_driver.o \
67               build/drivers/mmc_driver.o \
68               build/drivers/mwr_driver.o \
69               build/kernel/ctx_handler.o \
70               build/kernel/switch.o      \
71               build/boot/boot.o          \
72               build/boot/boot_entry.o
73
74### Objects to be linked for display.elf
75DISPLAY_OBJS = build/display/main.o \
76               build/libs/stdio.o
77
78### Objects to be linked for router.elf
79ROUTER_OBJS  = build/router/main.o        \
80               build/libs/mwmr_channel.o  \
81               build/libs/stdio.o
82
83### Objects to be linked for hello.elf
84HELLO_OBJS   = build/hello/main.o   \
85               build/libs/stdio.o         
86
87### Objects to be linked for pgcd.elf
88PGCD_OBJS    = build/pgcd/main.o          \
89               build/libs/stdio.o
90
91### Objects to be linked for game.elf
92GAMEOFLIFE_OBJS = build/gameoflife/main.o \
93                  build/libs/stdio.o      \
94                  build/libs/barrier.o
95
96### Objects to be linked for dhrystone.elf
97DHRYSTONE_OBJS = build/dhrystone/dhry_1.o \
98                 build/dhrystone/dhry_2.o \
99                 build/libs/stdlib.o      \
100                 build/libs/stdio.o       \
101                 build/libs/string.o      \
102                 build/libs/spin_lock.o   \
103                 build/libs/malloc.o
104
105### Objects to be linked for sort.elf
106SORT_OBJS   = build/sort/main.o        \
107              build/libs/stdio.o       \
108              build/libs/spin_lock.o   \
109              build/libs/barrier.o
110
111### Objects to be linked for transpose.elf
112TRANSPOSE_OBJS = build/transpose/main.o  \
113                 build/libs/stdio.o      \
114                 build/libs/barrier.o
115
116### Objects to be linked for convol.elf
117CONVOL_OBJS  = build/convol/main.o   \
118               build/libs/stdio.o    \
119               build/libs/stdlib.o    \
120               build/libs/barrier.o
121
122CFLAGS = -Wall -ffreestanding -mno-gpopt -mips32 -g -O2
123
124GIET_INCLUDE = -Igiet_boot    \
125               -Igiet_kernel  \
126               -Igiet_xml     \
127               -Igiet_fat32   \
128               -Igiet_drivers \
129               -Igiet_common  \
130               -Igiet_libs    \
131               -I.
132
133USER_INCLUDE = -Igiet_libs    \
134               -Igiet_xml     \
135               -I.
136
137DISK_IMAGE  := hdd/virt_hdd.dmg
138
139all: map.bin                         \
140     hard_config.h                   \
141     giet_vsegs.ld                   \
142     build/boot/boot.elf             \
143     build/kernel/kernel.elf         \
144     build/display/display.elf       \
145     build/hello/hello.elf           \
146     build/pgcd/pgcd.elf             \
147     build/router/router.elf         \
148     build/dhrystone/dhrystone.elf   \
149     build/gameoflife/gameoflife.elf \
150     build/sort/sort.elf             \
151     build/transpose/transpose.elf   \
152     build/convol/convol.elf         \
153     $(DISK_IMAGE)                   
154         
155### Copy always all files into disk image
156        mcopy -o -i $(DISK_IMAGE) build/kernel/kernel.elf ::/build/kernel
157        mcopy -o -i $(DISK_IMAGE) build/display/display.elf ::/build/display
158        mcopy -o -i $(DISK_IMAGE) build/sort/sort.elf ::/build/sort
159        mcopy -o -i $(DISK_IMAGE) build/transpose/transpose.elf ::/build/transpose
160        mcopy -o -i $(DISK_IMAGE) build/convol/convol.elf ::/build/convol
161        mcopy -o -i $(DISK_IMAGE) build/hello/hello.elf ::/build/hello
162        mcopy -o -i $(DISK_IMAGE) build/pgcd/pgcd.elf ::/build/pgcd
163        mcopy -o -i $(DISK_IMAGE) build/router/router.elf ::/build/router
164        mcopy -o -i $(DISK_IMAGE) build/gameoflife/gameoflife.elf ::/build/gameoflife
165        mcopy -o -i $(DISK_IMAGE) build/dhrystone/dhrystone.elf ::/build/dhrystone
166        mcopy -o -i $(DISK_IMAGE) transpose/images.raw ::/misc
167        mcopy -o -i $(DISK_IMAGE) convol/philips_image.raw ::/misc
168        mcopy -o -i $(DISK_IMAGE) map.bin ::/
169### Copy bootloader into sector 2 of disk image
170        dd if=build/boot/boot.elf of=$(DISK_IMAGE) seek=2 conv=notrunc
171### Checking root directory
172        mdir -/ -b -i $(DISK_IMAGE) ::/
173
174### Disk image generation (no files in this step)
175### This requires the generic LINUX/MacOS script "create_dmg" script
176### written by C.Fuguet. (should be installed in GIET-VM root directory).
177$(DISK_IMAGE):
178        ./create_dmg create $(basename $(DISK_IMAGE))
179        mmd -o -i $(DISK_IMAGE) ::/build
180        mmd -o -i $(DISK_IMAGE) ::/build/kernel
181        mmd -o -i $(DISK_IMAGE) ::/build/display
182        mmd -o -i $(DISK_IMAGE) ::/build/sort 
183        mmd -o -i $(DISK_IMAGE) ::/build/transpose
184        mmd -o -i $(DISK_IMAGE) ::/build/convol
185        mmd -o -i $(DISK_IMAGE) ::/build/hello
186        mmd -o -i $(DISK_IMAGE) ::/build/pgcd 
187        mmd -o -i $(DISK_IMAGE) ::/build/router
188        mmd -o -i $(DISK_IMAGE) ::/build/gameoflife
189        mmd -o -i $(DISK_IMAGE) ::/build/dhrystone
190        mmd -o -i $(DISK_IMAGE) ::/misc
191        dd if=$(DISK_IMAGE) of=temp.dmg count=65536
192        mv temp.dmg $(DISK_IMAGE)
193
194### mapping generation: map.bin / map.xml / hard_config.h / giet_vsegs.ld
195map.bin hard_config.h giet_vsegs.ld: $(ARCH)/arch.py  $(APP)/$(APP).py
196        giet_python/genmap --arch=$(ARCH) --x=$(X) --y=$(Y) --p=$(P) --giet=. --$(APP) --xml=.
197
198### drivers compilation
199build/drivers/cma_driver.o: giet_drivers/cma_driver.c  \
200                            giet_drivers/cma_driver.h  \
201                            hard_config.h              \
202                            giet_config.h
203        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
204
205build/drivers/dma_driver.o: giet_drivers/dma_driver.c  \
206                            giet_drivers/dma_driver.h  \
207                            hard_config.h              \
208                            giet_config.h
209        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
210
211build/drivers/fbf_driver.o: giet_drivers/fbf_driver.c  \
212                            giet_drivers/fbf_driver.h  \
213                            hard_config.h              \
214                            giet_config.h
215        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
216
217build/drivers/xcu_driver.o: giet_drivers/xcu_driver.c  \
218                            giet_drivers/xcu_driver.h  \
219                            hard_config.h              \
220                            giet_config.h
221        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
222
223build/drivers/icu_driver.o: giet_drivers/icu_driver.c  \
224                            giet_drivers/icu_driver.h  \
225                            hard_config.h              \
226                            giet_config.h
227        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
228
229build/drivers/ioc_driver.o: giet_drivers/ioc_driver.c  \
230                            giet_drivers/ioc_driver.h  \
231                            hard_config.h              \
232                            giet_config.h
233        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
234
235build/drivers/bdv_driver.o: giet_drivers/bdv_driver.c  \
236                            giet_drivers/bdv_driver.h  \
237                            hard_config.h              \
238                            giet_config.h
239        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
240
241build/drivers/hba_driver.o: giet_drivers/hba_driver.c  \
242                            giet_drivers/hba_driver.h  \
243                            hard_config.h              \
244                            giet_config.h
245        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
246
247build/drivers/sdc_driver.o: giet_drivers/sdc_driver.c  \
248                            giet_drivers/sdc_driver.h  \
249                            hard_config.h              \
250                            giet_config.h
251        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
252
253build/drivers/spi_driver.o: giet_drivers/spi_driver.c  \
254                            giet_drivers/spi_driver.h  \
255                            hard_config.h              \
256                            giet_config.h
257        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
258
259build/drivers/rdk_driver.o: giet_drivers/rdk_driver.c  \
260                            giet_drivers/rdk_driver.h  \
261                            hard_config.h              \
262                            giet_config.h
263        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
264
265build/drivers/iob_driver.o: giet_drivers/iob_driver.c  \
266                            giet_drivers/iob_driver.h  \
267                            hard_config.h              \
268                            giet_config.h
269        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
270
271build/drivers/mmc_driver.o: giet_drivers/mmc_driver.c  \
272                            giet_drivers/mmc_driver.h  \
273                            hard_config.h              \
274                            giet_config.h
275        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
276
277build/drivers/mwr_driver.o: giet_drivers/mwr_driver.c  \
278                            giet_drivers/mwr_driver.h  \
279                            hard_config.h              \
280                            giet_config.h
281        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
282
283build/drivers/nic_driver.o: giet_drivers/nic_driver.c  \
284                            giet_drivers/nic_driver.h  \
285                            hard_config.h              \
286                            giet_config.h
287        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
288
289build/drivers/tim_driver.o: giet_drivers/tim_driver.c  \
290                            giet_drivers/tim_driver.h  \
291                            hard_config.h              \
292                            giet_config.h
293        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
294
295build/drivers/tty_driver.o: giet_drivers/tty_driver.c  \
296                            giet_drivers/tty_driver.h  \
297                            hard_config.h              \
298                            giet_config.h
299        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
300
301build/drivers/pic_driver.o: giet_drivers/pic_driver.c  \
302                            giet_drivers/pic_driver.h  \
303                            hard_config.h              \
304                            giet_config.h
305        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
306
307### fat32 compilation
308build/fat32/fat32.o: giet_fat32/fat32.c \
309                     giet_fat32/fat32.h \
310                     hard_config.h      \
311                     giet_config.h
312        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
313
314### utils compilation
315build/common/utils.o: giet_common/utils.c \
316                      giet_common/utils.h \
317                      hard_config.h       \
318                      giet_config.h
319        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
320
321### vmem compilation
322build/common/vmem.o: giet_common/vmem.c \
323                     giet_common/vmem.h \
324                     hard_config.h      \
325                     giet_config.h
326        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
327
328### boot compilation
329build/boot/boot.elf: $(BOOT_OBJS)            \
330                     giet_boot/boot.ld
331        $(LD) -o $@ -T giet_boot/boot.ld $(BOOT_OBJS) 
332        $(DU) -D $@ > $@.txt
333
334build/boot/boot.o: giet_boot/boot.c          \
335                   giet_common/utils.h       \
336                   giet_fat32/fat32.h        \
337                   giet_common/vmem.h        \
338                   giet_drivers/tty_driver.h \
339                   giet_drivers/ioc_driver.h \
340                   hard_config.h             \
341                   giet_config.h
342        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
343
344build/boot/boot_entry.o: giet_boot/boot_entry.S \
345                         hard_config.h
346        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
347
348### kernel compilation
349build/kernel/kernel.elf: $(KERNEL_OBJS)        \
350                         giet_kernel/kernel.ld
351        $(LD) -o $@ -T giet_kernel/kernel.ld $(KERNEL_OBJS)
352        $(DU) -D $@ > $@.txt
353
354build/kernel/%.o: giet_kernel/%.c    \
355                  hard_config.h      \
356                  giet_config.h 
357        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
358
359build/kernel/%.o: giet_kernel/%.s    \
360                  hard_config.h      \
361                  giet_config.h
362        $(CC) $(GIET_INCLUDE) $(CFLAGS)  -c -o $@ $<
363
364
365
366
367### libs compilation
368build/libs/stdio.o: giet_libs/stdio.c \
369                    giet_libs/stdio.h \
370                    hard_config.h     \
371                    giet_config.h 
372        $(CC) $(CFLAGS) $(USER_INCLUDE) -c -o $@ $<
373
374build/libs/mwmr_channel.o: giet_libs/mwmr_channel.c \
375                           giet_libs/mwmr_channel.h \
376                           hard_config.h            \
377                           giet_config.h
378        $(CC) $(CFLAGS) $(USER_INCLUDE) -c -o $@ $<
379
380build/libs/malloc.o: giet_libs/malloc.c         \
381                     giet_libs/malloc.h         \
382                     giet_libs/malloc_private.h \
383                     hard_config.h              \
384                     giet_config.h
385        $(CC) $(CFLAGS) $(USER_INCLUDE) -c -o $@ $<
386
387build/libs/barrier.o: giet_libs/barrier.c \
388                      giet_libs/barrier.h \
389                      hard_config.h       \
390                      giet_config.h
391        $(CC) $(CFLAGS) $(USER_INCLUDE) -c -o $@ $<
392
393build/libs/stdlib.o: giet_libs/stdlib.c \
394                     giet_libs/stdlib.h \
395                     hard_config.h      \
396                     giet_config.h
397        $(CC) $(CFLAGS) $(USER_INCLUDE) -c -o $@ $<
398
399build/libs/string.o: giet_libs/string.c \
400                     giet_libs/string.h \
401                     hard_config.h      \
402                     giet_config.h
403        $(CC) $(CFLAGS) $(USER_INCLUDE) -c -o $@ $<
404
405build/libs/spin_lock.o: giet_libs/spin_lock.c \
406                        giet_libs/spin_lock.h \
407                        hard_config.h         \
408                        giet_config.h
409        $(CC) $(CFLAGS) $(USER_INCLUDE) -c -o $@ $<
410
411
412### display compilation
413build/display/display.elf: $(DISPLAY_OBJS) display/display.ld hard_config.h
414        $(LD) -o $@ -T display/display.ld $(DISPLAY_OBJS)
415        $(DU) -D $@ > $@.txt
416
417build/display/main.o: display/main_cma.c
418        $(CC) $(USER_INCLUDE) $(CFLAGS)  -c -o $@ $<
419
420### router compilation
421build/router/router.elf: $(ROUTER_OBJS) router/router.ld hard_config.h
422        $(LD) -o $@ -T router/router.ld $(ROUTER_OBJS)
423        $(DU) -D $@ > $@.txt
424
425build/router/main.o: router/main.c
426        $(CC) $(USER_INCLUDE) $(CFLAGS)  -c -o $@ $<
427
428### hello compilation
429build/hello/hello.elf: $(HELLO_OBJS) hello/hello.ld hard_config.h
430        $(LD) -o $@ -T hello/hello.ld $(HELLO_OBJS)
431        $(DU) -D $@ > $@.txt
432
433build/hello/main.o: hello/main.c
434        $(CC) $(USER_INCLUDE) $(CFLAGS) -c -o $@ $<
435
436### pgcd compilation
437build/pgcd/pgcd.elf: $(PGCD_OBJS) pgcd/pgcd.ld hard_config.h
438        $(LD) -o $@ -T pgcd/pgcd.ld $(PGCD_OBJS)
439        $(DU) -D $@ > $@.txt
440
441build/pgcd/main.o: pgcd/main.c
442        $(CC) $(USER_INCLUDE) $(CFLAGS) -c -o $@ $<
443
444### gameoflife compilation
445build/gameoflife/gameoflife.elf: $(GAMEOFLIFE_OBJS) gameoflife/gameoflife.ld
446        $(LD) -o $@ -T gameoflife/gameoflife.ld $(GAMEOFLIFE_OBJS)
447        $(DU) -D $@ > $@.txt
448
449build/gameoflife/main.o: gameoflife/main.c
450        $(CC) $(USER_INCLUDE) $(CFLAGS) -O3 -c -o $@ $<
451
452### dhrystone compilation
453build/dhrystone/dhrystone.elf: $(DHRYSTONE_OBJS) dhrystone/dhrystone.ld hard_config.h
454        $(LD) -o $@ -T dhrystone/dhrystone.ld $(DHRYSTONE_OBJS)
455        $(DU) -D $@ > $@.txt
456
457build/dhrystone/dhry_1.o: dhrystone/dhry_1.c
458        $(CC) $(USER_INCLUDE) $(CFLAGS)  -c -o $@ $<
459
460build/dhrystone/dhry_2.o: dhrystone/dhry_2.c
461        $(CC) $(USER_INCLUDE) $(CFLAGS)  -c -o $@ $<
462
463### sort compilation
464build/sort/sort.elf: $(SORT_OBJS) sort/sort.ld hard_config.h
465        $(LD) -o $@ -T sort/sort.ld $(SORT_OBJS)
466        $(DU) -D $@ > $@.txt
467
468build/sort/main.o: sort/main.c
469        $(CC) $(USER_INCLUDE) $(CFLAGS) -c -o $@ $<
470
471### transpose compilation
472build/transpose/transpose.elf: $(TRANSPOSE_OBJS) transpose/transpose.ld hard_config.h
473        $(LD) -o $@ -T transpose/transpose.ld $(TRANSPOSE_OBJS)
474        $(DU) -D $@ > $@.txt
475
476build/transpose/main.o: transpose/main.c
477        $(CC) $(USER_INCLUDE) $(CFLAGS) -c -o $@ $<
478
479### convol compilation
480build/convol/convol.elf: $(CONVOL_OBJS) convol/convol.ld hard_config.h
481        $(LD) -o $@ -T convol/convol.ld $(CONVOL_OBJS)
482        $(DU) -D $@ > $@.txt
483
484build/convol/main.o: convol/main.c
485        $(CC) $(USER_INCLUDE) $(CFLAGS) -O0 -c -o $@ $<
486
487### clean
488clean:
489        rm -f *.o *.elf *.bin *.txt core 
490        rm -f hard_config.h giet_vsegs.ld map.bin map.xml
491        rm -rf build/boot/*
492        rm -rf build/fat32/*
493        rm -rf build/common/*
494        rm -rf build/drivers/*
495        rm -rf build/kernel/*
496        rm -rf build/reset/*
497        rm -rf build/libs/*
498        rm -rf build/pgcd/*
499        rm -rf build/hello/*
500        rm -rf build/display/*
501        rm -rf build/router/*
502        rm -rf build/gameoflife/*
503        rm -rf build/dhrystone/*
504        rm -rf build/sort/*
505        rm -rf build/transpose/*
506        rm -rf build/convol/*
507        rm -rf $(DISK_IMAGE)
Note: See TracBrowser for help on using the repository browser.