• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆-23  評論-73  文章-3  trackbacks-0

            #include <ntifs.h>
            #include <ntddscsi.h>
            #include <ntdddisk.h>
            #include <stdio.h>


             


            void PrintIdeInfo (int drive, ULONG diskdata [256]);


            char *ConvertToString (ULONG diskdata [256], int firstIndex, int lastIndex);


            BOOLEAN getDiskID( PDEVICE_OBJECT DeviceObject,ULONG drive );


             


            #define IDENTIFY_BUFFER_SIZE 512


            #define  IDE_ATAPI_IDENTIFY  0xA1  //  Returns ID sector for ATAPI.
            #define  IDE_ATA_IDENTIFY    0xEC  //  Returns ID sector for ATA.


            #define  DFP_RECEIVE_DRIVE_DATA   0x0007c088


             


            //輸出地址
            char IdOutCmd [sizeof (SENDCMDOUTPARAMS) + IDENTIFY_BUFFER_SIZE - 1];


             


            BOOLEAN getDiskID( PDEVICE_OBJECT DeviceObject,ULONG drive )
            /*
            * DeviceObject:物理PDO
            * drive:磁盤設備號
            */
            {
                PUCHAR buffer;
                PSRB_IO_CONTROL srbControl;
                ULONG         controlCode = 0;
                PIRP irp2;
                KEVENT event;
                IO_STATUS_BLOCK ioStatus;   
                NTSTATUS status;
                ULONG length;
             PSENDCMDINPARAMS cmdInParameters;
             
             SENDCMDINPARAMS  scip;


             memset (&scip, 0, sizeof(scip));
                memset (IdOutCmd, 0, sizeof(IdOutCmd));
             scip.cBufferSize = IDENTIFY_BUFFER_SIZE;
             scip.irDriveRegs.bFeaturesReg = 0;
             scip.irDriveRegs.bSectorCountReg = 1;
             scip.irDriveRegs.bSectorNumberReg = 1;
             scip.irDriveRegs.bCylLowReg = 0;
             scip.irDriveRegs.bCylHighReg = 0;


               // Compute the drive number.
             scip.irDriveRegs.bDriveHeadReg = 0xA0 | (((UCHAR)drive & 1) << 4);


               // The command can either be IDE identify or ATAPI identify.
             scip.irDriveRegs.bCommandReg = IDE_ATA_IDENTIFY;
             scip.bDriveNumber = (UCHAR)drive;
             scip.cBufferSize = IDENTIFY_BUFFER_SIZE;


                //
                // 發DeviceIo,IdOutCmd接收結果
                //
                irp2 = IoBuildDeviceIoControlRequest(DFP_RECEIVE_DRIVE_DATA,
                                        DeviceObject,
                                        &scip,
                                        sizeof(SENDCMDINPARAMS) - 1,
                                        IdOutCmd,
                                        sizeof(SENDCMDOUTPARAMS) + IDENTIFY_BUFFER_SIZE - 1,
                                        FALSE,
                                        &event,
                                        &ioStatus);


                if (irp2 == NULL) {
                    DbgPrint("Build DeviceIoControl Error \n");
              return FALSE;
                }


                //
                // 向設備發Irp
                //


                status = IoCallDriver(DeviceObject, irp2);


                if (status == STATUS_PENDING) {
                    KeWaitForSingleObject(&event, Executive, KernelMode, FALSE, NULL);
                    status = ioStatus.Status;
                }


                //
                // 發送成功打印信息
                //
               
                if (NT_SUCCESS(status)) {
                      ULONG diskdata [256];
                      int ijk = 0;
                      USHORT *pIdSector = (USHORT *)
                                         ((PSENDCMDOUTPARAMS) IdOutCmd) -> bBuffer;
                DbgPrint("successs in read disk id \n");   


                      for (ijk = 0; ijk < 256; ijk++)
                        diskdata [ijk] = pIdSector [ijk];
                   
                 //打印函數
                    PrintIdeInfo (drive, diskdata);
              //這要調用完成例程而不是釋放IRP,具體請看DDK文檔
              IoCompleteRequest( irp2,IO_NO_INCREMENT );
                    return TRUE;    
                     
                } else {
                   DbgPrint("get disk id error\n");
               
                }
               
                return FALSE;
            }


            void PrintIdeInfo (int drive, ULONG diskdata [256])
            {
             char string1 [1024];


             strcpy (string1, ConvertToString (diskdata, 10, 19));


             DbgPrint("Disk NO. %d DiskID %s \n",drive,ConvertToString (diskdata, 10, 19));
            }


            char *ConvertToString (ULONG diskdata [256], int firstIndex, int lastIndex)
            {
            /*
            * 功能如下:高低字節對調,結尾補'\0'
            * string[10-19]遇空結尾
            */
               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++)
               {
                     //  高字節
                  string [position] = (char) (diskdata [index] / 256);
                  position++;


                     //  低字節
                  string [position] = (char) (diskdata [index] % 256);
                  position++;
               }


                  //  結尾
               string [position] = '\0';
                 
               for (index = position - 1; index > 0 && ' ' == string [index]; index--)
                  string [index] = '\0';


               return string;
            }

            posted on 2008-04-19 13:05 ViskerWong 閱讀(1388) 評論(2)  編輯 收藏 引用

            評論:
            # re: 得到物理磁盤序列號 2008-04-19 16:57 | Lenuns
            驅動的代碼,ms不完整啊  回復  更多評論
              
            # re: 得到物理磁盤序列號 2008-04-21 14:59 | ViskerWong
            想看完整的代碼可以找Diskid32的源代碼
            這只是一個庫  回復  更多評論
              
            亚洲午夜久久久久妓女影院| 久久99精品国产99久久| 久久人妻少妇嫩草AV蜜桃| 久久国产精品一区| 日本WV一本一道久久香蕉| 91精品国产综合久久精品| 久久国产高清一区二区三区| 新狼窝色AV性久久久久久| 精品一区二区久久| 亚洲va久久久噜噜噜久久天堂| 2021久久精品国产99国产精品| 无码国内精品久久人妻麻豆按摩| 亚洲国产视频久久| 国产亚洲精久久久久久无码AV| 人妻无码αv中文字幕久久琪琪布| 秋霞久久国产精品电影院| 久久久久亚洲av成人网人人软件 | 欧美牲交A欧牲交aⅴ久久| 亚洲一区中文字幕久久| 7777精品久久久大香线蕉| 久久久精品人妻无码专区不卡| 久久精品国产清高在天天线| 国产69精品久久久久APP下载| 亚洲国产天堂久久综合网站| 国产精品99久久免费观看| 久久综合狠狠综合久久| 久久久久久久波多野结衣高潮| 久久久久婷婷| 久久久精品久久久久特色影视| 精品久久久久中文字幕一区| 狠狠干狠狠久久| 亚洲综合精品香蕉久久网97| 亚洲国产天堂久久综合网站| 热99re久久国超精品首页| 久久99热精品| 国产精品成人无码久久久久久 | 精品人妻伦一二三区久久| 99久久精品费精品国产一区二区| 久久99精品久久久久久久久久| 久久久精品人妻一区二区三区蜜桃 | 综合久久给合久久狠狠狠97色 |