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

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

?? fat.c

?? linux dosfs 工具,可以移植到嵌入式系統下檢查存儲狀態下的磁盤狀況,修復文件系統
?? C
字號:
/* fat.c  -  Read/write access to the FAT *//* Written 1993 by Werner Almesberger *//* FAT32, VFAT, Atari format support, and various fixes additions May 1998 * by Roman Hodek <Roman.Hodek@informatik.uni-erlangen.de> */#include <stdio.h>#include <stdlib.h>#include <string.h>#include <unistd.h>#include "common.h"#include "dosfsck.h"#include "io.h"#include "check.h"#include "fat.h"static void get_fat(FAT_ENTRY *entry,void *fat,unsigned long cluster,DOS_FS *fs){    unsigned char *ptr;    switch(fs->fat_bits) {      case 12:	ptr = &((unsigned char *) fat)[cluster*3/2];	entry->value = 0xfff & (cluster & 1 ? (ptr[0] >> 4) | (ptr[1] << 4) :	  (ptr[0] | ptr[1] << 8));	break;      case 16:	entry->value = CF_LE_W(((unsigned short *) fat)[cluster]);	break;      case 32:	/* According to M$, the high 4 bits of a FAT32 entry are reserved and	 * are not part of the cluster number. So we cut them off. */	{	    unsigned long e = CF_LE_L(((unsigned int *) fat)[cluster]);	    entry->value = e & 0xfffffff;	    entry->reserved = e >> 28;	}	break;      default:	die("Bad FAT entry size: %d bits.",fs->fat_bits);    }    entry->owner = NULL;}void read_fat(DOS_FS *fs){    int eff_size;    unsigned long i;    void *first,*second,*use;    int first_ok,second_ok;    eff_size = ((fs->clusters+2)*fs->fat_bits+7)/8;    first = alloc(eff_size);    fs_read(fs->fat_start,eff_size,first);    use = first;    if (fs->nfats > 1) {	second = alloc(eff_size);	fs_read(fs->fat_start+fs->fat_size,eff_size,second);    }    else	second = NULL;    if (second && memcmp(first,second,eff_size) != 0) {	FAT_ENTRY first_media, second_media;	get_fat(&first_media,first,0,fs);	get_fat(&second_media,second,0,fs);	first_ok = (first_media.value & FAT_EXTD(fs)) == FAT_EXTD(fs);	second_ok = (second_media.value & FAT_EXTD(fs)) == FAT_EXTD(fs);	if (first_ok && !second_ok) {	    printf("FATs differ - using first FAT.\n");	    fs_write(fs->fat_start+fs->fat_size,eff_size,use = first);	}	if (!first_ok && second_ok) {	    printf("FATs differ - using second FAT.\n");	    fs_write(fs->fat_start,eff_size,use = second);	}	if (first_ok && second_ok) {	    if (interactive) {		printf("FATs differ but appear to be intact. Use which FAT ?\n"		  "1) Use first FAT\n2) Use second FAT\n");		if (get_key("12","?") == '1')		    fs_write(fs->fat_start+fs->fat_size,eff_size,use = first);		else fs_write(fs->fat_start,eff_size,use = second);	    }	    else {		printf("FATs differ but appear to be intact. Using first "		  "FAT.\n");		fs_write(fs->fat_start+fs->fat_size,eff_size,use = first);	    }	}	if (!first_ok && !second_ok) {	    printf("Both FATs appear to be corrupt. Giving up.\n");	    exit(1);	}    }    fs->fat = qalloc(&mem_queue,sizeof(FAT_ENTRY)*(fs->clusters+2));    for (i = 2; i < fs->clusters+2; i++) get_fat(&fs->fat[i],use,i,fs);    for (i = 2; i < fs->clusters+2; i++)	if (fs->fat[i].value >= fs->clusters+2 &&	    (fs->fat[i].value < FAT_MIN_BAD(fs))) {	    printf("Cluster %ld out of range (%ld > %ld). Setting to EOF.\n",		   i-2,fs->fat[i].value,fs->clusters+2-1);	    set_fat(fs,i,-1);	}    free(first);    if (second)	free(second);}void set_fat(DOS_FS *fs,unsigned long cluster,unsigned long new){    unsigned char data[4];    int size;    loff_t offs;    if ((long)new == -1)	new = FAT_EOF(fs);    else if ((long)new == -2)	new = FAT_BAD(fs);    switch( fs->fat_bits ) {      case 12:	offs = fs->fat_start+cluster*3/2;	if (cluster & 1) {	    data[0] = ((new & 0xf) << 4) | (fs->fat[cluster-1].value >> 8);	    data[1] = new >> 4;	}	else {	    data[0] = new & 0xff;	    data[1] = (new >> 8) | (cluster == fs->clusters-1 ? 0 :	      (0xff & fs->fat[cluster+1].value) << 4);	}	size = 2;	break;      case 16:	offs = fs->fat_start+cluster*2;	*(unsigned short *) data = CT_LE_W(new);	size = 2;	break;      case 32:	offs = fs->fat_start+cluster*4;	/* According to M$, the high 4 bits of a FAT32 entry are reserved and	 * are not part of the cluster number. So we never touch them. */	*(unsigned long *) data = CT_LE_L( (new & 0xfffffff) |					   (fs->fat[cluster].reserved << 28) );	size = 4;	break;      default:	die("Bad FAT entry size: %d bits.",fs->fat_bits);    }    fs->fat[cluster].value = new;    fs_write(offs,size,&data);    fs_write(offs+fs->fat_size,size,&data);}int bad_cluster(DOS_FS *fs,unsigned long cluster){    return FAT_IS_BAD(fs,fs->fat[cluster].value);}unsigned long next_cluster(DOS_FS *fs,unsigned long cluster){    unsigned long value;    value = fs->fat[cluster].value;    if (FAT_IS_BAD(fs,value))	die("Internal error: next_cluster on bad cluster");    return FAT_IS_EOF(fs,value) ? -1 : value;}loff_t cluster_start(DOS_FS *fs,unsigned long cluster){    return fs->data_start+((loff_t)cluster-2)*fs->cluster_size;}void set_owner(DOS_FS *fs,unsigned long cluster,DOS_FILE *owner){    if (owner && fs->fat[cluster].owner)	die("Internal error: attempt to change file owner");    fs->fat[cluster].owner = owner;}DOS_FILE *get_owner(DOS_FS *fs,unsigned long cluster){    return fs->fat[cluster].owner;}void fix_bad(DOS_FS *fs){    unsigned long i;    if (verbose)	printf("Checking for bad clusters.\n");    for (i = 2; i < fs->clusters+2; i++)	if (!get_owner(fs,i) && !FAT_IS_BAD(fs,fs->fat[i].value))	    if (!fs_test(cluster_start(fs,i),fs->cluster_size)) {		printf("Cluster %lu is unreadable.\n",i);		set_fat(fs,i,-2);	    }}void reclaim_free(DOS_FS *fs){    int reclaimed;    unsigned long i;    if (verbose)	printf("Checking for unused clusters.\n");    reclaimed = 0;    for (i = 2; i < fs->clusters+2; i++)	if (!get_owner(fs,i) && fs->fat[i].value &&	    !FAT_IS_BAD(fs,fs->fat[i].value)) {	    set_fat(fs,i,0);	    reclaimed++;	}    if (reclaimed)	printf("Reclaimed %d unused cluster%s (%d bytes).\n",reclaimed,	  reclaimed == 1 ?  "" : "s",reclaimed*fs->cluster_size);}static void tag_free(DOS_FS *fs,DOS_FILE *ptr){    DOS_FILE *owner;    int prev;    unsigned long i,walk;    for (i = 2; i < fs->clusters+2; i++)	if (fs->fat[i].value && !FAT_IS_BAD(fs,fs->fat[i].value) &&	    !get_owner(fs,i) && !fs->fat[i].prev) {	    prev = 0;	    for (walk = i; walk > 0 && walk != -1;		 walk = next_cluster(fs,walk)) {		if (!(owner = get_owner(fs,walk))) set_owner(fs,walk,ptr);		else if (owner != ptr)		        die("Internal error: free chain collides with file");		    else {			set_fat(fs,prev,-1);			break;		    }		prev = walk;	    }	}}void reclaim_file(DOS_FS *fs){    DOS_FILE dummy;    int reclaimed,files,changed;    unsigned long i,next,walk;    if (verbose)	printf("Reclaiming unconnected clusters.\n");    for (i = 2; i < fs->clusters+2; i++) fs->fat[i].prev = 0;    for (i = 2; i < fs->clusters+2; i++) {	next = fs->fat[i].value;	if (!get_owner(fs,i) && next && next < fs->clusters+2) {	    if (get_owner(fs,next) || !fs->fat[next].value ||		FAT_IS_BAD(fs,fs->fat[next].value)) set_fat(fs,i,-1);	    else fs->fat[next].prev++;	}    }    do {	tag_free(fs,&dummy);	changed = 0;	for (i = 2; i < fs->clusters+2; i++)	    if (fs->fat[i].value && !FAT_IS_BAD(fs,fs->fat[i].value) &&		!get_owner(fs, i)) {		if (!fs->fat[fs->fat[i].value].prev--)		    die("Internal error: prev going below zero");		set_fat(fs,i,-1);		changed = 1;		printf("Broke cycle at cluster %lu in free chain.\n",i);		break;	    }    }    while (changed);    files = reclaimed = 0;    for (i = 2; i < fs->clusters+2; i++)	if (get_owner(fs,i) == &dummy && !fs->fat[i].prev) {	    DIR_ENT de;	    loff_t offset;	    files++;	    offset = alloc_rootdir_entry(fs,&de,"FSCK%04dREC");	    de.start = CT_LE_W(i&0xffff);	    if (fs->fat_bits == 32)		de.starthi = CT_LE_W(i>>16);	    for (walk = i; walk > 0 && walk != -1;		 walk = next_cluster(fs,walk)) {		de.size = CT_LE_L(CF_LE_L(de.size)+fs->cluster_size);		reclaimed++;	    }	    fs_write(offset,sizeof(DIR_ENT),&de);	}    if (reclaimed)	printf("Reclaimed %d unused cluster%s (%d bytes) in %d chain%s.\n",	  reclaimed,reclaimed == 1 ? "" : "s",reclaimed*fs->cluster_size,files,	  files == 1 ? "" : "s");}unsigned long update_free(DOS_FS *fs){    unsigned long i;    unsigned long free = 0;    int do_set = 0;    for (i = 2; i < fs->clusters+2; i++)	if (!get_owner(fs,i) && !FAT_IS_BAD(fs,fs->fat[i].value))	    ++free;    if (!fs->fsinfo_start)	return free;    if (verbose)	printf("Checking free cluster summary.\n");    if (fs->free_clusters >= 0) {	if (free != fs->free_clusters) {	    printf( "Free cluster summary wrong (%ld vs. really %ld)\n",		    fs->free_clusters,free);	    if (interactive)		printf( "1) Correct\n2) Don't correct\n" );	    else printf( "  Auto-correcting.\n" );	    if (!interactive || get_key("12","?") == '1')		do_set = 1;	}    }    else {	printf( "Free cluster summary uninitialized (should be %ld)\n", free );	if (interactive)	    printf( "1) Set it\n2) Leave it uninitialized\n" );	else printf( "  Auto-setting.\n" );	if (!interactive || get_key("12","?") == '1')	    do_set = 1;    }    if (do_set) {	fs->free_clusters = free;	free = CT_LE_L(free);	fs_write(fs->fsinfo_start+offsetof(struct info_sector,free_clusters),		 sizeof(free),&free);    }    return free;}/* Local Variables: *//* tab-width: 8     *//* End:             */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品77777竹菊影视小说| 亚洲愉拍自拍另类高清精品| 51精品国自产在线| 欧美日韩精品是欧美日韩精品| 粉嫩aⅴ一区二区三区四区| 国产美女一区二区| 国产大陆精品国产| 97久久精品人人爽人人爽蜜臀| 久久久无码精品亚洲日韩按摩| 欧美三级资源在线| 一本色道久久综合亚洲91| 99re这里只有精品6| 在线免费观看日韩欧美| 欧美视频精品在线观看| 欧美一区二区三区免费| 久久亚洲捆绑美女| 国产欧美精品国产国产专区 | 欧美国产乱子伦| 欧美韩国日本不卡| 亚洲精品国产a| 日韩精品欧美成人高清一区二区| 捆绑紧缚一区二区三区视频 | 国产欧美一区二区三区鸳鸯浴 | 26uuu亚洲| 国产精品免费免费| 亚洲成av人影院在线观看网| 免费高清视频精品| caoporen国产精品视频| 欧美日韩一区 二区 三区 久久精品| 欧美一区二区三区喷汁尤物| 国产日韩精品一区二区三区在线| 亚洲免费观看视频| 久久国产剧场电影| 91视频免费播放| 欧美一区二区三区四区五区 | 精品1区2区在线观看| 国产精品第四页| 免费人成黄页网站在线一区二区| 国产成人免费xxxxxxxx| 欧美日本韩国一区| 欧美激情自拍偷拍| 日本视频在线一区| 97精品国产露脸对白| 精品国产成人在线影院 | 男女男精品网站| 色综合久久中文综合久久牛| 精品久久人人做人人爰| 亚洲综合视频在线| 不卡的av中国片| 欧美成人一区二区三区片免费| 亚洲人成亚洲人成在线观看图片| 久久99国产精品久久99| 欧美午夜寂寞影院| 中文一区二区完整视频在线观看| 麻豆国产一区二区| 精品视频1区2区3区| 亚洲私人影院在线观看| 国产精品1区2区3区| 欧美一级专区免费大片| 亚洲一区在线播放| www.欧美.com| 国产喂奶挤奶一区二区三区| 久久不见久久见免费视频1| 欧美日韩国产综合视频在线观看 | 精品在线播放午夜| 91麻豆精品国产91久久久资源速度 | 丝袜亚洲精品中文字幕一区| 91视频在线看| 中文字幕中文字幕在线一区 | 精品国一区二区三区| 视频一区中文字幕| 欧美日韩国产在线观看| 亚洲一区二区成人在线观看| 色吧成人激情小说| 亚洲精品一二三区| 在线观看亚洲一区| 一区二区三区四区激情| 在线观看视频91| 亚洲一区二区欧美日韩| 欧美日韩国产首页| 午夜av区久久| 制服丝袜亚洲播放| 久久不见久久见免费视频1| 精品国产一区二区三区久久久蜜月 | 午夜精品久久久久久久99水蜜桃| 在线观看av不卡| 亚洲不卡av一区二区三区| 欧美久久免费观看| 久久国产三级精品| 国产视频视频一区| 91免费看视频| 亚洲bt欧美bt精品777| 日韩一区二区免费高清| 国产一区二区三区| 国产三级精品视频| 91蜜桃免费观看视频| 亚洲狠狠爱一区二区三区| 51精品国自产在线| 国产成人啪免费观看软件| 亚洲欧洲另类国产综合| 欧美少妇bbb| 久久99精品视频| 国产精品无人区| 在线成人小视频| 国产高清不卡二三区| 亚洲精品久久久蜜桃| 日韩视频一区二区在线观看| 成人小视频在线| 天堂成人国产精品一区| 日本一区二区免费在线观看视频| 91免费观看国产| 久久爱www久久做| 亚洲精品国久久99热| 欧美tk丨vk视频| 在线看国产一区| 高潮精品一区videoshd| 五月天精品一区二区三区| 中文字幕精品一区| 91精品国产乱码久久蜜臀| heyzo一本久久综合| 捆绑调教一区二区三区| 亚洲午夜精品网| 国产精品网站一区| 欧美成人a视频| 欧美性猛片xxxx免费看久爱| 国产成人综合自拍| 麻豆成人久久精品二区三区红 | 国产精品一卡二| 亚洲丰满少妇videoshd| 国产精品久久精品日日| 精品久久久久一区二区国产| 欧美色成人综合| 色悠久久久久综合欧美99| 国产一区二区三区四区五区入口 | 欧美国产日本视频| 欧美tickling网站挠脚心| 欧美日韩国产成人在线免费| a4yy欧美一区二区三区| 国产jizzjizz一区二区| 国产在线精品不卡| 久久国产精品99精品国产| 日韩福利电影在线| 亚洲国产中文字幕在线视频综合| 最新日韩在线视频| 国产精品毛片高清在线完整版| 精品国产不卡一区二区三区| 日韩三级av在线播放| 91精品国产福利在线观看| 在线观看欧美日本| 欧洲一区二区三区在线| 99精品国产热久久91蜜凸| 不卡的av在线播放| 91毛片在线观看| 99精品一区二区三区| 91社区在线播放| 91亚洲男人天堂| 欧美在线一区二区| 欧美日韩三级视频| 欧美一区二区美女| 欧美草草影院在线视频| 26uuu国产日韩综合| 久久精品一区二区三区不卡牛牛| 久久久五月婷婷| 中文字幕一区二区三区在线播放| 中文一区一区三区高中清不卡| 国产精品国产馆在线真实露脸 | 日韩欧美一区二区久久婷婷| 日韩一区二区三区在线视频| 精品88久久久久88久久久| 国产色产综合色产在线视频| 国产精品乱码久久久久久| 亚洲日本在线a| 日韩成人午夜精品| 国产一区二区毛片| 97se狠狠狠综合亚洲狠狠| 欧美午夜片在线观看| 精品国产三级a在线观看| 中文字幕一区二区三区在线不卡 | 欧美性猛交xxxx乱大交退制版| 欧美日韩精品福利| www激情久久| 一区二区三区精品视频在线| 日本成人在线视频网站| 成人精品免费视频| 欧美久久久久中文字幕| 国产农村妇女毛片精品久久麻豆| 一区二区三区视频在线观看| 另类小说一区二区三区| 99热在这里有精品免费| 日韩一区二区电影网| 国产精品久久一级| 日本sm残虐另类| 色婷婷久久久亚洲一区二区三区| 欧美一区二区女人| 有码一区二区三区| 国产成人综合亚洲91猫咪| 欧美美女直播网站| 自拍偷拍国产精品| 国产乱子伦视频一区二区三区 | 久久不见久久见免费视频1|