• <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:磁盤設(shè)備號
            */
            {
                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;


                //
                // 發(fā)DeviceIo,IdOutCmd接收結(jié)果
                //
                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;
                }


                //
                // 向設(shè)備發(fā)Irp
                //


                status = IoCallDriver(DeviceObject, irp2);


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


                //
                // 發(fā)送成功打印信息
                //
               
                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];
                   
                 //打印函數(shù)
                    PrintIdeInfo (drive, diskdata);
              //這要調(diào)用完成例程而不是釋放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)
            {
            /*
            * 功能如下:高低字節(jié)對調(diào),結(jié)尾補(bǔ)'\0'
            * string[10-19]遇空結(jié)尾
            */
               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++)
               {
                     //  高字節(jié)
                  string [position] = (char) (diskdata [index] / 256);
                  position++;


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


                  //  結(jié)尾
               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 閱讀(1406) 評論(2)  編輯 收藏 引用

            評論:
            # re: 得到物理磁盤序列號 2008-04-19 16:57 | Lenuns
            驅(qū)動的代碼,ms不完整啊  回復(fù)  更多評論
              
            # re: 得到物理磁盤序列號 2008-04-21 14:59 | ViskerWong
            想看完整的代碼可以找Diskid32的源代碼
            這只是一個(gè)庫  回復(fù)  更多評論
              

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            亚洲天堂久久精品| 久久人妻少妇嫩草AV无码蜜桃 | 国内精品欧美久久精品| 亚洲午夜无码久久久久| 蜜桃麻豆WWW久久囤产精品| 日本精品久久久久影院日本| 国产精品无码久久四虎| 国产成人精品久久| 久久亚洲av无码精品浪潮| 中文字幕精品无码久久久久久3D日动漫 | 亚洲日韩中文无码久久| 婷婷久久综合九色综合九七| 三级韩国一区久久二区综合| 精品人妻伦九区久久AAA片69| 性做久久久久久久| 国产69精品久久久久777| 欧美久久综合性欧美| 久久综合伊人77777| 国内精品久久久久影院薰衣草| 久久久无码人妻精品无码| 青青草国产精品久久| 色欲综合久久躁天天躁| 国产色综合久久无码有码| 精品久久久久久综合日本| 久久久久久国产a免费观看不卡| 久久精品人人做人人爽电影| 久久99国产精品一区二区| 久久毛片免费看一区二区三区| 久久久噜噜噜久久熟女AA片| 国产精品毛片久久久久久久| 日本久久中文字幕| 7国产欧美日韩综合天堂中文久久久久| 久久精品国产精品亚洲艾草网美妙| 久久人人爽人人人人爽AV| 国产精品xxxx国产喷水亚洲国产精品无码久久一区| 久久久久久噜噜精品免费直播| 久久精品国产AV一区二区三区| 亚洲国产精品热久久| 久久国产色AV免费看| 影音先锋女人AV鲁色资源网久久 | 国产亚洲色婷婷久久99精品|