libintrovirt v0.57.4
IntroVirt introspection library
Loading...
Searching...
No Matches
NtQueueApcThread.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"
21
22#include <memory>
23
24namespace introvirt {
25namespace windows {
26namespace nt {
27
32 public:
33 /* Direct parameter getters */
34
40 virtual uint64_t ThreadHandle() const = 0;
46 virtual guest_ptr<void> ApcRoutinePtr() const = 0;
64 virtual uint32_t ApcReserved() const = 0;
65
66 /* Direct parameter setters */
67
73 virtual void ThreadHandle(uint64_t ThreadHandle) = 0;
79 virtual void ApcRoutinePtr(const guest_ptr<void>& pApcRoutine) = 0;
85 virtual void ApcRoutineContextPtr(const guest_ptr<void>& pApcRoutineContext) = 0;
91 virtual void ApcStatusBlockPtr(const guest_ptr<void>& pApcStatusBlock) = 0;
97 virtual void ApcReserved(uint32_t ApcReserved) = 0;
98
99 /*
100 * System call injection support. You probably want to use
101 * inject::system_call<NtQueueApcThread>.
102 */
103 static NTSTATUS inject(uint64_t ThreadHandle, const guest_ptr<void>& pApcRoutine,
104 const guest_ptr<void>& pApcRoutineContext,
105 const guest_ptr<void>& pApcStatusBlock, uint32_t ApcReserved);
106};
107
108} /* namespace nt */
109} /* namespace windows */
110} /* namespace introvirt */
Definition guest_ptr.hh:88
Status codes returned by Windows NT system calls.
Definition NTSTATUS.hh:34
Handler class for the NtQueueApcThread system call.
Definition NtQueueApcThread.hh:31
virtual void ApcRoutineContextPtr(const guest_ptr< void > &pApcRoutineContext)=0
Setter for ApcRoutineContextPtr.
virtual uint32_t ApcReserved() const =0
Getter for ApcReserved.
virtual guest_ptr< void > ApcRoutineContextPtr() const =0
Getter for ApcRoutineContextPtr.
virtual void ApcStatusBlockPtr(const guest_ptr< void > &pApcStatusBlock)=0
Setter for ApcStatusBlockPtr.
virtual guest_ptr< void > ApcStatusBlockPtr() const =0
Getter for ApcStatusBlockPtr.
virtual uint64_t ThreadHandle() const =0
Getter for ThreadHandle.
virtual guest_ptr< void > ApcRoutinePtr() const =0
Getter for ApcRoutinePtr.
virtual void ApcRoutinePtr(const guest_ptr< void > &pApcRoutine)=0
Setter for ApcRoutinePtr.
virtual void ApcReserved(uint32_t ApcReserved)=0
Setter for ApcReserved.
virtual void ThreadHandle(uint64_t ThreadHandle)=0
Setter for ThreadHandle.
static NTSTATUS inject(uint64_t ThreadHandle, const guest_ptr< void > &pApcRoutine, const guest_ptr< void > &pApcRoutineContext, const guest_ptr< void > &pApcStatusBlock, uint32_t ApcReserved)
Base type for NT system calls.
Definition NtSystemCall.hh:29
Core IntroVirt classes.
Definition Cr0.hh:20