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

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

?? diskid32.cpp

?? DiskId32最新版 在NT/2000/XP/2003/VISTA下取PATA/SATA/SCSI)下支持獲取硬盤的系列號。 編譯需要Windows SDK
?? CPP
?? 第 1 頁 / 共 4 頁
字號:
      sprintf (driveName, "\\\\.\\PhysicalDrive%d", drive);         //  Windows NT, Windows 2000, Windows XP - admin rights not required      hPhysicalDriveIOCTL = CreateFile (driveName, 0,                               FILE_SHARE_READ | FILE_SHARE_WRITE, NULL,                               OPEN_EXISTING, 0, NULL);      if (hPhysicalDriveIOCTL == INVALID_HANDLE_VALUE)      {#ifdef PRINTING_TO_CONSOLE_ALLOWED         if (PRINT_DEBUG)             printf ("\n%d ReadPhysicalDriveInNTWithZeroRights ERROR"		             "\nCreateFile(%s) returned INVALID_HANDLE_VALUE\n",		             __LINE__, driveName);#endif      }      else      {		 STORAGE_PROPERTY_QUERY query;         DWORD cbBytesReturned = 0;		 char buffer [10000];         memset ((void *) & query, 0, sizeof (query));		 query.PropertyId = StorageDeviceProperty;		 query.QueryType = PropertyStandardQuery;		 memset (buffer, 0, sizeof (buffer));         if ( DeviceIoControl (hPhysicalDriveIOCTL, IOCTL_STORAGE_QUERY_PROPERTY,                   & query,                   sizeof (query),				   & buffer,				   sizeof (buffer),                   & cbBytesReturned, NULL) )         {         			 STORAGE_DEVICE_DESCRIPTOR * descrip = (STORAGE_DEVICE_DESCRIPTOR *) & buffer;			 char serialNumber [1000];			 char modelNumber [1000];             char vendorId [1000];	         char productRevision [1000];#ifdef PRINTING_TO_CONSOLE_ALLOWED             if (PRINT_DEBUG)             {                 printf ("\n%d STORAGE_DEVICE_DESCRIPTOR contents for drive %d\n"		                 "                Version: %ld\n"		                 "                   Size: %ld\n"		                 "             DeviceType: %02x\n"		                 "     DeviceTypeModifier: %02x\n"		                 "         RemovableMedia: %d\n"		                 "        CommandQueueing: %d\n"		                 "         VendorIdOffset: %4ld (0x%02lx)\n"		                 "        ProductIdOffset: %4ld (0x%02lx)\n"		                 "  ProductRevisionOffset: %4ld (0x%02lx)\n"		                 "     SerialNumberOffset: %4ld (0x%02lx)\n"		                 "                BusType: %d\n"		                 "    RawPropertiesLength: %ld\n",		                 __LINE__, drive,			             (unsigned long) descrip->Version,		                 (unsigned long) descrip->Size,		                 (int) descrip->DeviceType,		                 (int) descrip->DeviceTypeModifier,		                 (int) descrip->RemovableMedia,		                 (int) descrip->CommandQueueing,		                 (unsigned long) descrip->VendorIdOffset,		                 (unsigned long) descrip->VendorIdOffset,		                 (unsigned long) descrip->ProductIdOffset,		                 (unsigned long) descrip->ProductIdOffset,		                 (unsigned long) descrip->ProductRevisionOffset,		                 (unsigned long) descrip->ProductRevisionOffset,		                 (unsigned long) descrip->SerialNumberOffset,		                 (unsigned long) descrip->SerialNumberOffset,		                 (int) descrip->BusType,		                 (unsigned long) descrip->RawPropertiesLength);	            dump_buffer ("Contents of RawDeviceProperties",			                 (unsigned char*) descrip->RawDeviceProperties,			                 descrip->RawPropertiesLength);	            dump_buffer ("Contents of first 256 bytes in buffer",			                 (unsigned char*) buffer, 256);			 }#endif             flipAndCodeBytes (buffer,                               descrip -> VendorIdOffset,			                   0, vendorId );	         flipAndCodeBytes (buffer,			                   descrip -> ProductIdOffset,			                   0, modelNumber );	         flipAndCodeBytes (buffer,			                   descrip -> ProductRevisionOffset,			                   0, productRevision );	         flipAndCodeBytes (buffer,			                   descrip -> SerialNumberOffset,			                   1, serialNumber );			 if (0 == HardDriveSerialNumber [0] &&						//  serial number must be alphanumeric			            //  (but there can be leading spaces on IBM drives)				   (isalnum (serialNumber [0]) || isalnum (serialNumber [19])))			 {				strcpy (HardDriveSerialNumber, serialNumber);				strcpy (HardDriveModelNumber, modelNumber);				done = TRUE;			 }#ifdef PRINTING_TO_CONSOLE_ALLOWED             printf ("\n**** STORAGE_DEVICE_DESCRIPTOR for drive %d ****\n"		             "Vendor Id = [%s]\n"		             "Product Id = [%s]\n"		             "Product Revision = [%s]\n"		             "Serial Number = [%s]\n",		             drive,		             vendorId,		             modelNumber,		             productRevision,		             serialNumber);#endif	           // Get the disk drive geometry.	         memset (buffer, 0, sizeof(buffer));	         if ( ! DeviceIoControl (hPhysicalDriveIOCTL,			          IOCTL_DISK_GET_DRIVE_GEOMETRY_EX,			          NULL,			          0,			          &buffer,			          sizeof(buffer),			          &cbBytesReturned,			          NULL))	         {#ifdef PRINTING_TO_CONSOLE_ALLOWED                if (PRINT_DEBUG)	               printf ("\n%d ReadPhysicalDriveInNTWithZeroRights ERROR"		                   "|nDeviceIoControl(%s, IOCTL_DISK_GET_DRIVE_GEOMETRY_EX) returned 0",		                   driveName);#endif          	 }	         else	         {         	            DISK_GEOMETRY_EX* geom = (DISK_GEOMETRY_EX*) &buffer;	            int fixed = (geom->Geometry.MediaType == FixedMedia);	            __int64 size = geom->DiskSize.QuadPart;				     #ifdef PRINTING_TO_CONSOLE_ALLOWED	            printf ("\n**** DISK_GEOMETRY_EX for drive %d ****\n"		                "Disk is%s fixed\n"		                "DiskSize = %I64d\n",		                drive,		                fixed ? "" : " NOT",		                size);#endif	        }         }		 else		 {			 DWORD err = GetLastError ();#ifdef PRINTING_TO_CONSOLE_ALLOWED			 printf ("\nDeviceIOControl IOCTL_STORAGE_QUERY_PROPERTY error = %d\n", err);#endif		 }         CloseHandle (hPhysicalDriveIOCTL);      }   }   return done;}   // DoIDENTIFY   // FUNCTION: Send an IDENTIFY command to the drive   // bDriveNum = 0-3   // bIDCmd = IDE_ATA_IDENTIFY or IDE_ATAPI_IDENTIFYBOOL DoIDENTIFY (HANDLE hPhysicalDriveIOCTL, PSENDCMDINPARAMS pSCIP,                 PSENDCMDOUTPARAMS pSCOP, BYTE bIDCmd, BYTE bDriveNum,                 PDWORD lpcbBytesReturned){      // Set up data structures for IDENTIFY command.   pSCIP -> cBufferSize = IDENTIFY_BUFFER_SIZE;   pSCIP -> irDriveRegs.bFeaturesReg = 0;   pSCIP -> irDriveRegs.bSectorCountReg = 1;   //pSCIP -> irDriveRegs.bSectorNumberReg = 1;   pSCIP -> irDriveRegs.bCylLowReg = 0;   pSCIP -> irDriveRegs.bCylHighReg = 0;      // Compute the drive number.   pSCIP -> irDriveRegs.bDriveHeadReg = 0xA0 | ((bDriveNum & 1) << 4);      // The command can either be IDE identify or ATAPI identify.   pSCIP -> irDriveRegs.bCommandReg = bIDCmd;   pSCIP -> bDriveNumber = bDriveNum;   pSCIP -> cBufferSize = IDENTIFY_BUFFER_SIZE;   return ( DeviceIoControl (hPhysicalDriveIOCTL, DFP_RECEIVE_DRIVE_DATA,               (LPVOID) pSCIP,               sizeof(SENDCMDINPARAMS) - 1,               (LPVOID) pSCOP,               sizeof(SENDCMDOUTPARAMS) + IDENTIFY_BUFFER_SIZE - 1,               lpcbBytesReturned, NULL) );}//  ---------------------------------------------------   // (* Output Bbuffer for the VxD (rt_IdeDinfo record) *)typedef struct _rt_IdeDInfo_{    BYTE IDEExists[4];    BYTE DiskExists[8];    WORD DisksRawInfo[8*256];} rt_IdeDInfo, *pt_IdeDInfo;   // (* IdeDinfo "data fields" *)typedef struct _rt_DiskInfo_{   BOOL DiskExists;   BOOL ATAdevice;   BOOL RemovableDevice;   WORD TotLogCyl;   WORD TotLogHeads;   WORD TotLogSPT;   char SerialNumber[20];   char FirmwareRevision[8];   char ModelNumber[40];   WORD CurLogCyl;   WORD CurLogHeads;   WORD CurLogSPT;} rt_DiskInfo;#define  m_cVxDFunctionIdesDInfo  1//  ---------------------------------------------------int ReadDrivePortsInWin9X (void){   int done = FALSE;   unsigned long int i = 0;   HANDLE VxDHandle = 0;   pt_IdeDInfo pOutBufVxD = 0;   DWORD lpBytesReturned = 0;		//  set the thread priority high so that we get exclusive access to the disk   BOOL status =		// SetThreadPriority (GetCurrentThread(), THREAD_PRIORITY_TIME_CRITICAL);		SetPriorityClass (GetCurrentProcess (), REALTIME_PRIORITY_CLASS);		// SetPriorityClass (GetCurrentProcess (), HIGH_PRIORITY_CLASS);#ifdef PRINTING_TO_CONSOLE_ALLOWED   if (0 == status) 	   // printf ("\nERROR: Could not SetThreadPriority, LastError: %d\n", GetLastError ());	   printf ("\nERROR: Could not SetPriorityClass, LastError: %d\n", GetLastError ());#endif      // 1. Make an output buffer for the VxD   rt_IdeDInfo info;   pOutBufVxD = &info;      // *****************      // KLUDGE WARNING!!!      // HAVE to zero out the buffer space for the IDE information!      // If this is NOT done then garbage could be in the memory      // locations indicating if a disk exists or not.   ZeroMemory (&info, sizeof(info));      // 1. Try to load the VxD       //  must use the short file name path to open a VXD file   //char StartupDirectory [2048];   //char shortFileNamePath [2048];   //char *p = NULL;   //char vxd [2048];      //  get the directory that the exe was started from   //GetModuleFileName (hInst, (LPSTR) StartupDirectory, sizeof (StartupDirectory));      //  cut the exe name from string   //p = &(StartupDirectory [strlen (StartupDirectory) - 1]);   //while (p >= StartupDirectory && *p && '\\' != *p) p--;   //*p = '\0';      //GetShortPathName (StartupDirectory, shortFileNamePath, 2048);   //sprintf (vxd, "\\\\.\\%s\\IDE21201.VXD", shortFileNamePath);   //VxDHandle = CreateFile (vxd, 0, 0, 0,   //               0, FILE_FLAG_DELETE_ON_CLOSE, 0);      VxDHandle = CreateFile ("\\\\.\\IDE21201.VXD", 0, 0, 0,							0, FILE_FLAG_DELETE_ON_CLOSE, 0);   if (VxDHandle != INVALID_HANDLE_VALUE)   {         // 2. Run VxD function      DeviceIoControl (VxDHandle, m_cVxDFunctionIdesDInfo,					0, 0, pOutBufVxD, sizeof(pt_IdeDInfo), &lpBytesReturned, 0);         // 3. Unload VxD      CloseHandle (VxDHandle);   }   else		MessageBox (NULL, "ERROR: Could not open IDE21201.VXD file", 					TITLE, MB_ICONSTOP);      // 4. Translate and store data   for (i=0; i<8; i++)   {      if((pOutBufVxD->DiskExists[i]) && (pOutBufVxD->IDEExists[i/2]))      {			DWORD diskinfo [256];			for (int j = 0; j < 256; j++) 				diskinfo [j] = pOutBufVxD -> DisksRawInfo [i * 256 + j];            // process the information for this buffer		   PrintIdeInfo (i, diskinfo);			done = TRUE;      }   }		//  reset the thread priority back to normal   // SetThreadPriority (GetCurrentThread(), THREAD_PRIORITY_NORMAL);   SetPriorityClass (GetCurrentProcess (), NORMAL_PRIORITY_CLASS);   return done;}#define  SENDIDLENGTH  sizeof (SENDCMDOUTPARAMS) + IDENTIFY_BUFFER_SIZEint ReadIdeDriveAsScsiDriveInNT (void){   int done = FALSE;   int controller = 0;   for (controller = 0; controller < 16; controller++)   {      HANDLE hScsiDriveIOCTL = 0;      char   driveName [256];         //  Try to get a handle to PhysicalDrive IOCTL, report failure         //  and exit if can't.      sprintf (driveName, "\\\\.\\Scsi%d:", controller);         //  Windows NT, Windows 2000, any rights should do      hScsiDriveIOCTL = CreateFile (driveName,                               GENERIC_READ | GENERIC_WRITE,                                FILE_SHARE_READ | FILE_SHARE_WRITE, NULL,                               OPEN_EXISTING, 0, NULL);      // if (hScsiDriveIOCTL == INVALID_HANDLE_VALUE)      //    printf ("Unable to open SCSI controller %d, error code: 0x%lX\n",      //            controller, GetLastError ());      if (hScsiDriveIOCTL != INVALID_HANDLE_VALUE)      {         int drive = 0;         for (drive = 0; drive < 2; drive++)         {            char buffer [sizeof (SRB_IO_CONTROL) + SENDIDLENGTH];            SRB_IO_CONTROL *p = (SRB_IO_CONTROL *) buffer;            SENDCMDINPARAMS *pin =                   (SENDCMDINPARAMS *) (buffer + sizeof (SRB_IO_CONTROL));            DWORD dummy;               memset (buffer, 0, sizeof (buffer));            p -> HeaderLength = sizeof (SRB_IO_CONTROL);            p -> Timeout = 10000;            p -> Length = SENDIDLENGTH;            p -> ControlCode = IOCTL_SCSI_MINIPORT_IDENTIFY;            strncpy ((char *) p -> Signature, "SCSIDISK", 8);              pin -> irDriveRegs.bCommandReg = IDE_ATA_IDENTIFY;            pin -> bDriveNumber = drive;            if (DeviceIoControl (hScsiDriveIOCTL, IOCTL_SCSI_MINIPORT,                                  buffer,                                 sizeof (SRB_IO_CONTROL) +                                         sizeof (SENDCMDINPARAMS) - 1,                                 buffer,                                 sizeof (SRB_IO_CONTROL) + SENDIDLENGTH,                                 &dummy, NULL))            {               SENDCMDOUTPARAMS *pOut =                    (SENDCMDOUTPARAMS *) (buffer + sizeof (SRB_IO_CONTROL));               IDSECTOR *pId = (IDSECTOR *) (pOut -> bBuffer);               if (pId -> sModelNumber [0])               {                  DWORD diskdata [256];                  int ijk = 0;                  USHORT *pIdSector = (USHORT *) pId;                            for (ijk = 0; ijk < 256; ijk++)                     diskdata [ijk] = pIdSector [ijk];                  PrintIdeInfo (controller * 2 + drive, diskdata);                  done = TRUE;               }            }         }         CloseHandle (hScsiDriveIOCTL);      }   }   return done;}void PrintIdeInfo (int drive, DWORD diskdata [256]){

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品国产三级国产aⅴ中文| 福利一区二区在线| 欧美日韩大陆一区二区| 亚洲成人一二三| 欧美二区三区91| 午夜伊人狠狠久久| 日韩写真欧美这视频| 久久国产婷婷国产香蕉| 久久久国产精华| 99这里只有久久精品视频| 99久久精品国产精品久久| 亚洲人精品午夜| 欧美日韩国产三级| 精品亚洲成a人| 国产精品剧情在线亚洲| 在线观看www91| 蜜臀av性久久久久蜜臀aⅴ四虎 | 欧美色图天堂网| 日韩av电影天堂| 国产日韩精品一区二区浪潮av| 99久免费精品视频在线观看| 亚洲专区一二三| 精品国产人成亚洲区| 91免费观看视频在线| 丝瓜av网站精品一区二区| 久久欧美中文字幕| 欧美视频一区二区三区在线观看| 免费国产亚洲视频| 中文字幕在线观看一区二区| 欧美人与性动xxxx| 成人av在线播放网站| 日韩精品亚洲专区| 18成人在线观看| 欧美成人a∨高清免费观看| 99久久99久久免费精品蜜臀| 日韩中文字幕1| 亚洲欧美一区二区视频| 欧美一级高清片| 99精品视频在线观看| 天天av天天翘天天综合网色鬼国产| 日韩美女一区二区三区四区| 成人美女视频在线看| 日日噜噜夜夜狠狠视频欧美人| 久久综合九色综合97婷婷| 99v久久综合狠狠综合久久| 日韩电影在线观看一区| 亚洲色大成网站www久久九九| 欧美日韩亚洲丝袜制服| 国产成人啪免费观看软件| 亚洲一区二区三区四区中文字幕| ww亚洲ww在线观看国产| 欧美日韩精品电影| 欧美www视频| 欧美精品日韩精品| 在线免费精品视频| 97久久久精品综合88久久| 国内久久精品视频| 日本中文字幕一区二区视频| 亚洲影院久久精品| 亚洲人成人一区二区在线观看| 久久久久久免费网| 2023国产一二三区日本精品2022| 欧美卡1卡2卡| 欧美日韩国产成人在线免费| 91精彩视频在线| 99国产精品久久久久| 国产凹凸在线观看一区二区| 国产在线播放一区二区三区| 久久精品国产精品亚洲精品| 三级在线观看一区二区| 亚洲一区二区成人在线观看| 亚洲激情av在线| 一区二区三区美女| 亚洲精品视频在线观看免费| 中文字幕一区二区三区在线播放 | 日韩久久久精品| 欧美一区二区视频免费观看| 欧美高清视频不卡网| 欧美理论在线播放| 4438亚洲最大| 日韩视频国产视频| 日韩免费观看2025年上映的电影| 91精品国产入口| 日韩欧美不卡在线观看视频| 精品美女在线观看| 久久久国产一区二区三区四区小说| 久久综合久久99| 欧美国产欧美综合| 中文字幕一区二区在线播放| 亚洲老妇xxxxxx| 日韩影院精彩在线| 日韩影视精彩在线| 日本在线不卡视频一二三区| 日本网站在线观看一区二区三区 | 麻豆视频观看网址久久| 日韩av二区在线播放| 自拍av一区二区三区| 中文乱码免费一区二区| 国产三级精品视频| 国产欧美一区二区精品秋霞影院| 亚洲色图欧美在线| 亚洲v中文字幕| 日本欧美在线观看| 日本国产一区二区| 丰满少妇久久久久久久 | 樱花草国产18久久久久| 成人影视亚洲图片在线| 精品国产髙清在线看国产毛片| 国产精品亚洲综合一区在线观看| 粉嫩aⅴ一区二区三区四区五区| 99这里都是精品| 欧美性三三影院| 精品国产污网站| 亚洲美女淫视频| 日本视频一区二区| 成人av网在线| 欧美美女直播网站| 国产女同互慰高潮91漫画| 亚洲一区二区影院| 国产激情视频一区二区在线观看 | 国产精品久久看| 一区二区在线观看视频 | 国产美女在线精品| 色综合天天综合在线视频| 欧美一级一区二区| 中文字幕在线不卡| 九色综合狠狠综合久久| 91激情在线视频| 中日韩av电影| 成人美女视频在线观看| 欧美猛男男办公室激情| 国产精品第四页| 久久国产日韩欧美精品| 欧美自拍偷拍午夜视频| 国产欧美日韩在线观看| 日本aⅴ精品一区二区三区| 99re在线精品| 国产片一区二区| 免费成人在线影院| 欧美视频一区二区| 中文av一区特黄| 国产精品一区二区三区99| 8x8x8国产精品| 一区二区三区资源| 亚洲品质自拍视频| 国产一区999| 欧美一卡二卡在线| 香蕉成人啪国产精品视频综合网| 成人av电影在线| 久久久国产一区二区三区四区小说 | 91麻豆国产自产在线观看| 国产欧美精品一区二区色综合| 日日夜夜精品视频免费| 欧美视频在线观看一区| 亚洲欧美色图小说| 91一区一区三区| 中文字幕色av一区二区三区| 国产91丝袜在线播放| 久久一留热品黄| 黄页网站大全一区二区| 欧美一区午夜视频在线观看| 亚洲成人tv网| 欧美日韩国产综合草草| 亚洲一区国产视频| 欧美天堂亚洲电影院在线播放| 一区二区在线免费观看| 一本到三区不卡视频| 亚洲日穴在线视频| 91网站黄www| 一区二区三区四区在线免费观看| 91蜜桃免费观看视频| 国产精品一区二区果冻传媒| 欧美伊人久久大香线蕉综合69| 国产精品久久影院| av中文字幕在线不卡| 亚洲婷婷在线视频| 在线观看欧美日本| 亚洲国产精品一区二区久久 | 欧美xxxxxxxxx| 黄色小说综合网站| 中文字幕国产一区二区| av动漫一区二区| 一区二区三区在线观看视频| 欧美日韩国产中文| 美国一区二区三区在线播放| 久久久久久久久久久久久女国产乱| 国产一区二区三区久久久| 欧美国产精品v| 一本色道久久加勒比精品 | 成人av午夜影院| 亚洲蜜臀av乱码久久精品| 欧美四级电影在线观看| 免费看日韩a级影片| 国产校园另类小说区| 色综合色狠狠天天综合色| 午夜国产不卡在线观看视频| 精品国一区二区三区| jlzzjlzz亚洲女人18| 婷婷中文字幕综合| 久久精品视频一区二区|