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

📄 ioman.c

📁 嵌入式文件系统 EFSL 0.3.5 / 嵌入式文件系统 EFSL 0.3.5
💻 C
📖 第 1 页 / 共 2 页
字号:
/*****************************************************************************\*                     EFSL - Embedded Filesystems Library                     **                     -----------------------------------                     **                                                                             ** Filename : ioman.c                                                          ** Release  : 0.3 - devel                                                      ** Description : The IO Manager receives all requests for sectors in a central **               allowing it to make smart decision regarding caching.         **               The IOMAN_NUMBUFFER parameter determines how many sectors     **               ioman can cache. ioman also supports overallocating and       **               backtracking sectors.                                         **                                                                             ** This program is free software; you can redistribute it and/or               ** modify it under the terms of the GNU General Public License                 ** as published by the Free Software Foundation; version 2                     ** of the License.                                                             **                                                                             ** This program is distributed in the hope that it will be useful,             ** but WITHOUT ANY WARRANTY; without even the implied warranty of              ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the               ** GNU General Public License for more details.                                **                                                                             ** As a special exception, if other files instantiate templates or             ** use macros or inline functions from this file, or you compile this          ** file and link it with other works to produce a work based on this file,     ** this file does not by itself cause the resulting work to be covered         ** by the GNU General Public License. However the source code for this         ** file must still be made available in accordance with section (3) of         ** the GNU General Public License.                                             **                                                                             ** This exception does not invalidate any other reasons why a work based       ** on this file might be covered by the GNU General Public License.            **                                                                             **                                                    (c)2006 Lennart Yseboodt **                                                    (c)2006 Michael De Nil   *\*****************************************************************************//*****************************************************************************/#include "ioman.h"/*****************************************************************************/esint8 ioman_init(IOManager *ioman, Interface *iface, euint8* bufferarea){	ioman->iface=iface;		ioman->bufptr = ioman_getBuffer(ioman,bufferarea);	ioman->numbuf = IOMAN_NUMBUFFER;	ioman->numit  = IOMAN_NUMITERATIONS;		ioman_reset(ioman);	return(0);}/*****************************************************************************/void ioman_reset(IOManager *ioman){	euint16 nb,ni;		memClr(ioman->sector,sizeof(euint32)*ioman->numbuf);	memClr(ioman->status,sizeof(euint8) *ioman->numbuf);	memClr(ioman->usage ,sizeof(euint8) *ioman->numbuf);	memClr(ioman->itptr ,sizeof(euint8) *ioman->numbuf);	ioman_setError(ioman,IOMAN_NOERROR);			for(nb=0;nb<ioman->numbuf;nb++){		for(ni=0;ni<ioman->numit;ni++){			ioman->stack[nb][ni].sector=0;			ioman->stack[nb][ni].status=0;			ioman->stack[nb][ni].usage =0;		}	}}/*****************************************************************************/euint8* ioman_getBuffer(IOManager *ioman,euint8* bufferarea){#ifdef IOMAN_DO_MEMALLOC	return(ioman->cache_mem);#else	return(bufferarea);#endif}/*****************************************************************************/void ioman_setAttr(IOManager *ioman,euint16 bufplace,euint8 attribute,euint8 val){	if(bufplace>=ioman->numbuf){		ioman_setError(ioman,IOMAN_ERR_SETATTROUTOFBOUNDS);		return; /* Out of bounds */	}		if(val){		ioman->status[bufplace]|=1<<attribute;	}else{		ioman->status[bufplace]&=~(1<<attribute);	}}/*****************************************************************************/euint8 ioman_getAttr(IOManager *ioman,euint16 bufplace,euint8 attribute){	if(bufplace>=ioman->numbuf){		ioman_setError(ioman,IOMAN_ERR_GETATTROUTOFBOUNDS);		return(0xFF); /* Out of bounds */	}	return(ioman->status[bufplace]&(1<<attribute));}/*****************************************************************************/euint8 ioman_getUseCnt(IOManager *ioman,euint16 bufplace){	if(bufplace>=ioman->numbuf){		ioman_setError(ioman,IOMAN_ERR_OPOUTOFBOUNDS);		return(0x00);	}	return(ioman->usage[bufplace]);}/*****************************************************************************/void ioman_incUseCnt(IOManager *ioman,euint16 bufplace){	if(bufplace>=ioman->numbuf){		ioman_setError(ioman,IOMAN_ERR_OPOUTOFBOUNDS);		return;	}	if(ioman->usage[bufplace]==0xFF)return;	else ioman->usage[bufplace]++;}/*****************************************************************************/void ioman_decUseCnt(IOManager *ioman,euint16 bufplace){	if(bufplace>=ioman->numbuf){		ioman_setError(ioman,IOMAN_ERR_OPOUTOFBOUNDS);		return;	}	if(ioman->usage[bufplace]==0x0)return;	else ioman->usage[bufplace]--;}/*****************************************************************************/void ioman_resetUseCnt(IOManager *ioman,euint16 bufplace){	if(bufplace>=ioman->numbuf){		ioman_setError(ioman,IOMAN_ERR_OPOUTOFBOUNDS);		return;	}	ioman->usage[bufplace]=0x00;}/*****************************************************************************/euint8 ioman_getRefCnt(IOManager *ioman,euint16 bufplace){	if(bufplace>=ioman->numbuf){		ioman_setError(ioman,IOMAN_ERR_OPOUTOFBOUNDS);		return(0x00);	}	return(ioman->reference[bufplace]);}/*****************************************************************************/void ioman_incRefCnt(IOManager *ioman,euint16 bufplace){	if(bufplace>=ioman->numbuf){		ioman_setError(ioman,IOMAN_ERR_OPOUTOFBOUNDS);		return;	}	if(ioman->reference[bufplace]==0xFF)return;	else ioman->reference[bufplace]++;}/*****************************************************************************/void ioman_decRefCnt(IOManager *ioman,euint16 bufplace){	if(bufplace>=ioman->numbuf){		ioman_setError(ioman,IOMAN_ERR_OPOUTOFBOUNDS);		return;	}	if(ioman->reference[bufplace]==0x00)return;	else ioman->reference[bufplace]--;}/*****************************************************************************/void ioman_resetRefCnt(IOManager *ioman,euint16 bufplace){	if(bufplace>=ioman->numbuf){		ioman_setError(ioman,IOMAN_ERR_OPOUTOFBOUNDS);		return;	}	ioman->reference[bufplace]=0x00;}/*****************************************************************************/esint8 ioman_pop(IOManager *ioman,euint16 bufplace){	if(bufplace>=ioman->numbuf){		ioman_setError(ioman,IOMAN_ERR_POPEMPTYSTACK);		return(-1);	}	if(ioman->itptr[bufplace]==0 || ioman->itptr[bufplace]>IOMAN_NUMITERATIONS)return(-1);	ioman->sector[bufplace] = ioman->stack[bufplace][ioman->itptr[bufplace]].sector;	ioman->status[bufplace] = ioman->stack[bufplace][ioman->itptr[bufplace]].status;	ioman->usage[bufplace]  = ioman->stack[bufplace][ioman->itptr[bufplace]].usage; 	ioman->itptr[bufplace]--;	return(0);}/*****************************************************************************/esint8 ioman_push(IOManager *ioman,euint16 bufplace){	if(bufplace>=ioman->numbuf){		ioman_setError(ioman,IOMAN_ERR_OPOUTOFBOUNDS);		return(-1);	}	if(ioman->itptr[bufplace]>=IOMAN_NUMITERATIONS){		ioman_setError(ioman,IOMAN_ERR_PUSHBEYONDSTACK);			return(-1);	}	ioman->itptr[bufplace]++;	ioman->stack[bufplace][ioman->itptr[bufplace]].sector = ioman->sector[bufplace];	ioman->stack[bufplace][ioman->itptr[bufplace]].status = ioman->status[bufplace];	ioman->stack[bufplace][ioman->itptr[bufplace]].usage  = ioman->usage[bufplace];	return(0);}/*****************************************************************************/euint8* ioman_getPtr(IOManager *ioman,euint16 bufplace){	if(bufplace>=ioman->numbuf){		ioman_setError(ioman,IOMAN_ERR_OPOUTOFBOUNDS);		return(0);	}	return(ioman->bufptr+bufplace*512);}/*****************************************************************************/esint16 ioman_getBp(IOManager *ioman,euint8* buf){	if(buf<(ioman->bufptr) || buf>=( ioman->bufptr+(ioman->numbuf*512) )){		ioman_setError(ioman,IOMAN_ERR_CACHEPTROUTOFRANGE);		return(-1);	}	return((buf-(ioman->bufptr))/512);}/*****************************************************************************/esint8 ioman_readSector(IOManager *ioman,euint32 address,euint8* buf){	esint8 r;	if(buf==0){		return(-1);	}		r=if_readBuf(ioman->iface,address,buf);		if(r!=0){		ioman_setError(ioman,IOMAN_ERR_READFAIL);		return(-1);	}	return(0);}/*****************************************************************************/esint8 ioman_writeSector(IOManager *ioman, euint32 address, euint8* buf){	esint8 r;	if(buf==0)return(-1);		r=if_writeBuf(ioman->iface,address,buf);	if(r<=0){		ioman_setError(ioman,IOMAN_ERR_WRITEFAIL);		return(-1);	}	return(0);}/*****************************************************************************/void ioman_resetCacheItem(IOManager *ioman,euint16 bufplace){	if(bufplace>=ioman->numbuf){		ioman_setError(ioman,IOMAN_ERR_OPOUTOFBOUNDS);		return;	}	ioman->sector[bufplace]    = 0;	ioman->status[bufplace]    = 0;	ioman->usage[bufplace]     = 0;	ioman->reference[bufplace] = 0;}/*****************************************************************************/esint32 ioman_findSectorInCache(IOManager *ioman, euint32 address){	euint16 c;

⌨️ 快捷键说明

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