libintrovirt v0.57.4
IntroVirt introspection library
Loading...
Searching...
No Matches
NtQueryInformationProcess.hh
Go to the documentation of this file.
1/*
2 * Copyright 2021 Assured Information Security, Inc.
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17/* This file is automatically generated. Do not edit. */
18#pragma once
19
20#include "NtSystemCall.hh"
23
24#include <memory>
25
26namespace introvirt {
27namespace windows {
28namespace nt {
29
34 public:
35 /* Direct parameter getters */
36
42 virtual uint64_t ProcessHandle() const = 0;
60 virtual uint32_t ProcessInformationLength() const = 0;
66 virtual guest_ptr<void> ResultLengthPtr() const = 0;
67
68 /* Direct parameter setters */
69
75 virtual void ProcessHandle(uint64_t ProcessHandle) = 0;
87 virtual void ProcessInformationPtr(const guest_ptr<void>& pProcessInformation) = 0;
99 virtual void ResultLengthPtr(const guest_ptr<void>& pResultLength) = 0;
100
101 /* Helper methods */
102 virtual const PROCESS_INFORMATION* ProcessInformation() const = 0;
104 virtual uint32_t ResultLength() const = 0;
105 virtual void ResultLength(uint32_t ResultLength) = 0;
106
107 /*
108 * System call injection support. You probably want to use
109 * inject::system_call<NtQueryInformationProcess>.
110 */
113 const guest_ptr<void>& pProcessInformation,
114 uint32_t ProcessInformationLength, uint32_t* ResultLength);
115};
116
117} /* namespace nt */
118} /* namespace windows */
119} /* namespace introvirt */
Definition guest_ptr.hh:88
Status codes returned by Windows NT system calls.
Definition NTSTATUS.hh:34
Handler class for the NtQueryInformationProcess system call.
Definition NtQueryInformationProcess.hh:33
virtual guest_ptr< void > ResultLengthPtr() const =0
Getter for ResultLengthPtr.
virtual void ProcessInformationPtr(const guest_ptr< void > &pProcessInformation)=0
Setter for ProcessInformationPtr.
virtual PROCESS_INFORMATION * ProcessInformation()=0
virtual const PROCESS_INFORMATION * ProcessInformation() const =0
static NTSTATUS inject(uint64_t ProcessHandle, PROCESS_INFORMATION_CLASS ProcessInformationClass, const guest_ptr< void > &pProcessInformation, uint32_t ProcessInformationLength, uint32_t *ResultLength)
virtual guest_ptr< void > ProcessInformationPtr() const =0
Getter for ProcessInformationPtr.
virtual void ProcessInformationLength(uint32_t ProcessInformationLength)=0
Setter for ProcessInformationLength.
virtual uint64_t ProcessHandle() const =0
Getter for ProcessHandle.
virtual PROCESS_INFORMATION_CLASS ProcessInformationClass() const =0
Getter for ProcessInformationClass.
virtual void ResultLengthPtr(const guest_ptr< void > &pResultLength)=0
Setter for ResultLengthPtr.
virtual uint32_t ProcessInformationLength() const =0
Getter for ProcessInformationLength.
virtual void ResultLength(uint32_t ResultLength)=0
virtual void ProcessHandle(uint64_t ProcessHandle)=0
Setter for ProcessHandle.
virtual void ProcessInformationClass(PROCESS_INFORMATION_CLASS ProcessInformationClass)=0
Setter for ProcessInformationClass.
Base type for NT system calls.
Definition NtSystemCall.hh:29
Definition PROCESS_INFORMATION.hh:32
PROCESS_INFORMATION_CLASS
Definition PROCESS_INFORMATION_CLASS.hh:25
Core IntroVirt classes.
Definition Cr0.hh:20