亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? icheck.c

?? unix v7是最后一個廣泛發布的研究型UNIX版本
?? C
字號:
#define	NI	16#define	NB	10#define	BITS	8#define	MAXFN	500#ifndef STANDALONE#include <stdio.h>#endif#include <sys/param.h>#include <sys/inode.h>#include <sys/ino.h>#include <sys/fblk.h>#include <sys/filsys.h>struct	filsys	sblock;struct	dinode	itab[INOPB*NI];daddr_t	iaddr[NADDR];daddr_t	blist[NB];char	*bmap;int	sflg;int	mflg;int	dflg;int	fi;ino_t	ino;ino_t	nrfile;ino_t	ndfile;ino_t	nbfile;ino_t	ncfile;daddr_t	ndirect;daddr_t	nindir;daddr_t	niindir;daddr_t	niiindir;daddr_t	nfree;daddr_t	ndup;int	nerror;long	atol();daddr_t	alloc();#ifndef STANDALONEchar	*malloc();#endifmain(argc, argv)char *argv[];{	register i;	long n;	blist[0] = -1;#ifndef STANDALONE	while (--argc) {		argv++;		if (**argv=='-')		switch ((*argv)[1]) {		case 'd':			dflg++;			continue;		case 'm':			mflg++;			continue;		case 's':			sflg++;			continue;		case 'b':			for(i=0; i<NB; i++) {				n = atol(argv[1]);				if(n == 0)					break;				blist[i] = n;				argv++;				argc--;			}			blist[i] = -1;			continue;		default:			printf("Bad flag\n");		}		check(*argv);	}#else	{		static char fname[0];		printf("File: ");		gets(fname);		check(fname);	}#endif	return(nerror);}check(file)char *file;{	register i, j;	ino_t mino;	daddr_t d;	long n;	fi = open(file, sflg?2:0);	if (fi < 0) {		printf("cannot open %s\n", file);		nerror |= 04;		return;	}	printf("%s:\n", file);	nrfile = 0;	ndfile = 0;	ncfile = 0;	nbfile = 0;	ndirect = 0;	nindir = 0;	niindir = 0;	niiindir = 0;	ndup = 0;#ifndef STANDALONE	sync();#endif	bread((daddr_t)1, (char *)&sblock, sizeof(sblock));	mino = (sblock.s_isize-2) * INOPB;	ino = 0;	n = (sblock.s_fsize - sblock.s_isize + BITS-1) / BITS;	if (n != (unsigned)n) {		printf("Check fsize and isize: %ld, %u\n",		   sblock.s_fsize, sblock.s_isize);	}#ifdef STANDALONE	bmap = NULL;#else	bmap = malloc((unsigned)n);#endif	if (bmap==NULL) {		printf("Not enough core; duplicates unchecked\n");		dflg++;		sflg = 0;	}	if(!dflg)	for(i=0; i<(unsigned)n; i++)		bmap[i] = 0;	for(i=2;; i+=NI) {		if(ino >= mino)			break;		bread((daddr_t)i, (char *)itab, sizeof(itab));		for(j=0; j<INOPB*NI; j++) {			if(ino >= mino)				break;			ino++;			pass1(&itab[j]);		}	}	ino = 0;#ifndef STANDALONE	sync();#endif	bread((daddr_t)1, (char *)&sblock, sizeof(sblock));	if (sflg) {		makefree();		close(fi);#ifndef STANDALONE		if (bmap)			free(bmap);#endif		return;	}	nfree = 0;	while(n = alloc()) {		if (chk(n, "free"))			break;		nfree++;	}	close(fi);#ifndef STANDALONE	if (bmap)		free(bmap);#endif	i = nrfile + ndfile + ncfile + nbfile;#ifndef STANDALONE	printf("files %6u (r=%u,d=%u,b=%u,c=%u)\n",		i, nrfile, ndfile, nbfile, ncfile);#else	printf("files %u (r=%u,d=%u,b=%u,c=%u)\n",		i, nrfile, ndfile, nbfile, ncfile);#endif	n = ndirect + nindir + niindir + niindir;#ifdef STANDALONE	printf("used %ld (i=%ld,ii=%ld,iii=%ld,d=%ld)\n",		n, nindir, niindir, niiindir, ndirect);	printf("free %ld\n", nfree);#else	printf("used %7ld (i=%ld,ii=%ld,iii=%ld,d=%ld)\n",		n, nindir, niindir, niiindir, ndirect);	printf("free %7ld\n", nfree);#endif	if(!dflg) {		n = 0;		for(d=sblock.s_isize; d<sblock.s_fsize; d++)			if(!duped(d)) {				if(mflg)					printf("%ld missing\n", d);				n++;			}		printf("missing%5ld\n", n);	}}pass1(ip)register struct dinode *ip;{	daddr_t ind1[NINDIR];	daddr_t ind2[NINDIR];	daddr_t ind3[NINDIR];	register i, j;	int k, l;	i = ip->di_mode & IFMT;	if(i == 0) {		sblock.s_tinode++;		return;	}	if(i == IFCHR) {		ncfile++;		return;	}	if(i == IFBLK) {		nbfile++;		return;	}	if(i == IFDIR)		ndfile++; else	if(i == IFREG)		nrfile++;	else {		printf("bad mode %u\n", ino);		return;	}	l3tol(iaddr, ip->di_addr, NADDR);	for(i=0; i<NADDR; i++) {		if(iaddr[i] == 0)			continue;		if(i < NADDR-3) {			ndirect++;			chk(iaddr[i], "data (small)");			continue;		}		nindir++;		if (chk(iaddr[i], "1st indirect"))				continue;		bread(iaddr[i], (char *)ind1, BSIZE);		for(j=0; j<NINDIR; j++) {			if(ind1[j] == 0)				continue;			if(i == NADDR-3) {				ndirect++;				chk(ind1[j], "data (large)");				continue;			}			niindir++;			if(chk(ind1[j], "2nd indirect"))				continue;			bread(ind1[j], (char *)ind2, BSIZE);			for(k=0; k<NINDIR; k++) {				if(ind2[k] == 0)					continue;				if(i == NADDR-2) {					ndirect++;					chk(ind2[k], "data (huge)");					continue;				}				niiindir++;				if(chk(ind2[k], "3rd indirect"))					continue;				bread(ind2[k], (char *)ind3, BSIZE);				for(l=0; l<NINDIR; l++)					if(ind3[l]) {						ndirect++;						chk(ind3[l], "data (garg)");					}			}		}	}}chk(bno, s)daddr_t bno;char *s;{	register n;	if (bno<sblock.s_isize || bno>=sblock.s_fsize) {		printf("%ld bad; inode=%u, class=%s\n", bno, ino, s);		return(1);	}	if(duped(bno)) {		printf("%ld dup; inode=%u, class=%s\n", bno, ino, s);		ndup++;	}	for (n=0; blist[n] != -1; n++)		if (bno == blist[n])			printf("%ld arg; inode=%u, class=%s\n", bno, ino, s);	return(0);}duped(bno)daddr_t bno;{	daddr_t d;	register m, n;	if(dflg)		return(0);	d = bno - sblock.s_isize;	m = 1 << (d%BITS);	n = (d/BITS);	if(bmap[n] & m)		return(1);	bmap[n] |= m;	return(0);}daddr_talloc(){	int i;	daddr_t bno;	union {		char	data[BSIZE];		struct	fblk fb;	} buf;	sblock.s_tfree--;	if (sblock.s_nfree<=0)		return(0);	if (sblock.s_nfree>NICFREE) {		printf("Bad free list, s.b. count = %d\n", sblock.s_nfree);		return(0);	}	bno = sblock.s_free[--sblock.s_nfree];	sblock.s_free[sblock.s_nfree] = (daddr_t)0;	if(bno == 0)		return(bno);	if(sblock.s_nfree <= 0) {		bread(bno, buf.data, BSIZE);		sblock.s_nfree = buf.df_nfree;		if (sblock.s_nfree<0 || sblock.s_nfree>NICFREE) {			printf("Bad free list, entry count of block %ld = %d\n",				bno, sblock.s_nfree);			sblock.s_nfree = 0;			return(0);		}		for(i=0; i<NICFREE; i++)			sblock.s_free[i] = buf.df_free[i];	}	return(bno);}bfree(bno)daddr_t bno;{	union {		char	data[BSIZE];		struct	fblk fb;	} buf;	int i;	sblock.s_tfree++;	if(sblock.s_nfree >= NICFREE) {		for(i=0; i<BSIZE; i++)			buf.data[i] = 0;		buf.df_nfree = sblock.s_nfree;		for(i=0; i<NICFREE; i++)			buf.df_free[i] = sblock.s_free[i];		bwrite(bno, buf.data);		sblock.s_nfree = 0;	}	sblock.s_free[sblock.s_nfree] = bno;	sblock.s_nfree++;}bread(bno, buf, cnt)daddr_t bno;char *buf;{	register i;	lseek(fi, bno*BSIZE, 0);	if (read(fi, buf, cnt) != cnt) {		printf("read error %ld\n", bno);		if (sflg) {			printf("No update\n");			sflg = 0;		}		for(i=0; i<BSIZE; i++)			buf[i] = 0;	}}bwrite(bno, buf)daddr_t bno;char	*buf;{	lseek(fi, bno*BSIZE, 0);	if (write(fi, buf, BSIZE) != BSIZE)		printf("write error %ld\n", bno);}makefree(){	char flg[MAXFN];	int adr[MAXFN];	register i, j;	daddr_t f, d;	int m, n;	n = sblock.s_n;	if(n <= 0 || n > MAXFN)		n = MAXFN;	sblock.s_n = n;	m = sblock.s_m;	if(m <= 0 || m > sblock.s_n)		m = 3;	sblock.s_m = m;	for(i=0; i<n; i++)		flg[i] = 0;	i = 0;	for(j=0; j<n; j++) {		while(flg[i])			i = (i+1)%n;		adr[j] = i+1;		flg[i]++;		i = (i+m)%n;	}	sblock.s_nfree = 0;	sblock.s_ninode = 0;	sblock.s_flock = 0;	sblock.s_ilock = 0;	sblock.s_fmod = 0;	sblock.s_ronly = 0;#ifndef STANDALONE	time(&sblock.s_time);#endif	sblock.s_tfree = 0;	sblock.s_tinode = 0;	bfree((daddr_t)0);	d = sblock.s_fsize-1;	while(d%sblock.s_n)		d++;	for(; d > 0; d -= sblock.s_n)	for(i=0; i<sblock.s_n; i++) {		f = d - adr[i];		if(f < sblock.s_fsize && f >= sblock.s_isize)			if(!duped(f))				bfree(f);	}	bwrite((daddr_t)1, (char *)&sblock);#ifndef STANDALONE	sync();#endif	return;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲色图色小说| 欧美精品一区二区三区蜜桃视频 | 日韩专区中文字幕一区二区| 国产精品国产三级国产三级人妇| 久久久五月婷婷| 精品国产乱码久久久久久蜜臀 | 自拍偷拍亚洲欧美日韩| 国产精品成人网| 亚洲日本va在线观看| 亚洲天堂免费看| 亚洲欧美日韩中文播放| 亚洲宅男天堂在线观看无病毒| 一区二区三区资源| 亚欧色一区w666天堂| 蜜臀久久久久久久| 久久精品国产澳门| 国产成人午夜高潮毛片| 国产ts人妖一区二区| 99精品偷自拍| 欧美日韩久久不卡| 精品精品欲导航| 中文字幕一区二区5566日韩| 亚洲午夜久久久久久久久久久| 日本视频一区二区| 国产91色综合久久免费分享| 97久久超碰国产精品| 777色狠狠一区二区三区| 精品久久人人做人人爽| 综合久久久久综合| 日韩经典中文字幕一区| 国产乱人伦偷精品视频免下载| 91在线视频免费观看| 日韩免费在线观看| 国产偷v国产偷v亚洲高清| 洋洋成人永久网站入口| 狠狠狠色丁香婷婷综合久久五月| 成人涩涩免费视频| 91精品婷婷国产综合久久性色| 国产欧美日韩亚州综合| 亚洲成人免费电影| 懂色av噜噜一区二区三区av | 图片区小说区区亚洲影院| 国产美女av一区二区三区| 91成人免费在线视频| 精品国产露脸精彩对白| 亚洲电影一区二区三区| 国产成人精品免费| 日韩午夜中文字幕| 亚洲综合色噜噜狠狠| 东方欧美亚洲色图在线| 日韩欧美亚洲一区二区| 久久亚洲春色中文字幕久久久| 国产精品久久影院| 欧美精品久久99久久在免费线| 久久亚洲精精品中文字幕早川悠里| 亚洲精品美国一| 国产成人三级在线观看| 91精品国产91综合久久蜜臀| 中文字幕亚洲欧美在线不卡| 国产精品88av| 精品人在线二区三区| 香蕉影视欧美成人| 在线观看欧美精品| 亚洲人xxxx| av影院午夜一区| 欧美国产综合一区二区| 激情久久久久久久久久久久久久久久| 91精品国产综合久久精品麻豆 | 99久精品国产| 国产精品美女久久久久aⅴ| 精品亚洲免费视频| 欧美电影免费观看高清完整版在线 | 日韩美女在线视频| 日韩电影在线观看网站| 67194成人在线观看| 亚洲午夜私人影院| 欧美日韩视频不卡| 午夜不卡av在线| 在线播放一区二区三区| 午夜视频一区在线观看| 91精品国产综合久久精品图片| 免费成人av资源网| 日韩精品一区二区三区在线| 紧缚捆绑精品一区二区| 精品国产电影一区二区| 国产一区二区三区精品视频| 久久久无码精品亚洲日韩按摩| 国产精品一区二区久久不卡| 中文字幕不卡三区| 不卡的电视剧免费网站有什么| 欧美国产乱子伦| 91网站最新网址| 天天亚洲美女在线视频| 日韩免费视频一区| av一区二区三区在线| 五月天视频一区| 久久综合色8888| 91蜜桃网址入口| 午夜影视日本亚洲欧洲精品| 91精品国产入口| 国产精品2024| 亚洲一区二区偷拍精品| 精品国产亚洲一区二区三区在线观看| 久久99日本精品| 成人免费在线视频观看| 欧美一级片在线看| 成人一级片网址| 首页亚洲欧美制服丝腿| 国产亚洲一区二区三区四区| 91老师片黄在线观看| 免费在线观看视频一区| 国产精品蜜臀在线观看| 欧美精选在线播放| 风流少妇一区二区| 日韩av不卡一区二区| 国产清纯白嫩初高生在线观看91 | 中日韩av电影| 91精品国产综合久久蜜臀| 成人高清免费观看| 日韩专区中文字幕一区二区| 国产精品久久久99| 日韩女优制服丝袜电影| 欧美亚洲图片小说| 粉嫩久久99精品久久久久久夜| 亚洲图片一区二区| 欧美老年两性高潮| 麻豆视频一区二区| 日本不卡免费在线视频| 久久精品人人做| 欧美高清性hdvideosex| 91猫先生在线| 国产精品性做久久久久久| 美日韩一区二区| 亚洲一区二区免费视频| 中文字幕在线观看一区二区| 精品欧美乱码久久久久久| 欧美日韩一区二区三区四区五区| 成人av动漫网站| 国产suv精品一区二区6| 国产一区视频在线看| 日本一道高清亚洲日美韩| 亚洲一区二区三区四区在线观看 | 国产精品系列在线播放| 乱中年女人伦av一区二区| 亚洲自拍都市欧美小说| 中文字幕综合网| 中文欧美字幕免费| 亚洲国产精品成人久久综合一区| 欧美成人福利视频| 欧美成人精品1314www| 91精品麻豆日日躁夜夜躁| 欧美高清一级片在线| 在线电影国产精品| 日韩欧美区一区二| 日韩女优制服丝袜电影| 久久综合久久久久88| 日韩免费在线观看| 久久久久久久精| 99re视频精品| 亚洲欧美日韩国产一区二区三区| 视频在线观看91| 亚洲精品中文在线观看| 一区二区日韩av| 亚洲一区二区三区在线看| 亚洲一区二区三区四区在线免费观看| 亚洲色图在线看| 亚洲成人精品在线观看| 日韩成人精品视频| 久久99精品久久久久久动态图| 久久国产视频网| 成人一道本在线| 色欧美乱欧美15图片| 欧美日韩激情在线| 欧美tk—视频vk| 欧美激情综合五月色丁香小说| 最新高清无码专区| 亚洲高清免费在线| 久久国产精品99久久久久久老狼| 国产一区二区三区国产| 不卡的av中国片| 91精品国产一区二区三区| www国产亚洲精品久久麻豆| 中文欧美字幕免费| 亚洲va国产va欧美va观看| 久久99热这里只有精品| k8久久久一区二区三区| 91精品国产综合久久蜜臀| 国产精品丝袜91| 青青草视频一区| av在线播放不卡| 日韩精品一区二区三区中文精品| 欧美激情中文字幕| 日本不卡一区二区| 99久久精品免费看| 精品理论电影在线观看 | 欧美一区二区三区成人| 欧美激情在线免费观看| 婷婷开心久久网| 色狠狠色噜噜噜综合网| 欧美一区二区精品久久911|