libintrovirt v0.57.4
IntroVirt introspection library
Loading...
Searching...
No Matches
NtCreateProcessBase.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"
22
25
26#include <memory>
27
28namespace introvirt {
29namespace windows {
30namespace nt {
31
36 public:
37 /* Direct parameter getters */
38
44 virtual guest_ptr<void> ProcessHandlePtr() const = 0;
62 virtual uint64_t ParentProcess() const = 0;
68 virtual uint64_t SectionHandle() const = 0;
74 virtual uint64_t DebugPort() const = 0;
80 virtual uint64_t ExceptionPort() const = 0;
81
82 /* Direct parameter setters */
83
89 virtual void ProcessHandlePtr(const guest_ptr<void>& pProcessHandle) = 0;
101 virtual void ObjectAttributesPtr(const guest_ptr<void>& pObjectAttributes) = 0;
107 virtual void ParentProcess(uint64_t ParentProcess) = 0;
113 virtual void SectionHandle(uint64_t SectionHandle) = 0;
119 virtual void DebugPort(uint64_t DebugPort) = 0;
125 virtual void ExceptionPort(uint64_t ExceptionPort) = 0;
126
127 /* Helper methods */
128 virtual uint64_t ProcessHandle() const = 0;
129 virtual void ProcessHandle(uint64_t ProcessHandle) = 0;
130 virtual const OBJECT_ATTRIBUTES* ObjectAttributes() const = 0;
138 virtual std::shared_ptr<PROCESS> get_new_process() = 0;
139
143 virtual const std::shared_ptr<PROCESS> get_new_process() const = 0;
144};
145
146} /* namespace nt */
147} /* namespace windows */
148} /* namespace introvirt */
Definition guest_ptr.hh:88
Handler class for the NtCreateProcessBase system call.
Definition NtCreateProcessBase.hh:35
virtual void ObjectAttributesPtr(const guest_ptr< void > &pObjectAttributes)=0
Setter for ObjectAttributesPtr.
virtual PROCESS_ACCESS_MASK DesiredAccess() const =0
Getter for DesiredAccess.
virtual guest_ptr< void > ProcessHandlePtr() const =0
Getter for ProcessHandlePtr.
virtual void DebugPort(uint64_t DebugPort)=0
Setter for DebugPort.
virtual std::shared_ptr< PROCESS > get_new_process()=0
Get the newly created PROCESS object.
virtual uint64_t SectionHandle() const =0
Getter for SectionHandle.
virtual void ExceptionPort(uint64_t ExceptionPort)=0
Setter for ExceptionPort.
virtual const std::shared_ptr< PROCESS > get_new_process() const =0
Get the newly created PROCESS object.
virtual void ParentProcess(uint64_t ParentProcess)=0
Setter for ParentProcess.
virtual void SectionHandle(uint64_t SectionHandle)=0
Setter for SectionHandle.
virtual const OBJECT_ATTRIBUTES * ObjectAttributes() const =0
virtual guest_ptr< void > ObjectAttributesPtr() const =0
Getter for ObjectAttributesPtr.
virtual uint64_t DebugPort() const =0
Getter for DebugPort.
virtual void DesiredAccess(PROCESS_ACCESS_MASK DesiredAccess)=0
Setter for DesiredAccess.
virtual uint64_t ParentProcess() const =0
Getter for ParentProcess.
virtual void ProcessHandlePtr(const guest_ptr< void > &pProcessHandle)=0
Setter for ProcessHandlePtr.
virtual void ProcessHandle(uint64_t ProcessHandle)=0
virtual uint64_t ProcessHandle() const =0
virtual OBJECT_ATTRIBUTES * ObjectAttributes()=0
virtual uint64_t ExceptionPort() const =0
Getter for ExceptionPort.
Base type for NT system calls.
Definition NtSystemCall.hh:29
Definition OBJECT_ATTRIBUTES.hh:38
ACCESS_MASK class for process permissions.
Definition PROCESS_ACCESS_MASK.hh:72
Core IntroVirt classes.
Definition Cr0.hh:20