137beaab2a20a3f87111ed33174ebeca4d9abf8b
[pintos-anon] / src / Makefile.inc
1 # -*- makefile -*-
2
3 SHELL = /bin/sh
4
5 CC = gcc
6
7 VPATH := $(TOP_SRCDIR)/threads
8 VPATH := $(VPATH):$(TOP_SRCDIR)/devices
9 VPATH := $(VPATH):$(TOP_SRCDIR)/lib
10 VPATH := $(VPATH):$(TOP_SRCDIR)/filesys
11 VPATH := $(VPATH):$(TOP_SRCDIR)/userprog
12
13 WARNINGS = -Wall -W -Wstrict-prototypes -Wmissing-prototypes
14 CFLAGS = -g -O3 -MMD -msoft-float $(WARNINGS) $(INCLUDES) $(DEFINES)
15 ASFLAGS = -Wa,--gstabs+ $(INCLUDES) $(DEFINES)
16
17 # Core kernel.
18 THREADS_SRC  = start.S          # Must be linked first.
19 THREADS_SRC += init.c           # Start-up code.
20 THREADS_SRC += thread.c         # Thread management core.
21 THREADS_SRC += switch.S         # Thread switch routine.
22 THREADS_SRC += interrupt.c      # Interrupt core.
23 THREADS_SRC += intr-stubs.S     # Interrupt stubs.
24 THREADS_SRC += synch.c          # Synchronization.
25 THREADS_SRC += paging.c         # Page tables.
26 THREADS_SRC += palloc.c         # Page allocator.
27 THREADS_SRC += malloc.c         # Subpage allocator.
28
29 # Device driver code.
30 DEVICES_SRC  = timer.c          # Timer device.
31 DEVICES_SRC += kbd.c            # Keyboard device.
32 DEVICES_SRC += vga.c            # Video device.
33 DEVICES_SRC += serial.c         # Serial port device.
34 DEVICES_SRC += disk.c           # IDE disk device.
35
36 # Library code.
37 LIB_SRC  = debug.c              # Debug helpers.
38 LIB_SRC += lib.c                # Standard C library.
39 LIB_SRC += random.c             # Pseudo-random numbers.
40 LIB_SRC += list.c               # Doubly-linked lists.
41 LIB_SRC += bitmap.c             # Bitmaps.
42
43 # Filesystem code.
44 FILESYS_SRC  = filesys.c        # Filesystem core.
45 FILESYS_SRC += file.c           # Files.
46 FILESYS_SRC += directory.c      # Directories.
47 FILESYS_SRC += filehdr.c        # File headers (inodes).
48 FILESYS_SRC += fsutil.c         # Utilities.
49
50 # User process code.
51 USERPROG_SRC  = addrspace.c     # Address spaces.
52
53 # Objects.
54 OBJECTS = $(patsubst %.c,%.o,$(patsubst %.S,%.o,$(SOURCES)))
55
56 all: diskimage.bin
57
58 intr-stubs.S: $(TOP_SRCDIR)/threads/intr-stubs.pl
59         $< > $@
60
61 kernel.lds.s: $(TOP_SRCDIR)/threads/kernel.lds.S $(TOP_SRCDIR)/threads/loader.h
62         $(CPP) -x assembler-with-cpp -P $< -o $@
63
64 kernel.o: $(OBJECTS) kernel.lds.s
65         ld -T kernel.lds.s -o $@ $(OBJECTS) `$(CC) -print-libgcc-file-name`
66
67 kernel.bin: kernel.o
68         objcopy -O binary -R .note -R .comment -S $< $@.tmp
69         $(TOP_SRCDIR)/pad 4096 < $@.tmp > $@
70
71 loader.bin: loader.S loader.h kernel.bin
72         gcc -c $< -DKERNEL_LOAD_PAGES=`perl -e 'print +(-s "kernel.bin") / 4096;'`
73         ld -N -e start -Ttext 0x7c00 --oformat binary -o $@ loader.o
74
75 diskimage.bin: loader.bin kernel.bin
76         cat loader.bin kernel.bin > diskimage.bin
77
78 clean:
79         rm -f *.o *.d *.bin
80         rm -f kernel.bin.data kernel.bin.pad intr-stubs.S kernel.lds.s
81
82 -include *.d