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

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

?? iomgr.cpp

?? 小型的操作系統開發的原代碼
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
//
//The WriteFile's implementation.
//The routine does the following:
// 1. Create a DRCB object,and initialize it;
// 2. Commit the write transaction by calling DeviceWrite routine;
// 3. According to the result,set appropriate return value(s).
//

static BOOL WriteFile(__COMMON_OBJECT*  lpThis,
					  __COMMON_OBJECT*  lpFileObj,
					  DWORD             dwWriteSize,
					  LPVOID            lpBuffer,
					  DWORD*            lpWrittenSize)
{
	BOOL              bResult           = FALSE;
	__DRCB*           lpDrcb            = NULL;
	__DEVICE_OBJECT*  lpDevObject       = NULL;
	__DRIVER_OBJECT*  lpDrvObject       = NULL;
	DWORD             dwWriteBlockSize  = 0L;
	DWORD             dwTotalSize       = 0L;

	if((NULL == lpThis) ||
	  (NULL == lpFileObj) ||
	  (0 == dwWriteSize) ||
	  (NULL == lpBuffer))    //Parameters check.
	  return bResult;

	lpDevObject = (__DEVICE_OBJECT*)lpFileObj;
	lpDrvObject = lpDevObject->lpDriverObject;

	lpDrcb = (__DRCB*)ObjectManager.CreateObject(&ObjectManager,
		NULL,
		OBJECT_TYPE_DRCB);
	if(NULL == lpDrcb)  //Failed to create DRCB object.
		goto __TERMINAL;

	if(!lpDrcb->Initialize((__COMMON_OBJECT*)lpDrcb)) //Failed to initialize.
		goto __TERMINAL;

	//
	//The following code gets the write block size of this device object.
	//
	lpDrcb->dwRequestMode     = DRCB_REQUEST_MODE_IOCTRL;
	lpDrcb->dwCtrlCommand     = IOCONTROL_GET_WRITE_BLOCK_SIZE;
	lpDrcb->dwStatus          = DRCB_STATUS_INITIALIZED;
	lpDrcb->dwOutputLen       = sizeof(DWORD);
	lpDrcb->lpOutputBuffer    = (LPVOID)&dwWriteBlockSize;

	lpDrcb->WaitForCompletion = WaitForCompletion;
	lpDrcb->OnCancel          = OnCancel;
	lpDrcb->OnCompletion      = OnCompletion;

	lpDrvObject->DeviceCtrl((__COMMON_OBJECT*)lpDrvObject,
		(__COMMON_OBJECT*)lpDevObject,
		lpDrcb);    //Get the write block size.
	if(DRCB_STATUS_SUCCESS != lpDrcb->dwStatus)    //Failed to get the write block size.
		goto __TERMINAL;

	//
	//Now,the variable dwWriteBlockSize countains the write block size.
	//The following code,we commit the write transaction to device driver object
	//by calling DeviceWrite.
	//

	dwTotalSize           = dwWriteSize;
	lpDrcb->dwRequestMode = DRCB_REQUEST_MODE_WRITE;
	lpDrcb->dwStatus      = DRCB_STATUS_INITIALIZED;

	while(TRUE)
	{
		lpDrcb->dwInputLen     = 
			dwTotalSize > dwWriteBlockSize ? dwWriteBlockSize : dwTotalSize;
		lpDrcb->lpInputBuffer  = lpBuffer;
		lpDrvObject->DeviceWrite((__COMMON_OBJECT*)lpDrvObject,
			(__COMMON_OBJECT*)lpDevObject,
			lpDrcb);  //Commit the write transaction.

		if(DRCB_STATUS_SUCCESS != lpDrcb->dwStatus)  //Failed to write.
		{
			goto __TERMINAL;
		}
		if(dwTotalSize <= dwWriteBlockSize)    //This indicates the write transaction is
			                                   //over.
		{
			*lpWrittenSize = dwWriteSize;
			bResult = TRUE;
			goto __TERMINAL;
		}
		dwTotalSize -= dwWriteBlockSize;
		lpBuffer = (LPVOID)((DWORD)lpBuffer + dwWriteBlockSize);  //Adjust the buffer.
	}

__TERMINAL:
	if(lpDrcb != NULL)    //Destroy the DRCB object.
	{
		ObjectManager.DestroyObject(&ObjectManager,
			(__COMMON_OBJECT*)lpDrcb);
	}
	return bResult;
}

