clean up Makefile; add wc

This commit is contained in:
rsc 2007-08-28 04:20:40 +00:00
parent a1af366500
commit 76f09d7dd0
2 changed files with 108 additions and 77 deletions

131
Makefile
View file

@ -1,10 +1,15 @@
OBJS = \ OBJS = \
8253pit.o\
bio.o\
console.o\ console.o\
exec.o\
file.o\ file.o\
fs.o\
ide.o\ ide.o\
kalloc.o\
lapic.o\
ioapic.o\ ioapic.o\
kalloc.o\
kbd.o\
lapic.o\
main.o\ main.o\
mp.o\ mp.o\
picirq.o\ picirq.o\
@ -19,32 +24,27 @@ OBJS = \
trapasm.o\ trapasm.o\
trap.o\ trap.o\
vectors.o\ vectors.o\
bio.o\
fs.o\
exec.o\
8253pit.o\
kbd.o\
# Cross-compiling (e.g., on Mac OS X) # Cross-compiling (e.g., on Mac OS X)
#TOOLPREFIX = i386-jos-elf- TOOLPREFIX = i386-jos-elf-
# Using native tools (e.g., on X86 Linux) # Using native tools (e.g., on X86 Linux)
TOOLPREFIX = #TOOLPREFIX =
CC = $(TOOLPREFIX)gcc CC = $(TOOLPREFIX)gcc
AS = $(TOOLPREFIX)gas
LD = $(TOOLPREFIX)ld LD = $(TOOLPREFIX)ld
OBJCOPY = $(TOOLPREFIX)objcopy OBJCOPY = $(TOOLPREFIX)objcopy
OBJDUMP = $(TOOLPREFIX)objdump OBJDUMP = $(TOOLPREFIX)objdump
# On newer gcc you may need to add -fno-stack-protector to $(CFLAGS) CFLAGS = -fno-builtin -O2 -Wall -MD -ggdb
CFLAGS = -fno-builtin -O2 -Wall -MD -ggdb -fno-stack-protector CFLAGS += $(shell $(CC) -fno-stack-protector -E -x c /dev/null >/dev/null 2>&1 && echo -fno-stack-protector)
AS = $(TOOLPREFIX)gas
xv6.img : bootblock kernel fs.img xv6.img: bootblock kernel fs.img
dd if=/dev/zero of=xv6.img count=10000 dd if=/dev/zero of=xv6.img count=10000
dd if=bootblock of=xv6.img conv=notrunc dd if=bootblock of=xv6.img conv=notrunc
dd if=kernel of=xv6.img seek=1 conv=notrunc dd if=kernel of=xv6.img seek=1 conv=notrunc
bootblock : bootasm.S bootmain.c bootblock: bootasm.S bootmain.c
$(CC) -O -nostdinc -I. -c bootmain.c $(CC) -O -nostdinc -I. -c bootmain.c
$(CC) -nostdinc -I. -c bootasm.S $(CC) -nostdinc -I. -c bootasm.S
$(LD) -N -e start -Ttext 0x7C00 -o bootblock.o bootasm.o bootmain.o $(LD) -N -e start -Ttext 0x7C00 -o bootblock.o bootasm.o bootmain.o
@ -52,71 +52,35 @@ bootblock : bootasm.S bootmain.c
$(OBJCOPY) -S -O binary bootblock.o bootblock $(OBJCOPY) -S -O binary bootblock.o bootblock
./sign.pl bootblock ./sign.pl bootblock
kernel : $(OBJS) bootother.S initcode.S bootother: bootother.S
$(CC) -nostdinc -I. -c bootother.S $(CC) -nostdinc -I. -c $*.S
$(LD) -N -e start -Ttext 0x7000 -o bootother.out bootother.o $(LD) -N -e start -Ttext 0x7000 -o bootother.out bootother.o
$(OBJCOPY) -S -O binary bootother.out bootother $(OBJCOPY) -S -O binary bootother.out bootother
$(OBJDUMP) -S bootother.o > bootother.asm $(OBJDUMP) -S bootother.o > bootother.asm
$(CC) -nostdinc -I. -c initcode.S
initcode: initcode.S
$(CC) -nostdinc -I. -c $*.S
$(LD) -N -e start -Ttext 0 -o initcode.out initcode.o $(LD) -N -e start -Ttext 0 -o initcode.out initcode.o
$(OBJCOPY) -S -O binary initcode.out initcode $(OBJCOPY) -S -O binary initcode.out initcode
$(OBJDUMP) -S initcode.o > initcode.asm $(OBJDUMP) -S initcode.o > initcode.asm
kernel: $(OBJS) bootother initcode
$(LD) -Ttext 0x100000 -e main -o kernel $(OBJS) -b binary initcode bootother $(LD) -Ttext 0x100000 -e main -o kernel $(OBJS) -b binary initcode bootother
$(OBJDUMP) -S kernel > kernel.asm $(OBJDUMP) -S kernel > kernel.asm
$(OBJDUMP) -t kernel | awk '/SYMBOL TABLE/ { go=1; next } go {print $$1, $$NF}' >kernel.sym $(OBJDUMP) -t kernel | sed '1,/SYMBOL TABLE/d; s/ .* //' > kernel.sym
tags: $(OBJS) bootother.S _init tags: $(OBJS) bootother.S _init
etags *.S *.c etags *.S *.c
vectors.S : vectors.pl vectors.S: vectors.pl
perl vectors.pl > vectors.S perl vectors.pl > vectors.S
ULIB = ulib.o usys.o printf.o umalloc.o ULIB = ulib.o usys.o printf.o umalloc.o
_usertests : usertests.o $(ULIB) _%: %.o $(ULIB)
$(LD) -N -e main -Ttext 0 -o _usertests usertests.o $(ULIB) $(LD) -N -e main -Ttext 0 -o $@ $^
$(OBJDUMP) -S _usertests > usertests.asm $(OBJDUMP) -S $@ > $*.asm
$(OBJDUMP) -t $@ | sed '1,/SYMBOL TABLE/d; s/ .* //' > $*.sym
_echo : echo.o $(ULIB)
$(LD) -N -e main -Ttext 0 -o _echo echo.o $(ULIB)
$(OBJDUMP) -S _echo > echo.asm
_cat : cat.o $(ULIB)
$(LD) -N -e main -Ttext 0 -o _cat cat.o $(ULIB)
$(OBJDUMP) -S _cat > cat.asm
_init : init.o $(ULIB)
$(LD) -N -e main -Ttext 0 -o _init init.o $(ULIB)
$(OBJDUMP) -S _init > init.asm
$(OBJDUMP) -t _init | awk '/SYMBOL TABLE/ { go=1; next } go {print $$1, $$NF}' >init.sym
_kill : kill.o $(ULIB)
$(LD) -N -e main -Ttext 0 -o _kill kill.o $(ULIB)
$(OBJDUMP) -S _kill > kill.asm
_ls : ls.o $(ULIB)
$(LD) -N -e main -Ttext 0 -o _ls ls.o $(ULIB)
$(OBJDUMP) -S _ls > ls.asm
_mkdir : mkdir.o $(ULIB)
$(LD) -N -e main -Ttext 0 -o _mkdir mkdir.o $(ULIB)
$(OBJDUMP) -S _mkdir > mkdir.asm
_rm : rm.o $(ULIB)
$(LD) -N -e main -Ttext 0 -o _rm rm.o $(ULIB)
$(OBJDUMP) -S _rm > rm.asm
_ln : ln.o $(ULIB)
$(LD) -N -e main -Ttext 0 -o _ln ln.o $(ULIB)
$(OBJDUMP) -S _ln > ln.asm
_sh : sh.o $(ULIB)
$(LD) -N -e main -Ttext 0 -o _sh sh.o $(ULIB)
$(OBJDUMP) -S _sh > sh.asm
_zombie: zombie.o $(ULIB)
$(LD) -N -e main -Ttext 0 -o _zombie zombie.o $(ULIB)
$(OBJDUMP) -S _zombie > zombie.asm
_forktest: forktest.o $(ULIB) _forktest: forktest.o $(ULIB)
# forktest has less library code linked in - needs to be small # forktest has less library code linked in - needs to be small
@ -124,18 +88,31 @@ _forktest: forktest.o $(ULIB)
$(LD) -N -e main -Ttext 0 -o _forktest forktest.o ulib.o usys.o $(LD) -N -e main -Ttext 0 -o _forktest forktest.o ulib.o usys.o
$(OBJDUMP) -S _forktest > forktest.asm $(OBJDUMP) -S _forktest > forktest.asm
mkfs : mkfs.c fs.h mkfs: mkfs.c fs.h
cc -o mkfs mkfs.c gcc -Wall -o mkfs mkfs.c
UPROGS=_usertests _echo _cat _init _kill _ln _ls _mkdir _rm _sh _zombie _forktest UPROGS=\
fs.img : mkfs README $(UPROGS) _cat\
_forktest\
_init\
_kill\
_ln\
_ls\
_mkdir\
_rm\
_sh\
_usertests\
_wc\
_zombie\
fs.img: mkfs README $(UPROGS)
./mkfs fs.img README $(UPROGS) ./mkfs fs.img README $(UPROGS)
-include *.d -include *.d
clean : clean:
rm -f *.ps *.tex *.dvi *.idx *.aux *.log *.ind *.ilg \ rm -f *.ps *.tex *.dvi *.idx *.aux *.log *.ind *.ilg \
*.o *.d *.asm vectors.S parport.out \ *.o *.d *.asm *.sym vectors.S parport.out \
bootblock kernel xv6.img fs.img mkfs \ bootblock kernel xv6.img fs.img mkfs \
$(UPROGS) $(UPROGS)
@ -153,10 +130,10 @@ PRINT = \
console.c\ console.c\
string.c\ string.c\
xv6.pdf : $(PRINT) xv6.pdf: $(PRINT)
./runoff ./runoff
print : xv6.pdf print: xv6.pdf
# run in emulators # run in emulators
@ -164,7 +141,7 @@ bochs : fs.img xv6.img
if [ ! -e .bochsrc ]; then ln -s dot-bochsrc .bochsrc; fi if [ ! -e .bochsrc ]; then ln -s dot-bochsrc .bochsrc; fi
bochs -q bochs -q
qemu : fs.img xv6.img qemu: fs.img xv6.img
qemu -parallel stdio -hdb fs.img xv6.img qemu -parallel stdio -hdb fs.img xv6.img
# CUT HERE # CUT HERE
@ -172,7 +149,7 @@ qemu : fs.img xv6.img
# after running make dist, probably want to # after running make dist, probably want to
# rename it to rev0 or rev1 or so on and then # rename it to rev0 or rev1 or so on and then
# check in that version. # check in that version.
dist : dist:
rm -rf dist rm -rf dist
mkdir dist mkdir dist
for i in *.c *.h *.S; \ for i in *.c *.h *.S; \
@ -182,7 +159,7 @@ dist :
sed '/CUT HERE/,$$d' Makefile >dist/Makefile sed '/CUT HERE/,$$d' Makefile >dist/Makefile
cp README dot-bochsrc *.pl toc.* runoff runoff1 runoff.list dist cp README dot-bochsrc *.pl toc.* runoff runoff1 runoff.list dist
dist-test : dist-test:
rm -rf dist-test rm -rf dist-test
mkdir dist-test mkdir dist-test
cp dist/* dist-test cp dist/* dist-test
@ -190,11 +167,11 @@ dist-test :
cd dist-test; ../m bochs || true cd dist-test; ../m bochs || true
cd dist-test; ../m qemu cd dist-test; ../m qemu
# update this rule (change rev0) when it is time to # update this rule (change rev1) when it is time to
# make a new revision. # make a new revision.
tar : tar:
rm -rf /tmp/xv6 rm -rf /tmp/xv6
mkdir -p /tmp/xv6 mkdir -p /tmp/xv6
cp dist/* /tmp/xv6 cp dist/* /tmp/xv6
(cd /tmp; tar cf - xv6) | gzip >xv6-rev0.tar.gz (cd /tmp; tar cf - xv6) | gzip >xv6-rev1.tar.gz

54
wc.c Normal file
View file

@ -0,0 +1,54 @@
#include "types.h"
#include "stat.h"
#include "user.h"
char buf[512];
void
wc(int fd, char *name)
{
int i, n;
int l, w, c, inword;
l = w = c = 0;
inword = 0;
while((n = read(fd, buf, sizeof(buf))) > 0){
for(i=0; i<n; i++){
c++;
if(buf[i] == '\n')
l++;
if(strchr(" \r\t\n\v", buf[i]))
inword = 0;
else if(!inword){
w++;
inword = 1;
}
}
}
if(n < 0){
printf(1, "wc: read error\n");
exit();
}
printf(1, "%d %d %d %s\n", l, w, c, name);
}
int
main(int argc, char *argv[])
{
int fd, i;
if(argc <= 1) {
wc(0, "");
exit();
}
for(i = 1; i < argc; i++){
if((fd = open(argv[i], 0)) < 0){
printf(1, "cat: cannot open %s\n", argv[i]);
exit();
}
wc(fd, argv[i]);
close(fd);
}
exit();
}