X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2FMakefile.build;h=017267f688b14a356d5c8556ecae12956efd29c6;hb=993c1d9f4452e2edd851f3175dfdf317f18bdb9f;hp=0a253095d03abf71d40a6ad63927a76fbb7fcf97;hpb=f6580e9ad405b519dbe85027691bf3c66074b0a4;p=pintos-anon diff --git a/src/Makefile.build b/src/Makefile.build index 0a25309..017267f 100644 --- a/src/Makefile.build +++ b/src/Makefile.build @@ -6,13 +6,13 @@ SHELL = /bin/sh CC = gcc -SRC_ROOT = ../.. -VPATH = $(SRC_ROOT) +VPATH = ../.. +DEFINES += -DKERNEL WARNINGS = -Wall -W -Wstrict-prototypes -Wmissing-prototypes -INCLUDES = -I$(SRC_ROOT) +INCLUDES = -nostdinc -I../.. -I- -I../../lib -I../../lib/kernel CFLAGS = -g -O3 -MMD -msoft-float $(INCLUDES) $(WARNINGS) $(DEFINES) -ASFLAGS = -Wa,--gstabs $(INCLUDES) $(DEFINES) +ASFLAGS = -Wa,--gstabs -MMD $(INCLUDES) $(DEFINES) # Core kernel. threads_SRC = threads/init.c # Main program. @@ -25,6 +25,7 @@ threads_SRC += threads/paging.c # Page tables. threads_SRC += threads/palloc.c # Page allocator. threads_SRC += threads/malloc.c # Subpage allocator. threads_SRC += threads/start.S # Startup code. +threads_SRC += threads/test.c # Test code. # Device driver code. devices_SRC = devices/timer.c # Timer device. @@ -32,20 +33,26 @@ devices_SRC += devices/kbd.c # Keyboard device. devices_SRC += devices/vga.c # Video device. devices_SRC += devices/serial.c # Serial port device. devices_SRC += devices/disk.c # IDE disk device. +devices_SRC += devices/intq.c # Interrupt queue. -# Library code. +# Library code shared between kernel and user programs. lib_SRC = lib/debug.c # Debug helpers. -lib_SRC += lib/lib.c # Standard C library. lib_SRC += lib/random.c # Pseudo-random numbers. -lib_SRC += lib/list.c # Doubly-linked lists. -lib_SRC += lib/bitmap.c # Bitmaps. -lib_SRC += lib/hash.c # Hash tables. +lib_SRC += lib/stdio.c # I/O library. +lib_SRC += lib/stdlib.c # Utility functions. +lib_SRC += lib/string.c # String functions. + +# Kernel-specific library code. +lib_kernel_SRC += lib/kernel/list.c # Doubly-linked lists. +lib_kernel_SRC += lib/kernel/bitmap.c # Bitmaps. +lib_kernel_SRC += lib/kernel/hash.c # Hash tables. +lib_kernel_SRC += lib/kernel/console.c # printf(), putchar(). # Filesystem code. filesys_SRC = filesys/filesys.c # Filesystem core. filesys_SRC += filesys/file.c # Files. filesys_SRC += filesys/directory.c # Directories. -filesys_SRC += filesys/filehdr.c # File headers (inodes). +filesys_SRC += filesys/inode.c # File headers. filesys_SRC += filesys/fsutil.c # Utilities. # User process code. @@ -55,7 +62,7 @@ userprog_SRC += userprog/syscall.c # System call handler. userprog_SRC += userprog/gdt.c # GDT initialization. userprog_SRC += userprog/tss.c # TSS management. -SOURCES = $(foreach dir,$(SUBDIRS),$($(dir)_SRC)) +SOURCES = $(foreach dir,$(SUBDIRS),$($(subst /,_,$(dir))_SRC)) OBJECTS = $(patsubst %.c,%.o,$(patsubst %.S,%.o,$(SOURCES))) DEPENDS = $(patsubst %.o,%.d,$(OBJECTS)) @@ -72,11 +79,11 @@ kernel.o: threads/kernel.lds.s $(OBJECTS) kernel.bin: kernel.o objcopy -O binary -R .note -R .comment -S $< $@.tmp - $(SRC_ROOT)/pad 4096 < $@.tmp > $@ + ../../pad 4096 < $@.tmp > $@ rm $@.tmp -threads/loader.o: threads/loader.S threads/loader.h kernel.bin - gcc -c $< -o $@ -DKERNEL_LOAD_PAGES=`perl -e 'print +(-s "kernel.bin") / 4096;'` +threads/loader.o: threads/loader.S kernel.bin + $(CC) -c $< -o $@ $(ASFLAGS) -DKERNEL_LOAD_PAGES=`perl -e 'print +(-s "kernel.bin") / 4096;'` loader.bin: threads/loader.o ld -N -e start -Ttext 0x7c00 --oformat binary -o $@ $<