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

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

?? yaffsfs.c

?? 優龍2410linux2.6.8內核源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
	{		yaffsfs_SetError(-ENOTDIR);	}	else if(!obj)	{		yaffsfs_SetError(-ENOENT);	}	else if(!isDirectory && obj->variantType == YAFFS_OBJECT_TYPE_DIRECTORY)	{		yaffsfs_SetError(-EISDIR);	}	else if(isDirectory && obj->variantType != YAFFS_OBJECT_TYPE_DIRECTORY)	{		yaffsfs_SetError(-ENOTDIR);	}	else if(isDirectory && obj->variantType != YAFFS_OBJECT_TYPE_DIRECTORY)	{		yaffsfs_SetError(-ENOTDIR);	}	else	{		result = yaffs_Unlink(dir,name);				if(result == YAFFS_FAIL && isDirectory)		{			yaffsfs_SetError(-ENOTEMPTY);		}	}		yaffsfs_Unlock();		// todo error		return (result == YAFFS_FAIL) ? -1 : 0;}int yaffs_rmdir(const char *path) {	return yaffsfs_DoUnlink(path,1);}int yaffs_unlink(const char *path) {	return yaffsfs_DoUnlink(path,0);}int yaffs_rename(const char *oldPath, const char *newPath){	yaffs_Object *olddir = NULL;	yaffs_Object *newdir = NULL;	yaffs_Object *obj = NULL;	char *oldname;	char *newname;	int result= YAFFS_FAIL;	int renameAllowed = 1;		yaffsfs_Lock();		olddir = yaffsfs_FindDirectory(NULL,oldPath,&oldname,0);	newdir = yaffsfs_FindDirectory(NULL,newPath,&newname,0);	obj = yaffsfs_FindObject(NULL,oldPath,0);		if(!olddir || !newdir || !obj)	{		// bad file		yaffsfs_SetError(-EBADF);			renameAllowed = 0;		}	else if(olddir->myDev != newdir->myDev)	{		// oops must be on same device		// todo error		yaffsfs_SetError(-EXDEV);		renameAllowed = 0;		}	else if(obj && obj->variantType == YAFFS_OBJECT_TYPE_DIRECTORY)	{		// It is a directory, check that it is not being renamed to 		// being its own decendent.		// Do this by tracing from the new directory back to the root, checking for obj				yaffs_Object *xx = newdir;				while( renameAllowed && xx)		{			if(xx == obj)			{				renameAllowed = 0;			}			xx = xx->parent;		}		if(!renameAllowed) yaffsfs_SetError(-EACCESS);	}		if(renameAllowed)	{		result = yaffs_RenameObject(olddir,oldname,newdir,newname);	}		yaffsfs_Unlock();		return (result == YAFFS_FAIL) ? -1 : 0;	}static int yaffsfs_DoStat(yaffs_Object *obj,struct yaffs_stat *buf){	int retVal = -1;	if(obj)	{		obj = yaffs_GetEquivalentObject(obj);	}	if(obj && buf)	{    	buf->yst_dev = (int)obj->myDev->genericDevice;    	buf->yst_ino = obj->objectId;    	buf->yst_mode = obj->yst_mode & ~S_IFMT; // clear out file type bits			if(obj->variantType == YAFFS_OBJECT_TYPE_DIRECTORY) 		{			buf->yst_mode |= S_IFDIR;		}		else if(obj->variantType == YAFFS_OBJECT_TYPE_SYMLINK) 		{			buf->yst_mode |= S_IFLNK;		}		else if(obj->variantType == YAFFS_OBJECT_TYPE_FILE)		{			buf->yst_mode |= S_IFREG;		}		    	buf->yst_nlink = yaffs_GetObjectLinkCount(obj);    	buf->yst_uid = 0;        	buf->yst_gid = 0;;         	buf->yst_rdev = obj->yst_rdev;    	buf->yst_size = yaffs_GetObjectFileLength(obj);		buf->yst_blksize = YAFFS_BYTES_PER_CHUNK;    	buf->yst_blocks = (buf->yst_size + YAFFS_BYTES_PER_CHUNK -1)/YAFFS_BYTES_PER_CHUNK;    	buf->yst_atime = obj->yst_atime;     	buf->yst_ctime = obj->yst_ctime;     	buf->yst_mtime = obj->yst_mtime; 		retVal = 0;	}	return retVal;}static int yaffsfs_DoStatOrLStat(const char *path, struct yaffs_stat *buf,int doLStat){	yaffs_Object *obj;		int retVal = -1;		yaffsfs_Lock();	obj = yaffsfs_FindObject(NULL,path,0);		if(!doLStat && obj)	{		obj = yaffsfs_FollowLink(obj,0);	}		if(obj)	{		retVal = yaffsfs_DoStat(obj,buf);	}	else	{		// todo error not found		yaffsfs_SetError(-ENOENT);	}		yaffsfs_Unlock();		return retVal;	}int yaffs_stat(const char *path, struct yaffs_stat *buf){	return yaffsfs_DoStatOrLStat(path,buf,0);}int yaffs_lstat(const char *path, struct yaffs_stat *buf){	return yaffsfs_DoStatOrLStat(path,buf,1);}int yaffs_fstat(int fd, struct yaffs_stat *buf){	yaffs_Object *obj;		int retVal = -1;		yaffsfs_Lock();	obj = yaffsfs_GetHandleObject(fd);		if(obj)	{		retVal = yaffsfs_DoStat(obj,buf);	}	else	{		// bad handle		yaffsfs_SetError(-EBADF);			}		yaffsfs_Unlock();		return retVal;}static int yaffsfs_DoChMod(yaffs_Object *obj,mode_t mode){	int result;	if(obj)	{		obj = yaffs_GetEquivalentObject(obj);	}		if(obj)	{		obj->yst_mode = mode;		obj->dirty = 1;		result = yaffs_FlushFile(obj,0);	}		return result == YAFFS_OK ? 0 : -1;}int yaffs_chmod(const char *path, mode_t mode){	yaffs_Object *obj;		int retVal = -1;		yaffsfs_Lock();	obj = yaffsfs_FindObject(NULL,path,0);		if(obj)	{		retVal = yaffsfs_DoChMod(obj,mode);	}	else	{		// todo error not found		yaffsfs_SetError(-ENOENT);	}		yaffsfs_Unlock();		return retVal;	}int yaffs_fchmod(int fd, mode_t mode){	yaffs_Object *obj;		int retVal = -1;		yaffsfs_Lock();	obj = yaffsfs_GetHandleObject(fd);		if(obj)	{		retVal = yaffsfs_DoChMod(obj,mode);	}	else	{		// bad handle		yaffsfs_SetError(-EBADF);			}		yaffsfs_Unlock();		return retVal;}int yaffs_mkdir(const char *path, mode_t mode){	yaffs_Object *parent = NULL;	yaffs_Object *dir;	char *name;	int retVal= -1;		yaffsfs_Lock();	parent = yaffsfs_FindDirectory(NULL,path,&name,0);	dir = yaffs_MknodDirectory(parent,name,mode,0,0);	if(dir)	{		retVal = 0;	}	else	{		yaffsfs_SetError(-ENOSPC); // just assume no space for now		retVal = -1;	}		yaffsfs_Unlock();		return retVal;}int yaffs_mount(const char *path){	int retVal=-1;	int result=YAFFS_FAIL;	yaffs_Device *dev=NULL;	char *dummy;		yaffsfs_Lock();	dev = yaffsfs_FindDevice(path,&dummy);	if(dev)	{		if(!dev->isMounted)		{			result = yaffs_GutsInitialise(dev);			if(result == YAFFS_FAIL)			{				// todo error - mount failed				yaffsfs_SetError(-ENOMEM);			}			retVal = result ? 0 : -1;					}		else		{			//todo error - already mounted.			yaffsfs_SetError(-EBUSY);		}	}	else	{		// todo error - no device		yaffsfs_SetError(-ENODEV);	}	yaffsfs_Unlock();	return retVal;	}int yaffs_unmount(const char *path){	int retVal=-1;	yaffs_Device *dev=NULL;	char *dummy;		yaffsfs_Lock();	dev = yaffsfs_FindDevice(path,&dummy);	if(dev)	{		if(dev->isMounted)		{			int i;			int inUse;			for(i = inUse = 0; i < YAFFSFS_N_HANDLES && !inUse; i++)			{				if(yaffsfs_handle[i].inUse && yaffsfs_handle[i].obj->myDev == dev)				{					inUse = 1; // the device is in use, can't unmount				}			}						if(!inUse)			{				yaffs_Deinitialise(dev);									retVal = 0;			}			else			{				// todo error can't unmount as files are open				yaffsfs_SetError(-EBUSY);			}					}		else		{			//todo error - not mounted.			yaffsfs_SetError(-EINVAL);					}	}	else	{		// todo error - no device		yaffsfs_SetError(-ENODEV);	}		yaffsfs_Unlock();	return retVal;	}off_t yaffs_freespace(const char *path){	off_t retVal=-1;	yaffs_Device *dev=NULL;	char *dummy;		yaffsfs_Lock();	dev = yaffsfs_FindDevice(path,&dummy);	if(dev)	{		retVal = yaffs_GetNumberOfFreeChunks(dev);		retVal *= YAFFS_BYTES_PER_CHUNK;			}	else	{		yaffsfs_SetError(-EINVAL);	}		yaffsfs_Unlock();	return retVal;	}void yaffs_initialise(yaffsfs_DeviceConfiguration *cfgList){		yaffsfs_DeviceConfiguration *cfg;		yaffsfs_configurationList = cfgList;		yaffsfs_InitHandles();		cfg = yaffsfs_configurationList;		while(cfg && cfg->prefix && cfg->dev)	{		cfg->dev->isMounted = 0;		cfg++;	}		}//// Directory search stuff.yaffs_DIR *yaffs_opendir(const char *dirname){	yaffs_DIR *dir = NULL; 	yaffs_Object *obj = NULL;	yaffsfs_DirectorySearchContext *dsc = NULL;		yaffsfs_Lock();		obj = yaffsfs_FindObject(NULL,dirname,0);		if(obj && obj->variantType == YAFFS_OBJECT_TYPE_DIRECTORY)	{				dsc = YMALLOC(sizeof(yaffsfs_DirectorySearchContext));		dir = (yaffs_DIR *)dsc;		if(dsc)		{			dsc->magic = YAFFS_MAGIC;			dsc->list = NULL;			memset(dsc->name,0,NAME_MAX+1);			strncpy(dsc->name,dirname,NAME_MAX);		}		}		yaffsfs_Unlock();		return dir;}struct yaffs_dirent *yaffs_readdir(yaffs_DIR *dirp){	yaffsfs_DirectorySearchContext *dsc = (yaffsfs_DirectorySearchContext *)dirp;	struct yaffs_dirent *retVal = NULL;	struct list_head *i;		yaffs_Object *entry = NULL;	int offset;	yaffs_Object *obj = NULL;	struct yaffsfs_ObjectListEntry *list = NULL;	int inList = 0;			yaffsfs_Lock();		offset = -1;		if(dsc && dsc->magic == YAFFS_MAGIC)	{		yaffsfs_SetError(0);				obj = yaffsfs_FindObject(NULL,dsc->name,0);			if(obj && obj->variantType == YAFFS_OBJECT_TYPE_DIRECTORY)		{						list_for_each(i,&obj->variant.directoryVariant.children)			{							offset++;					entry = (i) ?  list_entry(i, yaffs_Object,siblings) : NULL;								if(entry)					{						list = dsc->list;						inList = 0;						while(list && !inList)						{							if(list->objectId == entry->objectId)							{								inList = 1;							}							list = list->next;						}												if(!inList) goto foundNew;					}							}						foundNew:						if(!inList && entry)			{				//This is the entry we're going to return;				struct yaffsfs_ObjectListEntry *le;								le = YMALLOC(sizeof(struct yaffsfs_ObjectListEntry));								if(le)				{					le->next =  dsc->list;					le->objectId = entry->objectId;					dsc->list = le;										dsc->de.d_ino = yaffs_GetEquivalentObject(entry)->objectId;					dsc->de.d_off = offset;					yaffs_GetObjectName(entry,dsc->de.d_name,NAME_MAX+1);					dsc->de.d_reclen = sizeof(struct yaffs_dirent);										retVal = &dsc->de;				}							}		}	}	else	{		yaffsfs_SetError(-EBADF);	}		yaffsfs_Unlock();		return retVal;	}void yaffsfs_ListClear(yaffsfs_DirectorySearchContext *dsc) {		struct yaffsfs_ObjectListEntry *le;		if(dsc && dsc->magic == YAFFS_MAGIC)	{		while(dsc->list)		{			le = dsc->list;			dsc->list = dsc->list->next;			YFREE(le);		}	}	}void yaffs_rewinddir(yaffs_DIR *dirp){	yaffsfs_DirectorySearchContext *dsc = (yaffsfs_DirectorySearchContext *)dirp;			yaffsfs_Lock();	yaffsfs_ListClear(dsc);	yaffsfs_Unlock();}int yaffs_closedir(yaffs_DIR *dirp){	yaffsfs_DirectorySearchContext *dsc = (yaffsfs_DirectorySearchContext *)dirp;			yaffsfs_Lock();	yaffsfs_ListClear(dsc);	dsc->magic = 0;	YFREE(dsc);	yaffsfs_Unlock();	return 0;}int yaffs_symlink(const char *oldpath, const char *newpath){	yaffs_Object *parent = NULL;	yaffs_Object *obj;	char *name;	int retVal= -1;	int mode = 0; // ignore for now		yaffsfs_Lock();	parent = yaffsfs_FindDirectory(NULL,newpath,&name,0);	obj = yaffs_MknodSymLink(parent,name,mode,0,0,oldpath);	if(obj)	{		retVal = 0;	}	else	{		yaffsfs_SetError(-ENOSPC); // just assume no space for now		retVal = -1;	}		yaffsfs_Unlock();		return retVal;	}int yaffs_readlink(const char *path, char *buf, int bufsiz){	yaffs_Object *obj = NULL;	int retVal;			yaffsfs_Lock();		obj = yaffsfs_FindObject(NULL,path,0);		if(!obj)	{		yaffsfs_SetError(-ENOENT);		retVal = -1;	}	else if(obj->variantType != YAFFS_OBJECT_TYPE_SYMLINK)	{		yaffsfs_SetError(-EINVAL);		retVal = -1;	}	else	{		char *alias = obj->variant.symLinkVariant.alias;		memset(buf,0,bufsiz);		strncpy(buf,alias,bufsiz - 1);		retVal = 0;	}	yaffsfs_Unlock();	return retVal;}int yaffs_link(const char *oldpath, const char *newpath); int yaffs_mknod(const char *pathname, mode_t mode, dev_t dev);int yaffs_DumpDevStruct(const char *path){	char *rest;		yaffs_Object *obj = yaffsfs_FindRoot(path,&rest);		if(obj)	{		yaffs_Device *dev = obj->myDev;				printf("\n"			   "nPageWrites.......... %d\n"			   "nPageReads........... %d\n"			   "nBlockErasures....... %d\n"			   "nGCCopies............ %d\n"			   "garbageCollections... %d\n"			   "passiveGarbageColl'ns %d\n"			   "\n",				dev->nPageWrites,				dev->nPageReads,				dev->nBlockErasures,				dev->nGCCopies,				dev->garbageCollections,				dev->passiveGarbageCollections		);	}	return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品一卡二卡三卡四卡无卡| 亚洲视频一区在线观看| 久久se这里有精品| 精品国产伦一区二区三区观看体验 | 亚洲国产日韩精品| 欧美午夜片在线观看| 亚洲gay无套男同| 欧美大片在线观看| 风间由美中文字幕在线看视频国产欧美| 国产欧美一区二区三区在线老狼 | 亚洲午夜精品在线| 7777精品久久久大香线蕉| 老司机一区二区| 久久久久久久综合日本| 色综合天天综合狠狠| 午夜视频一区在线观看| 久久亚洲综合av| 色婷婷亚洲综合| 日本视频免费一区| 国产午夜精品福利| 色爱区综合激月婷婷| 视频一区二区三区入口| 久久免费精品国产久精品久久久久 | av在线一区二区| 午夜精品免费在线观看| 亚洲精品在线一区二区| 99在线视频精品| 日韩精品五月天| 国产精品久久久久久一区二区三区| 色久优优欧美色久优优| 极品瑜伽女神91| 亚洲黄色免费电影| 久久久久久久综合日本| 欧美日韩精品一区视频| 成人黄动漫网站免费app| 日韩国产高清在线| 亚洲免费三区一区二区| 欧美大尺度电影在线| 色偷偷88欧美精品久久久| 久久国产精品99久久人人澡| 一区二区三区在线免费观看 | 欧美日韩精品欧美日韩精品一综合| 理论电影国产精品| 亚洲一区二区综合| 国产精品国产三级国产aⅴ中文| 日韩一区二区三区免费看 | 中文字幕在线不卡| 欧美变态tickling挠脚心| 在线观看区一区二| 97精品国产露脸对白| 国产在线不卡一区| 美女视频黄a大片欧美| 亚洲在线免费播放| 《视频一区视频二区| 欧美精品一区二| 91精品国产色综合久久久蜜香臀| 91亚洲精品久久久蜜桃| 成人a区在线观看| 国产一区二区精品在线观看| 欧美aⅴ一区二区三区视频| 亚洲午夜激情网站| 一区二区日韩电影| 亚洲男人天堂av网| 亚洲色图制服丝袜| 日韩一区在线免费观看| 国产精品久久久久久福利一牛影视 | 一区二区三区在线观看欧美| 日本一区二区免费在线| 国产午夜精品一区二区| 久久综合色鬼综合色| 日韩无一区二区| 欧美一区二区三区在线| 91麻豆精品国产自产在线观看一区 | 午夜精品免费在线观看| 亚洲高清在线精品| 天天免费综合色| 日韩—二三区免费观看av| 日韩在线一区二区三区| 亚洲午夜精品一区二区三区他趣| 一区二区高清视频在线观看| 亚洲线精品一区二区三区八戒| 一级精品视频在线观看宜春院| 亚洲免费观看高清完整版在线观看熊| 国产精品护士白丝一区av| 中文字幕中文字幕中文字幕亚洲无线| 国产精品对白交换视频| 亚洲卡通动漫在线| 午夜精品免费在线观看| 日本不卡高清视频| 国内外成人在线| 风间由美一区二区av101| 成人看片黄a免费看在线| 91日韩在线专区| 91色乱码一区二区三区| 精品污污网站免费看| 日韩区在线观看| 国产精品素人视频| 亚洲与欧洲av电影| 美女视频免费一区| 高清视频一区二区| 欧美亚洲国产一区二区三区va| 5858s免费视频成人| 久久精品视频在线看| 亚洲三级视频在线观看| 五月激情综合婷婷| 国产在线观看一区二区| 色婷婷精品久久二区二区蜜臂av| 在线播放欧美女士性生活| 久久久精品日韩欧美| 一区二区久久久| 国产一区二区美女| 欧美日韩中文字幕精品| 国产亚洲自拍一区| 亚洲图片自拍偷拍| 国产精品白丝av| 欧美日韩一区视频| 国产精品精品国产色婷婷| 日韩精品色哟哟| 91亚洲永久精品| 精品国内片67194| 一区二区三区在线视频观看58 | 国产精品每日更新| 免费在线成人网| 91欧美一区二区| 久久这里只有精品首页| 亚洲国产精品人人做人人爽| 国产精品亚洲人在线观看| 欧美色视频在线| 国产精品萝li| 久久精品国产精品亚洲红杏| 色妞www精品视频| 久久免费精品国产久精品久久久久| 亚洲国产精品麻豆| 色综合色综合色综合 | 日韩午夜在线观看视频| 亚洲精品国产一区二区三区四区在线| 久久99精品一区二区三区三区| 91电影在线观看| 国产欧美日韩在线看| 毛片基地黄久久久久久天堂| 一本久道久久综合中文字幕| 久久嫩草精品久久久久| 蜜桃一区二区三区四区| 欧美在线免费播放| 国产精品成人一区二区艾草 | 99久免费精品视频在线观看| 精品日韩一区二区| 午夜精品久久久久久久久| 色狠狠综合天天综合综合| 国产亚洲va综合人人澡精品| 美女一区二区三区| 欧美高清视频不卡网| 一区二区三区国产豹纹内裤在线| 国产欧美久久久精品影院| 免费不卡在线视频| 欧美伦理视频网站| 亚洲图片自拍偷拍| 欧美日韩你懂得| 亚洲欧美另类久久久精品2019| 成人免费观看av| 国产精品伦一区| 成人免费高清视频在线观看| 国产婷婷色一区二区三区四区 | 欧美在线短视频| 亚洲一区二区精品3399| 91精品办公室少妇高潮对白| 亚洲摸摸操操av| 欧美午夜免费电影| 亚洲成av人片| 91精品婷婷国产综合久久竹菊| 亚洲成av人片在线| 这里只有精品免费| 久久99国产精品久久99| 亚洲精品一线二线三线无人区| 日韩精品成人一区二区在线| 91精品麻豆日日躁夜夜躁| 日韩一区欧美二区| 精品久久久久av影院| 国产伦精品一区二区三区免费| 久久综合久色欧美综合狠狠| 国产成人av一区二区三区在线观看| 国产精品你懂的在线| 99久久99久久精品免费观看 | 欧美一区二区三区色| 久久机这里只有精品| 亚洲精品一区二区三区蜜桃下载| 国产成人超碰人人澡人人澡| 一色屋精品亚洲香蕉网站| 色哟哟欧美精品| 热久久免费视频| 久久精品亚洲精品国产欧美kt∨| 99国产精品久久久| 亚洲a一区二区| 久久久久国产精品厨房| 色偷偷久久一区二区三区| 欧美aⅴ一区二区三区视频| 久久久91精品国产一区二区精品 | 色8久久精品久久久久久蜜| 亚洲成a人v欧美综合天堂| 欧美精品一区视频|