//
//The implementation of CloseFile.
//This routine does the following:
// 1. Check the validation of the parameters;
// 2. Check the device type of the target device object;
// 3. If the device to closed is a normal file,then destroy the object;
// 4. If the target deivce is not a normal file,then reduce the
//    reference counter,and return.
//

static VOID CloseFile(__COMMON_OBJECT*  lpThis,
					  __COMMON_OBJECT*  lpFileObj)
{
	__IO_MANAGER*              lpIoManager        = NULL;
	__DEVICE_OBJECT*           lpDevObject        = NULL;

	if((NULL == lpThis) || (NULL == lpFileObj)) //Parameter check.
		return;

	lpIoManager = (__IO_MANAGER*)lpThis;
	lpDevObject = (__DEVICE_OBJECT*)lpFileObj;

	/*if(lpDevObject->dwDevType != DEVICE_TYPE_FILE)  //Not a normal file.
	{
		//ENTER_CRITICAL_SECTION();
		//lpDevObject->dwRefCounter --;
		//LEAVE_CRITICAL_SECTION();
		return;
	}*/

	//
	//If control flow reaches here,it indicates that the device to be closed is
	//a normal file,then,we will destroy this file object by calling DestroyDevice
	//routine of IOManager object.
	//
	//lpIoManager->DestroyDevice(lpThis,lpFileObj);  //Destroy the file object.
}

//
//The implementation of IOControl.
//This routine does the following:
// 1. 
//

static BOOL IOControl(__COMMON_OBJECT* lpThis,
					  __COMMON_OBJECT* lpFileObj,
					  DWORD            dwCommand,
					  LPVOID           lpParameter,
					  DWORD            dwOutputBufLen,
					  LPVOID           lpOutputBuffer,
					  DWORD*           lpdwOutputFilled)
{
	BOOL              bResult          = FALSE;

	if((NULL == lpThis) ||
	   (NULL == lpFileObj))  //Parameters check.
	   return bResult;

	return bResult;
}

//
//The implementation of SetFilePointer.
//This routine does the following:
// 1. 
//

static BOOL SetFilePointer(__COMMON_OBJECT* lpThis,
						   __COMMON_OBJECT* lpFileObj,
						   DWORD            dwWhereBegin,
						   INT              nOffset)
{
	BOOL                   bResult          = FALSE;

	if((NULL == lpThis) || (NULL == lpFileObj)) //Parameters check.
		return bResult;

	return bResult;
}

//
//The implementation of FlushFile.
//This routine does the following:
// 1. 
//

static BOOL FlushFile(__COMMON_OBJECT*  lpThis,
					  __COMMON_OBJECT*  lpFileObj)
{
	BOOL              bResult           = FALSE;

	if((NULL == lpThis) || (NULL == lpFileObj))  //Parameters check.
		return bResult;

	return bResult;
}

//
//The implementation of CreateDevice,this routine is called by device
//driver(s) to create device object.Generally,this routine is called in
//DriverEntry of device driver(s).
//This routine does the following:
// 1. Creates a device object by calling ObjectManager's interface;
// 2. Initializes the device object;
// 3. Allocates a block of memory as device object's extension;
// 4. Inserts the device object into device object's list.
//

