Diff markup
>> 001
>> 002
>> 003
>> 004
>> 005
>> 006
>> 007
>> 008
>> 009
>> 010
>> 011
>> 012
>> 013
>> 014
>> 015
>> 016
>> 017
001 CC=gcc 018 CC=gcc
002 CFLAGS = -Wall -nostdlib -nostdinc -ffreestan !! 019 LD=ld
003 LDFLAGS = --warn-common !! 020 CFLAGS = -Wall -nostdinc -ffreestanding -DKERNEL_SOS
>> 021 LDFLAGS = --warn-common -nostdlib
004 OBJECTS = bootstrap/multiboot.o 022 OBJECTS = bootstrap/multiboot.o \
005 hwcore/idt.o hwcore/gdt.o 023 hwcore/idt.o hwcore/gdt.o \
006 hwcore/exception.o hwcore/exception_ 024 hwcore/exception.o hwcore/exception_wrappers.o \
007 hwcore/irq.o hwcore/irq_wrappers.o h 025 hwcore/irq.o hwcore/irq_wrappers.o hwcore/i8259.o \
008 hwcore/paging.o 026 hwcore/paging.o \
009 hwcore/i8254.o drivers/x86_videomem. 027 hwcore/i8254.o drivers/x86_videomem.o drivers/bochs.o \
>> 028 hwcore/cpu_context.o hwcore/cpu_context_switch.o \
010 sos/kmem_vmm.o sos/kmem_slab.o sos/k 029 sos/kmem_vmm.o sos/kmem_slab.o sos/kmalloc.o \
011 sos/physmem.o sos/klibc.o sos/main.o !! 030 sos/physmem.o sos/klibc.o \
>> 031 sos/thread.o sos/kwaitq.o \
>> 032 sos/time.o sos/sched.o sos/ksynch.o \
>> 033 sos/assert.o sos/main.o sos/mouse_sim.o
012 034
013 KERNEL_OBJ = sos.elf 035 KERNEL_OBJ = sos.elf
014 MULTIBOOT_IMAGE = fd.img 036 MULTIBOOT_IMAGE = fd.img
015 PWD := $(shell pwd) 037 PWD := $(shell pwd)
016 038
017 039
018 all: $(MULTIBOOT_IMAGE) 040 all: $(MULTIBOOT_IMAGE)
019 041
020 $(MULTIBOOT_IMAGE): $(KERNEL_OBJ) 042 $(MULTIBOOT_IMAGE): $(KERNEL_OBJ)
021 ./support/build_image.sh $@ $< 043 ./support/build_image.sh $@ $<
022 044
023 $(KERNEL_OBJ): $(OBJECTS) ./support/sos.lds 045 $(KERNEL_OBJ): $(OBJECTS) ./support/sos.lds
024 $(LD) $(LDFLAGS) -T ./support/sos.lds 046 $(LD) $(LDFLAGS) -T ./support/sos.lds -o $@ $(OBJECTS)
025 -nm -C $@ | cut -d ' ' -f 1,3 > sos.ma 047 -nm -C $@ | cut -d ' ' -f 1,3 > sos.map
>> 048 size $@
026 049
027 -include .mkvars 050 -include .mkvars
028 051
029 # Create objects from C source code 052 # Create objects from C source code
030 %.o: %.c 053 %.o: %.c
031 $(CC) -I$(PWD) -c $< $(CFLAGS) -o $@ 054 $(CC) -I$(PWD) -c $< $(CFLAGS) -o $@
032 055
033 056
034 %.o: %.S 057 %.o: %.S
035 $(CC) -I$(PWD) -c $< $(CFLAGS) -DASM_S 058 $(CC) -I$(PWD) -c $< $(CFLAGS) -DASM_SOURCE=1 -o $@
>> 059
>> 060 FORCE:
>> 061 @
036 062
037 063
038 clean: 064 clean:
039 $(RM) *.img *.o mtoolsrc *~ menu.txt * 065 $(RM) *.img *.o mtoolsrc *~ menu.txt *.img *.elf *.bin *.map
040 $(RM) *.log *.out bochs* 066 $(RM) *.log *.out bochs*
041 $(RM) bootstrap/*.o bootstrap/*~ 067 $(RM) bootstrap/*.o bootstrap/*~
042 $(RM) drivers/*.o drivers/*~ 068 $(RM) drivers/*.o drivers/*~
043 $(RM) hwcore/*.o hwcore/*~ 069 $(RM) hwcore/*.o hwcore/*~
044 $(RM) sos/*.o sos/*~ 070 $(RM) sos/*.o sos/*~
045 $(RM) support/*~ 071 $(RM) support/*~
046 $(RM) extra/*~ 072 $(RM) extra/*~