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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? scsi-wnt.c

?? 刻錄光盤的程序
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/* @(#)scsi-wnt.c	1.17 99/09/17 Copyright 1998, 1999 J. Schilling, A.L. Faber */#ifndef lintstatic	char __sccsid[] =	"@(#)scsi-wnt.c	1.17 99/09/17 Copyright 1998, 1999 J. Schilling, A.L. Faber";#endif/* *	Interface for the Win32 ASPI library. *		You need wnaspi32.dll and aspi32.sys *		Both can be installed from ASPI_ME * *	Warning: you may change this source, but if you do that *	you need to change the _scg_version and _scg_auth* string below. *	You may not return "schily" for an SCG_AUTHOR request anymore. *	Choose your name instead of "schily" and make clear that the version *	string is related to a modified source. * *	Copyright (c) 1998 J. Schilling *	Copyright (c) 1999 A.L. Faber for the first implementation *			   of this interface. *	TODO: *	-	DMA resid handling *	-	better handling of maxDMA *	-	SCSI reset support *//* * 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; either version 2, or (at your option) * any later version. * * 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. * * You should have received a copy of the GNU General Public License * along with this program; see the file COPYING.  If not, write to * the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. *//* * Include for Win32 ASPI AspiRouter * * NOTE: aspi-win32.h includes Windows.h and Windows.h includes *	 Base.h which has a second typedef for BOOL. *	 We define BOOL to make all local code use BOOL *	 from Windows.h and use the hidden __SBOOL for *	 our global interfaces. */#define	BOOL	WBOOL		/* This is the Win BOOL		*/#define	format	__format#include <scg/aspi-win32.h>#undef format#ifdef	__CYGWIN32__		/* Use dlopen()			*/#include <dlfcn.h>#endif/* *	Warning: you may change this source, but if you do that *	you need to change the _scg_version and _scg_auth* string below. *	You may not return "schily" for an SCG_AUTHOR request anymore. *	Choose your name instead of "schily" and make clear that the version *	string is related to a modified source. */LOCAL	char	_scg_trans_version[] = "scsi-wnt.c-1.17";	/* The version for this transport*//* * Local defines and constants *//*#define DEBUG_WNTASPI*/#define	MAX_SCG		16	/* Max # of SCSI controllers	*/#define	MAX_TGT		16	/* Max # of SCSI Targets	*/#define	MAX_LUN		8	/* Max # of SCSI LUNs		*/#ifdef DEBUG_WNTASPI#endifstruct scg_local {	int	dummy;};#define scglocal(p)	((struct scg_local *)((p)->local)) /* * Local variables */LOCAL	int	busses;LOCAL	DWORD	(*pfnGetASPI32SupportInfo)(void)		= NULL;LOCAL	DWORD	(*pfnSendASPI32Command)(LPSRB)			= NULL;LOCAL	BOOL	(*pfnGetASPI32Buffer)(PASPI32BUFF)		= NULL;LOCAL	BOOL	(*pfnFreeASPI32Buffer)(PASPI32BUFF)		= NULL;LOCAL	BOOL	(*pfnTranslateASPI32Address)(PDWORD, PDWORD)	= NULL;LOCAL	BOOL	AspiLoaded			= FALSE;LOCAL	HANDLE	hAspiLib			= NULL;	/* Used for Loadlib */#define	MAX_DMA_WNT	(63L*1024L) /* ASPI-Driver  allows up to 64k ??? *//* * Local function prototypes */LOCAL	void	exit_func	__PR((void));#ifdef DEBUG_WNTASPILOCAL	void	DebugScsiSend	__PR((SRB_ExecSCSICmd s, int bDisplayBuffer));#endifLOCAL	void	copy_sensedata	__PR((SRB_ExecSCSICmd *cp, struct scg_cmd *sp));LOCAL	void	set_error	__PR((SRB_ExecSCSICmd *cp, struct scg_cmd *sp));LOCAL	BOOL	open_driver	__PR((SCSI *scgp));LOCAL	BOOL	close_driver	__PR((void));LOCAL	int	ha_inquiry	__PR((SCSI *scgp, int id, SRB_HAInquiry	*ip));LOCAL	int	resetSCSIBus	__PR((void));LOCAL	int	scsiabort	__PR((SCSI *scgp, SRB_ExecSCSICmd *sp));LOCAL voidexit_func(){	if (!close_driver())		errmsgno(EX_BAD, "Cannot close Win32-ASPI-Driver.\n");}/* * Return version information for the low level SCSI transport code. * This has been introduced to make it easier to trace down problems * in applications. */EXPORT char *scg__version(scgp, what)	SCSI	*scgp;	int	what;{	if (scgp != (SCSI *)0) {		switch (what) {		case SCG_VERSION:			return (_scg_trans_version);		/*		 * If you changed this source, you are not allowed to		 * return "schily" for the SCG_AUTHOR request.		 */		case SCG_AUTHOR:			return (_scg_auth_schily);		case SCG_SCCS_ID:			return (__sccsid);		}	}	return ((char *)0);}EXPORT intscsi_open(scgp, device, busno, tgt, tlun)	SCSI	*scgp;	char	*device;	int	busno;	int	tgt;	int	tlun;{	if (busno >= MAX_SCG || tgt >= MAX_TGT || tlun >= MAX_LUN) {		errno = EINVAL;		if (scgp->errstr)			js_snprintf(scgp->errstr, SCSI_ERRSTR_SIZE,				"Illegal value for busno, target or lun '%d,%d,%d'",				busno, tgt, tlun);		return (-1);	}	if ((device != NULL && *device != '\0') || (busno == -2 && tgt == -2)) {		errno = EINVAL;		if (scgp->errstr)			js_snprintf(scgp->errstr, SCSI_ERRSTR_SIZE,				"Open by 'devname' not supported on this OS");		return (-1);	}	/*	 *  Check if variables are within the range	 */	if (tgt >= 0 && tgt >= 0 && tlun >= 0) {		/*		 * This is the non -scanbus case.		 */		;	} else if (tgt != -1 || tgt != -1 || tlun != -1) {		errno = EINVAL;		return (-1);	}	if (scgp->local == NULL) {		scgp->local = malloc(sizeof(struct scg_local));		if (scgp->local == NULL)			return (0);	}	/*	 * Try to open ASPI-Router	 */	if (!open_driver(scgp))		return (-1);	/*	 * More than we have ...	 */	if (busno >= busses) {		close_driver();		return (-1);	}	/*	 * Install Exit Function which closes the ASPI-Router	 */	atexit(exit_func);			/*	 * Success after all	 */	return (1);}EXPORT intscsi_close(scgp)	SCSI	*scgp;{	exit_func();	return (0);}LOCAL longscsi_maxdma(scgp)	SCSI	*scgp;{	return (MAX_DMA_WNT);}EXPORT void *scsi_getbuf(scgp, amt)	SCSI	*scgp;	long	amt;{	if (amt <= 0 || amt > scsi_maxdma(scgp)) {		errmsgno(EX_BAD,			"scsi_getbuf: buffer out of range; requested size is %ld bytes\n", amt);		return ((void *)0);	}	if (scgp->debug)		printf("scsi_getbuf: %ld bytes\n", amt);	scgp->bufbase = malloc((size_t)(amt));	return (scgp->bufbase);}EXPORT voidscsi_freebuf(scgp)	SCSI	*scgp;{	if (scgp->bufbase)		free(scgp->bufbase);	scgp->bufbase = NULL;}EXPORT __SBOOLscsi_havebus(scgp, busno)	SCSI	*scgp;	int	busno;{	if (busno < 0 || busno >= busses)		return (FALSE);	return (TRUE);}EXPORT intscsi_fileno(scgp, busno, tgt, tlun)	SCSI	*scgp;	int	busno;	int	tgt;	int	tlun;{	if (busno < 0 || busno >= busses ||	    tgt < 0 || tgt >= MAX_TGT ||	    tlun < 0 || tlun >= MAX_LUN)		return (-1);	/*	 * Return fake	 */	return (1);}EXPORT intscsi_initiator_id(scgp)	SCSI	*scgp;{	SRB_HAInquiry	s;	if (ha_inquiry(scgp, scgp->scsibus, &s) < 0)		return (-1);	return (s.HA_SCSI_ID);}EXPORT intscsi_isatapi(scgp)	SCSI	*scgp;{	return (-1);	/* XXX Need to add real test */}/* * XXX scsireset not yet tested */EXPORT intscsireset(scgp)	SCSI	*scgp;{	DWORD			Status = 0;	DWORD			EventStatus = WAIT_OBJECT_0;	HANDLE			Event	 = NULL;	SRB_BusDeviceReset	s;	if (scgp->debug)		printf("Attempting to reset SCSI device\n");	/*	 * Check if ASPI library is loaded	 */	if (AspiLoaded == FALSE) {		printf("error in scsireset: ASPI driver not loaded !\n");		return (FALSE);	}	memset(&s, 0, sizeof(s));	/* Clear SRB_BesDeviceReset structure */	Event = CreateEvent(NULL, TRUE, FALSE, NULL);	/*	 * Set structure variables	 */	s.SRB_Cmd	= SC_RESET_DEV;			/* ASPI command code = SC_RESET_DEV	*/	s.SRB_HaId	= scgp->scsibus;		/* ASPI host adapter number		*/	s.SRB_Flags	= SRB_EVENT_NOTIFY;		/* Flags				*/	s.SRB_Target	= scgp->target;			/* Target's SCSI ID			*/	s.SRB_Lun	= scgp->lun;			/* Target's LUN number			*/	s.SRB_PostProc	= (LPVOID)Event;		/* Post routine				*/		/*	 * Initiate SCSI command	 */	Status = pfnSendASPI32Command((LPSRB)&s);	/*	 * Check status	 */	if (Status == SS_PENDING) {		/*		 * Wait till command completes		 */		EventStatus = WaitForSingleObject(Event, INFINITE);	}	/**************************************************/	/* Reset event to non-signaled state.             */	/**************************************************/	if (EventStatus == WAIT_OBJECT_0) {		/*		 * Clear event		 */		ResetEvent(Event);	}	/*	 * Close the event handle	 */	CloseHandle(Event);	/*	 * Check condition	 */	if (s.SRB_Status != SS_COMP) {		printf("ERROR! 0x%08X\n", s.SRB_Status);		/*		 * Indicate that error has occured		 */		return (FALSE);	}	if (scgp->debug)		printf("Reset SCSI device completed\n");	/*	 * Everything went OK	 */	return (TRUE);}#ifdef DEBUG_WNTASPILOCAL voidDebugScsiSend(s, bDisplayBuffer)	SRB_ExecSCSICmd	s;	int		bDisplayBuffer;{	int i;	printf("\n\nDebugScsiSend\n");	printf("s.SRB_Cmd          = 0x%02x\n", s.SRB_Cmd);	printf("s.SRB_HaId         = 0x%02x\n", s.SRB_HaId);	printf("s.SRB_Flags        = 0x%02x\n", s.SRB_Flags); 	printf("s.SRB_Target       = 0x%02x\n", s.SRB_Target); 	printf("s.SRB_Lun          = 0x%02x\n", s.SRB_Lun);	printf("s.SRB_BufLen       = 0x%02x\n", s.SRB_BufLen);	printf("s.SRB_BufPointer   = %x\n",     s.SRB_BufPointer);	printf("s.SRB_CDBLen       = 0x%02x\n", s.SRB_CDBLen);	printf("s.SRB_SenseLen     = 0x%02x\n", s.SRB_SenseLen);	printf("s.CDBByte          =");	for (i=0; i < min(s.SRB_CDBLen, 16); i++) {		printf(" %02X ", s.CDBByte[i]);	}	printf("\n");	/*	if (bDisplayBuffer != 0 && s.SRB_BufLen >= 8) {				printf("s.SRB_BufPointer   =");		for (i=0; i < 8; i++) {			printf(" %02X ", ((char*)s.SRB_BufPointer)[i]);		}		printf("\n");	}*/	printf("Debug done\n");}#endifLOCAL voidcopy_sensedata(cp, sp)	SRB_ExecSCSICmd	*cp;	struct scg_cmd	*sp;{	sp->sense_count	= cp->SRB_SenseLen;	if (sp->sense_count > sp->sense_len)		sp->sense_count = sp->sense_len;	memset(&sp->u_sense.Sense, 0x00, sizeof(sp->u_sense.Sense));	memcpy(&sp->u_sense.Sense, cp->SenseArea, sp->sense_len);	sp->u_scb.cmd_scb[0] = cp->SRB_TargStat;}/* * Set error flags */LOCAL voidset_error(cp, sp)	SRB_ExecSCSICmd	*cp;	struct scg_cmd	*sp;{	switch (cp->SRB_Status) {	case SS_COMP:			/* 0x01 SRB completed without error  */		sp->error = SCG_NO_ERROR;		sp->ux_errno = 0;		break;	case SS_PENDING:		/* 0x00 SRB being processed          */		/*		 * XXX Could SS_PENDING happen ???		 */	case SS_ABORTED:		/* 0x02 SRB aborted                  */	case SS_ABORT_FAIL:		/* 0x03 Unable to abort SRB          */	case SS_ERR:			/* 0x04 SRB completed with error     */	default:		sp->error = SCG_RETRYABLE;		sp->ux_errno = EIO;		break;	case SS_INVALID_CMD:		/* 0x80 Invalid ASPI command         */	case SS_INVALID_HA:		/* 0x81 Invalid host adapter number  */	case SS_NO_DEVICE:		/* 0x82 SCSI device not installed    */	case SS_INVALID_SRB:		/* 0xE0 Invalid parameter set in SRB */

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品99国产精品| 亚洲成人在线免费| 精品免费日韩av| 日韩一区二区免费在线观看| 欧美精品日日鲁夜夜添| 欧美午夜一区二区| 欧美男女性生活在线直播观看| 日本精品视频一区二区| 欧美亚洲一区二区在线| 欧美色涩在线第一页| 911精品国产一区二区在线| 欧美电影一区二区三区| 日韩欧美中文一区二区| 精品国产乱码久久久久久闺蜜| 久久中文字幕电影| 国产清纯白嫩初高生在线观看91| 中文文精品字幕一区二区| 18欧美乱大交hd1984| 一区二区三区四区五区视频在线观看| 一区二区三区高清在线| 日本va欧美va精品发布| 国产精品1024| 色一情一伦一子一伦一区| 欧美福利视频一区| 久久久久久免费网| 亚洲图片欧美激情| 日韩中文字幕av电影| 国产成人精品综合在线观看| 色婷婷狠狠综合| 欧美成人猛片aaaaaaa| 国产精品美女久久久久久久久| 亚洲制服丝袜一区| 国内精品自线一区二区三区视频| 成人h动漫精品| 欧美精品丝袜久久久中文字幕| 久久久天堂av| 亚洲bdsm女犯bdsm网站| 国产91精品在线观看| 欧日韩精品视频| 国产亚洲美州欧州综合国| 亚洲综合色在线| 国产91精品入口| 91精品国产综合久久精品麻豆 | 一区二区三区电影在线播| 青青草国产成人99久久| 91丨porny丨最新| 久久久久国产一区二区三区四区| 一区二区高清在线| 国产成人精品www牛牛影视| 欧美日韩大陆一区二区| 国产精品每日更新在线播放网址| 欧美aa在线视频| 在线欧美日韩国产| 国产精品日韩精品欧美在线| 精品一区二区三区在线播放视频| 欧美午夜精品久久久久久超碰 | 国产一区二区三区久久悠悠色av | 极品少妇xxxx偷拍精品少妇| 欧美三级日韩在线| 最新高清无码专区| 国产成人小视频| 久久婷婷综合激情| 蜜桃av噜噜一区| 欧美男男青年gay1069videost| 一区二区三区免费看视频| 成人动漫一区二区在线| 国产视频在线观看一区二区三区 | 精品福利av导航| 日本午夜一本久久久综合| 欧美性xxxxxxxx| 亚洲综合激情另类小说区| 91蜜桃传媒精品久久久一区二区| 国产精品国产三级国产三级人妇| 国产宾馆实践打屁股91| 久久久久亚洲蜜桃| 国产精品自在欧美一区| 久久精品人人做人人爽97| 国内精品久久久久影院薰衣草| 精品国产一区二区在线观看| 久草这里只有精品视频| 精品国产成人系列| 国产精品亚洲专一区二区三区 | 亚洲视频一区二区免费在线观看| 国产suv精品一区二区883| 久久精品欧美一区二区三区麻豆 | 亚洲v精品v日韩v欧美v专区| 欧美日韩三级一区| 日韩和欧美一区二区三区| 日韩欧美高清dvd碟片| 精油按摩中文字幕久久| 久久久久久久久岛国免费| 懂色一区二区三区免费观看 | 日韩视频国产视频| 久久97超碰色| 亚洲欧洲精品一区二区三区不卡| 色婷婷久久久综合中文字幕| 亚洲成av人综合在线观看| 日韩欧美一区二区视频| 国产成人免费网站| 亚洲综合自拍偷拍| 欧美xxxxx牲另类人与| 国产suv一区二区三区88区| 亚洲激情av在线| 精品99999| 欧美自拍偷拍午夜视频| 久久精品国产秦先生| 国产精品色婷婷久久58| 欧美日韩国产免费一区二区| 国产乱子伦一区二区三区国色天香| 国产精品久久久爽爽爽麻豆色哟哟| 欧美日韩国产经典色站一区二区三区| 久久不见久久见免费视频7| 国产精品无圣光一区二区| 宅男噜噜噜66一区二区66| 国产成人精品免费视频网站| 日韩精品一级二级 | 免费av成人在线| 中文字幕一区二区三区精华液 | 亚洲成人在线免费| 日本一区二区三区dvd视频在线| 欧美怡红院视频| 成人高清免费在线播放| 视频在线观看一区二区三区| 中文字幕一区二区日韩精品绯色| 日韩视频免费直播| 欧美三级视频在线播放| 成人av在线影院| 麻豆91在线看| 午夜精品久久久久久久久| 中文字幕视频一区| 久久久久亚洲综合| 欧美大胆人体bbbb| 欧美精品乱码久久久久久| 91老师国产黑色丝袜在线| 国产福利一区二区三区视频| 理论片日本一区| 日韩极品在线观看| 亚洲成人1区2区| 国产成人在线观看免费网站| 欧美三级电影在线看| 91在线国产福利| 99re亚洲国产精品| 亚洲一区二三区| 亚洲三级小视频| 日韩电影一区二区三区四区| 国产美女一区二区| 日本高清不卡在线观看| 日韩亚洲欧美在线| 国产精品久久久久久久浪潮网站| 亚洲综合色丁香婷婷六月图片| 久久99久久精品欧美| 不卡视频在线观看| 91精品国产色综合久久ai换脸| 国产喷白浆一区二区三区| 亚洲精品国产视频| 精品亚洲免费视频| 日本福利一区二区| 精品精品国产高清a毛片牛牛| 亚洲免费观看高清| 国产综合久久久久久久久久久久| 色婷婷综合在线| 国产视频在线观看一区二区三区| 亚洲.国产.中文慕字在线| 国产成人av网站| 日韩午夜激情av| 亚洲一区二区综合| 国产精品系列在线观看| 欧美日韩国产另类一区| 国产精品国产成人国产三级| 老司机精品视频线观看86 | 亚洲一区二区三区中文字幕| 国产麻豆午夜三级精品| 欧美日韩mp4| 亚洲精品综合在线| 国产99久久久精品| 欧美www视频| 日韩不卡一区二区三区| 日本电影亚洲天堂一区| 国产精品三级久久久久三级| 狠狠色狠狠色综合| 91精品国产免费| 午夜精品久久久久久久蜜桃app| 99国产精品久| 中文字幕一区免费在线观看| 国产大陆a不卡| 亚洲精品一区二区三区99| 免费欧美高清视频| 欧美人动与zoxxxx乱| 一区二区日韩电影| 99国内精品久久| 国产精品久久久久久久第一福利| 国产成人亚洲综合色影视| 精品日韩一区二区| 美女免费视频一区二区| 欧美一区二区三区四区视频| 日韩av一区二区三区四区| 色av成人天堂桃色av| 亚洲精品视频一区二区| 91蜜桃免费观看视频| 亚洲天堂网中文字|