static __DEVICE_OBJECT* CreateDevice(__COMMON_OBJECT*  lpThis,
									 LPSTR             lpszDevName,
									 DWORD             dwAttribute,
									 DWORD             dwBlockSize,
									 DWORD             dwMaxReadSize,
									 DWORD             dwMaxWriteSize,
									 LPVOID            lpDevExtension,
									 __DRIVER_OBJECT*  lpDrvObject)
{
	__DEVICE_OBJECT*                 lpDevObject       = NULL;
	__IO_MANAGER*                    lpIoManager       = (__IO_MANAGER*)lpThis;
	DWORD                            dwFlags           = 0L;

	//Check the parameters.
	if((NULL == lpThis) || (NULL == lpszDevName) || (NULL == lpDrvObject))
	{
		BUG();
		return NULL;
	}

	if(StrLen(lpszDevName) > MAX_DEV_NAME_LEN)  //The device's name is too long.
	{
		return NULL;
	}
	
	lpDevObject    = (__DEVICE_OBJECT*)ObjectManager.CreateObject(
		&ObjectManager,
		NULL,
		OBJECT_TYPE_DEVICE);
	if(NULL == lpDevObject)      //Failed to create device object.
	{
		return NULL;
	}

	if(!lpDevObject->Initialize((__COMMON_OBJECT*)lpDevObject)) //Failed to initialize the object.
	{
		ObjectManager.DestroyObject(&ObjectManager,
			(__COMMON_OBJECT*)lpDevObject);
		return NULL;
	}

	//Initialize the device object's members.
	lpDevObject->lpDevExtension = lpDevExtension;
	lpDevObject->lpDriverObject = lpDrvObject;
	lpDevObject->dwAttribute    = dwAttribute;
	lpDevObject->dwBlockSize    = dwBlockSize;
	lpDevObject->dwMaxWriteSize = dwMaxWriteSize;
	lpDevObject->dwMaxReadSize  = dwMaxReadSize;

	StrCpy(lpszDevName,(LPSTR)&lpDevObject->DevName[0]);

	//
	//The following code add the device object into device object's list.
	//
	__ENTER_CRITICAL_SECTION(NULL,dwFlags);
	if(NULL == lpIoManager->lpDeviceRoot)  //This is the first object.
	{
		lpIoManager->lpDeviceRoot = lpDevObject;
	}
	else    //This is not the first object.
	{
		lpDevObject->lpNext                  = lpIoManager->lpDeviceRoot;
		lpDevObject->lpPrev                  = NULL;
		lpIoManager->lpDeviceRoot->lpPrev = lpDevObject;
		lpIoManager->lpDeviceRoot         = lpDevObject;
	}
	__LEAVE_CRITICAL_SECTION(NULL,dwFlags);

	return lpDevObject;
}

//
//The implementation of DestroyDevice.
//

static VOID DestroyDevice(__COMMON_OBJECT* lpThis,
						  __DEVICE_OBJECT* lpDeviceObject)
{
	__IO_MANAGER*         lpIoManager    = (__IO_MANAGER*)lpThis;
	DWORD                 dwFlags        = 0L;

	if((NULL == lpThis) || (NULL == lpDeviceObject)) //Parameters check.
	{
		BUG();
		return;
	}

	//
	//The following code deletes the device object from system list.
	//
	__ENTER_CRITICAL_SECTION(NULL,dwFlags);
	if(NULL == lpDeviceObject->lpPrev)    //This is the first object.
	{
		if(NULL == lpDeviceObject->lpNext)  //This is the last object.
		{
			lpIoManager->lpDeviceRoot = NULL;
		}
		else    //This is not the last object.
		{
			lpDeviceObject->lpNext->lpPrev = NULL;
			lpIoManager->lpDeviceRoot      = lpDeviceObject->lpNext;
		}
	}
	else    //This is not the first object.
	{
		if(NULL == lpDeviceObject->lpNext)  //This is the last object.
		{
			lpDeviceObject->lpPrev->lpNext = NULL;
		}
		else    //This is not the last object.
		{
			lpDeviceObject->lpPrev->lpNext = lpDeviceObject->lpNext;
			lpDeviceObject->lpNext->lpPrev = lpDeviceObject->lpPrev;
		}
	}
	__LEAVE_CRITICAL_SECTION(NULL,dwFlags);

	//Destroy the device object.
	ObjectManager.DestroyObject(&ObjectManager,
		(__COMMON_OBJECT*)lpDeviceObject);

	return;
}

//
//The implementation of ReserveResource.
//This routine does the following:
// 1. 
//

static BOOL ReserveResource(__COMMON_OBJECT*    lpThis,
							__RESOURCE_DESCRIPTOR*
							                    lpResDesc)
{
	BOOL                    bResult             = FALSE;

	if((NULL == lpThis) || (NULL == lpResDesc)) //Parameters check.
		return bResult;

	return bResult;
}

