⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 workqueue.c

📁 ReactOS是一些高手根据Windows XP的内核编写出的类XP。内核实现机理和API函数调用几乎相同。甚至可以兼容XP的程序。喜欢研究系统内核的人可以看一看。
💻 C
字号:
/*
 * COPYRIGHT:       See COPYING in the top level directory
 * PROJECT:         ReactOS kernel
 * FILE:            drivers/lib/chew/workqueue.c
 * PURPOSE:         Common Highlevel Executive Worker
 *
 * PROGRAMMERS:     arty (ayerkes@speakeasy.net)
 */
#include <ntddk.h>
#include <chew/chew.h>

#define NDEBUG

#define FOURCC(w,x,y,z) (((w) << 24) | ((x) << 16) | ((y) << 8) | (z))

PDEVICE_OBJECT WorkQueueDevice;
LIST_ENTRY     WorkQueue;
KSPIN_LOCK     WorkQueueLock;

typedef struct _WORK_ITEM {
    LIST_ENTRY Entry;
    PIO_WORKITEM WorkItem;
    VOID (*Worker)( PVOID Data );
    CHAR UserSpace[1];
} WORK_ITEM, *PWORK_ITEM;

VOID ChewInit( PDEVICE_OBJECT DeviceObject ) {
    WorkQueueDevice = DeviceObject;
    InitializeListHead( &WorkQueue );
    KeInitializeSpinLock( &WorkQueueLock );
}

VOID ChewShutdown() {
    KIRQL OldIrql;
    PLIST_ENTRY Entry;
    PWORK_ITEM WorkItem;

    KeAcquireSpinLock( &WorkQueueLock, &OldIrql );
    
    while( !IsListEmpty( &WorkQueue ) ) {
	Entry = RemoveHeadList( &WorkQueue );
	WorkItem = CONTAINING_RECORD( Entry, WORK_ITEM, Entry );
	IoFreeWorkItem( WorkItem->WorkItem );
	ExFreePool( WorkItem );
    }

    KeReleaseSpinLock( &WorkQueueLock, OldIrql );
}

VOID STDCALL ChewWorkItem( PDEVICE_OBJECT DeviceObject, PVOID ChewItem ) {
    PWORK_ITEM WorkItem = ChewItem;

    RemoveEntryList( &WorkItem->Entry );

    if( WorkItem->Worker ) 
	WorkItem->Worker( WorkItem->UserSpace );

    IoFreeWorkItem( WorkItem->WorkItem );
    ExFreePool( WorkItem );
}
    
BOOLEAN ChewCreate
( PVOID *ItemPtr, SIZE_T Bytes, VOID (*Worker)( PVOID ), PVOID UserSpace ) {
    PWORK_ITEM Item;
    
    if( KeGetCurrentIrql() == PASSIVE_LEVEL ) {
	if( ItemPtr )
	    *ItemPtr = NULL;
	Worker(UserSpace);
	return TRUE;
    } else {
	Item = ExAllocatePoolWithTag
	    ( NonPagedPool, 
	      sizeof( WORK_ITEM ) + Bytes - 1, 
	      FOURCC('C','H','E','W') );
	
	if( Item ) {
	    Item->WorkItem = IoAllocateWorkItem( WorkQueueDevice );
	    if( !Item->WorkItem ) {
		ExFreePool( Item );
		return FALSE;
	    }
	    Item->Worker = Worker;
	    if( Bytes && UserSpace )
		RtlCopyMemory( Item->UserSpace, UserSpace, Bytes );
	    
	    ExInterlockedInsertTailList
		( &WorkQueue, &Item->Entry, &WorkQueueLock );
	    IoQueueWorkItem
		( Item->WorkItem, ChewWorkItem, CriticalWorkQueue, Item );
	    
	    if( ItemPtr ) 
		*ItemPtr = Item;

	    return TRUE;
	} else {
	    return FALSE;
	}
    }
}

VOID ChewRemove( PVOID Item ) {
    PWORK_ITEM WorkItem = Item;
    IoFreeWorkItem( WorkItem->WorkItem );
    ExFreePool( WorkItem );
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -