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

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

?? gethardsoftinfo.cpp

?? win2000,vc6.0 硬盤信息讀取
?? CPP
字號:

////----------------------------------------------// File : GetHardSoftInfo.cpp//// Content : for displaying the details of hard drives in //// Author : 06/11/2000  Lynn McGuire  written with many contributions from others,//                            IDE drives only under Windows NT/2K and 9X,//                            maybe SCSI drives later//// Fix Bug : 06/06/2003 NieHuawen(nie173@sohu.com)//// Content : Replant to Class////-------------------------------------------------
#include "stdafx.h"
#include "GetHardSoftInfo.h"

CGetMachineInfo::CGetMachineInfo(void)
{
	OSVERSIONINFO version;	memset (&version, 0, sizeof (version));	version.dwOSVersionInfoSize = sizeof (OSVERSIONINFO);	GetVersionEx (&version);	if (version.dwPlatformId == VER_PLATFORM_WIN32_NT)//nt	{
     ReadPhysicalDriveInNT();
	}
	if(version.dwPlatformId==VER_PLATFORM_WIN32_WINDOWS)//9x
	{
		ReadDrivePortsInWin9X();
	}
}
BOOL CGetMachineInfo::ReturnInfo(int drive, DWORD diskdata [256])
{
	char string1 [1024];   __int64 sectors = 0;   __int64 bytes = 0;      //  copy the hard drive serial number to the buffer   strcpy (string1, ConvertToString (diskdata, 10, 19));   if (0 == HardDriveSerialNumber [0] &&            //  serial number must be alphanumeric            //  (but there can be leading spaces on IBM drives)       (isalnum (string1 [0]) || isalnum (string1 [19])))      strcpy (HardDriveSerialNumber, string1);//#ifdef PRINTING_TO_CONSOLE_ALLOWED   switch (drive / 2)   {      case 0: str_HardDesk_Form ="Primary Controller";              break;      case 1: str_HardDesk_Form ="Secondary Controller";              break;      case 2: str_HardDesk_Form ="Tertiary Controller";              break;      case 3: str_HardDesk_Form ="Quaternary Controller";              break;   }//MessageBox(NULL,str_HardDesk_Form,NULL,NULL);   switch (drive % 2)   {      case 0: str_Controller ="Master drive";              break;      case 1: str_Controller ="Slave drive";              break;   }   str_DN_Modol =CString(ConvertToString (diskdata, 27, 46));     str_DN_Serial =CString(ConvertToString (diskdata, 10, 19));   str_DN_ControllerRevision =CString(ConvertToString (diskdata, 23, 26));   str_HardDeskBufferSize.Format("%u", diskdata [21] * 512);   printf ("Drive Type________________________: ");   if (diskdata [0] & 0x0080)      str_HardDeskType ="Removable";   else if (diskdata [0] & 0x0040)      str_HardDeskType ="Fixed";   else str_HardDeskType ="Unknown";           		//  calculate size based on 28 bit or 48 bit addressing		//  48 bit addressing is reflected by bit 10 of word 83	if (diskdata [83] & 0x400) 		sectors = diskdata [103] * 65536I64 * 65536I64 * 65536I64 + 					diskdata [102] * 65536I64 * 65536I64 + 					diskdata [101] * 65536I64 + 					diskdata [100];	else		sectors = diskdata [61] * 65536 + diskdata [60];		//  there are 512 bytes in a sector	bytes = sectors * 512;	str_HardDeskSize.Format("%I64d",bytes);return 1;
}
//conversion to char 
char *CGetMachineInfo::ConvertToString(DWORD diskdata [256], int firstIndex, int lastIndex)
{
static char string [1024];   int index = 0;   int position = 0;      //  each integer has two characters stored in it backwards   for (index = firstIndex; index <= lastIndex; index++)   {         //  get high byte for 1st character      string [position] = (char) (diskdata [index] / 256);      position++;         //  get low byte for 2nd character      string [position] = (char) (diskdata [index] % 256);      position++;   }      //  end the string    string [position] = '\0';      //  cut off the trailing blanks   for (index = position - 1; index > 0 && ' ' == string [index]; index--)      string [index] = '\0';   return string;
}
//
 CGetMachineInfo::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) );
}
//
int CGetMachineInfo::ReadPhysicalDriveInNT(void)
{
	int done = FALSE;   int drive = 0;   for (drive = 0; drive < MAX_IDE_DRIVES; drive++)   {      HANDLE hPhysicalDriveIOCTL = 0;         //  Try to get a handle to PhysicalDrive IOCTL, report failure         //  and exit if can't.      char driveName [256];      sprintf (driveName, "\\\\.\\PhysicalDrive%d", drive);         //  Windows NT, Windows 2000, must have admin rights      hPhysicalDriveIOCTL = CreateFile (driveName,                               GENERIC_READ | GENERIC_WRITE,                                FILE_SHARE_READ | FILE_SHARE_WRITE, NULL,                               OPEN_EXISTING, 0, NULL);      // if (hPhysicalDriveIOCTL == INVALID_HANDLE_VALUE)      //    printf ("Unable to open physical drive %d, error code: 0x%lX\n",      //            drive, GetLastError ());      if (hPhysicalDriveIOCTL != INVALID_HANDLE_VALUE)      {         GETVERSIONOUTPARAMS VersionParams;         DWORD               cbBytesReturned = 0;            // Get the version, etc of PhysicalDrive IOCTL         memset ((void*) &VersionParams, 0, sizeof(VersionParams));         if ( ! DeviceIoControl (hPhysicalDriveIOCTL, DFP_GET_VERSION,                   NULL,                    0,                   &VersionParams,                   sizeof(VersionParams),                   &cbBytesReturned, NULL) )         {                     // printf ("DFP_GET_VERSION failed for drive %d\n", i);            // continue;         }            // If there is a IDE device at number "i" issue commands            // to the device         if (VersionParams.bIDEDeviceMap > 0)         {            BYTE             bIDCmd = 0;   // IDE or ATAPI IDENTIFY cmd            SENDCMDINPARAMS  scip;            //SENDCMDOUTPARAMS OutCmd;			BYTE IdOutCmd [sizeof (SENDCMDOUTPARAMS) + IDENTIFY_BUFFER_SIZE - 1];			// Now, get the ID sector for all IDE devices in the system.               // If the device is ATAPI use the IDE_ATAPI_IDENTIFY command,               // otherwise use the IDE_ATA_IDENTIFY command            bIDCmd = (VersionParams.bIDEDeviceMap >> drive & 0x10) ? \                      IDE_ATAPI_IDENTIFY : IDE_ATA_IDENTIFY;            memset (&scip, 0, sizeof(scip));            memset (IdOutCmd, 0, sizeof(IdOutCmd));            if ( DoIDENTIFY (hPhysicalDriveIOCTL,                        &scip,                        (PSENDCMDOUTPARAMS)&IdOutCmd,                        (BYTE) bIDCmd,                       (BYTE) drive,                       &cbBytesReturned))            {               DWORD diskdata [256];               int ijk = 0;               USHORT *pIdSector = (USHORT *)                             ((PSENDCMDOUTPARAMS) IdOutCmd) -> bBuffer;               for (ijk = 0; ijk < 256; ijk++)                  diskdata [ijk] = pIdSector [ijk];               ReturnInfo (drive, diskdata);               done = TRUE;            }	    }         CloseHandle (hPhysicalDriveIOCTL);      }   }   return done;
}
//
int CGetMachineInfo::ReadDrivePortsInWin9X(void)
{
	int done = FALSE;   HANDLE VxDHandle = 0;   pt_IdeDInfo pOutBufVxD = 0;   DWORD lpBytesReturned = 0;		//  set the thread priority high so that we get exclusive access to the diskSetPriorityClass (GetCurrentProcess (), REALTIME_PRIORITY_CLASS);	      // 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   unsigned long int i = 0;   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		   ReturnInfo (i, diskinfo);			done = TRUE;      }   }		//  reset the thread priority back to normal   // SetThreadPriority (GetCurrentThread(), THREAD_PRIORITY_NORMAL);   SetPriorityClass (GetCurrentProcess (), NORMAL_PRIORITY_CLASS);   return done;
}
//
int CGetMachineInfo::ReadIdeDriveAsScsiDriveInNT(void)
{
	int done = FALSE;   int controller = 0;   for (controller = 0; controller < 2; 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];                  ReturnInfo (controller * 2 + drive, diskdata);                  done = TRUE;               }            }         }         CloseHandle (hScsiDriveIOCTL);      }   }   return done;
}
//

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕一区二区三区精华液| 日韩一区欧美二区| 亚洲成人午夜影院| 国内国产精品久久| 欧美性受xxxx| 国产精品视频一二| 美国欧美日韩国产在线播放| 97久久精品人人爽人人爽蜜臀 | 亚洲成人一二三| 国产一区二区三区在线观看精品 | 免费的国产精品| 97久久人人超碰| 国产日韩亚洲欧美综合| 亚洲成av人片在www色猫咪| av资源网一区| 国产人伦精品一区二区| 九色综合国产一区二区三区| 欧美日韩一区 二区 三区 久久精品| 中文字幕免费观看一区| 久久99精品国产91久久来源| 欧美一区二区视频观看视频 | 在线观看区一区二| 国产精品无码永久免费888| 激情久久五月天| 日韩欧美国产综合在线一区二区三区 | 欧美日韩国产一级二级| 国产精品久久久久一区| 成人av网站在线| 中文字幕高清不卡| 成人在线视频首页| 国产拍欧美日韩视频二区| 精品中文字幕一区二区| 欧美成人一区二区三区片免费| 天堂在线一区二区| 91精品久久久久久蜜臀| 日韩成人一区二区三区在线观看| 欧美日韩在线三区| 亚州成人在线电影| 3d成人h动漫网站入口| 日韩精品高清不卡| 日韩欧美国产成人一区二区| 麻豆高清免费国产一区| 久久日韩粉嫩一区二区三区| 国产高清精品网站| 国产精品久久综合| 91色综合久久久久婷婷| 一区二区在线观看免费| 欧美色图激情小说| 日韩av网站在线观看| 日韩三级高清在线| 国产精选一区二区三区| 国产精品乱码人人做人人爱| 一本色道久久综合亚洲aⅴ蜜桃| 一区二区三区在线播| 欧美日韩国产不卡| 另类欧美日韩国产在线| 亚洲国产高清aⅴ视频| 在线视频国内一区二区| 另类专区欧美蜜桃臀第一页| 国产亚洲欧美日韩日本| 色94色欧美sute亚洲13| 蜜臀久久99精品久久久画质超高清| 久久久综合精品| 色吊一区二区三区| 精品一区二区三区久久| 中文字幕一区日韩精品欧美| 欧美中文字幕一区二区三区| 美女视频网站黄色亚洲| 中文字幕色av一区二区三区| 7777精品伊人久久久大香线蕉完整版| 精品一二线国产| 一区二区三区四区亚洲| ww亚洲ww在线观看国产| 99久久精品国产观看| 久久成人麻豆午夜电影| 亚洲视频综合在线| 日韩精品一区二区三区在线观看| 不卡的电视剧免费网站有什么| 午夜激情一区二区| 亚洲国产精品精华液ab| 精品视频在线免费| 成人动漫av在线| 美女脱光内衣内裤视频久久网站| 最好看的中文字幕久久| 精品日韩一区二区三区免费视频| 日本韩国一区二区三区视频| 国产麻豆精品theporn| 五月激情丁香一区二区三区| 国产精品美女久久久久aⅴ| 欧美一级二级在线观看| 日本韩国视频一区二区| 国产剧情一区二区| 蜜桃av噜噜一区| 性做久久久久久免费观看 | 日韩免费一区二区| 91天堂素人约啪| 国产大陆亚洲精品国产| 美国毛片一区二区三区| 亚洲一区二区在线播放相泽| 国产精品久久久久久久第一福利 | 欧美激情在线看| 欧美电视剧在线观看完整版| 欧美浪妇xxxx高跟鞋交| 色妹子一区二区| 色综合久久综合网97色综合| zzijzzij亚洲日本少妇熟睡| 国产精品一区二区不卡| 精品系列免费在线观看| 理论电影国产精品| 久久国产精品99久久久久久老狼 | 国产成人自拍高清视频在线免费播放| 亚洲大片一区二区三区| 亚洲综合小说图片| 一二三区精品视频| 亚洲综合色网站| 一级特黄大欧美久久久| 亚洲黄色免费电影| 亚洲综合图片区| 亚洲一区二区三区免费视频| 一区二区三区蜜桃网| 亚洲午夜精品网| 亚洲aaa精品| 久久国产精品72免费观看| 精品无人码麻豆乱码1区2区| 国产盗摄精品一区二区三区在线| 懂色av一区二区三区免费观看| 国产精品一区二区三区四区| 国产乱码精品一区二区三区av| 国产乱对白刺激视频不卡| 成人免费观看av| 91网页版在线| 91精品欧美综合在线观看最新| 欧美成人一区二区三区片免费| 久久久久国色av免费看影院| 国产精品你懂的在线欣赏| 亚洲欧洲av在线| 亚洲va欧美va人人爽午夜| 美女精品自拍一二三四| 国产电影一区在线| 色网站国产精品| 9191成人精品久久| 2020国产精品自拍| **欧美大码日韩| 亚洲成人动漫在线免费观看| 免费不卡在线观看| 不卡视频一二三四| 欧美日韩精品二区第二页| 精品美女在线播放| 中文字幕日韩欧美一区二区三区| 亚洲在线视频网站| 精品一区二区三区免费观看| 91丨九色丨国产丨porny| 欧美精品一卡两卡| 中文字幕精品在线不卡| 亚洲电影中文字幕在线观看| 国产一区在线观看视频| 欧美中文字幕一区| 久久久www成人免费无遮挡大片| 亚洲欧美国产77777| 免费成人你懂的| 91色婷婷久久久久合中文| 欧美一区二区三区小说| 亚洲日本青草视频在线怡红院| 日本不卡一区二区| 成人午夜av影视| 欧美一区中文字幕| 欧美国产精品一区二区三区| 午夜精品免费在线| 成人久久18免费网站麻豆| 日韩一区二区免费高清| 亚洲精品高清视频在线观看| 国产精品888| 日韩一区二区三区免费看| 怡红院av一区二区三区| 福利一区二区在线| 欧美成人一区二区| 国产91精品一区二区麻豆亚洲| 欧美影视一区在线| 日韩美女视频一区二区| 韩国一区二区在线观看| 日韩一区二区影院| 视频在线在亚洲| 欧亚一区二区三区| 综合分类小说区另类春色亚洲小说欧美| 麻豆91免费观看| 欧美私模裸体表演在线观看| 1024成人网色www| 国产成人av一区二区三区在线观看| 日韩亚洲欧美综合| 日韩av一区二区三区| 欧美日韩一区在线观看| 亚洲色图视频网站| 国产91精品一区二区麻豆亚洲| 精品播放一区二区| 另类小说一区二区三区| 欧美电影免费观看高清完整版在线观看 | 亚洲国产高清在线观看视频| 国产一区二区在线观看视频| 精品国产成人在线影院| 精品影院一区二区久久久|