Jump to content

KernWakeup: Difference between revisions

From EDM2
Created page with "==Synopsis== APIRET APIENTRY KernWakeup(ULONG eventid, ULONG flags, PULONG tcnt, ULONG retdata); ==Description== This wakes up threads that are blocking in KernBlock. The eve..."
 
Ak120 (talk | contribs)
mNo edit summary
Line 1: Line 1:
==Synopsis==
==Synopsis==
APIRET APIENTRY KernWakeup(ULONG eventid, ULONG flags, PULONG tcnt, ULONG retdata);
APIRET APIENTRY KernWakeup(ULONG eventid, ULONG flags, PULONG tcnt, ULONG retdata);


==Description==
==Description==
Line 6: Line 6:


==Parameters==
==Parameters==
 
;eventid:Event id of the blocked thread(s).
eventid
;flags:One or more of the following flag bits:
    Event id of the blocked thread(s).  
::KEE_WAKE_SINGLE - Only wakeup the first matching thread; by default, if multiple threads are waiting, all will be awaking.
flags
::KEE_WAKE_PRIOINCR - Run the woke threads with higher priority.
    One or more of the following flag bits:
::KEE_WAKE_RETDATA - return data value specified to the KernBlock retdata variable. By default, nothing is returned.
 
;tcnt:pointer to an ULONG to return the actual number of threads that were woke. Ignored when NULL.
    KEE_WAKE_SINGLE
;retdata:Data to be returned to the unblocked threads. Ignored when KEE_WAKE_RETDATA is not set.
        Only wakeup the first matching thread; by default, if multiple threads are waiting, all will be awaking.  
    KEE_WAKE_PRIOINCR
        Run the woke threads with higher priority.  
    KEE_WAKE_RETDATA
        return data value specified to the KernBlock retdata variable. By default, nothing is returned.  
 
tcnt
    pointer to an ULONG to return the actual number of threads that were woke. Ignored when NULL.  
retdata
    Data to be returned to the unblocked threads. Ignored when KEE_WAKE_RETDATA is not set.  


==Comments==
==Comments==

Revision as of 17:42, 20 October 2016

Synopsis

APIRET APIENTRY KernWakeup(ULONG eventid, ULONG flags, PULONG tcnt, ULONG retdata);

Description

This wakes up threads that are blocking in KernBlock. The eventid to be specified has to match the eventid used in KernBlock. It is possible to submit a 32 bit return value to the unblocked thread. The number of threads that are unblocked is returned. must match

Parameters

eventid
Event id of the blocked thread(s).
flags
One or more of the following flag bits:
KEE_WAKE_SINGLE - Only wakeup the first matching thread; by default, if multiple threads are waiting, all will be awaking.
KEE_WAKE_PRIOINCR - Run the woke threads with higher priority.
KEE_WAKE_RETDATA - return data value specified to the KernBlock retdata variable. By default, nothing is returned.
tcnt
pointer to an ULONG to return the actual number of threads that were woke. Ignored when NULL.
retdata
Data to be returned to the unblocked threads. Ignored when KEE_WAKE_RETDATA is not set.

Comments

I don't know whether the priority increase issued by KEE_WAKE_PRIOINCR is permanent, or only for the current timeslice. It shouldn't be permanent.