c125ebaeb7be4447f9258b2736c354a73c1538d9
[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           # Main program.
20 THREADS_SRC += gdt.c            # GDT initialization.
21 THREADS_SRC += tss.c            # TSS management.
22 THREADS_SRC += thread.c         # Thread management core.
23 THREADS_SRC += switch.S         # Thread switch routine.
24 THREADS_SRC += interrupt.c      # Interrupt core.
25 THREADS_SRC += intr-stubs.S     # Interrupt stubs.
26 THREADS_SRC += synch.c          # Synchronization.
27 THREADS_SRC += paging.c         # Page tables.
28 THREADS_SRC += palloc.c         # Page allocator.
29 THREADS_SRC += malloc.c         # Subpage allocator.
30
31 # Device driver code.
32 DEVICES_SRC  = timer.c          # Timer device.
33 DEVICES_SRC += kbd.c            # Keyboard device.
34 DEVICES_SRC += vga.c            # Video device.
35 DEVICES_SRC += serial.c         # Serial port device.
36 DEVICES_SRC += disk.c           # IDE disk device.
37
38 # Library code.
39 LIB_SRC  = debug.c              # Debug helpers.
40 LIB_SRC += lib.c                # Standard C library.
41 LIB_SRC += random.c             # Pseudo-random numbers.
42 LIB_SRC += list.c               # Doubly-linked lists.
43 LIB_SRC += bitmap.c             # Bitmaps.
44
45 # Filesystem code.
46 FILESYS_SRC  = filesys.c        # Filesystem core.
47 FILESYS_SRC += file.c           # Files.
48 FILESYS_SRC += directory.c      # Directories.
49 FILESYS_SRC += filehdr.c        # File headers (inodes).
50 FILESYS_SRC += fsutil.c         # Utilities.
51
52 # User process code.
53 USERPROG_SRC  = addrspace.c     # Address spaces.
54
55 # Objects.
56 OBJECTS = $(patsubst %.c,%.o,$(patsubst %.S,%.o,$(SOURCES)))
57
58 all: diskimage.bin
59
60 intr-stubs.S: $(TOP_SRCDIR)/threads/intr-stubs.pl $(TOP_SRCDIR)/threads/gdt.h
61         $< > $@
62
63 kernel.lds.s: $(TOP_SRCDIR)/threads/kernel.lds.S $(TOP_SRCDIR)/threads/loader.h
64         $(CPP) -x assembler-with-cpp -P $< -o $@
65
66 kernel.o: $(OBJECTS) kernel.lds.s
67         ld -T kernel.lds.s -o $@ $(OBJECTS) `$(CC) -print-libgcc-file-name`
68
69 kernel.bin: kernel.o
70         objcopy -O binary -R .note -R .comment -S $< $@.tmp
71         $(TOP_SRCDIR)/pad 4096 < $@.tmp > $@
72
73 loader.bin: loader.S loader.h kernel.bin
74         gcc -c $< -DKERNEL_LOAD_PAGES=`perl -e 'print +(-s "kernel.bin") / 4096;'`
75         ld -N -e start -Ttext 0x7c00 --oformat binary -o $@ loader.o
76
77 diskimage.bin: loader.bin kernel.bin
78         cat loader.bin kernel.bin > diskimage.bin
79
80 clean:
81         rm -f *.o *.d *.bin
82         rm -f kernel.bin.data kernel.bin.pad intr-stubs.S kernel.lds.s
83
84 -include *.d