• <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>

            兩個(gè)控制碼,Windows下發(fā)送ATAPI Command必須用到的

            雖然文檔說只有Server 2003才有,但在XP SP2下也可以發(fā)送,只是支持可能不是那么完全,某些硬件配置下可能不起作用。

             


            Storage Devices: Windows Driver Kit

            IOCTL_ATA_PASS_THROUGH

            Operation

            Allows an application to send almost any ATA command to a target device, with the following restrictions:

            • If a class driver for the target type of device exists, the application must send the request to the class driver. Thus, an application can send this request directly to the system port driver for a target logical unit (LU) only if there is no class driver for the type of device connected to that LU. The system port driver does not check to determine if a device has been claimed by a class driver before processing a pass-through request. Therefore, if an application bypasses a class driver that has claimed a device and sends a pass-through request for that device directly to the port driver, a conflict for control of the device can occur between the class driver and the application.
            • This request cannot be used if the command requires the underlying driver to access memory directly. If the caller's command might require direct access to memory, use IOCTL_ATA_PASS_THROUGH_DIRECT instead.
            • Applications must not attempt to send a pass-through request asynchronously. All pass-through requests must be synchronous.
            • Applications do not require administrative privileges to send a pass-through request to a device, but they must have read-write access to the device.

            The calling application provides the ATA task file register contents for the intended command in the ATA_PASS_THROUGH_EX structure. The system double buffers all data transfers. This request is typically used for transferring small amounts of data (less than 16 KB).

            Input

            Parameters.DeviceIoControl.InputBufferLength indicates the size in bytes of the buffer at Irp->AssociatedIrp.SystemBuffer. If the embedded ATA command is a write operation, the size of the input buffer should be the sum of sizeof(ATA_PASS_THROUGH_EX) and the value in the DataTransferLength member of ATA_PASS_THROUGH_EX. The following pseudocode example shows how to calculate the buffer size:

            ULONG buffsize; // size of the buffer
            ATA_PASS_THROUGH_EX hdr;
            hdr.DataTransferLength = size in bytes of the data transfer
            buffsize = sizeof (ATA_PASS_THROUGH_EX) + hdr.DataTransferLength

            If the embedded ATA command is a read operation or a device control operation that does not involve data transfer, InputBufferLength should be equal to sizeof (ATA_PASS_THROUGH_EX).

            In either case, if InputBufferLength is less than sizeof (ATA_PASS_THROUGH_EX), the port driver fails the I/O request and returns an error.

            The buffer at Irp->AssociatedIrp.SystemBuffer should contain an ATA_PASS_THROUGH_EX structure, which includes a set of task file input registers that indicate the sort of command to be performed and its parameters. The caller must initialize all the members of this structure except for PathId, TargetId, and Lun, which the port driver fills in. For a data-out command, the DataBufferOffset member of the structure must point to a cache-aligned buffer containing the data to be written.

            Output

            The port driver formats the return data using an ATA_PASS_THROUGH_EX structure and stores the data in the buffer at Irp->AssociatedIrp.SystemBuffer.

            The port driver updates the DataTransferLength member of ATA_PASS_THROUGH_EX to indicate the amount of data actually transferred from the device. If the embedded ATA command is a write operation or a device control operation that does not transfer data, OutputBufferLength is equal to sizeof(ATA_PASS_THROUGH_EX). If the embedded ATA command is a read operation, OutputBufferLength is equal to sizeof(ATA_PASS_THROUGH_EX) + DataTransferLength.

            The port driver fills the CurrentTaskFile member with the values that are present in the device's output registers at the completion of the embedded ATA command. If the command was a data transfer, the port driver stores the transferred data in a cache-aligned buffer that is located at an offset of DataBufferOffset bytes from the beginning of the structure. The application is responsible for interpreting the contents of the output registers to determine what errors, if any, were returned by the device.

            I/O Status Block

            The Information member is set to the number of bytes returned in the output buffer at Irp->AssociatedIrp.SystemBuffer. The Status member is set to STATUS_SUCCESS or possibly to STATUS_BUFFER_TOO_SMALL or STATUS_INVALID_PARAMETER if the input Length value in ATA_PASS_THROUGH is improperly set.

            Requirements

            Versions: Available in Microsoft Windows Server 2003 and later operating systems.

            Headers: Defined in ntddscsi.h. Include ntddscsi.h.

            ? 2007 Microsoft Corporation
            Send feedback on this topic
            Windows Driver Kit
            Built on August 15, 2007

            Build machine: CAPEBUILD

            Requirements

            Versions: Available in Microsoft Windows Server 2003 and later operating systems.

            Headers: Defined in ntddscsi.h. Include ntddscsi.h.

             


            Storage Devices: Windows Driver Kit

            IOCTL_ATA_PASS_THROUGH_DIRECT

            Operation

            Allows an application to send almost any ATA command to a target device, with the following restrictions:

            • If a class driver for the target type of device exists, the application must send the request to the class driver. Thus, an application can send this request directly to the system port driver for a target logical unit only if there is no class driver for the device.
            • The application must use this request rather than IOCTL_ATA_PASS_THROUGH if the embedded ATA command might require the underlying miniport driver to access memory directly.

            If the ATA command requests a data transfer operation, the caller must set up a cache-aligned buffer from which, or into which, the driver can transfer data directly. The IOCTL_ATA_PASS_THROUGH_DIRECT request is typically used for transferring large amounts of data (more than 16 KB).

            Input

            Parameters.DeviceIoControl.InputBufferLength indicates the size in bytes of the buffer at Irp->AssociatedIrp.SystemBuffer. The value of InputBufferLength is fixed and does not depend on the amount of data transferred. It is equal to sizeof (ATA_PASS_THROUGH_DIRECT). If the size of the buffer is less than sizeof(ATA_PASS_THROUGH_DIRECT), the port driver fails the I/O request and returns an error.

            The buffer at Irp->AssociatedIrp.SystemBuffer contains an ATA_PASS_THROUGH_DIRECT structure that includes a set of task file input registers that indicate the sort of command to be performed. The caller must initialize all the members of this structure except for PathId, TargetId, and Lun, which the port driver fills in. For a data-out command, the DataBuffer member of ATA_PASS_THROUGH_DIRECT must point to a cache-aligned buffer containing the data to be written.

            Output

            The port driver formats the return data using an ATA_PASS_THROUGH_DIRECT structure that it stores in the buffer at Irp->AssociatedIrp.SystemBuffer. The port driver updates the DataTransferLength member of the ATA_PASS_THROUGH_DIRECT structure to indicate the amount of data that was transferred from the device.

            The port driver stores the transferred data in the cache-aligned buffer pointed to by the DataBuffer member of ATA_PASS_THROUGH_DIRECT.

            The port driver fills the CurrentTaskFile member of ATA_PASS_THROUGH_DIRECT with the values present in the device's output registers at the completion of the ATA command. The application is responsible for interpreting the contents of the output registers to determine what errors, if any, were returned by the device.

            I/O Status Block

            The Information member is set to the number of bytes returned in the output buffer at Irp->AssociatedIrp.SystemBuffer. The Status member is set to STATUS_SUCCESS or possibly to STATUS_BUFFER_TOO_SMALL or STATUS_INVALID_PARAMETER if the input Length value in ATA_PASS_THROUGH is improperly set.

            Requirements

            Headers: Defined in ntddscsi.h. Include ntddscsi.h.

            ? 2007 Microsoft Corporation
            Send feedback on this topic
            Windows Driver Kit
            Built on August 15, 2007

            Build machine: CAPEBUILD

            Requirements

            Headers: Defined in ntddscsi.h. Include ntddscsi.h.

            posted on 2008-07-01 14:12 FongLuo 閱讀(2783) 評論(0)  編輯 收藏 引用


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


            <2008年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導(dǎo)航

            常用鏈接

            留言簿

            隨筆分類(11)

            隨筆檔案(79)

            文章檔案(1)

            收藏夾(38)

            學(xué)習(xí)網(wǎng)站

            一般網(wǎng)站

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            久久91精品久久91综合| 香蕉久久AⅤ一区二区三区| 精品久久久久久久中文字幕| 久久天天躁狠狠躁夜夜网站 | 国产精品久久精品| 国内精品久久久久影院薰衣草| 亚洲精品视频久久久| 久久受www免费人成_看片中文 | 日韩精品久久久久久久电影蜜臀| 久久精品中文字幕一区| 久久午夜羞羞影院免费观看| 色综合久久综合中文综合网| 久久99国产精品久久| 久久最新精品国产| A级毛片无码久久精品免费| 久久久精品人妻一区二区三区蜜桃| 亚洲香蕉网久久综合影视| 99久久久精品| 久久久久国产一区二区| 久久久久久久综合狠狠综合| 国内精品伊人久久久久777| 国内精品人妻无码久久久影院 | 日韩精品无码久久久久久| 精品久久久久香蕉网| 久久精品国产72国产精福利| 久久久午夜精品| 国产精品成人99久久久久91gav| 亚洲国产高清精品线久久 | 中文字幕久久亚洲一区| 精品免费久久久久久久| 国产精品狼人久久久久影院 | 亚洲国产精品久久久天堂| 99久久综合狠狠综合久久| 久久91精品国产91久| 亚洲国产成人久久综合一| 国内精品久久久久影院薰衣草| 91久久成人免费| 久久精品无码专区免费东京热| 色综合久久天天综线观看| 一级做a爰片久久毛片16| 亚洲狠狠婷婷综合久久蜜芽|