clean up Makefile; add wc
This commit is contained in:
		
							parent
							
								
									a1af366500
								
							
						
					
					
						commit
						76f09d7dd0
					
				
					 2 changed files with 108 additions and 77 deletions
				
			
		
							
								
								
									
										131
									
								
								Makefile
									
										
									
									
									
								
							
							
						
						
									
										131
									
								
								Makefile
									
										
									
									
									
								
							| 
						 | 
					@ -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
									
								
							
							
						
						
									
										54
									
								
								wc.c
									
										
									
									
									
										Normal 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();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
		Loading…
	
	Add table
		
		Reference in a new issue