⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 srcload.c

📁 这是一个同样来自贝尔实验室的和UNIX有着渊源的操作系统, 其简洁的设计和实现易于我们学习和理解
💻 C
字号:
#include "stdinc.h"#include <bio.h>#include "dat.h"#include "fns.h"#include "error.h"int num = 100;int length = 20*1024;int block= 1024;int bush = 4;int iter = 100;Biobuf *bout;int maxdepth;Source *mkroot(Cache*);void new(Source*, int trace, int);int delete(Source*);int count(Source *s, int);void stats(Source *s);void dump(Source *s, int ident, ulong entry);static void bench(Source *r);voidmain(int argc, char *argv[]){	int i;	Fs *fs;	int csize = 1000;	ulong t;	Source *r;	ARGBEGIN{	case 'i':		iter = atoi(ARGF());		break;	case 'n':		num = atoi(ARGF());		break;	case 'l':		length = atoi(ARGF());		break;	case 'b':			block = atoi(ARGF());		break;	case 'u':		bush = atoi(ARGF());		break;	case 'c':		csize = atoi(ARGF());		break;	}ARGEND;	vtAttach();	bout = vtMemAllocZ(sizeof(Biobuf));	Binit(bout, 1, OWRITE);	fmtinstall('V', vtScoreFmt);	fmtinstall('R', vtErrFmt);	fs = fsOpen(argv[0], nil, csize, OReadWrite);	if(fs == nil)		sysfatal("could not open fs: %r");	t = time(0);	srand(0);	r = fs->source;dump(r, 0, 0);	fprint(2, "count = %d\n", count(r, 1));	for(i=0; i<num; i++)		new(r, 0, 0);	for(i=0; i<iter; i++){if(i % 10000 == 0)stats(r);		new(r, 0, 0);		delete(r);	}//	dump(r, 0, 0);	fprint(2, "count = %d\n", count(r, 1));//	cacheCheck(c);fprint(2, "deleting\n");	for(i=0; i<num; i++)		delete(r);//	dump(r, 0, 0);	fprint(2, "count = %d\n", count(r, 1));	fprint(2, "total time = %ld\n", time(0)-t);		fsClose(fs);	vtDetach();	exits(0);}static voidbench(Source *r){	vlong t;	Entry e;	int i;	t = nsec();	for(i=0; i<1000000; i++)		sourceGetEntry(r, &e);	fprint(2, "%f\n", 1e-9*(nsec() - t));}voidnew(Source *s, int trace, int depth){	int i, n;	Source *ss;	Entry e;		if(depth > maxdepth)		maxdepth = depth;	Bflush(bout);	n = sourceGetDirSize(s);	for(i=0; i<n; i++){		ss = sourceOpen(s, nrand(n), OReadWrite);		if(ss == nil || !sourceGetEntry(ss, &e))			continue;		if((e.flags & VtEntryDir) && frand() < 1./bush){			if(trace){				int j;				for(j=0; j<trace; j++)					Bprint(bout, " ");				Bprint(bout, "decend %d\n", i);			}			new(ss, trace?trace+1:0, depth+1);			sourceClose(ss);			return;		}		sourceClose(ss);	}	ss = sourceCreate(s, s->dsize, 1+frand()>.5, 0);	if(ss == nil){		Bprint(bout, "could not create directory: %R\n");		return;	}	if(trace){		int j;		for(j=1; j<trace; j++)			Bprint(bout, " ");		Bprint(bout, "create %d\n", ss->offset);	}	sourceClose(ss);}intdelete(Source *s){	int i, n;	Source *ss;	n = sourceGetDirSize(s);	/* check if empty */	for(i=0; i<n; i++){		ss = sourceOpen(s, i, OReadWrite);		if(ss != nil){			sourceClose(ss);			break;		}	}	if(i == n)		return 0;			for(;;){		ss = sourceOpen(s, nrand(n), OReadWrite);		if(ss == nil)			continue;		if(s->dir && delete(ss)){			sourceClose(ss);			return 1;		}		if(1)			break;		sourceClose(ss);	}	sourceRemove(ss);	return 1;}voiddump(Source *s, int ident, ulong entry){	ulong i, n;	Source *ss;	Entry e;	for(i=0; i<ident; i++)		Bprint(bout, " ");	if(!sourceGetEntry(s, &e)){		fprint(2, "sourceGetEntry failed: %r\n");		return;	}	Bprint(bout, "%4lud: gen %4ud depth %d tag=%x score=%V", entry, e.gen, e.depth, e.tag, e.score);	if(!s->dir){		Bprint(bout, " data size: %llud\n", e.size);		return;	}	n = sourceGetDirSize(s);	Bprint(bout, " dir size: %lud\n", n);	for(i=0; i<n; i++){		ss = sourceOpen(s, i, 1);		if(ss == nil)			continue;		dump(ss, ident+1, i);		sourceClose(ss);	}	return;}intcount(Source *s, int rec){	ulong i, n;	int c;	Source *ss;	n = sourceGetDirSize(s);	c = 0;	for(i=0; i<n; i++){		ss = sourceOpen(s, i, OReadOnly);		if(ss == nil)			continue;		if(rec)			c += count(ss, rec);		c++;		sourceClose(ss);	}	return c;}voidstats(Source *s){	int n, i, c, cc, max;	Source *ss;	cc = 0;	max = 0;	n = sourceGetDirSize(s);	for(i=0; i<n; i++){		ss = sourceOpen(s, i, 1);		if(ss == nil)			continue;		cc++;		c = count(ss, 1);		if(c > max)			max = c;		sourceClose(ss);	}fprint(2, "count = %d top = %d depth=%d maxcount %d\n", cc, n, maxdepth, max);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -