@cheatron/native-mock 1.0.0 → 1.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/index.d.ts +7 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +6 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/kernel32.d.ts +31 -0
- package/dist/src/kernel32.d.ts.map +1 -0
- package/dist/src/kernel32.js +232 -0
- package/dist/src/kernel32.js.map +1 -0
- package/dist/src/logger.d.ts.map +1 -0
- package/dist/{logger.js → src/logger.js} +1 -0
- package/dist/src/logger.js.map +1 -0
- package/dist/src/msvcrt.d.ts +15 -0
- package/dist/src/msvcrt.d.ts.map +1 -0
- package/dist/src/msvcrt.js +43 -0
- package/dist/src/msvcrt.js.map +1 -0
- package/dist/src/os/handles.d.ts +17 -0
- package/dist/src/os/handles.d.ts.map +1 -0
- package/dist/{os → src/os}/handles.js +2 -0
- package/dist/src/os/handles.js.map +1 -0
- package/dist/src/os/kernel.d.ts +21 -0
- package/dist/src/os/kernel.d.ts.map +1 -0
- package/dist/{os → src/os}/kernel.js +36 -1
- package/dist/src/os/kernel.js.map +1 -0
- package/dist/{os → src/os}/memory.d.ts +1 -5
- package/dist/src/os/memory.d.ts.map +1 -0
- package/dist/{os → src/os}/memory.js +3 -8
- package/dist/src/os/memory.js.map +1 -0
- package/dist/src/os/module.d.ts +11 -0
- package/dist/src/os/module.d.ts.map +1 -0
- package/dist/src/os/module.js +20 -0
- package/dist/src/os/module.js.map +1 -0
- package/dist/{os → src/os}/process.d.ts +4 -0
- package/dist/src/os/process.d.ts.map +1 -0
- package/dist/{os → src/os}/process.js +12 -0
- package/dist/src/os/process.js.map +1 -0
- package/dist/{os → src/os}/thread.d.ts +4 -4
- package/dist/src/os/thread.d.ts.map +1 -0
- package/dist/{os → src/os}/thread.js +1 -0
- package/dist/src/os/thread.js.map +1 -0
- package/dist/utils/src/handle.d.ts +26 -0
- package/dist/utils/src/handle.d.ts.map +1 -0
- package/dist/utils/src/handle.js +56 -0
- package/dist/utils/src/handle.js.map +1 -0
- package/dist/utils/src/index.d.ts +4 -0
- package/dist/utils/src/index.d.ts.map +1 -0
- package/dist/utils/src/index.js +4 -0
- package/dist/utils/src/index.js.map +1 -0
- package/dist/utils/src/module.d.ts +22 -0
- package/dist/utils/src/module.d.ts.map +1 -0
- package/dist/utils/src/module.js +54 -0
- package/dist/utils/src/module.js.map +1 -0
- package/dist/utils/src/process.d.ts +30 -0
- package/dist/utils/src/process.d.ts.map +1 -0
- package/dist/utils/src/process.js +103 -0
- package/dist/utils/src/process.js.map +1 -0
- package/dist/utils/src/thread.d.ts +38 -0
- package/dist/utils/src/thread.d.ts.map +1 -0
- package/dist/utils/src/thread.js +136 -0
- package/dist/utils/src/thread.js.map +1 -0
- package/package.json +7 -7
- package/dist/constants.d.ts +0 -175
- package/dist/constants.d.ts.map +0 -1
- package/dist/constants.js +0 -173
- package/dist/index.d.ts +0 -5
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -4
- package/dist/kernel32.d.ts +0 -22
- package/dist/kernel32.d.ts.map +0 -1
- package/dist/kernel32.js +0 -170
- package/dist/logger.d.ts.map +0 -1
- package/dist/os/handles.d.ts +0 -17
- package/dist/os/handles.d.ts.map +0 -1
- package/dist/os/kernel.d.ts +0 -18
- package/dist/os/kernel.d.ts.map +0 -1
- package/dist/os/memory.d.ts.map +0 -1
- package/dist/os/process.d.ts.map +0 -1
- package/dist/os/thread.d.ts.map +0 -1
- package/dist/process.d.ts +0 -30
- package/dist/process.d.ts.map +0 -1
- package/dist/process.js +0 -124
- package/dist/thread.d.ts +0 -28
- package/dist/thread.d.ts.map +0 -1
- package/dist/thread.js +0 -113
- /package/dist/{logger.d.ts → src/logger.d.ts} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,cAAc,YAAY,CAAC;AAC3B,cAAc,UAAU,CAAC;AACzB,cAAc,qBAAqB,CAAC;AACpC,mBAAmB,qBAAqB,CAAC;AACzC,cAAc,wBAAwB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,cAAc,YAAY,CAAC;AAC3B,cAAc,UAAU,CAAC;AACzB,cAAc,qBAAqB,CAAC;AAEpC,cAAc,wBAAwB,CAAC"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import * as Def from '@cheatron/win32-ext';
|
|
2
|
+
export declare const Kernel32Impl: {
|
|
3
|
+
OpenProcess: (dwDesiredAccess: Def.DWORD, bInheritHandle: Def.BOOL, dwProcessId: Def.DWORD) => Def.HANDLE;
|
|
4
|
+
GetCurrentProcess: () => Def.HANDLE;
|
|
5
|
+
GetCurrentProcessId: () => Def.DWORD;
|
|
6
|
+
GetProcessId: (hProcess: Def.HANDLE) => Def.DWORD;
|
|
7
|
+
CloseHandle: (hObject: Def.HANDLE) => Def.BOOL;
|
|
8
|
+
ReadProcessMemory: (hProcess: Def.HANDLE, lpBaseAddress: Def.LPCVOID, lpBuffer: Buffer, nSize: Def.SIZE_T, _lpNumberOfBytesRead: Def.SIZE_T | null) => Def.BOOL;
|
|
9
|
+
WriteProcessMemory: (hProcess: Def.HANDLE, lpBaseAddress: Def.LPVOID, lpBuffer: Buffer, nSize: Def.SIZE_T, _lpNumberOfBytesWritten: Def.SIZE_T | null) => Def.BOOL;
|
|
10
|
+
VirtualAlloc: (lpAddress: Def.LPVOID | null, dwSize: Def.SIZE_T, flAllocationType: Def.DWORD, flProtect: Def.DWORD) => Def.LPVOID;
|
|
11
|
+
VirtualAllocEx: (hProcess: Def.HANDLE, lpAddress: Def.LPVOID | null, dwSize: Def.SIZE_T, flAllocationType: Def.DWORD, flProtect: Def.DWORD) => Def.LPVOID;
|
|
12
|
+
VirtualQuery: (lpAddress: Def.LPCVOID, lpBuffer: Buffer, dwLength: Def.SIZE_T) => Def.SIZE_T;
|
|
13
|
+
VirtualQueryEx: (hProcess: Def.HANDLE, lpAddress: Def.LPCVOID, lpBuffer: Buffer, dwLength: Def.SIZE_T) => Def.SIZE_T;
|
|
14
|
+
OpenThread: (dwDesiredAccess: Def.DWORD, bInheritHandle: Def.BOOL, dwThreadId: Def.DWORD) => Def.HANDLE;
|
|
15
|
+
GetCurrentThread: () => Def.HANDLE;
|
|
16
|
+
GetCurrentThreadId: () => Def.DWORD;
|
|
17
|
+
GetThreadId: (hThread: Def.HANDLE) => Def.DWORD;
|
|
18
|
+
SuspendThread: (hThread: Def.HANDLE) => Def.DWORD;
|
|
19
|
+
ResumeThread: (hThread: Def.HANDLE) => Def.DWORD;
|
|
20
|
+
GetExitCodeThread: (hThread: Def.HANDLE, lpExitCode: Buffer) => Def.BOOL;
|
|
21
|
+
GetThreadContext: (hThread: Def.HANDLE, _lpContext: Buffer) => Def.BOOL;
|
|
22
|
+
SetThreadContext: (hThread: Def.HANDLE, _lpContext: Buffer) => Def.BOOL;
|
|
23
|
+
CreateThread: (_lpThreadAttributes: Def.SecurityAttributes | Def.LPVOID | null, _dwStackSize: Def.SIZE_T, _lpStartAddress: Def.LPVOID, _lpParameter: Def.LPVOID | null, _dwCreationFlags: Def.ThreadCreationFlags | Def.DWORD, lpThreadId: Buffer | null) => Def.HANDLE;
|
|
24
|
+
CreateRemoteThread: (hProcess: Def.HANDLE, _lpThreadAttributes: Def.SecurityAttributes | Def.LPVOID | null, _dwStackSize: Def.SIZE_T, _lpStartAddress: Def.LPVOID, _lpParameter: Def.LPVOID | null, _dwCreationFlags: Def.ThreadCreationFlags | Def.DWORD, lpThreadId: Buffer | null) => Def.HANDLE;
|
|
25
|
+
WaitForSingleObject: (hHandle: Def.HANDLE, _dwMilliseconds: Def.DWORD) => Def.DWORD;
|
|
26
|
+
GetModuleHandleW: (lpModuleName: string | null) => Def.HMODULE;
|
|
27
|
+
GetModuleHandleA: (lpModuleName: string | null) => Def.HMODULE;
|
|
28
|
+
GetProcAddress: (hModule: Def.HMODULE, lpProcName: string) => Def.LPVOID;
|
|
29
|
+
GetLastError: () => Def.DWORD;
|
|
30
|
+
};
|
|
31
|
+
//# sourceMappingURL=kernel32.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kernel32.d.ts","sourceRoot":"","sources":["../../src/kernel32.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,232 @@
|
|
|
1
|
+
import * as Def from '@cheatron/win32-ext';
|
|
2
|
+
import { kernel } from './os/kernel';
|
|
3
|
+
import { SimulatedProcess } from './os/process';
|
|
4
|
+
import { SimulatedThread } from './os/thread';
|
|
5
|
+
// Constants
|
|
6
|
+
const PSEUDO_HANDLE_PROCESS = 0xffffffffffffffffn; // -1
|
|
7
|
+
const PSEUDO_HANDLE_THREAD = 0xfffffffffffffffen; // -2
|
|
8
|
+
export const Kernel32Impl = {
|
|
9
|
+
// Process
|
|
10
|
+
OpenProcess: (dwDesiredAccess, bInheritHandle, dwProcessId) => {
|
|
11
|
+
return kernel.OpenProcess(dwDesiredAccess, !!bInheritHandle, dwProcessId);
|
|
12
|
+
},
|
|
13
|
+
GetCurrentProcess: () => PSEUDO_HANDLE_PROCESS,
|
|
14
|
+
GetCurrentProcessId: () => kernel.currentProcess.id,
|
|
15
|
+
GetProcessId: (hProcess) => kernel.GetProcessId(hProcess),
|
|
16
|
+
CloseHandle: (hObject) => {
|
|
17
|
+
return kernel.CloseHandle(hObject) ? 1 : 0;
|
|
18
|
+
},
|
|
19
|
+
// Memory
|
|
20
|
+
ReadProcessMemory: (hProcess, lpBaseAddress, lpBuffer, nSize, _lpNumberOfBytesRead) => {
|
|
21
|
+
let process;
|
|
22
|
+
if (hProcess === PSEUDO_HANDLE_PROCESS) {
|
|
23
|
+
process = kernel.currentProcess;
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
const handleObj = kernel.getObjectFromHandle(hProcess);
|
|
27
|
+
if (handleObj && handleObj.type === 'Process') {
|
|
28
|
+
process = handleObj.object;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
if (!process)
|
|
32
|
+
return 0;
|
|
33
|
+
try {
|
|
34
|
+
const data = process.memory.read(Number(lpBaseAddress), Number(nSize));
|
|
35
|
+
data.copy(lpBuffer);
|
|
36
|
+
return 1;
|
|
37
|
+
}
|
|
38
|
+
catch (_e) {
|
|
39
|
+
return 0;
|
|
40
|
+
}
|
|
41
|
+
},
|
|
42
|
+
WriteProcessMemory: (hProcess, lpBaseAddress, lpBuffer, nSize, _lpNumberOfBytesWritten) => {
|
|
43
|
+
let process;
|
|
44
|
+
if (hProcess === PSEUDO_HANDLE_PROCESS) {
|
|
45
|
+
process = kernel.currentProcess;
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
const handleObj = kernel.getObjectFromHandle(hProcess);
|
|
49
|
+
if (handleObj && handleObj.type === 'Process') {
|
|
50
|
+
process = handleObj.object;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
if (!process)
|
|
54
|
+
return 0;
|
|
55
|
+
const dataToWrite = lpBuffer.subarray(0, Number(nSize));
|
|
56
|
+
try {
|
|
57
|
+
if (process.memory.write(Number(lpBaseAddress), dataToWrite) > 0) {
|
|
58
|
+
return 1;
|
|
59
|
+
}
|
|
60
|
+
return 0;
|
|
61
|
+
}
|
|
62
|
+
catch (_e) {
|
|
63
|
+
return 0;
|
|
64
|
+
}
|
|
65
|
+
},
|
|
66
|
+
VirtualAlloc: (lpAddress, dwSize, flAllocationType, flProtect) => {
|
|
67
|
+
return Kernel32Impl.VirtualAllocEx(PSEUDO_HANDLE_PROCESS, lpAddress, dwSize, flAllocationType, flProtect);
|
|
68
|
+
},
|
|
69
|
+
VirtualAllocEx: (hProcess, lpAddress, dwSize, flAllocationType, flProtect) => {
|
|
70
|
+
let process;
|
|
71
|
+
if (hProcess === PSEUDO_HANDLE_PROCESS) {
|
|
72
|
+
process = kernel.currentProcess;
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
const handleObj = kernel.getObjectFromHandle(hProcess);
|
|
76
|
+
if (handleObj && handleObj.type === 'Process') {
|
|
77
|
+
process = handleObj.object;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
if (!process)
|
|
81
|
+
return 0n;
|
|
82
|
+
try {
|
|
83
|
+
const addr = process.memory.allocate(Number(lpAddress || 0), Number(dwSize), flAllocationType, flProtect);
|
|
84
|
+
return BigInt(addr);
|
|
85
|
+
}
|
|
86
|
+
catch (_e) {
|
|
87
|
+
return 0n;
|
|
88
|
+
}
|
|
89
|
+
},
|
|
90
|
+
VirtualQuery: (lpAddress, lpBuffer, dwLength) => {
|
|
91
|
+
return Kernel32Impl.VirtualQueryEx(PSEUDO_HANDLE_PROCESS, lpAddress, lpBuffer, dwLength);
|
|
92
|
+
},
|
|
93
|
+
VirtualQueryEx: (hProcess, lpAddress, lpBuffer, dwLength) => {
|
|
94
|
+
let process;
|
|
95
|
+
if (hProcess === PSEUDO_HANDLE_PROCESS) {
|
|
96
|
+
process = kernel.currentProcess;
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
const handleObj = kernel.getObjectFromHandle(hProcess);
|
|
100
|
+
if (handleObj && handleObj.type === 'Process') {
|
|
101
|
+
process = handleObj.object;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
if (!process)
|
|
105
|
+
return 0n;
|
|
106
|
+
const info = process.memory.query(Number(lpAddress));
|
|
107
|
+
// Serialize info to lpBuffer (PMEMORY_BASIC_INFORMATION)
|
|
108
|
+
lpBuffer.writeBigUInt64LE(BigInt(info.BaseAddress), 0);
|
|
109
|
+
lpBuffer.writeBigUInt64LE(BigInt(info.AllocationBase), 8);
|
|
110
|
+
lpBuffer.writeUInt32LE(info.AllocationProtect, 16);
|
|
111
|
+
lpBuffer.writeBigUInt64LE(BigInt(info.RegionSize), 24);
|
|
112
|
+
lpBuffer.writeUInt32LE(info.State, 32);
|
|
113
|
+
lpBuffer.writeUInt32LE(info.Protect, 36);
|
|
114
|
+
lpBuffer.writeUInt32LE(info.Type, 40);
|
|
115
|
+
return BigInt(dwLength);
|
|
116
|
+
},
|
|
117
|
+
// Thread
|
|
118
|
+
OpenThread: (dwDesiredAccess, bInheritHandle, dwThreadId) => {
|
|
119
|
+
return kernel.OpenThread(dwDesiredAccess, !!bInheritHandle, dwThreadId);
|
|
120
|
+
},
|
|
121
|
+
GetCurrentThread: () => PSEUDO_HANDLE_THREAD,
|
|
122
|
+
GetCurrentThreadId: () => kernel.GetThreadId(PSEUDO_HANDLE_THREAD),
|
|
123
|
+
GetThreadId: (hThread) => kernel.GetThreadId(hThread),
|
|
124
|
+
SuspendThread: (hThread) => {
|
|
125
|
+
if (hThread === PSEUDO_HANDLE_THREAD) {
|
|
126
|
+
// Find current thread of current process
|
|
127
|
+
const tid = kernel.GetThreadId(hThread);
|
|
128
|
+
const thread = kernel.currentProcess.getThread(tid);
|
|
129
|
+
return thread ? thread.suspend() : 0;
|
|
130
|
+
}
|
|
131
|
+
const handleObj = kernel.getObjectFromHandle(hThread);
|
|
132
|
+
if (handleObj && handleObj.type === 'Thread') {
|
|
133
|
+
return handleObj.object.suspend();
|
|
134
|
+
}
|
|
135
|
+
return 0;
|
|
136
|
+
},
|
|
137
|
+
ResumeThread: (hThread) => {
|
|
138
|
+
if (hThread === PSEUDO_HANDLE_THREAD) {
|
|
139
|
+
const tid = kernel.GetThreadId(hThread);
|
|
140
|
+
const thread = kernel.currentProcess.getThread(tid);
|
|
141
|
+
return thread ? thread.resume() : 0;
|
|
142
|
+
}
|
|
143
|
+
const handleObj = kernel.getObjectFromHandle(hThread);
|
|
144
|
+
if (handleObj && handleObj.type === 'Thread') {
|
|
145
|
+
return handleObj.object.resume();
|
|
146
|
+
}
|
|
147
|
+
return 0;
|
|
148
|
+
},
|
|
149
|
+
GetExitCodeThread: (hThread, lpExitCode) => {
|
|
150
|
+
const handleObj = kernel.getObjectFromHandle(hThread);
|
|
151
|
+
if (handleObj && handleObj.type === 'Thread') {
|
|
152
|
+
const thread = handleObj.object;
|
|
153
|
+
lpExitCode.writeUInt32LE(thread.state === 4 /* TERMINATED */ ? 0 : 259 /* STILL_ACTIVE */, 0);
|
|
154
|
+
return 1;
|
|
155
|
+
}
|
|
156
|
+
return 0;
|
|
157
|
+
},
|
|
158
|
+
GetThreadContext: (hThread, _lpContext) => {
|
|
159
|
+
const handleObj = kernel.getObjectFromHandle(hThread);
|
|
160
|
+
if (handleObj && handleObj.type === 'Thread') {
|
|
161
|
+
handleObj.object.getContext(0);
|
|
162
|
+
// Context serialization would go here. For now just 1.
|
|
163
|
+
return 1;
|
|
164
|
+
}
|
|
165
|
+
return 0;
|
|
166
|
+
},
|
|
167
|
+
SetThreadContext: (hThread, _lpContext) => {
|
|
168
|
+
const handleObj = kernel.getObjectFromHandle(hThread);
|
|
169
|
+
return handleObj && handleObj.type === 'Thread' ? 1 : 0;
|
|
170
|
+
},
|
|
171
|
+
CreateThread: (_lpThreadAttributes, _dwStackSize, _lpStartAddress, _lpParameter, _dwCreationFlags, lpThreadId) => {
|
|
172
|
+
return Kernel32Impl.CreateRemoteThread(PSEUDO_HANDLE_PROCESS, _lpThreadAttributes, _dwStackSize, _lpStartAddress, _lpParameter, _dwCreationFlags, lpThreadId);
|
|
173
|
+
},
|
|
174
|
+
CreateRemoteThread: (hProcess, _lpThreadAttributes, _dwStackSize, _lpStartAddress, _lpParameter, _dwCreationFlags, lpThreadId) => {
|
|
175
|
+
let process;
|
|
176
|
+
if (hProcess === PSEUDO_HANDLE_PROCESS) {
|
|
177
|
+
process = kernel.currentProcess;
|
|
178
|
+
}
|
|
179
|
+
else {
|
|
180
|
+
const handleObj = kernel.getObjectFromHandle(hProcess);
|
|
181
|
+
if (handleObj && handleObj.type === 'Process') {
|
|
182
|
+
process = handleObj.object;
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
if (!process)
|
|
186
|
+
return 0n;
|
|
187
|
+
const thread = process.createThread();
|
|
188
|
+
if (lpThreadId) {
|
|
189
|
+
lpThreadId.writeUInt32LE(thread.id, 0);
|
|
190
|
+
}
|
|
191
|
+
return kernel.currentProcess.handles.createHandle(thread, 'Thread', 0x1fffff /* ALL_ACCESS */);
|
|
192
|
+
},
|
|
193
|
+
// Synchronization
|
|
194
|
+
WaitForSingleObject: (hHandle, _dwMilliseconds) => {
|
|
195
|
+
const handleObj = kernel.getObjectFromHandle(hHandle);
|
|
196
|
+
if (handleObj && handleObj.type === 'Thread') {
|
|
197
|
+
handleObj.object.state = 4; // TERMINATED
|
|
198
|
+
}
|
|
199
|
+
return 0; // WAIT_OBJECT_0
|
|
200
|
+
},
|
|
201
|
+
// Modules
|
|
202
|
+
GetModuleHandleW: (lpModuleName) => {
|
|
203
|
+
const name = lpModuleName || 'kernel32.dll';
|
|
204
|
+
const mod = kernel.currentProcess.getModule(name);
|
|
205
|
+
if (mod)
|
|
206
|
+
return BigInt(mod.baseAddress);
|
|
207
|
+
// Create on the fly if not exists (lazy loading simulation)
|
|
208
|
+
const base = 0x7ff00000 + kernel.currentProcess.modules.size * 0x100000;
|
|
209
|
+
const newMod = kernel.currentProcess.createModule(name, base, 0x100000);
|
|
210
|
+
return BigInt(newMod.baseAddress);
|
|
211
|
+
},
|
|
212
|
+
GetModuleHandleA: (lpModuleName) => {
|
|
213
|
+
return Kernel32Impl.GetModuleHandleW(lpModuleName);
|
|
214
|
+
},
|
|
215
|
+
GetProcAddress: (hModule, lpProcName) => {
|
|
216
|
+
// Find module by base address
|
|
217
|
+
const mod = Array.from(kernel.currentProcess.modules.values()).find((m) => BigInt(m.baseAddress) === BigInt(hModule));
|
|
218
|
+
if (mod) {
|
|
219
|
+
let addr = mod.getProcAddress(lpProcName);
|
|
220
|
+
if (!addr) {
|
|
221
|
+
// Add pseudo-export if it doesn't exist
|
|
222
|
+
const offset = mod.exports.size * 16;
|
|
223
|
+
mod.addExport(lpProcName, offset);
|
|
224
|
+
addr = mod.getProcAddress(lpProcName);
|
|
225
|
+
}
|
|
226
|
+
return BigInt(addr);
|
|
227
|
+
}
|
|
228
|
+
return 0n;
|
|
229
|
+
},
|
|
230
|
+
GetLastError: () => 0,
|
|
231
|
+
};
|
|
232
|
+
//# sourceMappingURL=kernel32.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kernel32.js","sourceRoot":"","sources":["../../src/kernel32.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/logger.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,GAAG,uCAAgC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/logger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAEhD,MAAM,CAAC,MAAM,GAAG,GAAG,eAAe,CAAC,YAAY,CAAC,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { type LPVOID, type SIZE_T } from '@cheatron/win32-ext';
|
|
2
|
+
/**
|
|
3
|
+
* MSVCRT function definitions
|
|
4
|
+
*/
|
|
5
|
+
export interface MSVCRT {
|
|
6
|
+
malloc: (size: SIZE_T) => LPVOID;
|
|
7
|
+
free: (ptr: LPVOID) => void;
|
|
8
|
+
memcpy: (dest: LPVOID, src: LPVOID, count: SIZE_T) => LPVOID;
|
|
9
|
+
memset: (dest: LPVOID, value: number, count: SIZE_T) => LPVOID;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Simulated implementation of MSVCRT
|
|
13
|
+
*/
|
|
14
|
+
export declare const MsvcrtImpl: MSVCRT;
|
|
15
|
+
//# sourceMappingURL=msvcrt.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"msvcrt.d.ts","sourceRoot":"","sources":["../../src/msvcrt.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,MAAM,EAAE,KAAK,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAG/D;;GAEG;AACH,MAAM,WAAW,MAAM;IACrB,MAAM,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,MAAM,CAAC;IACjC,IAAI,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,CAAC;IAC5B,MAAM,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC;IAC7D,MAAM,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC;CAChE;AAED;;GAEG;AACH,eAAO,MAAM,UAAU,EAAE,MA6CxB,CAAC"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import {} from '@cheatron/win32-ext';
|
|
2
|
+
import { kernel } from './os/kernel';
|
|
3
|
+
/**
|
|
4
|
+
* Simulated implementation of MSVCRT
|
|
5
|
+
*/
|
|
6
|
+
export const MsvcrtImpl = {
|
|
7
|
+
malloc: (size) => {
|
|
8
|
+
const addr = kernel.currentProcess.memory.allocate(0, Number(size));
|
|
9
|
+
return BigInt(addr);
|
|
10
|
+
},
|
|
11
|
+
free: (ptr) => {
|
|
12
|
+
kernel.currentProcess.memory.free(Number(ptr));
|
|
13
|
+
},
|
|
14
|
+
memcpy: (dest, src, count) => {
|
|
15
|
+
const size = Number(count);
|
|
16
|
+
let data;
|
|
17
|
+
if (Buffer.isBuffer(src)) {
|
|
18
|
+
data = src.subarray(0, size);
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
data = kernel.currentProcess.memory.read(Number(src), size);
|
|
22
|
+
}
|
|
23
|
+
if (Buffer.isBuffer(dest)) {
|
|
24
|
+
data.copy(dest);
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
kernel.currentProcess.memory.write(Number(dest), data);
|
|
28
|
+
}
|
|
29
|
+
return dest;
|
|
30
|
+
},
|
|
31
|
+
memset: (dest, value, count) => {
|
|
32
|
+
const size = Number(count);
|
|
33
|
+
const data = Buffer.alloc(size, value);
|
|
34
|
+
if (Buffer.isBuffer(dest)) {
|
|
35
|
+
data.copy(dest);
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
kernel.currentProcess.memory.write(Number(dest), data);
|
|
39
|
+
}
|
|
40
|
+
return dest;
|
|
41
|
+
},
|
|
42
|
+
};
|
|
43
|
+
//# sourceMappingURL=msvcrt.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"msvcrt.js","sourceRoot":"","sources":["../../src/msvcrt.ts"],"names":[],"mappings":"AAAA,OAAO,EAA4B,MAAM,qBAAqB,CAAC;AAC/D,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAYrC;;GAEG;AACH,MAAM,CAAC,MAAM,UAAU,GAAW;IAChC,MAAM,EAAE,CAAC,IAAY,EAAU,EAAE;QAC/B,MAAM,IAAI,GAAG,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;QACpE,OAAO,MAAM,CAAC,IAAI,CAAsB,CAAC;IAC3C,CAAC;IAED,IAAI,EAAE,CAAC,GAAW,EAAQ,EAAE;QAC1B,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;IACjD,CAAC;IAED,MAAM,EAAE,CACN,IAAqB,EACrB,GAAoB,EACpB,KAAa,EACL,EAAE;QACV,MAAM,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAC3B,IAAI,IAAY,CAAC;QAEjB,IAAI,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YACzB,IAAI,GAAG,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;QAC/B,CAAC;aAAM,CAAC;YACN,IAAI,GAAG,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,CAAC;QAC9D,CAAC;QAED,IAAI,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;YAC1B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClB,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC;QACzD,CAAC;QAED,OAAO,IAAc,CAAC;IACxB,CAAC;IAED,MAAM,EAAE,CAAC,IAAqB,EAAE,KAAa,EAAE,KAAa,EAAU,EAAE;QACtE,MAAM,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAC3B,MAAM,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QAEvC,IAAI,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;YAC1B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClB,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC;QACzD,CAAC;QAED,OAAO,IAAc,CAAC;IACxB,CAAC;CACF,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import * as Def from '@cheatron/win32-ext';
|
|
2
|
+
export interface ISimulatedObject {
|
|
3
|
+
id: number;
|
|
4
|
+
}
|
|
5
|
+
export interface HandleObject {
|
|
6
|
+
type: 'Process' | 'Thread' | 'Module' | 'File' | 'Event' | 'Unknown';
|
|
7
|
+
object: ISimulatedObject;
|
|
8
|
+
accessMask: number;
|
|
9
|
+
}
|
|
10
|
+
export declare class HandleTable {
|
|
11
|
+
private handles;
|
|
12
|
+
private nextHandleValue;
|
|
13
|
+
createHandle(object: ISimulatedObject, type: HandleObject['type'], accessMask: number): Def.HANDLE;
|
|
14
|
+
getObject(handle: Def.HANDLE): HandleObject | undefined;
|
|
15
|
+
closeHandle(handle: Def.HANDLE): boolean;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=handles.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handles.d.ts","sourceRoot":"","sources":["../../../src/os/handles.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAE3C,MAAM,WAAW,gBAAgB;IAC/B,EAAE,EAAE,MAAM,CAAC;CACZ;AAED,MAAM,WAAW,YAAY;IAC3B,IAAI,EAAE,SAAS,GAAG,QAAQ,GAAG,QAAQ,GAAG,MAAM,GAAG,OAAO,GAAG,SAAS,CAAC;IACrE,MAAM,EAAE,gBAAgB,CAAC;IACzB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,qBAAa,WAAW;IACtB,OAAO,CAAC,OAAO,CAAmC;IAClD,OAAO,CAAC,eAAe,CAAM;IAE7B,YAAY,CACV,MAAM,EAAE,gBAAgB,EACxB,IAAI,EAAE,YAAY,CAAC,MAAM,CAAC,EAC1B,UAAU,EAAE,MAAM,GACjB,GAAG,CAAC,MAAM;IAeb,SAAS,CAAC,MAAM,EAAE,GAAG,CAAC,MAAM,GAAG,YAAY,GAAG,SAAS;IAIvD,WAAW,CAAC,MAAM,EAAE,GAAG,CAAC,MAAM,GAAG,OAAO;CAGzC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import * as Def from '@cheatron/win32-ext';
|
|
1
2
|
export class HandleTable {
|
|
2
3
|
handles = new Map();
|
|
3
4
|
nextHandleValue = 4n; // Windows handles are often multiples of 4
|
|
@@ -19,3 +20,4 @@ export class HandleTable {
|
|
|
19
20
|
return this.handles.delete(BigInt(handle));
|
|
20
21
|
}
|
|
21
22
|
}
|
|
23
|
+
//# sourceMappingURL=handles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handles.js","sourceRoot":"","sources":["../../../src/os/handles.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAY3C,MAAM,OAAO,WAAW;IACd,OAAO,GAAG,IAAI,GAAG,EAAwB,CAAC;IAC1C,eAAe,GAAG,EAAE,CAAC,CAAC,2CAA2C;IAEzE,YAAY,CACV,MAAwB,EACxB,IAA0B,EAC1B,UAAkB;QAElB,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC;QACzC,IAAI,CAAC,eAAe,IAAI,EAAE,CAAC;QAE3B,kDAAkD;QAElD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,WAAW,EAAE;YAC5B,IAAI;YACJ,MAAM;YACN,UAAU;SACX,CAAC,CAAC;QAEH,OAAO,WAAoC,CAAC;IAC9C,CAAC;IAED,SAAS,CAAC,MAAkB;QAC1B,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,MAAgB,CAAC,CAAC,CAAC;IACpD,CAAC;IAED,WAAW,CAAC,MAAkB;QAC5B,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,MAAgB,CAAC,CAAC,CAAC;IACvD,CAAC;CACF"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { SimulatedProcess } from './process';
|
|
2
|
+
import type { HandleObject } from './handles';
|
|
3
|
+
import * as Def from '@cheatron/win32-ext';
|
|
4
|
+
export declare class Kernel {
|
|
5
|
+
static instance: Kernel;
|
|
6
|
+
private processes;
|
|
7
|
+
private nextPid;
|
|
8
|
+
currentProcess: SimulatedProcess;
|
|
9
|
+
constructor();
|
|
10
|
+
private createSystemProcess;
|
|
11
|
+
createProcess(name: string): SimulatedProcess;
|
|
12
|
+
getProcess(pid: number): SimulatedProcess | undefined;
|
|
13
|
+
OpenProcess(dwDesiredAccess: number, _bInheritHandle: boolean, dwProcessId: number): Def.HANDLE;
|
|
14
|
+
OpenThread(dwDesiredAccess: number, _bInheritHandle: boolean, dwThreadId: number): Def.HANDLE;
|
|
15
|
+
CloseHandle(hObject: Def.HANDLE): boolean;
|
|
16
|
+
GetProcessId(hProcess: Def.HANDLE): number;
|
|
17
|
+
GetThreadId(hThread: Def.HANDLE): number;
|
|
18
|
+
getObjectFromHandle(handle: Def.HANDLE): HandleObject | undefined;
|
|
19
|
+
}
|
|
20
|
+
export declare const kernel: Kernel;
|
|
21
|
+
//# sourceMappingURL=kernel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kernel.d.ts","sourceRoot":"","sources":["../../../src/os/kernel.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAC7C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAC9C,OAAO,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAE3C,qBAAa,MAAM;IACjB,OAAc,QAAQ,EAAE,MAAM,CAAC;IAE/B,OAAO,CAAC,SAAS,CAA4C;IAC7D,OAAO,CAAC,OAAO,CAAa;IAGrB,cAAc,EAAE,gBAAgB,CAAC;;IAgBxC,OAAO,CAAC,mBAAmB;IAKpB,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,gBAAgB;IAQ7C,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,gBAAgB,GAAG,SAAS;IAMrD,WAAW,CAChB,eAAe,EAAE,MAAM,EACvB,eAAe,EAAE,OAAO,EACxB,WAAW,EAAE,MAAM,GAClB,GAAG,CAAC,MAAM;IAeN,UAAU,CACf,eAAe,EAAE,MAAM,EACvB,eAAe,EAAE,OAAO,EACxB,UAAU,EAAE,MAAM,GACjB,GAAG,CAAC,MAAM;IAeN,WAAW,CAAC,OAAO,EAAE,GAAG,CAAC,MAAM,GAAG,OAAO;IAMzC,YAAY,CAAC,QAAQ,EAAE,GAAG,CAAC,MAAM,GAAG,MAAM;IAQ1C,WAAW,CAAC,OAAO,EAAE,GAAG,CAAC,MAAM,GAAG,MAAM;IASxC,mBAAmB,CAAC,MAAM,EAAE,GAAG,CAAC,MAAM,GAAG,YAAY,GAAG,SAAS;CAGzE;AAGD,eAAO,MAAM,MAAM,QAAe,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { SimulatedProcess } from './process';
|
|
2
|
+
import * as Def from '@cheatron/win32-ext';
|
|
2
3
|
export class Kernel {
|
|
3
4
|
static instance;
|
|
4
5
|
processes = new Map();
|
|
@@ -13,6 +14,8 @@ export class Kernel {
|
|
|
13
14
|
// We simulate it as a process so it can have a Handle Table.
|
|
14
15
|
this.currentProcess = new SimulatedProcess(9999, 'CurrentTestRunner.exe');
|
|
15
16
|
this.processes.set(this.currentProcess.id, this.currentProcess);
|
|
17
|
+
// Create initial thread for current process
|
|
18
|
+
this.currentProcess.createThread();
|
|
16
19
|
}
|
|
17
20
|
createSystemProcess() {
|
|
18
21
|
const sys = new SimulatedProcess(4, 'System');
|
|
@@ -29,7 +32,7 @@ export class Kernel {
|
|
|
29
32
|
return this.processes.get(pid);
|
|
30
33
|
}
|
|
31
34
|
// --- Syscalls (Simulated) ---
|
|
32
|
-
OpenProcess(dwDesiredAccess,
|
|
35
|
+
OpenProcess(dwDesiredAccess, _bInheritHandle, dwProcessId) {
|
|
33
36
|
const targetProc = this.processes.get(dwProcessId);
|
|
34
37
|
if (!targetProc) {
|
|
35
38
|
return 0n; // NULL
|
|
@@ -38,9 +41,40 @@ export class Kernel {
|
|
|
38
41
|
const handle = this.currentProcess.handles.createHandle(targetProc, 'Process', dwDesiredAccess);
|
|
39
42
|
return handle;
|
|
40
43
|
}
|
|
44
|
+
OpenThread(dwDesiredAccess, _bInheritHandle, dwThreadId) {
|
|
45
|
+
// Find thread across all processes
|
|
46
|
+
for (const proc of this.processes.values()) {
|
|
47
|
+
const thread = proc.getThread(dwThreadId);
|
|
48
|
+
if (thread) {
|
|
49
|
+
return this.currentProcess.handles.createHandle(thread, 'Thread', dwDesiredAccess);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
return 0n;
|
|
53
|
+
}
|
|
41
54
|
CloseHandle(hObject) {
|
|
55
|
+
const h = BigInt.asIntN(64, BigInt(hObject));
|
|
56
|
+
if (h === -1n || h === -2n)
|
|
57
|
+
return true;
|
|
42
58
|
return this.currentProcess.handles.closeHandle(hObject);
|
|
43
59
|
}
|
|
60
|
+
GetProcessId(hProcess) {
|
|
61
|
+
const h = BigInt.asIntN(64, BigInt(hProcess));
|
|
62
|
+
if (h === -1n)
|
|
63
|
+
return this.currentProcess.id;
|
|
64
|
+
const obj = this.getObjectFromHandle(hProcess);
|
|
65
|
+
if (obj && obj.type === 'Process')
|
|
66
|
+
return obj.object.id;
|
|
67
|
+
return 0;
|
|
68
|
+
}
|
|
69
|
+
GetThreadId(hThread) {
|
|
70
|
+
const h = BigInt.asIntN(64, BigInt(hThread));
|
|
71
|
+
if (h === -2n)
|
|
72
|
+
return this.currentProcess.threads.keys().next().value || 0;
|
|
73
|
+
const obj = this.getObjectFromHandle(hThread);
|
|
74
|
+
if (obj && obj.type === 'Thread')
|
|
75
|
+
return obj.object.id;
|
|
76
|
+
return 0;
|
|
77
|
+
}
|
|
44
78
|
// Helper to dereference a handle from the current process context
|
|
45
79
|
getObjectFromHandle(handle) {
|
|
46
80
|
return this.currentProcess.handles.getObject(handle);
|
|
@@ -48,3 +82,4 @@ export class Kernel {
|
|
|
48
82
|
}
|
|
49
83
|
// Global kernel instance
|
|
50
84
|
export const kernel = new Kernel();
|
|
85
|
+
//# sourceMappingURL=kernel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kernel.js","sourceRoot":"","sources":["../../../src/os/kernel.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { type MemoryBasicInformation } from '
|
|
1
|
+
import { type MemoryBasicInformation } from '@cheatron/win32-ext';
|
|
2
2
|
export declare class MemoryManager {
|
|
3
3
|
private pages;
|
|
4
4
|
constructor();
|
|
@@ -6,10 +6,6 @@ export declare class MemoryManager {
|
|
|
6
6
|
* Aligns an address down to the nearest page boundary.
|
|
7
7
|
*/
|
|
8
8
|
private alignDown;
|
|
9
|
-
/**
|
|
10
|
-
* Aligns an address up to the nearest page boundary.
|
|
11
|
-
*/
|
|
12
|
-
private alignUp;
|
|
13
9
|
/**
|
|
14
10
|
* Allocates memory.
|
|
15
11
|
* Simplification: Always allocates MEM_PRIVATE, MEM_COMMIT | MEM_RESERVE.
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"memory.d.ts","sourceRoot":"","sources":["../../../src/os/memory.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,sBAAsB,EAI5B,MAAM,qBAAqB,CAAC;AAY7B,qBAAa,aAAa;IACxB,OAAO,CAAC,KAAK,CAA2B;;IAIxC;;OAEG;IACH,OAAO,CAAC,SAAS;IAIjB;;;OAGG;IACH,QAAQ,CACN,OAAO,EAAE,MAAM,EAAE,wBAAwB;IACzC,IAAI,EAAE,MAAM,EACZ,eAAe,GAAE,MAAiD,EAClE,OAAO,GAAE,MAAmC,GAC3C,MAAM;IA+CT,IAAI,CACF,OAAO,EAAE,MAAM,EACf,KAAK,GAAE,MAAU,EACjB,SAAS,GAAE,MAAe,GACzB,OAAO;IASV,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,MAAM;IAiC3C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,MAAM;IAwC5C,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,sBAAsB;CA0B/C"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { MemoryProtection, MemoryState, MemoryType, } from '
|
|
1
|
+
import { MemoryProtection, MemoryState, MemoryType, } from '@cheatron/win32-ext';
|
|
2
2
|
const PAGE_SIZE = 4096;
|
|
3
3
|
export class MemoryManager {
|
|
4
4
|
pages = new Map();
|
|
@@ -9,12 +9,6 @@ export class MemoryManager {
|
|
|
9
9
|
alignDown(address) {
|
|
10
10
|
return Math.floor(address / PAGE_SIZE) * PAGE_SIZE;
|
|
11
11
|
}
|
|
12
|
-
/**
|
|
13
|
-
* Aligns an address up to the nearest page boundary.
|
|
14
|
-
*/
|
|
15
|
-
alignUp(address) {
|
|
16
|
-
return Math.ceil(address / PAGE_SIZE) * PAGE_SIZE;
|
|
17
|
-
}
|
|
18
12
|
/**
|
|
19
13
|
* Allocates memory.
|
|
20
14
|
* Simplification: Always allocates MEM_PRIVATE, MEM_COMMIT | MEM_RESERVE.
|
|
@@ -44,7 +38,7 @@ export class MemoryManager {
|
|
|
44
38
|
else {
|
|
45
39
|
// Verify requested range is free
|
|
46
40
|
for (let i = 0; i < numPages; i++) {
|
|
47
|
-
const _addr = startAddress + i * PAGE_SIZE;
|
|
41
|
+
// const _addr = startAddress + i * PAGE_SIZE;
|
|
48
42
|
// Should check for collisions or if re-allocation is allowed
|
|
49
43
|
}
|
|
50
44
|
}
|
|
@@ -145,3 +139,4 @@ export class MemoryManager {
|
|
|
145
139
|
};
|
|
146
140
|
}
|
|
147
141
|
}
|
|
142
|
+
//# sourceMappingURL=memory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"memory.js","sourceRoot":"","sources":["../../../src/os/memory.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export declare class SimulatedModule {
|
|
2
|
+
id: number;
|
|
3
|
+
name: string;
|
|
4
|
+
baseAddress: number;
|
|
5
|
+
size: number;
|
|
6
|
+
exports: Map<string, number>;
|
|
7
|
+
constructor(id: number, name: string, baseAddress: number, size: number);
|
|
8
|
+
addExport(name: string, offset: number): void;
|
|
9
|
+
getProcAddress(name: string): number | undefined;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=module.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"module.d.ts","sourceRoot":"","sources":["../../../src/os/module.ts"],"names":[],"mappings":"AAAA,qBAAa,eAAe;IACnB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAa;gBAEpC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM;IAOvE,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM;IAItC,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS;CAGjD"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export class SimulatedModule {
|
|
2
|
+
id;
|
|
3
|
+
name;
|
|
4
|
+
baseAddress;
|
|
5
|
+
size;
|
|
6
|
+
exports = new Map();
|
|
7
|
+
constructor(id, name, baseAddress, size) {
|
|
8
|
+
this.id = id;
|
|
9
|
+
this.name = name;
|
|
10
|
+
this.baseAddress = baseAddress;
|
|
11
|
+
this.size = size;
|
|
12
|
+
}
|
|
13
|
+
addExport(name, offset) {
|
|
14
|
+
this.exports.set(name, this.baseAddress + offset);
|
|
15
|
+
}
|
|
16
|
+
getProcAddress(name) {
|
|
17
|
+
return this.exports.get(name);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=module.js.map
|