Jump to content

DevHelp PushRequest: Difference between revisions

From EDM2
 
(2 intermediate revisions by the same user not shown)
Line 1: Line 1:
{{DISPLAYTITLE:DevHelp_PushRequest}}
This service adds the current device request packet to the linked list of packets to be executed by the physical device driver.  
This service adds the current device request packet to the linked list of packets to be executed by the physical device driver.  


Line 44: Line 45:


PushRequest can also be used to place request packets that were allocated by AllocReqPacket in the request packet work queue.  
PushRequest can also be used to place request packets that were allocated by AllocReqPacket in the request packet work queue.  
==Alternative Names==
DevHelp_PushRequest, DevHlp_PushRequest, DevHelp_PushReqPacket.


==Example Code==
==Example Code==
Line 53: Line 57:
                                     PBYTE  ReqPktAddr );
                                     PBYTE  ReqPktAddr );
</PRE>
</PRE>
==Alternative Names==
DevHelp_PushRequest, DevHlp_PushRequest, DevHlp_PushReqPacket.


[[Category:DevHlps]]
[[Category:DevHlps]]

Latest revision as of 16:39, 23 May 2025

This service adds the current device request packet to the linked list of packets to be executed by the physical device driver.

Syntax

C

USHORT APIENTRY DevHelp_PushRequest( NPBYTE Queue, PBYTE  ReqPktAddr );

Assembler

MOV   SI,OFFSET DS:queue      ; Location of the DWORD queue head
                              ; (which points to the first request in the list)
LES   BX,request_packet       ; Pointer to request packet.

MOV   DL,DevHlp_PushRequest

CALL  [Device_Help]

Parameters

C

Queue (NPBYTE) - input
Location of the queue head which points to the first request in the list.
ReqPktAddr (PBYTE) - input
Pointer to the request packet.

Assembler

MOV   SI,OFFSET DS:queue      ; Location of the DWORD queue head
                              ; (which points to the first request in the list)
LES   BX,request_packet       ; Pointer to request packet.

Return Code

C

Success Indicator: 0

Possible errors: None.

Assembler

None

Remarks

A physical device driver uses PushRequest and PullRequest to maintain a work queue for each of its devices. The physical device driver must provide the storage for the DWORD work queue head, which defines the start of the request packet linked list. The work queue head must be initialized to 0.

The physical device driver task-time thread adds all incoming Read/Write requests to its Request List. The device driver task-time thread then determines whether the interrupt-time thread is active, and if not, it sends the request to the device. Because the device can be active at this point, the device driver task-time thread must turn off interrupts before calling the device; otherwise, a window exists in which the device finishes before the packet is put on the list.

PushRequest can also be used to place request packets that were allocated by AllocReqPacket in the request packet work queue.

Alternative Names

DevHelp_PushRequest, DevHlp_PushRequest, DevHelp_PushReqPacket.

Example Code

C

#include  "dhcalls.h"

USHORT APIENTRY DevHelp_PushRequest( NPBYTE Queue,
                                     PBYTE  ReqPktAddr );

Alternative Names

DevHelp_PushRequest, DevHlp_PushRequest, DevHlp_PushReqPacket.