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

📄 procname.h

📁 臭氧层主动防御系统驱动源代码!臭氧层主动防御系统驱动源代码!
💻 H
字号:
/*
 * Copyright (c) 2004 Security Architects Corporation. All rights reserved.
 *
 * Module Name:
 *
 *		procname.h
 *
 * Abstract:
 *
 *		This module defines various types used by process id to process name conversion routines.
 *
 * Author:
 *
 *		Eugene Tsyrklevich 23-Feb-2004
 *
 * Revision History:
 *
 *		07-Apr-2004 ET - Copied from process.h
 */

#ifndef __PROCNAME_H__
#define __PROCNAME_H__


#include "userland.h"


typedef struct	_IMAGE_PID_ENTRY
{
	struct _IMAGE_PID_ENTRY		*next;
	ULONG						ProcessId;
	ULONG						ParentId;
	BOOLEAN						FirstThread;				// Was more than one thread already created?
															// (some actions need to take place only in the main thread)
	UCHAR						WaitingForUserRequestId;	// contains the sequence id of the reply we are waiting for
	KEVENT						UserlandRequestDoneEvent;
	PUSERLAND_REPLY_HEADER		UserlandReply;
	SECURITY_POLICY				SecPolicy;
	WCHAR						ImageName[1];

} IMAGE_PID_ENTRY, *PIMAGE_PID_ENTRY;


/*
 * 1. The following number should be prime.
 * 2. It should also be slightly larger than the "average" number of processes of any given machine to
 *    minimize the number of hash table collisions (we want O(1) access) and at the same time not
 *    eating up too much memory (gImagePidHtbl[]).
 */
#define	IMAGE_PID_HASHTABLE_SIZE	67

extern IMAGE_PID_ENTRY	gImagePidHtbl[IMAGE_PID_HASHTABLE_SIZE];

extern USHORT			ProcessNameOffset, ThreadServiceTableOffset;
extern BOOLEAN			BootingUp;


BOOLEAN				InitProcessNameEntries();
VOID				RemoveProcessNameEntries();
PIMAGE_PID_ENTRY	FindImagePidEntry(ULONG ProcessId, ULONG ParentId);
BOOLEAN				ProcessInsertImagePidEntry(ULONG ProcessId, PIMAGE_PID_ENTRY NewProcess);
PIMAGE_PID_ENTRY	CreateNewProcessEntry(ULONG ProcessId, ULONG ParentId, PUNICODE_STRING ProcessName, BOOLEAN NewProcess);
//PIMAGE_PID_ENTRY	CreateAndLoadNewProcessEntry(ULONG ProcessId, PUNICODE_STRING ProcessName, BOOLEAN NewProcess);
VOID				EnumerateExistingProcesses();
PWCHAR				GetCurrentProcessName();


#endif	/* __PROCNAME_H__ */

⌨️ 快捷键说明

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