//
//The implementation of LoadDriver.
//This routine is used by OS loader to load device drivers.
//
static BOOL LoadDriver(__DRIVER_ENTRY DrvEntry)
{
	__DRIVER_OBJECT*   lpDrvObject  = NULL;

	if(NULL == DrvEntry)  //Invalid parameter.
	{
		BUG();
		return FALSE;
	}

	lpDrvObject = (__DRIVER_OBJECT*)ObjectManager.CreateObject(
		&ObjectManager,
		NULL,
		OBJECT_TYPE_DRIVER);
	if(NULL == lpDrvObject)  //Can not create driver object.
	{
		return FALSE;
	}
	if(!lpDrvObject->Initialize((__COMMON_OBJECT*)lpDrvObject)) //Initialize failed.
	{
		return FALSE;
	}

	//Call the driver entry.
	if(DrvEntry(lpDrvObject))
	{
		return TRUE;
	}
	//Failed to call DrvEntry routine,so release the driver object.
	ObjectManager.DestroyObject(
		&ObjectManager,
		(__COMMON_OBJECT*)lpDrvObject);
	return FALSE;
}

/*************************************************************************
**************************************************************************
**************************************************************************
**************************************************************************
*************************************************************************/

//
//The following code defines one of the global objects in Hello China - IOManager.
//This object is a global object,and only one in the whole system life-cycle.
//

__IO_MANAGER IOManager = {
	NULL,                                   //lpDeviceRoot.
	NULL,                                   //lpDriverRoot.
	NULL,                                   //lpResDescriptor.
	IOManagerInitialize,                    //Initialize.
	CreateFile,                             //CreateFile.
	ReadFile,                               //ReadFile.
	WriteFile,                              //WriteFile.
	CloseFile,                              //CloseFile.
	IOControl,                              //IOControl.
	SetFilePointer,                         //SetFilePointer.
	FlushFile,                              //FileFlush.

	CreateDevice,                           //CreateDevice.
	DestroyDevice,                          //DestroyDevice.
	ReserveResource,                        //ReserveResource.
	LoadDriver
};

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一级特黄大欧美久久久| 亚洲一区二区欧美激情| 日韩亚洲电影在线| 欧美精品第一页| 欧美一区二区网站| 精品免费国产一区二区三区四区| 日韩免费视频线观看| 久久免费美女视频| 国产欧美日本一区视频| 中文字幕一区二区三区四区不卡| 中文字幕五月欧美| 亚洲无线码一区二区三区| 日本aⅴ亚洲精品中文乱码| 爽好久久久欧美精品| 久久精品国产亚洲高清剧情介绍 | 精品免费国产一区二区三区四区| 日韩久久免费av| 久久久99精品久久| 亚洲男人天堂av网| 性做久久久久久| 国内精品写真在线观看| 99久久婷婷国产| 欧美日韩国产另类一区| 精品粉嫩aⅴ一区二区三区四区| 久久精品亚洲精品国产欧美 | 5月丁香婷婷综合| 精品电影一区二区| 亚洲四区在线观看| 蜜桃久久久久久| 成人精品电影在线观看| 欧美一区中文字幕| 国产精品乱人伦中文| 日韩二区在线观看| 国产成人在线观看免费网站| 一本色道久久综合亚洲91| 在线播放欧美女士性生活| 国产三级精品三级在线专区| 亚洲高清久久久| 国产91在线观看丝袜| 91精品免费观看| 综合亚洲深深色噜噜狠狠网站| 日韩成人一级大片| 色婷婷亚洲综合| 国产女人aaa级久久久级| 性做久久久久久免费观看欧美| 成人免费视频国产在线观看| 91精品国产高清一区二区三区蜜臀| 国产精品国产自产拍高清av | 欧美xingq一区二区| 亚洲精品老司机| 国产寡妇亲子伦一区二区| 欧美日韩大陆在线| 一区二区三区高清在线| 懂色av中文一区二区三区 | 成人高清在线视频| 欧美xxxxxxxx| 美女任你摸久久| 欧美在线免费视屏| 亚洲欧美一区二区久久| 成人高清免费在线播放| 国产日产精品1区| 蓝色福利精品导航| 日韩视频永久免费| 蜜臀av性久久久久蜜臀aⅴ| 欧美精品一卡两卡| 日本aⅴ免费视频一区二区三区| 在线观看三级视频欧美| 一区二区三区蜜桃| 一本大道综合伊人精品热热| 国产精品福利av| 99热国产精品| 亚洲乱码国产乱码精品精可以看| 国产a久久麻豆| 国产欧美日韩另类视频免费观看 | 日本中文在线一区| 欧美女孩性生活视频| 亚洲成人精品一区二区| 欧美无乱码久久久免费午夜一区| 一区二区日韩av| 欧美午夜不卡在线观看免费| 亚洲sss视频在线视频| 欧美三电影在线| 视频一区在线播放| 精品国产123| 国产98色在线|日韩| 亚洲四区在线观看| 欧美三级电影一区| 日本欧美一区二区| 日韩欧美电影在线| 国产精品一线二线三线| 中文字幕不卡三区| 在线视频中文字幕一区二区| 亚洲福利视频三区| 日韩欧美成人一区二区| 成人一道本在线| 亚洲福利一区二区三区| 亚洲精品一区二区三区福利 | 色综合av在线| 免费高清视频精品| 国产精品伦一区二区三级视频| 91网站最新网址| 热久久国产精品| 国产欧美一区二区精品秋霞影院| 91影院在线免费观看| 免费成人你懂的| 亚洲欧洲日韩综合一区二区| 欧美亚洲一区二区在线观看| 久久99精品一区二区三区 | 日韩一区二区在线观看视频播放| 免费看日韩精品| 国产精品国产三级国产aⅴ原创| 欧美日韩国产中文| 国产成人在线看| 奇米亚洲午夜久久精品| 中文字幕日韩一区| 日韩精品一区二区三区三区免费| 99久久精品久久久久久清纯| 日本女人一区二区三区| 亚洲欧美日韩一区二区| 精品国产露脸精彩对白| 欧美日韩在线播放三区| 丁香天五香天堂综合| 亚洲v精品v日韩v欧美v专区| 久久精品视频网| 91精品国产色综合久久不卡蜜臀| 99久久精品情趣| 久久99国产精品免费| 亚洲福利一二三区| 亚洲欧美日韩国产成人精品影院 | 亚洲人成在线观看一区二区| 制服.丝袜.亚洲.中文.综合| av一区二区久久| 国产不卡视频在线播放| 日本美女一区二区| 亚洲午夜三级在线| 综合av第一页| 国产精品久久久久久久裸模| 欧美精品一区二区三区在线播放| 欧美日韩午夜在线| 欧美中文字幕不卡| 色综合天天在线| 99久久精品情趣| 成人黄色免费短视频| 国产成人精品免费网站| 国产专区综合网| 国产在线乱码一区二区三区| 久久99精品久久久久久久久久久久 | 亚洲美腿欧美偷拍| 亚洲欧洲三级电影| 亚洲色图欧美偷拍| 亚洲免费观看高清| 亚洲一级片在线观看| 一区二区三区久久| 午夜精品久久久久久久99樱桃| 亚洲综合男人的天堂| 午夜精品久久久久久久蜜桃app| 一区二区成人在线视频| 亚洲国产精品久久人人爱| 午夜成人免费电影| 精品一区二区三区在线播放| 国产一区二区三区四| 成人午夜又粗又硬又大| 一本久道久久综合中文字幕| 欧美日韩精品一区二区三区四区| 欧美高清视频不卡网| 精品国产乱码久久| 中文字幕制服丝袜成人av | 美女在线视频一区| 精品一区免费av| 成人免费高清在线| 在线观看免费视频综合| 欧美日韩亚洲丝袜制服| 日韩一级大片在线观看| 国产欧美精品一区二区三区四区 | 国产成人精品一区二区三区四区| 成人午夜大片免费观看| 欧美亚洲愉拍一区二区| 精品国产污污免费网站入口| 国产欧美精品国产国产专区| 亚洲一区在线观看视频| 蜜桃av噜噜一区二区三区小说| 国产一区二区三区| 91免费观看视频| 日韩一区二区三| 亚洲天堂a在线| 蜜臀av性久久久久蜜臀aⅴ| 99久久精品99国产精品 | 国产乱人伦精品一区二区在线观看 | 国产精品中文字幕欧美| 色综合久久久久综合体桃花网| 欧美日韩一区视频| 国产欧美一区二区在线| 亚洲电影在线播放| 成人视屏免费看| 欧美一区欧美二区| 亚洲美女视频在线| 国产精品538一区二区在线| 欧美色手机在线观看| 亚洲国产精品二十页| 美女任你摸久久|