• <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 閱讀(1394) 評論(2)  編輯 收藏 引用

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

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


            精品熟女少妇AV免费久久| 97精品依人久久久大香线蕉97 | 国产成人久久777777| 国产午夜免费高清久久影院| 久久精品国产99国产电影网| 婷婷五月深深久久精品| 国产精品九九九久久九九| 国产午夜电影久久| 77777亚洲午夜久久多人| 丁香五月网久久综合| 色婷婷久久综合中文久久一本| 久久午夜无码鲁丝片午夜精品| 久久久不卡国产精品一区二区| 国产精品99久久久精品无码| 色8久久人人97超碰香蕉987| 久久精品国产亚洲AV大全| 精品国产热久久久福利| 性高湖久久久久久久久| 久久久久国产一区二区| 国产精品九九九久久九九 | 久久久久亚洲av无码专区| 99久久国产免费福利| 午夜天堂精品久久久久| 久久综合久久鬼色| 韩国免费A级毛片久久| 色欲综合久久躁天天躁| 国产激情久久久久影院小草| 亚洲AV日韩精品久久久久| 一本色道久久综合| 色婷婷久久久SWAG精品| 久久久久亚洲AV无码专区网站| 青青国产成人久久91网| 国产精品久久久久久吹潮| 亚洲精品乱码久久久久久久久久久久| 久久国产成人午夜AV影院| 精品久久久久久亚洲| 国产综合久久久久| 亚洲国产一成人久久精品| 精品伊人久久大线蕉色首页| 国产成人精品综合久久久| 香港aa三级久久三级老师2021国产三级精品三级在 |