]>
Commit | Line | Data |
---|---|---|
72d89ab4 TG |
1 | /** @file |
2 | * VirtualBox Status Codes. | |
3 | */ | |
4 | ||
5 | /* | |
6 | * Copyright (C) 2006-2016 Oracle Corporation | |
7 | * | |
8 | * This file is part of VirtualBox Open Source Edition (OSE), as | |
9 | * available from http://www.virtualbox.org. This file is free software; | |
10 | * you can redistribute it and/or modify it under the terms of the GNU | |
11 | * General Public License (GPL) as published by the Free Software | |
12 | * Foundation, in version 2 as it comes in the "COPYING" file of the | |
13 | * VirtualBox OSE distribution. VirtualBox OSE is distributed in the | |
14 | * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind. | |
15 | * | |
16 | * The contents of this file may alternatively be used under the terms | |
17 | * of the Common Development and Distribution License Version 1.0 | |
18 | * (CDDL) only, as it comes in the "COPYING.CDDL" file of the | |
19 | * VirtualBox OSE distribution, in which case the provisions of the | |
20 | * CDDL are applicable instead of those of the GPL. | |
21 | * | |
22 | * You may elect to license modified versions of this file under the | |
23 | * terms and conditions of either the GPL or the CDDL or both. | |
24 | */ | |
25 | ||
26 | #ifndef ___VBox_err_h | |
27 | #define ___VBox_err_h | |
28 | ||
29 | #include <VBox/cdefs.h> | |
30 | #include <iprt/err.h> | |
31 | ||
32 | ||
33 | /** @defgroup grp_err VBox Error Codes | |
34 | * @{ | |
35 | */ | |
36 | ||
37 | /* SED-START */ | |
38 | ||
39 | /** @name Misc. Status Codes | |
40 | * @{ | |
41 | */ | |
42 | /** Failed to allocate VM memory. */ | |
43 | #define VERR_NO_VM_MEMORY (-1000) | |
44 | /** RC is toasted and the VMM should be terminated at once, but no need to | |
45 | * panic about it :-) */ | |
46 | #define VERR_DONT_PANIC (-1001) | |
47 | /** Unsupported CPU. */ | |
48 | #define VERR_UNSUPPORTED_CPU (-1002) | |
49 | /** Unsupported CPU mode. */ | |
50 | #define VERR_UNSUPPORTED_CPU_MODE (-1003) | |
51 | /** Page not present. */ | |
52 | #define VERR_PAGE_NOT_PRESENT (-1004) | |
53 | /** Invalid/Corrupted configuration file. */ | |
54 | #define VERR_CFG_INVALID_FORMAT (-1005) | |
55 | /** No configuration value exists. */ | |
56 | #define VERR_CFG_NO_VALUE (-1006) | |
57 | /** Selector not present. */ | |
58 | #define VERR_SELECTOR_NOT_PRESENT (-1007) | |
59 | /** Not code selector. */ | |
60 | #define VERR_NOT_CODE_SELECTOR (-1008) | |
61 | /** Not data selector. */ | |
62 | #define VERR_NOT_DATA_SELECTOR (-1009) | |
63 | /** Out of selector bounds. */ | |
64 | #define VERR_OUT_OF_SELECTOR_BOUNDS (-1010) | |
65 | /** Invalid selector. Usually beyond table limits. */ | |
66 | #define VERR_INVALID_SELECTOR (-1011) | |
67 | /** Invalid requested privilege level. */ | |
68 | #define VERR_INVALID_RPL (-1012) | |
69 | /** PML4 entry not present. */ | |
70 | #define VERR_PAGE_MAP_LEVEL4_NOT_PRESENT (-1013) | |
71 | /** Page directory pointer not present. */ | |
72 | #define VERR_PAGE_DIRECTORY_PTR_NOT_PRESENT (-1014) | |
73 | /** Raw mode doesn't support SMP. */ | |
74 | #define VERR_RAW_MODE_INVALID_SMP (-1015) | |
75 | /** Invalid VM handle. */ | |
76 | #define VERR_INVALID_VM_HANDLE (-1016) | |
77 | /** Invalid VM handle. */ | |
78 | #define VERR_INVALID_VMCPU_HANDLE (-1017) | |
79 | /** Invalid Virtual CPU ID. */ | |
80 | #define VERR_INVALID_CPU_ID (-1018) | |
81 | /** Too many VCPUs. */ | |
82 | #define VERR_TOO_MANY_CPUS (-1019) | |
83 | /** The service was disabled on the host. | |
84 | * Returned by pfnInit in VBoxService to indicated a non-fatal error that | |
85 | * should results in the particular service being disabled. */ | |
86 | #define VERR_SERVICE_DISABLED (-1020) | |
87 | /** The requested feature is not supported in raw-mode. */ | |
88 | #define VERR_NOT_SUP_IN_RAW_MODE (-1021) | |
89 | /** Invalid CPU index. */ | |
90 | #define VERR_INVALID_CPU_INDEX (-1022) | |
91 | /** This VirtualBox build does not support raw-mode. */ | |
92 | #define VERR_RAW_MODE_NOT_SUPPORTED (-1023) | |
93 | /** @} */ | |
94 | ||
95 | ||
96 | /** @name Execution Monitor/Manager (EM) Status Codes | |
97 | * | |
98 | * The order of the status codes between VINF_EM_FIRST and VINF_EM_LAST | |
99 | * are of vital importance. The lower the number the higher importance | |
100 | * as a scheduling instruction. | |
101 | * @{ | |
102 | */ | |
103 | /** First scheduling related status code. */ | |
104 | #define VINF_EM_FIRST 1100 | |
105 | /** Indicating that the VM is being terminated and that the execution | |
106 | * shall stop. */ | |
107 | #define VINF_EM_TERMINATE 1100 | |
108 | /** Hypervisor code was stepped. | |
109 | * EM will first send this to the debugger, and if the issue isn't | |
110 | * resolved there it will enter guru meditation. */ | |
111 | #define VINF_EM_DBG_HYPER_STEPPED 1101 | |
112 | /** Hit a breakpoint in the hypervisor code, | |
113 | * EM will first send this to the debugger, and if the issue isn't | |
114 | * resolved there it will enter guru meditation. */ | |
115 | #define VINF_EM_DBG_HYPER_BREAKPOINT 1102 | |
116 | /** Hit a possible assertion in the hypervisor code, | |
117 | * EM will first send this to the debugger, and if the issue isn't | |
118 | * resolved there it will enter guru meditation. */ | |
119 | #define VINF_EM_DBG_HYPER_ASSERTION 1103 | |
120 | /** Generic debug event, suspend the VM for debugging. */ | |
121 | #define VINF_EM_DBG_EVENT 1104 | |
122 | /** Indicating that the VM should be suspended for debugging because | |
123 | * the developer wants to inspect the VM state. */ | |
124 | #define VINF_EM_DBG_STOP 1105 | |
125 | /** Indicating success single stepping and that EM should report that | |
126 | * event to the debugger. */ | |
127 | #define VINF_EM_DBG_STEPPED 1106 | |
128 | /** Indicating that a breakpoint was hit and that EM should notify the debugger | |
129 | * and in the event there is no debugger fail fatally. */ | |
130 | #define VINF_EM_DBG_BREAKPOINT 1107 | |
131 | /** Indicating that EM should single step an instruction. | |
132 | * The instruction is stepped in the current execution mode (RAW/REM). */ | |
133 | #define VINF_EM_DBG_STEP 1108 | |
134 | /** Indicating that the VM is being turned off and that the EM should | |
135 | * exit to the VM awaiting the destruction request. */ | |
136 | #define VINF_EM_OFF 1109 | |
137 | /** Indicating that the VM has been suspended and that the thread | |
138 | * should wait for request telling it what to do next. */ | |
139 | #define VINF_EM_SUSPEND 1110 | |
140 | /** Indicating that the VM has been reset and that scheduling goes | |
141 | * back to startup defaults. */ | |
142 | #define VINF_EM_RESET 1111 | |
143 | /** Indicating that the VM has executed a halt instruction and that | |
144 | * the emulation thread should wait for an interrupt before resuming | |
145 | * execution. */ | |
146 | #define VINF_EM_HALT 1112 | |
147 | /** Indicating that the VM has been resumed and that the thread should | |
148 | * start executing. */ | |
149 | #define VINF_EM_RESUME 1113 | |
150 | /** Indicating that we've got an out-of-memory condition and that we need | |
151 | * to take the appropriate actions to deal with this. | |
152 | * @remarks It might seem odd at first that this has lower priority than VINF_EM_HALT, | |
153 | * VINF_EM_SUSPEND, and VINF_EM_RESUME. The reason is that these events are | |
154 | * vital to correctly operating the VM. Also, they can't normally occur together | |
155 | * with an out-of-memory condition, and even if that should happen the condition | |
156 | * will be rediscovered before executing any more code. */ | |
157 | #define VINF_EM_NO_MEMORY 1114 | |
158 | /** The fatal variant of VINF_EM_NO_MEMORY. */ | |
159 | #define VERR_EM_NO_MEMORY (-1114) | |
160 | /** Indicating that a rescheduling to recompiled execution. | |
161 | * Typically caused by raw-mode executing code which is difficult/slow | |
162 | * to virtualize rawly. | |
163 | * @remarks Important to have a higher priority (lower number) than the other rescheduling status codes. */ | |
164 | #define VINF_EM_RESCHEDULE_REM 1115 | |
165 | /** Indicating that a rescheduling to vmx-mode execution. | |
166 | * Typically caused by REM detecting that hardware-accelerated raw-mode execution is possible. */ | |
167 | #define VINF_EM_RESCHEDULE_HM 1116 | |
168 | /** Indicating that a rescheduling to raw-mode execution. | |
169 | * Typically caused by REM detecting that raw-mode execution is possible. | |
170 | * @remarks Important to have a higher priority (lower number) than VINF_EM_RESCHEDULE. */ | |
171 | #define VINF_EM_RESCHEDULE_RAW 1117 | |
172 | /** Indicating that a rescheduling now is required. Typically caused by | |
173 | * interrupts having changed the EIP. */ | |
174 | #define VINF_EM_RESCHEDULE 1118 | |
175 | /** PARAV call */ | |
176 | #define VINF_EM_RESCHEDULE_PARAV 1119 | |
177 | /** Go back into wait for SIPI mode */ | |
178 | #define VINF_EM_WAIT_SIPI 1120 | |
179 | /** Last scheduling related status code. (inclusive) */ | |
180 | #define VINF_EM_LAST 1120 | |
181 | ||
182 | /** Reason for leaving RC: Guest trap which couldn't be handled in RC. | |
183 | * The trap is generally forwarded to the REM and executed there. */ | |
184 | #define VINF_EM_RAW_GUEST_TRAP 1121 | |
185 | /** Reason for leaving RC: Interrupted by external interrupt. | |
186 | * The interrupt needed to be handled by the host OS. */ | |
187 | #define VINF_EM_RAW_INTERRUPT 1122 | |
188 | /** Reason for leaving RC: Interrupted by external interrupt while in hypervisor | |
189 | * code. The interrupt needed to be handled by the host OS and hypervisor | |
190 | * execution must be resumed. VM state is not complete at this point. */ | |
191 | #define VINF_EM_RAW_INTERRUPT_HYPER 1123 | |
192 | /** Reason for leaving RC: A Ring switch was attempted. | |
193 | * Normal cause of action is to execute this in REM. */ | |
194 | #define VINF_EM_RAW_RING_SWITCH 1124 | |
195 | /** Reason for leaving RC: A Ring switch was attempted using software interrupt. | |
196 | * Normal cause of action is to execute this in REM. */ | |
197 | #define VINF_EM_RAW_RING_SWITCH_INT 1125 | |
198 | /** Reason for leaving RC: A privileged instruction was attempted executed. | |
199 | * Normal cause of action is to execute this in REM. */ | |
200 | #define VINF_EM_RAW_EXCEPTION_PRIVILEGED 1126 | |
201 | ||
202 | /** Reason for leaving RZ: Emulate instruction. */ | |
203 | #define VINF_EM_RAW_EMULATE_INSTR 1127 | |
204 | /** Reason for leaving RC: Unhandled TSS write. | |
205 | * Recompiler gets control. */ | |
206 | #define VINF_EM_RAW_EMULATE_INSTR_TSS_FAULT 1128 | |
207 | /** Reason for leaving RC: Unhandled LDT write. | |
208 | * Recompiler gets control. */ | |
209 | #define VINF_EM_RAW_EMULATE_INSTR_LDT_FAULT 1129 | |
210 | /** Reason for leaving RC: Unhandled IDT write. | |
211 | * Recompiler gets control. */ | |
212 | #define VINF_EM_RAW_EMULATE_INSTR_IDT_FAULT 1130 | |
213 | /** Reason for leaving RC: Partly handled GDT write. | |
214 | * Recompiler gets control. */ | |
215 | #define VINF_EM_RAW_EMULATE_INSTR_GDT_FAULT 1131 | |
216 | /** Reason for leaving RC: jump inside generated patch jump. | |
217 | * Fatal error. */ | |
218 | #define VERR_EM_RAW_PATCH_CONFLICT (-1133) | |
219 | /** Reason for leaving RZ: Ring-3 operation pending. */ | |
220 | #define VINF_EM_RAW_TO_R3 1135 | |
221 | /** Reason for leaving RZ: Timer pending. */ | |
222 | #define VINF_EM_RAW_TIMER_PENDING 1136 | |
223 | /** Reason for leaving RC: Interrupt pending (guest). */ | |
224 | #define VINF_EM_RAW_INTERRUPT_PENDING 1137 | |
225 | /** Reason for leaving RC: Encountered a stale selector. */ | |
226 | #define VINF_EM_RAW_STALE_SELECTOR 1138 | |
227 | /** Reason for leaving RC: The IRET resuming guest code trapped. */ | |
228 | #define VINF_EM_RAW_IRET_TRAP 1139 | |
229 | /** Reason for leaving RC: Emulate (MM)IO intensive code in the recompiler. */ | |
230 | #define VINF_EM_RAW_EMULATE_IO_BLOCK 1140 | |
231 | /** The interpreter was unable to deal with the instruction at hand. */ | |
232 | #define VERR_EM_INTERPRETER (-1148) | |
233 | /** Internal EM error caused by an unknown warning or informational status code. */ | |
234 | #define VERR_EM_INTERNAL_ERROR (-1149) | |
235 | /** Pending VM request packet. */ | |
236 | #define VINF_EM_PENDING_REQUEST 1150 | |
237 | /** Start instruction stepping (debug only). */ | |
238 | #define VINF_EM_RAW_EMULATE_DBG_STEP 1151 | |
239 | /** Patch TPR access instruction. */ | |
240 | #define VINF_EM_HM_PATCH_TPR_INSTR 1152 | |
241 | /** Unexpected guest mapping conflict detected. */ | |
242 | #define VERR_EM_UNEXPECTED_MAPPING_CONFLICT (-1154) | |
243 | /** Reason for leaving RC: A triple-fault condition. Currently, causes | |
244 | * a guru meditation. */ | |
245 | #define VINF_EM_TRIPLE_FAULT 1155 | |
246 | /** The specified execution engine cannot execute guest code in the current | |
247 | * state. */ | |
248 | #define VERR_EM_CANNOT_EXEC_GUEST (-1156) | |
249 | /** Reason for leaving RC: Inject a TRPM event. */ | |
250 | #define VINF_EM_RAW_INJECT_TRPM_EVENT 1157 | |
251 | /** Guest tried to trigger a CPU hang. The guest is probably up to no good. */ | |
252 | #define VERR_EM_GUEST_CPU_HANG (-1158) | |
253 | /** @} */ | |
254 | ||
255 | ||
256 | /** @name Debugging Facility (DBGF) DBGF Status Codes | |
257 | * @{ | |
258 | */ | |
259 | /** The function called requires the caller to be attached as a | |
260 | * debugger to the VM. */ | |
261 | #define VERR_DBGF_NOT_ATTACHED (-1200) | |
262 | /** Someone (including the caller) was already attached as | |
263 | * debugger to the VM. */ | |
264 | #define VERR_DBGF_ALREADY_ATTACHED (-1201) | |
265 | /** Tried to halt a debugger which was already halted. | |
266 | * (This is a warning and not an error.) */ | |
267 | #define VWRN_DBGF_ALREADY_HALTED 1202 | |
268 | /** The DBGF has no more free breakpoint slots. */ | |
269 | #define VERR_DBGF_NO_MORE_BP_SLOTS (-1203) | |
270 | /** The DBGF couldn't find the specified breakpoint. */ | |
271 | #define VERR_DBGF_BP_NOT_FOUND (-1204) | |
272 | /** Attempted to enabled a breakpoint which was already enabled. */ | |
273 | #define VINF_DBGF_BP_ALREADY_ENABLED 1205 | |
274 | /** Attempted to disabled a breakpoint which was already disabled. */ | |
275 | #define VINF_DBGF_BP_ALREADY_DISABLED 1206 | |
276 | /** The breakpoint already exists. */ | |
277 | #define VINF_DBGF_BP_ALREADY_EXIST 1207 | |
278 | /** The byte string was not found. */ | |
279 | #define VERR_DBGF_MEM_NOT_FOUND (-1208) | |
280 | /** The OS was not detected. */ | |
281 | #define VERR_DBGF_OS_NOT_DETCTED (-1209) | |
282 | /** The OS was not detected. */ | |
283 | #define VINF_DBGF_OS_NOT_DETCTED 1209 | |
284 | /** The specified register was not found. */ | |
285 | #define VERR_DBGF_REGISTER_NOT_FOUND (-1210) | |
286 | /** The value was truncated to fit. | |
287 | * For queries this means that the register is wider than the queried value. | |
288 | * For setters this means that the value is wider than the register. */ | |
289 | #define VINF_DBGF_TRUNCATED_REGISTER 1211 | |
290 | /** The value was zero extended to fit. | |
291 | * For queries this means that the register is narrower than the queried value. | |
292 | * For setters this means that the value is narrower than the register. */ | |
293 | #define VINF_DBGF_ZERO_EXTENDED_REGISTER 1212 | |
294 | /** The requested type conversion was not supported. */ | |
295 | #define VERR_DBGF_UNSUPPORTED_CAST (-1213) | |
296 | /** The register is read-only and cannot be modified. */ | |
297 | #define VERR_DBGF_READ_ONLY_REGISTER (-1214) | |
298 | /** Internal processing error \#1 in the DBGF register code. */ | |
299 | #define VERR_DBGF_REG_IPE_1 (-1215) | |
300 | /** Internal processing error \#2 in the DBGF register code. */ | |
301 | #define VERR_DBGF_REG_IPE_2 (-1216) | |
302 | /** Unhandled \#DB in hypervisor code. */ | |
303 | #define VERR_DBGF_HYPER_DB_XCPT (-1217) | |
304 | /** Internal processing error \#1 in the DBGF stack code. */ | |
305 | #define VERR_DBGF_STACK_IPE_1 (-1218) | |
306 | /** Internal processing error \#2 in the DBGF stack code. */ | |
307 | #define VERR_DBGF_STACK_IPE_2 (-1219) | |
308 | /** No trace buffer available, please change the VM config. */ | |
309 | #define VERR_DBGF_NO_TRACE_BUFFER (-1220) | |
310 | /** @} */ | |
311 | ||
312 | ||
313 | /** @name Patch Manager (PATM) Status Codes | |
314 | * @{ | |
315 | */ | |
316 | /** Non fatal Patch Manager analysis phase warning */ | |
317 | #define VWRN_CONTINUE_ANALYSIS 1400 | |
318 | /** Non fatal Patch Manager recompile phase warning (mapped to VWRN_CONTINUE_ANALYSIS). */ | |
319 | #define VWRN_CONTINUE_RECOMPILE VWRN_CONTINUE_ANALYSIS | |
320 | /** Continue search (mapped to VWRN_CONTINUE_ANALYSIS). */ | |
321 | #define VWRN_PATM_CONTINUE_SEARCH VWRN_CONTINUE_ANALYSIS | |
322 | /** Patch installation refused (patch too complex or unsupported instructions ) */ | |
323 | #define VERR_PATCHING_REFUSED (-1401) | |
324 | /** Unable to find patch */ | |
325 | #define VERR_PATCH_NOT_FOUND (-1402) | |
326 | /** Patch disabled */ | |
327 | #define VERR_PATCH_DISABLED (-1403) | |
328 | /** Patch enabled */ | |
329 | #define VWRN_PATCH_ENABLED 1404 | |
330 | /** Patch was already disabled */ | |
331 | #define VERR_PATCH_ALREADY_DISABLED (-1405) | |
332 | /** Patch was already enabled */ | |
333 | #define VERR_PATCH_ALREADY_ENABLED (-1406) | |
334 | /** Patch was removed. */ | |
335 | #define VWRN_PATCH_REMOVED 1407 | |
336 | ||
337 | /** Reason for leaving RC: \#GP with EIP pointing to patch code. */ | |
338 | #define VINF_PATM_PATCH_TRAP_GP 1408 | |
339 | /** First leave RC code. */ | |
340 | #define VINF_PATM_LEAVE_RC_FIRST VINF_PATM_PATCH_TRAP_GP | |
341 | /** Reason for leaving RC: \#PF with EIP pointing to patch code. */ | |
342 | #define VINF_PATM_PATCH_TRAP_PF 1409 | |
343 | /** Reason for leaving RC: int3 with EIP pointing to patch code. */ | |
344 | #define VINF_PATM_PATCH_INT3 1410 | |
345 | /** Reason for leaving RC: \#PF for monitored patch page. */ | |
346 | #define VINF_PATM_CHECK_PATCH_PAGE 1411 | |
347 | /** Reason for leaving RC: duplicate instruction called at current eip. */ | |
348 | #define VINF_PATM_DUPLICATE_FUNCTION 1412 | |
349 | /** Execute one instruction with the recompiler */ | |
350 | #define VINF_PATCH_EMULATE_INSTR 1413 | |
351 | /** Reason for leaving RC: attempt to patch MMIO write. */ | |
352 | #define VINF_PATM_HC_MMIO_PATCH_WRITE 1414 | |
353 | /** Reason for leaving RC: attempt to patch MMIO read. */ | |
354 | #define VINF_PATM_HC_MMIO_PATCH_READ 1415 | |
355 | /** Reason for leaving RC: pending irq after iret that sets IF. */ | |
356 | #define VINF_PATM_PENDING_IRQ_AFTER_IRET 1416 | |
357 | /** Last leave RC code. */ | |
358 | #define VINF_PATM_LEAVE_RC_LAST VINF_PATM_PENDING_IRQ_AFTER_IRET | |
359 | ||
360 | /** No conflicts to resolve */ | |
361 | #define VERR_PATCH_NO_CONFLICT (-1425) | |
362 | /** Detected unsafe code for patching */ | |
363 | #define VERR_PATM_UNSAFE_CODE (-1426) | |
364 | /** Terminate search branch */ | |
365 | #define VWRN_PATCH_END_BRANCH 1427 | |
366 | /** Already patched */ | |
367 | #define VERR_PATM_ALREADY_PATCHED (-1428) | |
368 | /** Spinlock detection failed. */ | |
369 | #define VINF_PATM_SPINLOCK_FAILED (1429) | |
370 | /** Continue execution after patch trap. */ | |
371 | #define VINF_PATCH_CONTINUE (1430) | |
372 | /** The patch manager is not used because we're using HM and VT-x/AMD-V. */ | |
373 | #define VERR_PATM_HM_IPE (-1431) | |
374 | /** Unexpected trap in patch code. */ | |
375 | #define VERR_PATM_IPE_TRAP_IN_PATCH_CODE (-1432) | |
376 | ||
377 | /** @} */ | |
378 | ||
379 | ||
380 | /** @name Code Scanning and Analysis Manager (CSAM) Status Codes | |
381 | * @{ | |
382 | */ | |
383 | /** Trap not handled */ | |
384 | #define VWRN_CSAM_TRAP_NOT_HANDLED 1500 | |
385 | /** Patch installed */ | |
386 | #define VWRN_CSAM_INSTRUCTION_PATCHED 1501 | |
387 | /** Page record not found */ | |
388 | #define VWRN_CSAM_PAGE_NOT_FOUND 1502 | |
389 | /** Reason for leaving RC: CSAM wants perform a task in ring-3. */ | |
390 | #define VINF_CSAM_PENDING_ACTION 1503 | |
391 | /** The CSAM is not used because we're using HM and VT-x/AMD-V. */ | |
392 | #define VERR_CSAM_HM_IPE (-1504) | |
393 | /** @} */ | |
394 | ||
395 | ||
396 | /** @name Page Monitor/Manager (PGM) Status Codes | |
397 | * @{ | |
398 | */ | |
399 | /** Attempt to create a GC mapping which conflicts with an existing mapping. */ | |
400 | #define VERR_PGM_MAPPING_CONFLICT (-1600) | |
401 | /** The physical handler range has no corresponding RAM range. | |
402 | * If this is MMIO, see todo above the return. If not MMIO, then it's | |
403 | * someone else's fault... */ | |
404 | #define VERR_PGM_HANDLER_PHYSICAL_NO_RAM_RANGE (-1601) | |
405 | /** Attempt to register an access handler for a virtual range of which a part | |
406 | * was already handled. */ | |
407 | #define VERR_PGM_HANDLER_VIRTUAL_CONFLICT (-1602) | |
408 | /** Attempt to register an access handler for a physical range of which a part | |
409 | * was already handled. */ | |
410 | #define VERR_PGM_HANDLER_PHYSICAL_CONFLICT (-1603) | |
411 | /** Invalid page directory specified to PGM. */ | |
412 | #define VERR_PGM_INVALID_PAGE_DIRECTORY (-1604) | |
413 | /** Invalid GC physical address. */ | |
414 | #define VERR_PGM_INVALID_GC_PHYSICAL_ADDRESS (-1605) | |
415 | /** Invalid GC physical range. Usually used when a specified range crosses | |
416 | * a RAM region boundary. */ | |
417 | #define VERR_PGM_INVALID_GC_PHYSICAL_RANGE (-1606) | |
418 | /** Specified access handler was not found. */ | |
419 | #define VERR_PGM_HANDLER_NOT_FOUND (-1607) | |
420 | /** Attempt to register a RAM range of which parts are already | |
421 | * covered by existing RAM ranges. */ | |
422 | #define VERR_PGM_RAM_CONFLICT (-1608) | |
423 | /** Failed to add new mappings because the current mappings are fixed | |
424 | * in guest os memory. */ | |
425 | #define VERR_PGM_MAPPINGS_FIXED (-1609) | |
426 | /** Failed to fix mappings because of a conflict with the intermediate code. */ | |
427 | #define VERR_PGM_MAPPINGS_FIX_CONFLICT (-1610) | |
428 | /** Failed to fix mappings because a mapping rejected the address. */ | |
429 | #define VERR_PGM_MAPPINGS_FIX_REJECTED (-1611) | |
430 | /** Failed to fix mappings because the proposed memory area was to small. */ | |
431 | #define VERR_PGM_MAPPINGS_FIX_TOO_SMALL (-1612) | |
432 | /** Reason for leaving RZ: The urge to syncing CR3. */ | |
433 | #define VINF_PGM_SYNC_CR3 1613 | |
434 | /** Page not marked for dirty bit tracking */ | |
435 | #define VINF_PGM_NO_DIRTY_BIT_TRACKING 1614 | |
436 | /** Page fault caused by dirty bit tracking; corrected */ | |
437 | #define VINF_PGM_HANDLED_DIRTY_BIT_FAULT 1615 | |
438 | /** Go ahead with the default Read/Write operation. | |
439 | * This is returned by a R3 physical or virtual handler when it wants the | |
440 | * PGMPhys[Read|Write] routine do the reading/writing. */ | |
441 | #define VINF_PGM_HANDLER_DO_DEFAULT 1616 | |
442 | /** The paging mode of the host is not supported yet. */ | |
443 | #define VERR_PGM_UNSUPPORTED_HOST_PAGING_MODE (-1617) | |
444 | /** The physical guest page is a reserved/MMIO page and does not have any HC | |
445 | * address. */ | |
446 | #define VERR_PGM_PHYS_PAGE_RESERVED (-1618) | |
447 | /** No page directory available for the hypervisor. */ | |
448 | #define VERR_PGM_NO_HYPERVISOR_ADDRESS (-1619) | |
449 | /** The shadow page pool was flushed. | |
450 | * This means that a global CR3 sync was flagged. Anyone receiving this kind of status | |
451 | * will have to get down to a SyncCR3 ASAP. See also VINF_PGM_SYNC_CR3. */ | |
452 | #define VERR_PGM_POOL_FLUSHED (-1620) | |
453 | /** The shadow page pool was cleared. | |
454 | * This is a error code internal to the shadow page pool, it will be | |
455 | * converted to a VERR_PGM_POOL_FLUSHED before leaving the pool code. */ | |
456 | #define VERR_PGM_POOL_CLEARED (-1621) | |
457 | /** The returned shadow page is cached. */ | |
458 | #define VINF_PGM_CACHED_PAGE 1622 | |
459 | /** Returned by handler registration, modification and deregistration | |
460 | * when the shadow PTs could be updated because the guest page | |
461 | * aliased or/and mapped by multiple PTs. */ | |
462 | #define VINF_PGM_GCPHYS_ALIASED 1623 | |
463 | /** Reason for leaving RC: Paging mode changed. | |
464 | * PGMChangeMode() uses this to force a switch to R3 so it can safely deal with | |
465 | * a mode switch. */ | |
466 | #define VINF_PGM_CHANGE_MODE 1624 | |
467 | /** SyncPage modified the PDE. | |
468 | * This is an internal status code used to communicate back to the \#PF handler | |
469 | * that the PDE was (probably) marked not-present and it should restart the instruction. */ | |
470 | #define VINF_PGM_SYNCPAGE_MODIFIED_PDE 1625 | |
471 | /** Physical range crosses dynamic ram chunk boundary; translation to HC ptr not safe. */ | |
472 | #define VERR_PGM_GCPHYS_RANGE_CROSSES_BOUNDARY (-1626) | |
473 | /** Conflict between the core memory and the intermediate paging context, try again. | |
474 | * There are some very special conditions applying to the intermediate paging context | |
475 | * (used during the world switches), and some times we continuously run into these | |
476 | * when asking the host kernel for memory during VM init. Let us know if you run into | |
477 | * this and we'll adjust the code so it tries harder to avoid it. | |
478 | */ | |
479 | #define VERR_PGM_INTERMEDIATE_PAGING_CONFLICT (-1627) | |
480 | /** The shadow paging mode is not supported yet. */ | |
481 | #define VERR_PGM_UNSUPPORTED_SHADOW_PAGING_MODE (-1628) | |
482 | /** The dynamic mapping cache for physical memory failed. */ | |
483 | #define VERR_PGM_DYNMAP_FAILED (-1629) | |
484 | /** The auto usage cache for the dynamic mapping set is full. */ | |
485 | #define VERR_PGM_DYNMAP_FULL_SET (-1630) | |
486 | /** The initialization of the dynamic mapping cache failed. */ | |
487 | #define VERR_PGM_DYNMAP_SETUP_ERROR (-1631) | |
488 | /** The expanding of the dynamic mapping cache failed. */ | |
489 | #define VERR_PGM_DYNMAP_EXPAND_ERROR (-1632) | |
490 | /** The page is unassigned (akin to VERR_PGM_INVALID_GC_PHYSICAL_ADDRESS). */ | |
491 | #define VERR_PGM_PHYS_TLB_UNASSIGNED (-1633) | |
492 | /** Catch any access and route it thru PGM. */ | |
493 | #define VERR_PGM_PHYS_TLB_CATCH_ALL (-1634) | |
494 | /** Catch write access and route it thru PGM. */ | |
495 | #define VINF_PGM_PHYS_TLB_CATCH_WRITE 1635 | |
496 | /** Catch write access and route it thru PGM. */ | |
497 | #define VERR_PGM_PHYS_TLB_CATCH_WRITE (-1635) | |
498 | /** No CR3 root shadow page table. */ | |
499 | #define VERR_PGM_NO_CR3_SHADOW_ROOT (-1636) | |
500 | /** Trying to free a page with an invalid Page ID. */ | |
501 | #define VERR_PGM_PHYS_INVALID_PAGE_ID (-1637) | |
502 | /** PGMPhysWrite/Read hit a handler in Ring-0 or raw-mode context. */ | |
503 | #define VERR_PGM_PHYS_WR_HIT_HANDLER (-1638) | |
504 | /** Trying to free a page that isn't RAM. */ | |
505 | #define VERR_PGM_PHYS_NOT_RAM (-1639) | |
506 | /** Not ROM page. */ | |
507 | #define VERR_PGM_PHYS_NOT_ROM (-1640) | |
508 | /** Not MMIO page. */ | |
509 | #define VERR_PGM_PHYS_NOT_MMIO (-1641) | |
510 | /** Not MMIO2 page. */ | |
511 | #define VERR_PGM_PHYS_NOT_MMIO2 (-1642) | |
512 | /** Already aliased to a different page. */ | |
513 | #define VERR_PGM_HANDLER_ALREADY_ALIASED (-1643) | |
514 | /** Already aliased to the same page. */ | |
515 | #define VINF_PGM_HANDLER_ALREADY_ALIASED (1643) | |
516 | /** PGM pool flush pending - return to ring 3. */ | |
517 | #define VINF_PGM_POOL_FLUSH_PENDING (1644) | |
518 | /** Unable to use the range for a large page. */ | |
519 | #define VERR_PGM_INVALID_LARGE_PAGE_RANGE (-1645) | |
520 | /** Don't mess around with ballooned pages. */ | |
521 | #define VERR_PGM_PHYS_PAGE_BALLOONED (-1646) | |
522 | /** Internal processing error \#1 in page access handler code. */ | |
523 | #define VERR_PGM_HANDLER_IPE_1 (-1647) | |
524 | ||
525 | ||
526 | /** pgmPhysPageMapCommon encountered PGMPAGETYPE_MMIO2_ALIAS_MMIO. */ | |
527 | #define VERR_PGM_MAP_MMIO2_ALIAS_MMIO (-1651) | |
528 | /** Guest mappings are disabled. */ | |
529 | #define VERR_PGM_MAPPINGS_DISABLED (-1652) | |
530 | /** No guest mappings when SMP is enabled. */ | |
531 | #define VERR_PGM_MAPPINGS_SMP (-1653) | |
532 | /** Invalid saved page state. */ | |
533 | #define VERR_PGM_INVALID_SAVED_PAGE_STATE (-1654) | |
534 | /** Encountered an unexpected page type in the saved state. */ | |
535 | #define VERR_PGM_LOAD_UNEXPECTED_PAGE_TYPE (-1655) | |
536 | /** Encountered an unexpected page state in the saved state. */ | |
537 | #define VERR_PGM_UNEXPECTED_PAGE_STATE (-1656) | |
538 | /** Couldn't find MMIO2 range from saved state. */ | |
539 | #define VERR_PGM_SAVED_MMIO2_RANGE_NOT_FOUND (-1657) | |
540 | /** Couldn't find MMIO2 page from saved state. */ | |
541 | #define VERR_PGM_SAVED_MMIO2_PAGE_NOT_FOUND (-1658) | |
542 | /** Couldn't find ROM range from saved state. */ | |
543 | #define VERR_PGM_SAVED_ROM_RANGE_NOT_FOUND (-1659) | |
544 | /** Couldn't find ROM page from saved state. */ | |
545 | #define VERR_PGM_SAVED_ROM_PAGE_NOT_FOUND (-1660) | |
546 | /** ROM page mismatch between saved state and the VM. */ | |
547 | #define VERR_PGM_SAVED_ROM_PAGE_PROT (-1661) | |
548 | /** Unknown saved state record. */ | |
549 | #define VERR_PGM_SAVED_REC_TYPE (-1662) | |
550 | /** Internal processing error in the PGM dynmap (r0/rc). */ | |
551 | #define VERR_PGM_DYNMAP_IPE (-1663) | |
552 | /** Internal processing error in the PGM handy page allocator. */ | |
553 | #define VERR_PGM_HANDY_PAGE_IPE (-1664) | |
554 | /** Failed to map the guest PML4. */ | |
555 | #define VERR_PGM_PML4_MAPPING (-1665) | |
556 | /** Failed to obtain a pool page. */ | |
557 | #define VERR_PGM_POOL_GET_PAGE_FAILED (-1666) | |
558 | /** A PGM function was called in a mode where it isn't supposed to be used. */ | |
559 | #define VERR_PGM_NOT_USED_IN_MODE (-1667) | |
560 | /** The CR3 address specified memory we don't know about. */ | |
561 | #define VERR_PGM_INVALID_CR3_ADDR (-1668) | |
562 | /** One or the PDPEs specified memory we don't know about. */ | |
563 | #define VERR_PGM_INVALID_PDPE_ADDR (-1669) | |
564 | /** Internal processing error in the PGM physical handler code. */ | |
565 | #define VERR_PGM_PHYS_HANDLER_IPE (-1670) | |
566 | /** Internal processing error \#1 in the PGM physial page mapping code. */ | |
567 | #define VERR_PGM_PHYS_PAGE_MAP_IPE_1 (-1671) | |
568 | /** Internal processing error \#2 in the PGM physial page mapping code. */ | |
569 | #define VERR_PGM_PHYS_PAGE_MAP_IPE_2 (-1672) | |
570 | /** Internal processing error \#3 in the PGM physial page mapping code. */ | |
571 | #define VERR_PGM_PHYS_PAGE_MAP_IPE_3 (-1673) | |
572 | /** Internal processing error \#4 in the PGM physial page mapping code. */ | |
573 | #define VERR_PGM_PHYS_PAGE_MAP_IPE_4 (-1674) | |
574 | /** Too many loops looking for a page to reuse. */ | |
575 | #define VERR_PGM_POOL_TOO_MANY_LOOPS (-1675) | |
576 | /** Internal processing error related to guest mappings. */ | |
577 | #define VERR_PGM_MAPPING_IPE (-1676) | |
578 | /** An attempt was made to grow an already maxed out page pool. */ | |
579 | #define VERR_PGM_POOL_MAXED_OUT_ALREADY (-1677) | |
580 | /** Internal processing error in the page pool code. */ | |
581 | #define VERR_PGM_POOL_IPE (-1678) | |
582 | /** The write monitor is already engaged. */ | |
583 | #define VERR_PGM_WRITE_MONITOR_ENGAGED (-1679) | |
584 | /** Failed to get a guest page which is expected to be present. */ | |
585 | #define VERR_PGM_PHYS_PAGE_GET_IPE (-1680) | |
586 | /** We were given a NULL pPage parameter. */ | |
587 | #define VERR_PGM_PHYS_NULL_PAGE_PARAM (-1681) | |
588 | /** PCI passthru is not supported by this build. */ | |
589 | #define VERR_PGM_PCI_PASSTHRU_MISCONFIG (-1682) | |
590 | /** Too many MMIO2 ranges. */ | |
591 | #define VERR_PGM_TOO_MANY_MMIO2_RANGES (-1683) | |
592 | /** Internal processing error in the PGM physical page mapping code dealing | |
593 | * with MMIO2 pages. */ | |
594 | #define VERR_PGM_PHYS_PAGE_MAP_MMIO2_IPE (-1684) | |
595 | /** Internal processing error in the PGM physcal page handling code related to | |
596 | * MMIO/MMIO2. */ | |
597 | #define VERR_PGM_PHYS_MMIO_EX_IPE (-1685) | |
598 | /** @} */ | |
599 | ||
600 | ||
601 | /** @name Memory Monitor (MM) Status Codes | |
602 | * @{ | |
603 | */ | |
604 | /** Attempt to register a RAM range of which parts are already | |
605 | * covered by existing RAM ranges. */ | |
606 | #define VERR_MM_RAM_CONFLICT (-1700) | |
607 | /** Hypervisor memory allocation failed. */ | |
608 | #define VERR_MM_HYPER_NO_MEMORY (-1701) | |
609 | /** A bad trap type ended up in mmGCRamTrap0eHandler. */ | |
610 | #define VERR_MM_BAD_TRAP_TYPE_IPE (-1702) | |
611 | /** @} */ | |
612 | ||
613 | ||
614 | /** @name CPU Monitor (CPUM) Status Codes | |
615 | * @{ | |
616 | */ | |
617 | /** The caller shall raise an \#GP(0) exception. */ | |
618 | #define VERR_CPUM_RAISE_GP_0 (-1750) | |
619 | /** Incompatible CPUM configuration. */ | |
620 | #define VERR_CPUM_INCOMPATIBLE_CONFIG (-1751) | |
621 | /** CPUMR3DisasmInstrCPU unexpectedly failed to determine the hidden | |
622 | * parts of the CS register. */ | |
623 | #define VERR_CPUM_HIDDEN_CS_LOAD_ERROR (-1752) | |
624 | /** Couldn't find the end of CPUID sub-leaves. */ | |
625 | #define VERR_CPUM_TOO_MANY_CPUID_SUBLEAVES (-1753) | |
626 | /** CPUM internal processing error \#1. */ | |
627 | #define VERR_CPUM_IPE_1 (-1754) | |
628 | /** CPUM internal processing error \#2. */ | |
629 | #define VERR_CPUM_IPE_2 (-1755) | |
630 | /** The specified CPU cannot be found in the CPU database. */ | |
631 | #define VERR_CPUM_DB_CPU_NOT_FOUND (-1756) | |
632 | /** Invalid CPUMCPU offset in MSR range. */ | |
633 | #define VERR_CPUM_MSR_BAD_CPUMCPU_OFFSET (-1757) | |
634 | /** Return to ring-3 to read the MSR there. */ | |
635 | #define VINF_CPUM_R3_MSR_READ (1758) | |
636 | /** Return to ring-3 to write the MSR there. */ | |
637 | #define VINF_CPUM_R3_MSR_WRITE (1759) | |
638 | /** Too many CPUID leaves. */ | |
639 | #define VERR_TOO_MANY_CPUID_LEAVES (-1760) | |
640 | /** Invalid config value. */ | |
641 | #define VERR_CPUM_INVALID_CONFIG_VALUE (-1761) | |
642 | /** The loaded XSAVE component mask is not compatible with the host CPU | |
643 | * or/and VM config. */ | |
644 | #define VERR_CPUM_INCOMPATIBLE_XSAVE_COMP_MASK (-1762) | |
645 | /** The loaded XSAVE component mask is not valid. */ | |
646 | #define VERR_CPUM_INVALID_XSAVE_COMP_MASK (-1763) | |
647 | /** The loaded XSAVE header is not valid. */ | |
648 | #define VERR_CPUM_INVALID_XSAVE_HDR (-1764) | |
649 | /** The loaded XCR0 register value is not valid. */ | |
650 | #define VERR_CPUM_INVALID_XCR0 (-1765) | |
651 | /** Indicates that we modified the host CR0 (FPU related). */ | |
652 | #define VINF_CPUM_HOST_CR0_MODIFIED (1766) | |
653 | /** @} */ | |
654 | ||
655 | ||
656 | /** @name Save State Manager (SSM) Status Codes | |
657 | * @{ | |
658 | */ | |
659 | /** The specified data unit already exist. */ | |
660 | #define VERR_SSM_UNIT_EXISTS (-1800) | |
661 | /** The specified data unit wasn't found. */ | |
662 | #define VERR_SSM_UNIT_NOT_FOUND (-1801) | |
663 | /** The specified data unit wasn't owned by caller. */ | |
664 | #define VERR_SSM_UNIT_NOT_OWNER (-1802) | |
665 | ||
666 | /** General saved state file integrity error. */ | |
667 | #define VERR_SSM_INTEGRITY (-1810) | |
668 | /** The saved state file magic was not recognized. */ | |
669 | #define VERR_SSM_INTEGRITY_MAGIC (-1811) | |
670 | /** The saved state file version is not supported. */ | |
671 | #define VERR_SSM_INTEGRITY_VERSION (-1812) | |
672 | /** The saved state file size didn't match the one in the header. */ | |
673 | #define VERR_SSM_INTEGRITY_SIZE (-1813) | |
674 | /** The CRC of the saved state file did not match. */ | |
675 | #define VERR_SSM_INTEGRITY_CRC (-1814) | |
676 | /** The machine uuid field wasn't null. */ | |
677 | #define VERR_SMM_INTEGRITY_MACHINE (-1815) | |
678 | /** Saved state header integrity error. */ | |
679 | #define VERR_SSM_INTEGRITY_HEADER (-1816) | |
680 | /** Unit header integrity error. */ | |
681 | #define VERR_SSM_INTEGRITY_UNIT (-1817) | |
682 | /** Invalid unit magic (internal data tag). */ | |
683 | #define VERR_SSM_INTEGRITY_UNIT_MAGIC (-1818) | |
684 | /** The file contained a data unit which no-one wants. */ | |
685 | #define VERR_SSM_INTEGRITY_UNIT_NOT_FOUND (-1819) | |
686 | /** Incorrect version numbers in the header. */ | |
687 | #define VERR_SSM_INTEGRITY_VBOX_VERSION (-1820) | |
688 | /** Footer integrity error. */ | |
689 | #define VERR_SSM_INTEGRITY_FOOTER (-1821) | |
690 | /** Record header integrity error. */ | |
691 | #define VERR_SSM_INTEGRITY_REC_HDR (-1822) | |
692 | /** Termination record integrity error. */ | |
693 | #define VERR_SSM_INTEGRITY_REC_TERM (-1823) | |
694 | /** Termination record CRC mismatch. */ | |
695 | #define VERR_SSM_INTEGRITY_REC_TERM_CRC (-1824) | |
696 | /** Decompression integrity error. */ | |
697 | #define VERR_SSM_INTEGRITY_DECOMPRESSION (-1825) | |
698 | /** Saved state directory wintertides error. */ | |
699 | #define VERR_SSM_INTEGRITY_DIR (-1826) | |
700 | /** The saved state directory magic is wrong. */ | |
701 | #define VERR_SSM_INTEGRITY_DIR_MAGIC (-1827) | |
702 | ||
703 | /** A data unit in the saved state file was defined but didn't any | |
704 | * routine for processing it. */ | |
705 | #define VERR_SSM_NO_LOAD_EXEC (-1830) | |
706 | /** A restore routine attempted to load more data then the unit contained. */ | |
707 | #define VERR_SSM_LOADED_TOO_MUCH (-1831) | |
708 | /** Not in the correct state for the attempted operation. */ | |
709 | #define VERR_SSM_INVALID_STATE (-1832) | |
710 | /** Not in the correct state for the attempted operation. */ | |
711 | #define VERR_SSM_LOADED_TOO_LITTLE (-1833) | |
712 | ||
713 | /** Unsupported data unit version. | |
714 | * A SSM user returns this if it doesn't know the u32Version. */ | |
715 | #define VERR_SSM_UNSUPPORTED_DATA_UNIT_VERSION (-1840) | |
716 | /** The format of a data unit has changed. | |
717 | * A SSM user returns this if it's not able to read the format for | |
718 | * other reasons than u32Version. */ | |
719 | #define VERR_SSM_DATA_UNIT_FORMAT_CHANGED (-1841) | |
720 | /** The CPUID instruction returns different information when loading than when saved. | |
721 | * Normally caused by hardware changes on the host, but could also be caused by | |
722 | * changes in the BIOS setup. */ | |
723 | #define VERR_SSM_LOAD_CPUID_MISMATCH (-1842) | |
724 | /** The RAM size differs between the saved state and the VM config. */ | |
725 | #define VERR_SSM_LOAD_MEMORY_SIZE_MISMATCH (-1843) | |
726 | /** The state doesn't match the VM configuration in one or another way. | |
727 | * (There are certain PCI reconfiguration which the OS could potentially | |
728 | * do which can cause this problem. Check this out when it happens.) */ | |
729 | #define VERR_SSM_LOAD_CONFIG_MISMATCH (-1844) | |
730 | /** The virtual clock frequency differs too much. | |
731 | * The clock source for the virtual time isn't reliable or the code have changed. */ | |
732 | #define VERR_SSM_VIRTUAL_CLOCK_HZ (-1845) | |
733 | /** A timeout occurred while waiting for async IDE operations to finish. */ | |
734 | #define VERR_SSM_IDE_ASYNC_TIMEOUT (-1846) | |
735 | /** One of the structure magics was wrong. */ | |
736 | #define VERR_SSM_STRUCTURE_MAGIC (-1847) | |
737 | /** The data in the saved state doesn't conform to expectations. */ | |
738 | #define VERR_SSM_UNEXPECTED_DATA (-1848) | |
739 | /** Trying to read a 64-bit guest physical address into a 32-bit variable. */ | |
740 | #define VERR_SSM_GCPHYS_OVERFLOW (-1849) | |
741 | /** Trying to read a 64-bit guest virtual address into a 32-bit variable. */ | |
742 | #define VERR_SSM_GCPTR_OVERFLOW (-1850) | |
743 | /** Vote for another pass. */ | |
744 | #define VINF_SSM_VOTE_FOR_ANOTHER_PASS 1851 | |
745 | /** Vote for done tell SSM not to call again until the final pass. */ | |
746 | #define VINF_SSM_VOTE_DONE_DONT_CALL_AGAIN 1852 | |
747 | /** Vote for giving up. */ | |
748 | #define VERR_SSM_VOTE_FOR_GIVING_UP (-1853) | |
749 | /** Don't call again until the final pass. */ | |
750 | #define VINF_SSM_DONT_CALL_AGAIN 1854 | |
751 | /** Giving up a live snapshot/teleportation attempt because of too many | |
752 | * passes. */ | |
753 | #define VERR_SSM_TOO_MANY_PASSES (-1855) | |
754 | /** Giving up a live snapshot/teleportation attempt because the state grew to | |
755 | * big. */ | |
756 | #define VERR_SSM_STATE_GREW_TOO_BIG (-1856) | |
757 | /** Giving up a live snapshot attempt because we're low on disk space. */ | |
758 | #define VERR_SSM_LOW_ON_DISK_SPACE (-1857) | |
759 | /** The operation was cancelled. */ | |
760 | #define VERR_SSM_CANCELLED (-1858) | |
761 | /** Nothing that can be cancelled. */ | |
762 | #define VERR_SSM_NO_PENDING_OPERATION (-1859) | |
763 | /** The operation has already been cancelled. */ | |
764 | #define VERR_SSM_ALREADY_CANCELLED (-1860) | |
765 | /** The machine was powered off while saving. */ | |
766 | #define VERR_SSM_LIVE_POWERED_OFF (-1861) | |
767 | /** The live snapshot/teleportation operation was aborted because of a guru | |
768 | * meditation. */ | |
769 | #define VERR_SSM_LIVE_GURU_MEDITATION (-1862) | |
770 | /** The live snapshot/teleportation operation was aborted because of a fatal | |
771 | * runtime error. */ | |
772 | #define VERR_SSM_LIVE_FATAL_ERROR (-1863) | |
773 | /** The VM was suspended before or while saving, don't resume execution. */ | |
774 | #define VINF_SSM_LIVE_SUSPENDED 1864 | |
775 | /** Complex SSM field fed to SSMR3PutStruct or SSMR3GetStruct. Use the | |
776 | * extended API. */ | |
777 | #define VERR_SSM_FIELD_COMPLEX (-1864) | |
778 | /** Invalid size of a SSM field with the specified transformation. */ | |
779 | #define VERR_SSM_FIELD_INVALID_SIZE (-1865) | |
780 | /** The specified field is outside the structure. */ | |
781 | #define VERR_SSM_FIELD_OUT_OF_BOUNDS (-1866) | |
782 | /** The field does not follow immediately the previous one. */ | |
783 | #define VERR_SSM_FIELD_NOT_CONSECUTIVE (-1867) | |
784 | /** The field contains an invalid callback or transformation index. */ | |
785 | #define VERR_SSM_FIELD_INVALID_CALLBACK (-1868) | |
786 | /** The field contains an invalid padding size. */ | |
787 | #define VERR_SSM_FIELD_INVALID_PADDING_SIZE (-1869) | |
788 | /** The field contains a value that is out of range. */ | |
789 | #define VERR_SSM_FIELD_INVALID_VALUE (-1870) | |
790 | /** Generic stream error. */ | |
791 | #define VERR_SSM_STREAM_ERROR (-1871) | |
792 | /** SSM did a callback for a pass we didn't expect. */ | |
793 | #define VERR_SSM_UNEXPECTED_PASS (-1872) | |
794 | /** Someone is trying to skip backwards in the stream... */ | |
795 | #define VERR_SSM_SKIP_BACKWARDS (-1873) | |
796 | /** Someone is trying to write a memory block which is too big to encode. */ | |
797 | #define VERR_SSM_MEM_TOO_BIG (-1874) | |
798 | /** Encountered an bad (/unknown) record type. */ | |
799 | #define VERR_SSM_BAD_REC_TYPE (-1875) | |
800 | /** Internal processing error \#1 in SSM code. */ | |
801 | #define VERR_SSM_IPE_1 (-1876) | |
802 | /** Internal processing error \#2 in SSM code. */ | |
803 | #define VERR_SSM_IPE_2 (-1877) | |
804 | /** Internal processing error \#3 in SSM code. */ | |
805 | #define VERR_SSM_IPE_3 (-1878) | |
806 | /** A field contained an transformation that should only be used when loading | |
807 | * old states. */ | |
808 | #define VERR_SSM_FIELD_LOAD_ONLY_TRANSFORMATION (-1879) | |
809 | /** @} */ | |
810 | ||
811 | ||
812 | /** @name Virtual Machine (VM) Status Codes | |
813 | * @{ | |
814 | */ | |
815 | /** The specified at reset handler wasn't found. */ | |
816 | #define VERR_VM_ATRESET_NOT_FOUND (-1900) | |
817 | /** Invalid VM request type. | |
818 | * For the VMR3ReqAlloc() case, the caller just specified an illegal enmType. For | |
819 | * all the other occurrences it means indicates corruption, broken logic, or stupid | |
820 | * interface user. */ | |
821 | #define VERR_VM_REQUEST_INVALID_TYPE (-1901) | |
822 | /** Invalid VM request state. | |
823 | * The state of the request packet was not the expected and accepted one(s). Either | |
824 | * the interface user screwed up, or we've got corruption/broken logic. */ | |
825 | #define VERR_VM_REQUEST_STATE (-1902) | |
826 | /** Invalid VM request packet. | |
827 | * One or more of the VM controlled packet members didn't contain the correct | |
828 | * values. Some thing's broken. */ | |
829 | #define VERR_VM_REQUEST_INVALID_PACKAGE (-1903) | |
830 | /** The status field has not been updated yet as the request is still | |
831 | * pending completion. Someone queried the iStatus field before the request | |
832 | * has been fully processed. */ | |
833 | #define VERR_VM_REQUEST_STATUS_STILL_PENDING (-1904) | |
834 | /** The request has been freed, don't read the status now. | |
835 | * Someone is reading the iStatus field of a freed request packet. */ | |
836 | #define VERR_VM_REQUEST_STATUS_FREED (-1905) | |
837 | /** A VM api requiring EMT was called from another thread. | |
838 | * Use the VMR3ReqCall() apis to call it! */ | |
839 | #define VERR_VM_THREAD_NOT_EMT (-1906) | |
840 | /** The VM state was invalid for the requested operation. | |
841 | * Go check the 'VM Statechart Diagram.gif'. */ | |
842 | #define VERR_VM_INVALID_VM_STATE (-1907) | |
843 | /** The support driver is not installed. | |
844 | * On linux, open returned ENOENT. */ | |
845 | #define VERR_VM_DRIVER_NOT_INSTALLED (-1908) | |
846 | /** The support driver is not accessible. | |
847 | * On linux, open returned EPERM. */ | |
848 | #define VERR_VM_DRIVER_NOT_ACCESSIBLE (-1909) | |
849 | /** Was not able to load the support driver. | |
850 | * On linux, open returned ENODEV. */ | |
851 | #define VERR_VM_DRIVER_LOAD_ERROR (-1910) | |
852 | /** Was not able to open the support driver. | |
853 | * Generic open error used when none of the other ones fit. */ | |
854 | #define VERR_VM_DRIVER_OPEN_ERROR (-1911) | |
855 | /** The installed support driver doesn't match the version of the user. */ | |
856 | #define VERR_VM_DRIVER_VERSION_MISMATCH (-1912) | |
857 | /** Saving the VM state is temporarily not allowed. Try again later. */ | |
858 | #define VERR_VM_SAVE_STATE_NOT_ALLOWED (-1913) | |
859 | /** An EMT called an API which cannot be called on such a thread. */ | |
860 | #define VERR_VM_THREAD_IS_EMT (-1914) | |
861 | /** Encountered an unexpected VM state. */ | |
862 | #define VERR_VM_UNEXPECTED_VM_STATE (-1915) | |
863 | /** Unexpected unstable VM state. */ | |
864 | #define VERR_VM_UNEXPECTED_UNSTABLE_STATE (-1916) | |
865 | /** Too many arguments passed to a VM request / request corruption. */ | |
866 | #define VERR_VM_REQUEST_TOO_MANY_ARGS_IPE (-1917) | |
867 | /** Fatal EMT wait error. */ | |
868 | #define VERR_VM_FATAL_WAIT_ERROR (-1918) | |
869 | /** The VM request was killed at VM termination. */ | |
870 | #define VERR_VM_REQUEST_KILLED (-1919) | |
871 | /** @} */ | |
872 | ||
873 | ||
874 | /** @name VBox Remote Desktop Protocol (VRDP) Status Codes | |
875 | * @{ | |
876 | */ | |
877 | /** Successful completion of operation (mapped to generic iprt status code). */ | |
878 | #define VINF_VRDP_SUCCESS VINF_SUCCESS | |
879 | /** VRDP transport operation timed out (mapped to generic iprt status code). */ | |
880 | #define VERR_VRDP_TIMEOUT VERR_TIMEOUT | |
881 | ||
882 | /** Unsupported ISO protocol feature */ | |
883 | #define VERR_VRDP_ISO_UNSUPPORTED (-2000) | |
884 | /** Security (en/decryption) engine error */ | |
885 | #define VERR_VRDP_SEC_ENGINE_FAIL (-2001) | |
886 | /** VRDP protocol violation */ | |
887 | #define VERR_VRDP_PROTOCOL_ERROR (-2002) | |
888 | /** Unsupported VRDP protocol feature */ | |
889 | #define VERR_VRDP_NOT_SUPPORTED (-2003) | |
890 | /** VRDP protocol violation, client sends less data than expected */ | |
891 | #define VERR_VRDP_INSUFFICIENT_DATA (-2004) | |
892 | /** Internal error, VRDP packet is in wrong operation mode */ | |
893 | #define VERR_VRDP_INVALID_MODE (-2005) | |
894 | /** Memory allocation failed */ | |
895 | #define VERR_VRDP_NO_MEMORY (-2006) | |
896 | /** Client has been rejected */ | |
897 | #define VERR_VRDP_ACCESS_DENIED (-2007) | |
898 | /** VRPD receives a packet that is not supported */ | |
899 | #define VWRN_VRDP_PDU_NOT_SUPPORTED 2008 | |
900 | /** VRDP script allowed the packet to be processed further */ | |
901 | #define VINF_VRDP_PROCESS_PDU 2009 | |
902 | /** VRDP script has completed its task */ | |
903 | #define VINF_VRDP_OPERATION_COMPLETED 2010 | |
904 | /** VRDP thread has started OK and will run */ | |
905 | #define VINF_VRDP_THREAD_STARTED 2011 | |
906 | /** Framebuffer is resized, terminate send bitmap procedure */ | |
907 | #define VINF_VRDP_RESIZE_REQUESTED 2012 | |
908 | /** Output can be enabled for the client. */ | |
909 | #define VINF_VRDP_OUTPUT_ENABLE 2013 | |
910 | /** @} */ | |
911 | ||
912 | ||
913 | /** @name Configuration Manager (CFGM) Status Codes | |
914 | * @{ | |
915 | */ | |
916 | /** The integer value was too big for the requested representation. */ | |
917 | #define VERR_CFGM_INTEGER_TOO_BIG (-2100) | |
918 | /** Child node was not found. */ | |
919 | #define VERR_CFGM_CHILD_NOT_FOUND (-2101) | |
920 | /** Path to child node was invalid (i.e. empty). */ | |
921 | #define VERR_CFGM_INVALID_CHILD_PATH (-2102) | |
922 | /** Value not found. */ | |
923 | #define VERR_CFGM_VALUE_NOT_FOUND (-2103) | |
924 | /** No parent node specified. */ | |
925 | #define VERR_CFGM_NO_PARENT (-2104) | |
926 | /** No node was specified. */ | |
927 | #define VERR_CFGM_NO_NODE (-2105) | |
928 | /** The value is not an integer. */ | |
929 | #define VERR_CFGM_NOT_INTEGER (-2106) | |
930 | /** The value is not a zero terminated character string. */ | |
931 | #define VERR_CFGM_NOT_STRING (-2107) | |
932 | /** The value is not a byte string. */ | |
933 | #define VERR_CFGM_NOT_BYTES (-2108) | |
934 | /** The specified string / bytes buffer was to small. Specify a larger one and retry. */ | |
935 | #define VERR_CFGM_NOT_ENOUGH_SPACE (-2109) | |
936 | /** The path of a new node contained slashes or was empty. */ | |
937 | #define VERR_CFGM_INVALID_NODE_PATH (-2160) | |
938 | /** A new node couldn't be inserted because one with the same name exists. */ | |
939 | #define VERR_CFGM_NODE_EXISTS (-2161) | |
940 | /** A new leaf couldn't be inserted because one with the same name exists. */ | |
941 | #define VERR_CFGM_LEAF_EXISTS (-2162) | |
942 | /** An unknown config value was encountered. */ | |
943 | #define VERR_CFGM_CONFIG_UNKNOWN_VALUE (-2163) | |
944 | /** An unknown config node (key) was encountered. */ | |
945 | #define VERR_CFGM_CONFIG_UNKNOWN_NODE (-2164) | |
946 | /** Internal processing error \#1 in CFGM. */ | |
947 | #define VERR_CFGM_IPE_1 (-2165) | |
948 | /** @} */ | |
949 | ||
950 | ||
951 | /** @name Time Manager (TM) Status Codes | |
952 | * @{ | |
953 | */ | |
954 | /** The loaded timer state was incorrect. */ | |
955 | #define VERR_TM_LOAD_STATE (-2200) | |
956 | /** The timer was not in the correct state for the request operation. */ | |
957 | #define VERR_TM_INVALID_STATE (-2201) | |
958 | /** The timer was in a unknown state. Corruption or stupid coding error. */ | |
959 | #define VERR_TM_UNKNOWN_STATE (-2202) | |
960 | /** The timer was stuck in an unstable state until we grew impatient and returned. */ | |
961 | #define VERR_TM_UNSTABLE_STATE (-2203) | |
962 | /** TM requires GIP. */ | |
963 | #define VERR_TM_GIP_REQUIRED (-2204) | |
964 | /** TM does not support the GIP version. */ | |
965 | #define VERR_TM_GIP_VERSION (-2205) | |
966 | /** The GIP update interval is too large. */ | |
967 | #define VERR_TM_GIP_UPDATE_INTERVAL_TOO_BIG (-2206) | |
968 | /** The timer has a bad clock enum value, probably corruption. */ | |
969 | #define VERR_TM_TIMER_BAD_CLOCK (-2207) | |
970 | /** The timer failed to reach a stable state. */ | |
971 | #define VERR_TM_TIMER_UNSTABLE_STATE (-2208) | |
972 | /** Attempt to resume a running TSC. */ | |
973 | #define VERR_TM_TSC_ALREADY_TICKING (-2209) | |
974 | /** Attempt to pause a paused TSC. */ | |
975 | #define VERR_TM_TSC_ALREADY_PAUSED (-2210) | |
976 | /** Invalid value for cVirtualTicking. */ | |
977 | #define VERR_TM_VIRTUAL_TICKING_IPE (-2211) | |
978 | /** @} */ | |
979 | ||
980 | ||
981 | /** @name Recompiled Execution Manager (REM) Status Codes | |
982 | * @{ | |
983 | */ | |
984 | /** Fatal error in virtual hardware. */ | |
985 | #define VERR_REM_VIRTUAL_HARDWARE_ERROR (-2300) | |
986 | /** Fatal error in the recompiler cpu. */ | |
987 | #define VERR_REM_VIRTUAL_CPU_ERROR (-2301) | |
988 | /** Recompiler execution was interrupted by forced action. */ | |
989 | #define VINF_REM_INTERRUPED_FF 2302 | |
990 | /** Too many similar traps. This is a very useful debug only | |
991 | * check (we don't do double/triple faults in REM). */ | |
992 | #define VERR_REM_TOO_MANY_TRAPS (-2304) | |
993 | /** The REM is out of breakpoint slots. */ | |
994 | #define VERR_REM_NO_MORE_BP_SLOTS (-2305) | |
995 | /** The REM could not find any breakpoint on the specified address. */ | |
996 | #define VERR_REM_BP_NOT_FOUND (-2306) | |
997 | /** @} */ | |
998 | ||
999 | ||
1000 | /** @name Trap Manager / Monitor (TRPM) Status Codes | |
1001 | * @{ | |
1002 | */ | |
1003 | /** No active trap. Cannot query or reset a non-existing trap. */ | |
1004 | #define VERR_TRPM_NO_ACTIVE_TRAP (-2400) | |
1005 | /** Active trap. Cannot assert a new trap when one is already active. */ | |
1006 | #define VERR_TRPM_ACTIVE_TRAP (-2401) | |
1007 | /** Reason for leaving RC: Guest tried to write to our IDT - fatal. | |
1008 | * The VM will be terminated assuming the worst, i.e. that the | |
1009 | * guest has read the idtr register. */ | |
1010 | #define VERR_TRPM_SHADOW_IDT_WRITE (-2402) | |
1011 | /** Reason for leaving RC: Fatal trap in hypervisor. */ | |
1012 | #define VERR_TRPM_DONT_PANIC (-2403) | |
1013 | /** Reason for leaving RC: Double Fault. */ | |
1014 | #define VERR_TRPM_PANIC (-2404) | |
1015 | /** The exception was dispatched for raw-mode execution. */ | |
1016 | #define VINF_TRPM_XCPT_DISPATCHED 2405 | |
1017 | /** Bad TRPM_TRAP_IN_OP. */ | |
1018 | #define VERR_TRPM_BAD_TRAP_IN_OP (-2406) | |
1019 | /** Internal processing error \#1 in TRPM. */ | |
1020 | #define VERR_TRPM_IPE_1 (-2407) | |
1021 | /** Internal processing error \#2 in TRPM. */ | |
1022 | #define VERR_TRPM_IPE_2 (-2408) | |
1023 | /** Internal processing error \#3 in TRPM. */ | |
1024 | #define VERR_TRPM_IPE_3 (-2409) | |
1025 | /** Got into a part of TRPM that is not used when HM (VT-x/AMD-V) is enabled. */ | |
1026 | #define VERR_TRPM_HM_IPE (-2410) | |
1027 | /** @} */ | |
1028 | ||
1029 | ||
1030 | /** @name Selector Manager / Monitor (SELM) Status Code | |
1031 | * @{ | |
1032 | */ | |
1033 | /** Reason for leaving RC: Guest tried to write to our GDT - fatal. | |
1034 | * The VM will be terminated assuming the worst, i.e. that the | |
1035 | * guest has read the gdtr register. */ | |
1036 | #define VERR_SELM_SHADOW_GDT_WRITE (-2500) | |
1037 | /** Reason for leaving RC: Guest tried to write to our LDT - fatal. | |
1038 | * The VM will be terminated assuming the worst, i.e. that the | |
1039 | * guest has read the ldtr register. */ | |
1040 | #define VERR_SELM_SHADOW_LDT_WRITE (-2501) | |
1041 | /** Reason for leaving RC: Guest tried to write to our TSS - fatal. | |
1042 | * The VM will be terminated assuming the worst, i.e. that the | |
1043 | * guest has read the ltr register. */ | |
1044 | #define VERR_SELM_SHADOW_TSS_WRITE (-2502) | |
1045 | /** Reason for leaving RC: Sync the GDT table to solve a conflict. */ | |
1046 | #define VINF_SELM_SYNC_GDT 2503 | |
1047 | /** No valid TSS present. */ | |
1048 | #define VERR_SELM_NO_TSS (-2504) | |
1049 | /** Invalid guest LDT selector. */ | |
1050 | #define VERR_SELM_INVALID_LDT (-2505) | |
1051 | /** The guest LDT selector is out of bounds. */ | |
1052 | #define VERR_SELM_LDT_OUT_OF_BOUNDS (-2506) | |
1053 | /** Unknown error while reading the guest GDT during shadow table updating. */ | |
1054 | #define VERR_SELM_GDT_READ_ERROR (-2507) | |
1055 | /** The guest GDT so full that we cannot find free space for our own | |
1056 | * selectors. */ | |
1057 | #define VERR_SELM_GDT_TOO_FULL (-2508) | |
1058 | /** Got into a part of SELM that is not used when HM (VT-x/AMD-V) is enabled. */ | |
1059 | #define VERR_SELM_HM_IPE (-2509) | |
1060 | /** @} */ | |
1061 | ||
1062 | ||
1063 | /** @name I/O Manager / Monitor (IOM) Status Code | |
1064 | * @{ | |
1065 | */ | |
1066 | /** The specified I/O port range was invalid. | |
1067 | * It was either empty or it was out of bounds. */ | |
1068 | #define VERR_IOM_INVALID_IOPORT_RANGE (-2600) | |
1069 | /** The specified R0 or RC I/O port range didn't have a corresponding R3 range. | |
1070 | * IOMR3IOPortRegisterR3() must be called first. */ | |
1071 | #define VERR_IOM_NO_R3_IOPORT_RANGE (-2601) | |
1072 | /** The specified I/O port range intruded on an existing range. There is | |
1073 | * a I/O port conflict between two device, or a device tried to register | |
1074 | * the same range twice. */ | |
1075 | #define VERR_IOM_IOPORT_RANGE_CONFLICT (-2602) | |
1076 | /** The I/O port range specified for removal wasn't found or it wasn't contiguous. */ | |
1077 | #define VERR_IOM_IOPORT_RANGE_NOT_FOUND (-2603) | |
1078 | /** The specified I/O port range was owned by some other device(s). Both registration | |
1079 | * and deregistration, but in the first case only RC and R0 ranges. */ | |
1080 | #define VERR_IOM_NOT_IOPORT_RANGE_OWNER (-2604) | |
1081 | ||
1082 | /** The specified MMIO range was invalid. | |
1083 | * It was either empty or it was out of bounds. */ | |
1084 | #define VERR_IOM_INVALID_MMIO_RANGE (-2605) | |
1085 | /** The specified R0 or RC MMIO range didn't have a corresponding R3 range. | |
1086 | * IOMR3MMIORegisterR3() must be called first. */ | |
1087 | #define VERR_IOM_NO_R3_MMIO_RANGE (-2606) | |
1088 | /** The specified MMIO range was owned by some other device(s). Both registration | |
1089 | * and deregistration, but in the first case only RC and R0 ranges. */ | |
1090 | #define VERR_IOM_NOT_MMIO_RANGE_OWNER (-2607) | |
1091 | /** The specified MMIO range intruded on an existing range. There is | |
1092 | * a MMIO conflict between two device, or a device tried to register | |
1093 | * the same range twice. */ | |
1094 | #define VERR_IOM_MMIO_RANGE_CONFLICT (-2608) | |
1095 | /** The MMIO range specified for removal was not found. */ | |
1096 | #define VERR_IOM_MMIO_RANGE_NOT_FOUND (-2609) | |
1097 | /** The MMIO range specified for removal was invalid. The range didn't match | |
1098 | * quite match a set of existing ranges. It's not possible to remove parts of | |
1099 | * a MMIO range, only one or more full ranges. */ | |
1100 | #define VERR_IOM_INCOMPLETE_MMIO_RANGE (-2610) | |
1101 | /** An invalid I/O port size was specified for a read or write operation. */ | |
1102 | #define VERR_IOM_INVALID_IOPORT_SIZE (-2611) | |
1103 | /** The MMIO handler was called for a bogus address! Internal error! */ | |
1104 | #define VERR_IOM_MMIO_HANDLER_BOGUS_CALL (-2612) | |
1105 | /** The MMIO handler experienced a problem with the disassembler. */ | |
1106 | #define VERR_IOM_MMIO_HANDLER_DISASM_ERROR (-2613) | |
1107 | /** The port being read was not present(/unused) and IOM shall return ~0 according to size. */ | |
1108 | #define VERR_IOM_IOPORT_UNUSED (-2614) | |
1109 | /** Unused MMIO register read, fill with 00. */ | |
1110 | #define VINF_IOM_MMIO_UNUSED_00 2615 | |
1111 | /** Unused MMIO register read, fill with FF. */ | |
1112 | #define VINF_IOM_MMIO_UNUSED_FF 2616 | |
1113 | ||
1114 | /** Reason for leaving RZ: I/O port read. */ | |
1115 | #define VINF_IOM_R3_IOPORT_READ 2620 | |
1116 | /** Reason for leaving RZ: I/O port write. */ | |
1117 | #define VINF_IOM_R3_IOPORT_WRITE 2621 | |
1118 | /** Reason for leaving RZ: Pending I/O port write. Since there is also | |
1119 | * VMCPU_FF_IOM for this condition, it's ok to drop this status code for | |
1120 | * some other VINF_EM_XXX statuses. */ | |
1121 | #define VINF_IOM_R3_IOPORT_COMMIT_WRITE 2622 | |
1122 | /** Reason for leaving RZ: MMIO read. */ | |
1123 | #define VINF_IOM_R3_MMIO_READ 2623 | |
1124 | /** Reason for leaving RZ: MMIO write. */ | |
1125 | #define VINF_IOM_R3_MMIO_WRITE 2624 | |
1126 | /** Reason for leaving RZ: MMIO read/write. */ | |
1127 | #define VINF_IOM_R3_MMIO_READ_WRITE 2625 | |
1128 | /** Reason for leaving RZ: Pending MMIO write. Since there is also | |
1129 | * VMCPU_FF_IOM for this condition, it's ok to drop this status code for | |
1130 | * some other VINF_EM_XXX statuses. */ | |
1131 | #define VINF_IOM_R3_MMIO_COMMIT_WRITE 2626 | |
1132 | ||
1133 | /** IOMGCIOPortHandler was given an unexpected opcode. */ | |
1134 | #define VERR_IOM_IOPORT_UNKNOWN_OPCODE (-2630) | |
1135 | /** Internal processing error \#1 in the I/O port code. */ | |
1136 | #define VERR_IOM_IOPORT_IPE_1 (-2631) | |
1137 | /** Internal processing error \#2 in the I/O port code. */ | |
1138 | #define VERR_IOM_IOPORT_IPE_2 (-2632) | |
1139 | /** Internal processing error \#3 in the I/O port code. */ | |
1140 | #define VERR_IOM_IOPORT_IPE_3 (-2633) | |
1141 | /** Internal processing error \#1 in the MMIO code. */ | |
1142 | #define VERR_IOM_MMIO_IPE_1 (-2634) | |
1143 | /** Internal processing error \#2 in the MMIO code. */ | |
1144 | #define VERR_IOM_MMIO_IPE_2 (-2635) | |
1145 | /** Internal processing error \#3 in the MMIO code. */ | |
1146 | #define VERR_IOM_MMIO_IPE_3 (-2636) | |
1147 | /** Got into a part of IOM that is not used when HM (VT-x/AMD-V) is enabled. */ | |
1148 | #define VERR_IOM_HM_IPE (-2637) | |
1149 | /** Internal processing error while merging status codes. */ | |
1150 | #define VERR_IOM_FF_STATUS_IPE (-2638) | |
1151 | /** @} */ | |
1152 | ||
1153 | ||
1154 | /** @name Virtual Machine Monitor (VMM) Status Codes | |
1155 | * @{ | |
1156 | */ | |
1157 | /** Reason for leaving RZ: Calling host function. */ | |
1158 | #define VINF_VMM_CALL_HOST 2700 | |
1159 | /** Reason for leaving R0: Hit a ring-0 assertion on EMT. */ | |
1160 | #define VERR_VMM_RING0_ASSERTION (-2701) | |
1161 | /** The hyper CR3 differs between PGM and CPUM. */ | |
1162 | #define VERR_VMM_HYPER_CR3_MISMATCH (-2702) | |
1163 | /** Reason for leaving RZ: Illegal call to ring-3. */ | |
1164 | #define VERR_VMM_RING3_CALL_DISABLED (-2703) | |
1165 | /** The VMMR0.r0 module version does not match VBoxVMM.dll/so/dylib. | |
1166 | * If you just upgraded VirtualBox, please terminate all VMs and make sure | |
1167 | * that neither VBoxNetDHCP nor VBoxNetNAT is running. Then try again. | |
1168 | * If this error persists, try re-installing VirtualBox. */ | |
1169 | #define VERR_VMM_R0_VERSION_MISMATCH (-2704) | |
1170 | /** The VMMRC.rc module version does not match VBoxVMM.dll/so/dylib. | |
1171 | * Re-install if you are a user. Developers should make sure the build is | |
1172 | * complete or try with a clean build. */ | |
1173 | #define VERR_VMM_RC_VERSION_MISMATCH (-2705) | |
1174 | /** VMM set jump error. */ | |
1175 | #define VERR_VMM_SET_JMP_ERROR (-2706) | |
1176 | /** VMM set jump stack overflow error. */ | |
1177 | #define VERR_VMM_SET_JMP_STACK_OVERFLOW (-2707) | |
1178 | /** VMM set jump resume error. */ | |
1179 | #define VERR_VMM_SET_JMP_ABORTED_RESUME (-2708) | |
1180 | /** VMM long jump error. */ | |
1181 | #define VERR_VMM_LONG_JMP_ERROR (-2709) | |
1182 | /** Unknown ring-3 call attempted. */ | |
1183 | #define VERR_VMM_UNKNOWN_RING3_CALL (-2710) | |
1184 | /** The ring-3 call didn't set an RC. */ | |
1185 | #define VERR_VMM_RING3_CALL_NO_RC (-2711) | |
1186 | /** Reason for leaving RC: Caller the tracer in ring-0. */ | |
1187 | #define VINF_VMM_CALL_TRACER (2712) | |
1188 | /** Internal processing error \#1 in the switcher code. */ | |
1189 | #define VERR_VMM_SWITCHER_IPE_1 (-2713) | |
1190 | /** Reason for leaving RZ: Unknown call to ring-3. */ | |
1191 | #define VINF_VMM_UNKNOWN_RING3_CALL (2714) | |
1192 | /** Attempted to use stub switcher. */ | |
1193 | #define VERR_VMM_SWITCHER_STUB (-2715) | |
1194 | /** HM returned in the wrong state. */ | |
1195 | #define VERR_VMM_WRONG_HM_VMCPU_STATE (-2716) | |
1196 | /** SMAP enabled, but the AC flag was found to be clear - check the kernel | |
1197 | * log for details. */ | |
1198 | #define VERR_VMM_SMAP_BUT_AC_CLEAR (-2717) | |
1199 | /** @} */ | |
1200 | ||
1201 | ||
1202 | /** @name Pluggable Device and Driver Manager (PDM) Status Codes | |
1203 | * @{ | |
1204 | */ | |
1205 | /** An invalid LUN specification was given. */ | |
1206 | #define VERR_PDM_NO_SUCH_LUN (-2800) | |
1207 | /** A device encountered an unknown configuration value. | |
1208 | * This means that the device is potentially misconfigured and the device | |
1209 | * construction or unit attachment failed because of this. */ | |
1210 | #define VERR_PDM_DEVINS_UNKNOWN_CFG_VALUES (-2801) | |
1211 | /** The above driver doesn't export a interface required by a driver being | |
1212 | * attached to it. Typical misconfiguration problem. */ | |
1213 | #define VERR_PDM_MISSING_INTERFACE_ABOVE (-2802) | |
1214 | /** The below driver doesn't export a interface required by the drive | |
1215 | * having attached it. Typical misconfiguration problem. */ | |
1216 | #define VERR_PDM_MISSING_INTERFACE_BELOW (-2803) | |
1217 | /** A device didn't find a required interface with an attached driver. | |
1218 | * Typical misconfiguration problem. */ | |
1219 | #define VERR_PDM_MISSING_INTERFACE (-2804) | |
1220 | /** A driver encountered an unknown configuration value. | |
1221 | * This means that the driver is potentially misconfigured and the driver | |
1222 | * construction failed because of this. */ | |
1223 | #define VERR_PDM_DRVINS_UNKNOWN_CFG_VALUES (-2805) | |
1224 | /** The PCI bus assigned to a device didn't have room for it. | |
1225 | * Either too many devices are configured on the same PCI bus, or there are | |
1226 | * some internal problem where PDM/PCI doesn't free up slots when unplugging devices. */ | |
1227 | #define VERR_PDM_TOO_PCI_MANY_DEVICES (-2806) | |
1228 | /** A queue is out of free items, the queueing operation failed. */ | |
1229 | #define VERR_PDM_NO_QUEUE_ITEMS (-2807) | |
1230 | /** Not possible to attach further drivers to the driver. | |
1231 | * A driver which doesn't support attachments (below of course) will | |
1232 | * return this status code if it found that further drivers were configured | |
1233 | * to be attached to it. */ | |
1234 | #define VERR_PDM_DRVINS_NO_ATTACH (-2808) | |
1235 | /** Not possible to attach drivers to the device. | |
1236 | * A device which doesn't support attachments (below of course) will | |
1237 | * return this status code if it found that drivers were configured | |
1238 | * to be attached to it. */ | |
1239 | #define VERR_PDM_DEVINS_NO_ATTACH (-2809) | |
1240 | /** No attached driver. | |
1241 | * The PDMDRVHLP::pfnAttach and PDMDEVHLP::pfnDriverAttach will return | |
1242 | * this error when no driver was configured to be attached. */ | |
1243 | #define VERR_PDM_NO_ATTACHED_DRIVER (-2810) | |
1244 | /** The media geometry hasn't been set yet, so it cannot be obtained. | |
1245 | * The caller should then calculate the geometry from the media size. */ | |
1246 | #define VERR_PDM_GEOMETRY_NOT_SET (-2811) | |
1247 | /** The media translation hasn't been set yet, so it cannot be obtained. | |
1248 | * The caller should then guess the translation. */ | |
1249 | #define VERR_PDM_TRANSLATION_NOT_SET (-2812) | |
1250 | /** The media is not mounted, operation requires a mounted media. */ | |
1251 | #define VERR_PDM_MEDIA_NOT_MOUNTED (-2813) | |
1252 | /** Mount failed because a media was already mounted. Unmount the media | |
1253 | * and retry the mount. */ | |
1254 | #define VERR_PDM_MEDIA_MOUNTED (-2814) | |
1255 | /** The media is locked and cannot be unmounted. */ | |
1256 | #define VERR_PDM_MEDIA_LOCKED (-2815) | |
1257 | /** No 'Type' attribute in the DrvBlock configuration. | |
1258 | * Misconfiguration. */ | |
1259 | #define VERR_PDM_BLOCK_NO_TYPE (-2816) | |
1260 | /** The 'Type' attribute in the DrvBlock configuration had an unknown value. | |
1261 | * Misconfiguration. */ | |
1262 | #define VERR_PDM_BLOCK_UNKNOWN_TYPE (-2817) | |
1263 | /** The 'Translation' attribute in the DrvBlock configuration had an unknown value. | |
1264 | * Misconfiguration. */ | |
1265 | #define VERR_PDM_BLOCK_UNKNOWN_TRANSLATION (-2818) | |
1266 | /** The block driver type wasn't supported. | |
1267 | * Misconfiguration of the kind you get when attaching a floppy to an IDE controller. */ | |
1268 | #define VERR_PDM_UNSUPPORTED_BLOCK_TYPE (-2819) | |
1269 | /** A attach or prepare mount call failed because the driver already | |
1270 | * had a driver attached. */ | |
1271 | #define VERR_PDM_DRIVER_ALREADY_ATTACHED (-2820) | |
1272 | /** An attempt on detaching a driver without anyone actually being attached, or | |
1273 | * performing any other operation on an attached driver. */ | |
1274 | #define VERR_PDM_NO_DRIVER_ATTACHED (-2821) | |
1275 | /** The attached driver configuration is missing the 'Driver' attribute. */ | |
1276 | #define VERR_PDM_CFG_MISSING_DRIVER_NAME (-2822) | |
1277 | /** The configured driver wasn't found. | |
1278 | * Either the necessary driver modules wasn't loaded, the name was | |
1279 | * misspelled, or it was a misconfiguration. */ | |
1280 | #define VERR_PDM_DRIVER_NOT_FOUND (-2823) | |
1281 | /** The Ring-3 module was already loaded. */ | |
1282 | #define VINF_PDM_ALREADY_LOADED (2824) | |
1283 | /** The name of the module clashed with an existing module. */ | |
1284 | #define VERR_PDM_MODULE_NAME_CLASH (-2825) | |
1285 | /** Couldn't find any export for registration of drivers/devices. */ | |
1286 | #define VERR_PDM_NO_REGISTRATION_EXPORT (-2826) | |
1287 | /** A module name is too long. */ | |
1288 | #define VERR_PDM_MODULE_NAME_TOO_LONG (-2827) | |
1289 | /** Driver name clash. Another driver with the same name as the | |
1290 | * one being registered exists. */ | |
1291 | #define VERR_PDM_DRIVER_NAME_CLASH (-2828) | |
1292 | /** The version of the driver registration structure is unknown | |
1293 | * to this VBox version. Either mixing incompatible versions or | |
1294 | * the structure isn't correctly initialized. */ | |
1295 | #define VERR_PDM_UNKNOWN_DRVREG_VERSION (-2829) | |
1296 | /** Invalid entry in the driver registration structure. */ | |
1297 | #define VERR_PDM_INVALID_DRIVER_REGISTRATION (-2830) | |
1298 | /** Invalid host bit mask. */ | |
1299 | #define VERR_PDM_INVALID_DRIVER_HOST_BITS (-2831) | |
1300 | /** Not possible to detach a driver because the above driver/device | |
1301 | * doesn't support it. The above entity doesn't implement the pfnDetach call. */ | |
1302 | #define VERR_PDM_DRIVER_DETACH_NOT_POSSIBLE (-2832) | |
1303 | /** No PCI Bus is available to register the device with. This is usually a | |
1304 | * misconfiguration or in rare cases a buggy pci device. */ | |
1305 | #define VERR_PDM_NO_PCI_BUS (-2833) | |
1306 | /** The device is not a registered PCI device and thus cannot | |
1307 | * perform any PCI operations. The device forgot to register it self. */ | |
1308 | #define VERR_PDM_NOT_PCI_DEVICE (-2834) | |
1309 | ||
1310 | /** The version of the device registration structure is unknown | |
1311 | * to this VBox version. Either mixing incompatible versions or | |
1312 | * the structure isn't correctly initialized. */ | |
1313 | #define VERR_PDM_UNKNOWN_DEVREG_VERSION (-2835) | |
1314 | /** Invalid entry in the device registration structure. */ | |
1315 | #define VERR_PDM_INVALID_DEVICE_REGISTRATION (-2836) | |
1316 | /** Invalid host bit mask. */ | |
1317 | #define VERR_PDM_INVALID_DEVICE_GUEST_BITS (-2837) | |
1318 | /** The guest bit mask didn't match the guest being loaded. */ | |
1319 | #define VERR_PDM_INVALID_DEVICE_HOST_BITS (-2838) | |
1320 | /** Device name clash. Another device with the same name as the | |
1321 | * one being registered exists. */ | |
1322 | #define VERR_PDM_DEVICE_NAME_CLASH (-2839) | |
1323 | /** The device wasn't found. There was no registered device | |
1324 | * by that name. */ | |
1325 | #define VERR_PDM_DEVICE_NOT_FOUND (-2840) | |
1326 | /** The device instance was not found. */ | |
1327 | #define VERR_PDM_DEVICE_INSTANCE_NOT_FOUND (-2841) | |
1328 | /** The device instance have no base interface. */ | |
1329 | #define VERR_PDM_DEVICE_INSTANCE_NO_IBASE (-2842) | |
1330 | /** The device instance have no such logical unit. */ | |
1331 | #define VERR_PDM_DEVICE_INSTANCE_LUN_NOT_FOUND (-2843) | |
1332 | /** The driver instance could not be found. */ | |
1333 | #define VERR_PDM_DRIVER_INSTANCE_NOT_FOUND (-2844) | |
1334 | /** Logical Unit was not found. */ | |
1335 | #define VERR_PDM_LUN_NOT_FOUND (-2845) | |
1336 | /** The Logical Unit was found, but it had no driver attached to it. */ | |
1337 | #define VERR_PDM_NO_DRIVER_ATTACHED_TO_LUN (-2846) | |
1338 | /** The Logical Unit was found, but it had no driver attached to it. */ | |
1339 | #define VINF_PDM_NO_DRIVER_ATTACHED_TO_LUN 2846 | |
1340 | /** No PIC device instance is registered with the current VM and thus | |
1341 | * the PIC operation cannot be performed. */ | |
1342 | #define VERR_PDM_NO_PIC_INSTANCE (-2847) | |
1343 | /** No APIC device instance is registered with the current VM and thus | |
1344 | * the APIC operation cannot be performed. */ | |
1345 | #define VERR_PDM_NO_APIC_INSTANCE (-2848) | |
1346 | /** No DMAC device instance is registered with the current VM and thus | |
1347 | * the DMA operation cannot be performed. */ | |
1348 | #define VERR_PDM_NO_DMAC_INSTANCE (-2849) | |
1349 | /** No RTC device instance is registered with the current VM and thus | |
1350 | * the RTC or CMOS operation cannot be performed. */ | |
1351 | #define VERR_PDM_NO_RTC_INSTANCE (-2850) | |
1352 | /** Unable to open the host interface due to a sharing violation . */ | |
1353 | #define VERR_PDM_HIF_SHARING_VIOLATION (-2851) | |
1354 | /** Unable to open the host interface. */ | |
1355 | #define VERR_PDM_HIF_OPEN_FAILED (-2852) | |
1356 | /** The device doesn't support runtime driver attaching. | |
1357 | * The PDMDEVREG::pfnAttach callback function is NULL. */ | |
1358 | #define VERR_PDM_DEVICE_NO_RT_ATTACH (-2853) | |
1359 | /** The driver doesn't support runtime driver attaching. | |
1360 | * The PDMDRVREG::pfnAttach callback function is NULL. */ | |
1361 | #define VERR_PDM_DRIVER_NO_RT_ATTACH (-2854) | |
1362 | /** Invalid host interface version. */ | |
1363 | #define VERR_PDM_HIF_INVALID_VERSION (-2855) | |
1364 | ||
1365 | /** The version of the USB device registration structure is unknown | |
1366 | * to this VBox version. Either mixing incompatible versions or | |
1367 | * the structure isn't correctly initialized. */ | |
1368 | #define VERR_PDM_UNKNOWN_USBREG_VERSION (-2856) | |
1369 | /** Invalid entry in the device registration structure. */ | |
1370 | #define VERR_PDM_INVALID_USB_REGISTRATION (-2857) | |
1371 | /** Driver name clash. Another driver with the same name as the | |
1372 | * one being registered exists. */ | |
1373 | #define VERR_PDM_USB_NAME_CLASH (-2858) | |
1374 | /** The USB hub is already registered. */ | |
1375 | #define VERR_PDM_USB_HUB_EXISTS (-2859) | |
1376 | /** Couldn't find any USB hubs to attach the device to. */ | |
1377 | #define VERR_PDM_NO_USB_HUBS (-2860) | |
1378 | /** Couldn't find any free USB ports to attach the device to. */ | |
1379 | #define VERR_PDM_NO_USB_PORTS (-2861) | |
1380 | /** Couldn't find the USB Proxy device. Using OSE? */ | |
1381 | #define VERR_PDM_NO_USBPROXY (-2862) | |
1382 | /** The async completion template is still used. */ | |
1383 | #define VERR_PDM_ASYNC_TEMPLATE_BUSY (-2863) | |
1384 | /** The async completion task is already suspended. */ | |
1385 | #define VERR_PDM_ASYNC_COMPLETION_ALREADY_SUSPENDED (-2864) | |
1386 | /** The async completion task is not suspended. */ | |
1387 | #define VERR_PDM_ASYNC_COMPLETION_NOT_SUSPENDED (-2865) | |
1388 | /** The driver properties were invalid, and as a consequence construction | |
1389 | * failed. Caused my unusable media or similar problems. */ | |
1390 | #define VERR_PDM_DRIVER_INVALID_PROPERTIES (-2866) | |
1391 | /** Too many instances of a device. */ | |
1392 | #define VERR_PDM_TOO_MANY_DEVICE_INSTANCES (-2867) | |
1393 | /** Too many instances of a driver. */ | |
1394 | #define VERR_PDM_TOO_MANY_DRIVER_INSTANCES (-2868) | |
1395 | /** Too many instances of a usb device. */ | |
1396 | #define VERR_PDM_TOO_MANY_USB_DEVICE_INSTANCES (-2869) | |
1397 | /** The device instance structure version has changed. | |
1398 | * | |
1399 | * If you have upgraded VirtualBox recently, please make sure you have | |
1400 | * terminated all VMs and upgraded any extension packs. If this error | |
1401 | * persists, try re-installing VirtualBox. */ | |
1402 | #define VERR_PDM_DEVINS_VERSION_MISMATCH (-2870) | |
1403 | /** The device helper structure version has changed. | |
1404 | * | |
1405 | * If you have upgraded VirtualBox recently, please make sure you have | |
1406 | * terminated all VMs and upgraded any extension packs. If this error | |
1407 | * persists, try re-installing VirtualBox. */ | |
1408 | #define VERR_PDM_DEVHLPR3_VERSION_MISMATCH (-2871) | |
1409 | /** The USB device instance structure version has changed. | |
1410 | * | |
1411 | * If you have upgraded VirtualBox recently, please make sure you have | |
1412 | * terminated all VMs and upgraded any extension packs. If this error | |
1413 | * persists, try re-installing VirtualBox. */ | |
1414 | #define VERR_PDM_USBINS_VERSION_MISMATCH (-2872) | |
1415 | /** The USB device helper structure version has changed. | |
1416 | * | |
1417 | * If you have upgraded VirtualBox recently, please make sure you have | |
1418 | * terminated all VMs and upgraded any extension packs. If this error | |
1419 | * persists, try re-installing VirtualBox. */ | |
1420 | #define VERR_PDM_USBHLPR3_VERSION_MISMATCH (-2873) | |
1421 | /** The driver instance structure version has changed. | |
1422 | * | |
1423 | * If you have upgraded VirtualBox recently, please make sure you have | |
1424 | * terminated all VMs and upgraded any extension packs. If this error | |
1425 | * persists, try re-installing VirtualBox. */ | |
1426 | #define VERR_PDM_DRVINS_VERSION_MISMATCH (-2874) | |
1427 | /** The driver helper structure version has changed. | |
1428 | * | |
1429 | * If you have upgraded VirtualBox recently, please make sure you have | |
1430 | * terminated all VMs and upgraded any extension packs. If this error | |
1431 | * persists, try re-installing VirtualBox. */ | |
1432 | #define VERR_PDM_DRVHLPR3_VERSION_MISMATCH (-2875) | |
1433 | /** Generic device structure version mismatch. | |
1434 | * | |
1435 | * If you have upgraded VirtualBox recently, please make sure you have | |
1436 | * terminated all VMs and upgraded any extension packs. If this error | |
1437 | * persists, try re-installing VirtualBox. */ | |
1438 | #define VERR_PDM_DEVICE_VERSION_MISMATCH (-2876) | |
1439 | /** Generic USB device structure version mismatch. | |
1440 | * | |
1441 | * If you have upgraded VirtualBox recently, please make sure you have | |
1442 | * terminated all VMs and upgraded any extension packs. If this error | |
1443 | * persists, try re-installing VirtualBox. */ | |
1444 | #define VERR_PDM_USBDEV_VERSION_MISMATCH (-2877) | |
1445 | /** Generic driver structure version mismatch. | |
1446 | * | |
1447 | * If you have upgraded VirtualBox recently, please make sure you have | |
1448 | * terminated all VMs and upgraded any extension packs. If this error | |
1449 | * persists, try re-installing VirtualBox. */ | |
1450 | #define VERR_PDM_DRIVER_VERSION_MISMATCH (-2878) | |
1451 | /** PDMVMMDevHeapR3ToGCPhys failure. */ | |
1452 | #define VERR_PDM_DEV_HEAP_R3_TO_GCPHYS (-2879) | |
1453 | /** A legacy device isn't implementing the HPET notification interface. */ | |
1454 | #define VERR_PDM_HPET_LEGACY_NOTIFY_MISSING (-2880) | |
1455 | /** Internal processing error in the critical section code. */ | |
1456 | #define VERR_PDM_CRITSECT_IPE (-2881) | |
1457 | /** The critical section being deleted was not found. */ | |
1458 | #define VERR_PDM_CRITSECT_NOT_FOUND (-2882) | |
1459 | /** A PDMThread API was called by the wrong thread. */ | |
1460 | #define VERR_PDM_THREAD_INVALID_CALLER (-2883) | |
1461 | /** Internal processing error \#1 in the PDM Thread code. */ | |
1462 | #define VERR_PDM_THREAD_IPE_1 (-2884) | |
1463 | /** Internal processing error \#2 in the PDM Thread code. */ | |
1464 | #define VERR_PDM_THREAD_IPE_2 (-2885) | |
1465 | /** Only one PCI function is supported per PDM device. */ | |
1466 | #define VERR_PDM_ONE_PCI_FUNCTION_PER_DEVICE (-2886) | |
1467 | /** Bad PCI configuration. */ | |
1468 | #define VERR_PDM_BAD_PCI_CONFIG (-2887) | |
1469 | /** Internal processing error # in the PDM device code. */ | |
1470 | #define VERR_PDM_DEV_IPE_1 (-2888) | |
1471 | /** Misconfigured driver chain transformation. */ | |
1472 | #define VERR_PDM_MISCONFIGURED_DRV_TRANSFORMATION (-2889) | |
1473 | /** The driver is already removed, not more transformations possible (at | |
1474 | * present). */ | |
1475 | #define VERR_PDM_CANNOT_TRANSFORM_REMOVED_DRIVER (-2890) | |
1476 | /** The PCI device isn't configured as a busmaster, physical memory access | |
1477 | * rejected. */ | |
1478 | #define VERR_PDM_NOT_PCI_BUS_MASTER (-2891) | |
1479 | /** Got into a part of PDM that is not used when HM (VT-x/AMD-V) is enabled. */ | |
1480 | #define VERR_PDM_HM_IPE (-2892) | |
1481 | /** The I/O request was canceled. */ | |
1482 | #define VERR_PDM_MEDIAEX_IOREQ_CANCELED (-2893) | |
1483 | /** There is not enough room to store the data. */ | |
1484 | #define VERR_PDM_MEDIAEX_IOBUF_OVERFLOW (-2894) | |
1485 | /** There is not enough data to satisfy the request. */ | |
1486 | #define VERR_PDM_MEDIAEX_IOBUF_UNDERRUN (-2895) | |
1487 | /** The I/O request ID is already existing. */ | |
1488 | #define VERR_PDM_MEDIAEX_IOREQID_CONFLICT (-2896) | |
1489 | /** The I/O request ID was not found. */ | |
1490 | #define VERR_PDM_MEDIAEX_IOREQID_NOT_FOUND (-2897) | |
1491 | /** The I/O request is in progress. */ | |
1492 | #define VINF_PDM_MEDIAEX_IOREQ_IN_PROGRESS 2898 | |
1493 | /** The I/O request is in an invalid state for this operation. */ | |
1494 | #define VERR_PDM_MEDIAEX_IOREQ_INVALID_STATE (-2899) | |
1495 | /** @} */ | |
1496 | ||
1497 | ||
1498 | /** @name Host-Guest Communication Manager (HGCM) Status Codes | |
1499 | * @{ | |
1500 | */ | |
1501 | /** Requested service does not exist. */ | |
1502 | #define VERR_HGCM_SERVICE_NOT_FOUND (-2900) | |
1503 | /** Service rejected client connection */ | |
1504 | #define VINF_HGCM_CLIENT_REJECTED 2901 | |
1505 | /** Command address is invalid. */ | |
1506 | #define VERR_HGCM_INVALID_CMD_ADDRESS (-2902) | |
1507 | /** Service will execute the command in background. */ | |
1508 | #define VINF_HGCM_ASYNC_EXECUTE 2903 | |
1509 | /** HGCM could not perform requested operation because of an internal error. */ | |
1510 | #define VERR_HGCM_INTERNAL (-2904) | |
1511 | /** Invalid HGCM client id. */ | |
1512 | #define VERR_HGCM_INVALID_CLIENT_ID (-2905) | |
1513 | /** The HGCM is saving state. */ | |
1514 | #define VINF_HGCM_SAVE_STATE (2906) | |
1515 | /** Requested service already exists. */ | |
1516 | #define VERR_HGCM_SERVICE_EXISTS (-2907) | |
1517 | ||
1518 | /** @} */ | |
1519 | ||
1520 | ||
1521 | /** @name Network Address Translation Driver (DrvNAT) Status Codes | |
1522 | * @{ | |
1523 | */ | |
1524 | /** Failed to find the DNS configured for this machine. */ | |
1525 | #define VINF_NAT_DNS 3000 | |
1526 | /** Failed to convert the specified Guest IP to a binary IP address. | |
1527 | * Malformed input. */ | |
1528 | #define VERR_NAT_REDIR_GUEST_IP (-3001) | |
1529 | /** Failed while setting up a redirector rule. | |
1530 | * There probably is a conflict between the rule and some existing | |
1531 | * service on the computer. */ | |
1532 | #define VERR_NAT_REDIR_SETUP (-3002) | |
1533 | /** @} */ | |
1534 | ||
1535 | ||
1536 | /** @name HostIF Driver (DrvTUN) Status Codes | |
1537 | * @{ | |
1538 | */ | |
1539 | /** The Host Interface Networking init program failed. */ | |
1540 | #define VERR_HOSTIF_INIT_FAILED (-3100) | |
1541 | /** The Host Interface Networking device name is too long. */ | |
1542 | #define VERR_HOSTIF_DEVICE_NAME_TOO_LONG (-3101) | |
1543 | /** The Host Interface Networking name config IOCTL call failed. */ | |
1544 | #define VERR_HOSTIF_IOCTL (-3102) | |
1545 | /** Failed to make the Host Interface Networking handle non-blocking. */ | |
1546 | #define VERR_HOSTIF_BLOCKING (-3103) | |
1547 | /** If a Host Interface Networking filehandle was specified it's not allowed to | |
1548 | * have any init or term programs. */ | |
1549 | #define VERR_HOSTIF_FD_AND_INIT_TERM (-3104) | |
1550 | /** The Host Interface Networking terminate program failed. */ | |
1551 | #define VERR_HOSTIF_TERM_FAILED (-3105) | |
1552 | /** @} */ | |
1553 | ||
1554 | ||
1555 | /** @name VBox HDD Container (VD) Status Codes | |
1556 | * @{ | |
1557 | */ | |
1558 | /** Invalid image type. */ | |
1559 | #define VERR_VD_INVALID_TYPE (-3200) | |
1560 | /** Operation can't be done in current HDD container state. */ | |
1561 | #define VERR_VD_INVALID_STATE (-3201) | |
1562 | /** Configuration value not found. */ | |
1563 | #define VERR_VD_VALUE_NOT_FOUND (-3202) | |
1564 | /** Virtual HDD is not opened. */ | |
1565 | #define VERR_VD_NOT_OPENED (-3203) | |
1566 | /** Requested image is not opened. */ | |
1567 | #define VERR_VD_IMAGE_NOT_FOUND (-3204) | |
1568 | /** Image is read-only. */ | |
1569 | #define VERR_VD_IMAGE_READ_ONLY (-3205) | |
1570 | /** Geometry hasn't been set. */ | |
1571 | #define VERR_VD_GEOMETRY_NOT_SET (-3206) | |
1572 | /** No data for this block in image. */ | |
1573 | #define VERR_VD_BLOCK_FREE (-3207) | |
1574 | /** Differencing and parent images can't be used together due to UUID. */ | |
1575 | #define VERR_VD_UUID_MISMATCH (-3208) | |
1576 | /** Asynchronous I/O request finished. */ | |
1577 | #define VINF_VD_ASYNC_IO_FINISHED 3209 | |
1578 | /** Asynchronous I/O is not finished yet. */ | |
1579 | #define VERR_VD_ASYNC_IO_IN_PROGRESS (-3210) | |
1580 | /** The image is too small or too large for this format. */ | |
1581 | #define VERR_VD_INVALID_SIZE (-3211) | |
1582 | /** Configuration value is unknown. This indicates misconfiguration. */ | |
1583 | #define VERR_VD_UNKNOWN_CFG_VALUES (-3212) | |
1584 | /** Interface is unknown. This indicates misconfiguration. */ | |
1585 | #define VERR_VD_UNKNOWN_INTERFACE (-3213) | |
1586 | /** The DEK for disk encryption is missing. */ | |
1587 | #define VERR_VD_DEK_MISSING (-3214) | |
1588 | /** The provided password to decrypt the DEK was incorrect. */ | |
1589 | #define VERR_VD_PASSWORD_INCORRECT (-3215) | |
1590 | /** Generic: Invalid image file header. Use this for plugins. */ | |
1591 | #define VERR_VD_GEN_INVALID_HEADER (-3220) | |
1592 | /** VDI: Invalid image file header. */ | |
1593 | #define VERR_VD_VDI_INVALID_HEADER (-3230) | |
1594 | /** VDI: Invalid image file header: invalid signature. */ | |
1595 | #define VERR_VD_VDI_INVALID_SIGNATURE (-3231) | |
1596 | /** VDI: Invalid image file header: invalid version. */ | |
1597 | #define VERR_VD_VDI_UNSUPPORTED_VERSION (-3232) | |
1598 | /** Comment string is too long. */ | |
1599 | #define VERR_VD_VDI_COMMENT_TOO_LONG (-3233) | |
1600 | /** VMDK: Invalid image file header. */ | |
1601 | #define VERR_VD_VMDK_INVALID_HEADER (-3240) | |
1602 | /** VMDK: Invalid image file header: invalid version. */ | |
1603 | #define VERR_VD_VMDK_UNSUPPORTED_VERSION (-3241) | |
1604 | /** VMDK: Image property not found. */ | |
1605 | #define VERR_VD_VMDK_VALUE_NOT_FOUND (-3242) | |
1606 | /** VMDK: Operation can't be done in current image state. */ | |
1607 | #define VERR_VD_VMDK_INVALID_STATE (-3243) | |
1608 | /** VMDK: Format is invalid/inconsistent. */ | |
1609 | #define VERR_VD_VMDK_INVALID_FORMAT (-3244) | |
1610 | /** VMDK: Invalid write position. */ | |
1611 | #define VERR_VD_VMDK_INVALID_WRITE (-3245) | |
1612 | /** iSCSI: Invalid header, i.e. dummy for validity check. */ | |
1613 | #define VERR_VD_ISCSI_INVALID_HEADER (-3250) | |
1614 | /** iSCSI: Operation can't be done in current image state. */ | |
1615 | #define VERR_VD_ISCSI_INVALID_STATE (-3251) | |
1616 | /** iSCSI: Invalid device type (not a disk). */ | |
1617 | #define VERR_VD_ISCSI_INVALID_TYPE (-3252) | |
1618 | /** iSCSI: Initiator secret not decrypted */ | |
1619 | #define VERR_VD_ISCSI_SECRET_ENCRYPTED (-3253) | |
1620 | /** VHD: Invalid image file header. */ | |
1621 | #define VERR_VD_VHD_INVALID_HEADER (-3260) | |
1622 | /** Parallels HDD: Invalid image file header. */ | |
1623 | #define VERR_VD_PARALLELS_INVALID_HEADER (-3265) | |
1624 | /** DMG: Invalid image file header. */ | |
1625 | #define VERR_VD_DMG_INVALID_HEADER (-3267) | |
1626 | /** Raw: Invalid image file header. */ | |
1627 | #define VERR_VD_RAW_INVALID_HEADER (-3270) | |
1628 | /** Raw: Invalid image file type. */ | |
1629 | #define VERR_VD_RAW_INVALID_TYPE (-3271) | |
1630 | /** The backend needs more metadata before it can continue. */ | |
1631 | #define VERR_VD_NOT_ENOUGH_METADATA (-3272) | |
1632 | /** Halt the current I/O context until further notification from the backend. */ | |
1633 | #define VERR_VD_IOCTX_HALT (-3273) | |
1634 | /** The disk has a cache attached already. */ | |
1635 | #define VERR_VD_CACHE_ALREADY_EXISTS (-3274) | |
1636 | /** There is no cache attached to the disk. */ | |
1637 | #define VERR_VD_CACHE_NOT_FOUND (-3275) | |
1638 | /** The cache is not up to date with the image. */ | |
1639 | #define VERR_VD_CACHE_NOT_UP_TO_DATE (-3276) | |
1640 | /** The given range does not meet the required alignment. */ | |
1641 | #define VERR_VD_DISCARD_ALIGNMENT_NOT_MET (-3277) | |
1642 | /** The discard operation is not supported for this image. */ | |
1643 | #define VERR_VD_DISCARD_NOT_SUPPORTED (-3278) | |
1644 | /** The image is the correct format but is corrupted. */ | |
1645 | #define VERR_VD_IMAGE_CORRUPTED (-3279) | |
1646 | /** Repairing the image is not supported. */ | |
1647 | #define VERR_VD_IMAGE_REPAIR_NOT_SUPPORTED (-3280) | |
1648 | /** Repairing the image is not possible because the corruption is to severe. */ | |
1649 | #define VERR_VD_IMAGE_REPAIR_IMPOSSIBLE (-3281) | |
1650 | /** Reading from the image was not possible because the offset is out of the image range. | |
1651 | * This usually indicates that there is a minor corruption in the image meta data. */ | |
1652 | #define VERR_VD_READ_OUT_OF_RANGE (-3282) | |
1653 | /** Block read was marked as free in the image and returned as a zero block. */ | |
1654 | #define VINF_VD_NEW_ZEROED_BLOCK 3283 | |
1655 | /** Unable to parse the XML in DMG file. */ | |
1656 | #define VERR_VD_DMG_XML_PARSE_ERROR (-3284) | |
1657 | /** Unable to locate a usable DMG file within the XAR archive. */ | |
1658 | #define VERR_VD_DMG_NOT_FOUND_INSIDE_XAR (-3285) | |
1659 | /** The size of the raw image is not dividable by 512 */ | |
1660 | #define VERR_VD_RAW_SIZE_MODULO_512 (-3286) | |
1661 | /** The size of the raw image is not dividable by 2048 */ | |
1662 | #define VERR_VD_RAW_SIZE_MODULO_2048 (-3287) | |
1663 | /** The size of the raw optical image is too small (<= 32K) */ | |
1664 | #define VERR_VD_RAW_SIZE_OPTICAL_TOO_SMALL (-3288) | |
1665 | /** The size of the raw floppy image is too big (>2.88MB) */ | |
1666 | #define VERR_VD_RAW_SIZE_FLOPPY_TOO_BIG (-3289) | |
1667 | ||
1668 | /** @} */ | |
1669 | ||
1670 | ||
1671 | /** @name VBox Guest Library (VBGL) Status Codes | |
1672 | * @{ | |
1673 | */ | |
1674 | /** Library was not initialized. */ | |
1675 | #define VERR_VBGL_NOT_INITIALIZED (-3300) | |
1676 | /** Virtual address was not allocated by the library. */ | |
1677 | #define VERR_VBGL_INVALID_ADDR (-3301) | |
1678 | /** IOCtl to VBoxGuest driver failed. */ | |
1679 | #define VERR_VBGL_IOCTL_FAILED (-3302) | |
1680 | /** @} */ | |
1681 | ||
1682 | ||
1683 | /** @name VBox USB (VUSB) Status Codes | |
1684 | * @{ | |
1685 | */ | |
1686 | /** No available ports on the hub. | |
1687 | * This error is returned when a device is attempted created and/or attached | |
1688 | * to a hub which is out of ports. */ | |
1689 | #define VERR_VUSB_NO_PORTS (-3400) | |
1690 | /** The requested operation cannot be performed on a detached USB device. */ | |
1691 | #define VERR_VUSB_DEVICE_NOT_ATTACHED (-3401) | |
1692 | /** Failed to allocate memory for a URB. */ | |
1693 | #define VERR_VUSB_NO_URB_MEMORY (-3402) | |
1694 | /** General failure during URB queuing. | |
1695 | * This will go away when the queueing gets proper status code handling. */ | |
1696 | #define VERR_VUSB_FAILED_TO_QUEUE_URB (-3403) | |
1697 | /** Device creation failed because the USB device name was not found. */ | |
1698 | #define VERR_VUSB_DEVICE_NAME_NOT_FOUND (-3404) | |
1699 | /** Not permitted to open the USB device. | |
1700 | * The user doesn't have access to the device in the usbfs, check the mount options. */ | |
1701 | #define VERR_VUSB_USBFS_PERMISSION (-3405) | |
1702 | /** The requested operation cannot be performed because the device | |
1703 | * is currently being reset. */ | |
1704 | #define VERR_VUSB_DEVICE_IS_RESETTING (-3406) | |
1705 | /** The requested operation cannot be performed because the device | |
1706 | * is currently suspended. */ | |
1707 | #define VERR_VUSB_DEVICE_IS_SUSPENDED (-3407) | |
1708 | /** Not permitted to open the USB device. | |
1709 | * The user doesn't have access to the device node, check group memberships. */ | |
1710 | #define VERR_VUSB_USB_DEVICE_PERMISSION (-3408) | |
1711 | /** @} */ | |
1712 | ||
1713 | ||
1714 | /** @name VBox VGA Status Codes | |
1715 | * @{ | |
1716 | */ | |
1717 | /** One of the custom modes was incorrect. | |
1718 | * The format or bit count of the custom mode value is invalid. */ | |
1719 | #define VERR_VGA_INVALID_CUSTOM_MODE (-3500) | |
1720 | /** The display connector is resizing. */ | |
1721 | #define VINF_VGA_RESIZE_IN_PROGRESS (3501) | |
1722 | /** @} */ | |
1723 | ||
1724 | ||
1725 | /** @name Internal Networking Status Codes | |
1726 | * @{ | |
1727 | */ | |
1728 | /** The networking interface to filter was not found. */ | |
1729 | #define VERR_INTNET_FLT_IF_NOT_FOUND (-3600) | |
1730 | /** The networking interface to filter was busy (used by someone). */ | |
1731 | #define VERR_INTNET_FLT_IF_BUSY (-3601) | |
1732 | /** Failed to create or connect to a networking interface filter. */ | |
1733 | #define VERR_INTNET_FLT_IF_FAILED (-3602) | |
1734 | /** The network already exists with a different trunk configuration. */ | |
1735 | #define VERR_INTNET_INCOMPATIBLE_TRUNK (-3603) | |
1736 | /** The network already exists with a different security profile (restricted / public). */ | |
1737 | #define VERR_INTNET_INCOMPATIBLE_FLAGS (-3604) | |
1738 | /** Failed to create a virtual network interface instance. */ | |
1739 | #define VERR_INTNET_FLT_VNIC_CREATE_FAILED (-3605) | |
1740 | /** Failed to retrieve a virtual network interface link ID. */ | |
1741 | #define VERR_INTNET_FLT_VNIC_LINK_ID_NOT_FOUND (-3606) | |
1742 | /** Failed to initialize a virtual network interface instance. */ | |
1743 | #define VERR_INTNET_FLT_VNIC_INIT_FAILED (-3607) | |
1744 | /** Failed to open a virtual network interface instance. */ | |
1745 | #define VERR_INTNET_FLT_VNIC_OPEN_FAILED (-3608) | |
1746 | /** Failed to retrieve underlying (lower mac) link. */ | |
1747 | #define VERR_INTNET_FLT_LOWER_LINK_INFO_NOT_FOUND (-3609) | |
1748 | /** Failed to open underlying link instance. */ | |
1749 | #define VERR_INTNET_FLT_LOWER_LINK_OPEN_FAILED (-3610) | |
1750 | /** Failed to get underlying link ID. */ | |
1751 | #define VERR_INTNET_FLT_LOWER_LINK_ID_NOT_FOUND (-3611) | |
1752 | /** @} */ | |
1753 | ||
1754 | ||
1755 | /** @name Support Driver Status Codes | |
1756 | * @{ | |
1757 | */ | |
1758 | /** The component factory was not found. */ | |
1759 | #define VERR_SUPDRV_COMPONENT_NOT_FOUND (-3700) | |
1760 | /** The component factories do not support the requested interface. */ | |
1761 | #define VERR_SUPDRV_INTERFACE_NOT_SUPPORTED (-3701) | |
1762 | /** The service module was not found. */ | |
1763 | #define VERR_SUPDRV_SERVICE_NOT_FOUND (-3702) | |
1764 | /** The host kernel is too old. */ | |
1765 | #define VERR_SUPDRV_KERNEL_TOO_OLD_FOR_VTX (-3703) | |
1766 | /** Bad VTG magic value. */ | |
1767 | #define VERR_SUPDRV_VTG_MAGIC (-3704) | |
1768 | /** Bad VTG bit count value. */ | |
1769 | #define VERR_SUPDRV_VTG_BITS (-3705) | |
1770 | /** Bad VTG header - misc. */ | |
1771 | #define VERR_SUPDRV_VTG_BAD_HDR_MISC (-3706) | |
1772 | /** Bad VTG header - offset. */ | |
1773 | #define VERR_SUPDRV_VTG_BAD_HDR_OFF (-3707) | |
1774 | /** Bad VTG header - offset. */ | |
1775 | #define VERR_SUPDRV_VTG_BAD_HDR_PTR (-3708) | |
1776 | /** Bad VTG header - to low value. */ | |
1777 | #define VERR_SUPDRV_VTG_BAD_HDR_TOO_FEW (-3709) | |
1778 | /** Bad VTG header - to high value. */ | |
1779 | #define VERR_SUPDRV_VTG_BAD_HDR_TOO_MUCH (-3710) | |
1780 | /** Bad VTG header - size value is not a multiple of the structure size. */ | |
1781 | #define VERR_SUPDRV_VTG_BAD_HDR_NOT_MULTIPLE (-3711) | |
1782 | /** Bad VTG string table offset. */ | |
1783 | #define VERR_SUPDRV_VTG_STRTAB_OFF (-3712) | |
1784 | /** Bad VTG string. */ | |
1785 | #define VERR_SUPDRV_VTG_BAD_STRING (-3713) | |
1786 | /** VTG string is too long. */ | |
1787 | #define VERR_SUPDRV_VTG_STRING_TOO_LONG (-3714) | |
1788 | /** Bad VTG attribute value. */ | |
1789 | #define VERR_SUPDRV_VTG_BAD_ATTR (-3715) | |
1790 | /** Bad VTG provider descriptor. */ | |
1791 | #define VERR_SUPDRV_VTG_BAD_PROVIDER (-3716) | |
1792 | /** Bad VTG probe descriptor. */ | |
1793 | #define VERR_SUPDRV_VTG_BAD_PROBE (-3717) | |
1794 | /** Bad VTG argument list descriptor. */ | |
1795 | #define VERR_SUPDRV_VTG_BAD_ARGLIST (-3718) | |
1796 | /** Bad VTG probe enabled data. */ | |
1797 | #define VERR_SUPDRV_VTG_BAD_PROBE_ENABLED (-3719) | |
1798 | /** Bad VTG probe location record. */ | |
1799 | #define VERR_SUPDRV_VTG_BAD_PROBE_LOC (-3720) | |
1800 | /** The VTG object for the session or image has already been registered. */ | |
1801 | #define VERR_SUPDRV_VTG_ALREADY_REGISTERED (-3721) | |
1802 | /** A driver may only register one VTG object per session. */ | |
1803 | #define VERR_SUPDRV_VTG_ONLY_ONCE_PER_SESSION (-3722) | |
1804 | /** A tracer has already been registered. */ | |
1805 | #define VERR_SUPDRV_TRACER_ALREADY_REGISTERED (-3723) | |
1806 | /** The session has no tracer associated with it. */ | |
1807 | #define VERR_SUPDRV_TRACER_NOT_REGISTERED (-3724) | |
1808 | /** The tracer has already been opened in this sesssion. */ | |
1809 | #define VERR_SUPDRV_TRACER_ALREADY_OPENED (-3725) | |
1810 | /** The tracer has not been opened. */ | |
1811 | #define VERR_SUPDRV_TRACER_NOT_OPENED (-3726) | |
1812 | /** There is no tracer present. */ | |
1813 | #define VERR_SUPDRV_TRACER_NOT_PRESENT (-3727) | |
1814 | /** The tracer is unloading. */ | |
1815 | #define VERR_SUPDRV_TRACER_UNLOADING (-3728) | |
1816 | /** Another thread in the session is talking to the tracer. */ | |
1817 | #define VERR_SUPDRV_TRACER_SESSION_BUSY (-3729) | |
1818 | /** The tracer cannot open it self in the same session. */ | |
1819 | #define VERR_SUPDRV_TRACER_CANNOT_OPEN_SELF (-3730) | |
1820 | /** Bad argument flags. */ | |
1821 | #define VERR_SUPDRV_TRACER_BAD_ARG_FLAGS (-3731) | |
1822 | /** The session has reached the max number of (user mode) providers. */ | |
1823 | #define VERR_SUPDRV_TRACER_TOO_MANY_PROVIDERS (-3732) | |
1824 | /** The tracepoint provider object is too large. */ | |
1825 | #define VERR_SUPDRV_TRACER_TOO_LARGE (-3733) | |
1826 | /** The probe location array isn't adjacent to the probe enable array. */ | |
1827 | #define VERR_SUPDRV_TRACER_UMOD_NOT_ADJACENT (-3734) | |
1828 | /** The user mode tracepoint provider has too many probe locations and | |
1829 | * probes. */ | |
1830 | #define VERR_SUPDRV_TRACER_UMOD_TOO_MANY_PROBES (-3735) | |
1831 | /** The user mode tracepoint provider string table is too large. */ | |
1832 | #define VERR_SUPDRV_TRACER_UMOD_STRTAB_TOO_BIG (-3736) | |
1833 | /** The user mode tracepoint provider string table offset is bad. */ | |
1834 | #define VERR_SUPDRV_TRACER_UMOD_STRTAB_OFF_BAD (-3737) | |
1835 | /** The VM process was denied access to vboxdrv because someone have managed to | |
1836 | * open the process or its main thread with too broad access rights. */ | |
1837 | #define VERR_SUPDRV_HARDENING_EVIL_HANDLE (-3738) | |
1838 | /** Error opening the ApiPort LPC object. */ | |
1839 | #define VERR_SUPDRV_APIPORT_OPEN_ERROR (-3739) | |
1840 | /** Error enumerating all processes in the session. */ | |
1841 | #define VERR_SUPDRV_SESSION_PROCESS_ENUM_ERROR (-3740) | |
1842 | /** The CSRSS instance associated with the client process could not be | |
1843 | * located. */ | |
1844 | #define VERR_SUPDRV_CSRSS_NOT_FOUND (-3741) | |
1845 | /** Type error opening the ApiPort LPC object. */ | |
1846 | #define VERR_SUPDRV_APIPORT_OPEN_ERROR_TYPE (-3742) | |
1847 | /** Failed to measure the TSC delta between two CPUs. */ | |
1848 | #define VERR_SUPDRV_TSC_DELTA_MEASUREMENT_FAILED (-3743) | |
1849 | /** Failed to calculate the TSC frequency. */ | |
1850 | #define VERR_SUPDRV_TSC_FREQ_MEASUREMENT_FAILED (-3744) | |
1851 | /** Failed to get the delta-adjusted TSC value. */ | |
1852 | #define VERR_SUPDRV_TSC_READ_FAILED (-3745) | |
1853 | /** Failed to measure the TSC delta between two CPUs, continue without any | |
1854 | * TSC-delta. */ | |
1855 | #define VWRN_SUPDRV_TSC_DELTA_MEASUREMENT_FAILED 3746 | |
1856 | /** A TSC-delta measurement request is currently being serviced. */ | |
1857 | #define VERR_SUPDRV_TSC_DELTA_MEASUREMENT_BUSY (-3747) | |
1858 | /** The process trying to open VBoxDrv is not a budding VM process (1). */ | |
1859 | #define VERR_SUPDRV_NOT_BUDDING_VM_PROCESS_1 (-3748) | |
1860 | /** The process trying to open VBoxDrv is not a budding VM process (2). */ | |
1861 | #define VERR_SUPDRV_NOT_BUDDING_VM_PROCESS_2 (-3749) | |
1862 | /** @} */ | |
1863 | ||
1864 | ||
1865 | /** @name Support Library Status Codes | |
1866 | * @{ | |
1867 | */ | |
1868 | /** The specified path was not absolute (hardening). */ | |
1869 | #define VERR_SUPLIB_PATH_NOT_ABSOLUTE (-3750) | |
1870 | /** The specified path was not clean (hardening). */ | |
1871 | #define VERR_SUPLIB_PATH_NOT_CLEAN (-3751) | |
1872 | /** The specified path is too long (hardening). */ | |
1873 | #define VERR_SUPLIB_PATH_TOO_LONG (-3752) | |
1874 | /** The specified path is too short (hardening). */ | |
1875 | #define VERR_SUPLIB_PATH_TOO_SHORT (-3753) | |
1876 | /** The specified path has too many components (hardening). */ | |
1877 | #define VERR_SUPLIB_PATH_TOO_MANY_COMPONENTS (-3754) | |
1878 | /** The specified path is a root path (hardening). */ | |
1879 | #define VERR_SUPLIB_PATH_IS_ROOT (-3755) | |
1880 | /** Failed to enumerate directory (hardening). */ | |
1881 | #define VERR_SUPLIB_DIR_ENUM_FAILED (-3756) | |
1882 | /** Failed to stat a file/dir during enumeration (hardening). */ | |
1883 | #define VERR_SUPLIB_STAT_ENUM_FAILED (-3757) | |
1884 | /** Failed to stat a file/dir (hardening). */ | |
1885 | #define VERR_SUPLIB_STAT_FAILED (-3758) | |
1886 | /** Failed to fstat a native handle (hardening). */ | |
1887 | #define VERR_SUPLIB_FSTAT_FAILED (-3759) | |
1888 | /** Found an illegal symbolic link (hardening). */ | |
1889 | #define VERR_SUPLIB_SYMLINKS_ARE_NOT_PERMITTED (-3760) | |
1890 | /** Found something which isn't a file nor a directory (hardening). */ | |
1891 | #define VERR_SUPLIB_NOT_DIR_NOT_FILE (-3761) | |
1892 | /** The specified path is a directory and not a file (hardening). */ | |
1893 | #define VERR_SUPLIB_IS_DIRECTORY (-3762) | |
1894 | /** The specified path is a file and not a directory (hardening). */ | |
1895 | #define VERR_SUPLIB_IS_FILE (-3763) | |
1896 | /** The path is not the same object as the native handle (hardening). */ | |
1897 | #define VERR_SUPLIB_NOT_SAME_OBJECT (-3764) | |
1898 | /** The owner is not root (hardening). */ | |
1899 | #define VERR_SUPLIB_OWNER_NOT_ROOT (-3765) | |
1900 | /** The group is a non-system group and it has write access (hardening). */ | |
1901 | #define VERR_SUPLIB_WRITE_NON_SYS_GROUP (-3766) | |
1902 | /** The file or directory is world writable (hardening). */ | |
1903 | #define VERR_SUPLIB_WORLD_WRITABLE (-3767) | |
1904 | /** The argv[0] of an internal application does not match the executable image | |
1905 | * path (hardening). */ | |
1906 | #define VERR_SUPLIB_INVALID_ARGV0_INTERNAL (-3768) | |
1907 | /** The internal application does not reside in the correct place (hardening). */ | |
1908 | #define VERR_SUPLIB_INVALID_INTERNAL_APP_DIR (-3769) | |
1909 | /** Unable to establish trusted of VM process (0). */ | |
1910 | #define VERR_SUPLIB_NT_PROCESS_UNTRUSTED_0 (-3770) | |
1911 | /** Unable to establish trusted of VM process (1). */ | |
1912 | #define VERR_SUPLIB_NT_PROCESS_UNTRUSTED_1 (-3771) | |
1913 | /** Unable to establish trusted of VM process (2). */ | |
1914 | #define VERR_SUPLIB_NT_PROCESS_UNTRUSTED_2 (-3772) | |
1915 | /** Unable to establish trusted of VM process (3). */ | |
1916 | #define VERR_SUPLIB_NT_PROCESS_UNTRUSTED_3 (-3773) | |
1917 | /** Unable to establish trusted of VM process (4). */ | |
1918 | #define VERR_SUPLIB_NT_PROCESS_UNTRUSTED_4 (-3774) | |
1919 | /** Unable to establish trusted of VM process (5). */ | |
1920 | #define VERR_SUPLIB_NT_PROCESS_UNTRUSTED_5 (-3775) | |
1921 | /** @} */ | |
1922 | ||
1923 | ||
1924 | /** @name VBox GMM Status Codes | |
1925 | * @{ | |
1926 | */ | |
1927 | /** The GMM is out of pages and needs to be give another chunk of user memory that | |
1928 | * it can lock down and borrow pages from. */ | |
1929 | #define VERR_GMM_SEED_ME (-3800) | |
1930 | /** Unable to allocate more pages from the host system. */ | |
1931 | #define VERR_GMM_OUT_OF_MEMORY (-3801) | |
1932 | /** Hit the global allocation limit. | |
1933 | * If you know there is still sufficient memory available, try raising the limit. */ | |
1934 | #define VERR_GMM_HIT_GLOBAL_LIMIT (-3802) | |
1935 | /** Hit the a VM account limit. */ | |
1936 | #define VERR_GMM_HIT_VM_ACCOUNT_LIMIT (-3803) | |
1937 | /** Attempt to free more memory than what was previously allocated. */ | |
1938 | #define VERR_GMM_ATTEMPT_TO_FREE_TOO_MUCH (-3804) | |
1939 | /** Attempted to report too many pages as deflated. */ | |
1940 | #define VERR_GMM_ATTEMPT_TO_DEFLATE_TOO_MUCH (-3805) | |
1941 | /** The page to be freed or updated was not found. */ | |
1942 | #define VERR_GMM_PAGE_NOT_FOUND (-3806) | |
1943 | /** The specified shared page was not actually private. */ | |
1944 | #define VERR_GMM_PAGE_NOT_PRIVATE (-3807) | |
1945 | /** The specified shared page was not actually shared. */ | |
1946 | #define VERR_GMM_PAGE_NOT_SHARED (-3808) | |
1947 | /** The page to be freed was already freed. */ | |
1948 | #define VERR_GMM_PAGE_ALREADY_FREE (-3809) | |
1949 | /** The page to be updated or freed was noted owned by the caller. */ | |
1950 | #define VERR_GMM_NOT_PAGE_OWNER (-3810) | |
1951 | /** The specified chunk was not found. */ | |
1952 | #define VERR_GMM_CHUNK_NOT_FOUND (-3811) | |
1953 | /** The chunk has already been mapped into the process. */ | |
1954 | #define VERR_GMM_CHUNK_ALREADY_MAPPED (-3812) | |
1955 | /** The chunk to be unmapped isn't actually mapped into the process. */ | |
1956 | #define VERR_GMM_CHUNK_NOT_MAPPED (-3813) | |
1957 | /** The chunk has been mapped too many times already (impossible). */ | |
1958 | #define VERR_GMM_TOO_MANY_CHUNK_MAPPINGS (-3814) | |
1959 | /** The reservation or reservation update was declined - too many VMs, too | |
1960 | * little memory, and/or too low GMM configuration. */ | |
1961 | #define VERR_GMM_MEMORY_RESERVATION_DECLINED (-3815) | |
1962 | /** A GMM sanity check failed. */ | |
1963 | #define VERR_GMM_IS_NOT_SANE (-3816) | |
1964 | /** Inserting a new chunk failed. */ | |
1965 | #define VERR_GMM_CHUNK_INSERT (-3817) | |
1966 | /** Failed to obtain the GMM instance. */ | |
1967 | #define VERR_GMM_INSTANCE (-3818) | |
1968 | /** Bad mutex semaphore flags. */ | |
1969 | #define VERR_GMM_MTX_FLAGS (-3819) | |
1970 | /** Internal processing error in the page allocator. */ | |
1971 | #define VERR_GMM_ALLOC_PAGES_IPE (-3820) | |
1972 | /** Invalid page count given to GMMR3FreePagesPerform. */ | |
1973 | #define VERR_GMM_ACTUAL_PAGES_IPE (-3821) | |
1974 | /** The shared module name is too long. */ | |
1975 | #define VERR_GMM_MODULE_NAME_TOO_LONG (-3822) | |
1976 | /** The shared module version string is too long. */ | |
1977 | #define VERR_GMM_MODULE_VERSION_TOO_LONG (-3823) | |
1978 | /** The shared module has too many regions. */ | |
1979 | #define VERR_GMM_TOO_MANY_REGIONS (-3824) | |
1980 | /** The guest has reported too many modules. */ | |
1981 | #define VERR_GMM_TOO_MANY_PER_VM_MODULES (-3825) | |
1982 | /** The guest has reported too many modules. */ | |
1983 | #define VERR_GMM_TOO_MANY_GLOBAL_MODULES (-3826) | |
1984 | /** The shared module is already registered. */ | |
1985 | #define VINF_GMM_SHARED_MODULE_ALREADY_REGISTERED (3827) | |
1986 | /** The shared module clashed address wise with a previously registered | |
1987 | * module. */ | |
1988 | #define VERR_GMM_SHARED_MODULE_ADDRESS_CLASH (-3828) | |
1989 | /** The shared module was not found. */ | |
1990 | #define VERR_GMM_SHARED_MODULE_NOT_FOUND (-3829) | |
1991 | /** The size of the shared module was out of range. */ | |
1992 | #define VERR_GMM_BAD_SHARED_MODULE_SIZE (-3830) | |
1993 | /** The size of the one or more regions in the shared module was out of | |
1994 | * range. */ | |
1995 | #define VERR_GMM_SHARED_MODULE_BAD_REGIONS_SIZE (-3831) | |
1996 | /** @} */ | |
1997 | ||
1998 | ||
1999 | /** @name VBox GVM Status Codes | |
2000 | * @{ | |
2001 | */ | |
2002 | /** The GVM is out of VM handle space. */ | |
2003 | #define VERR_GVM_TOO_MANY_VMS (-3900) | |
2004 | /** The EMT was not blocked at the time of the call. */ | |
2005 | #define VINF_GVM_NOT_BLOCKED 3901 | |
2006 | /** The EMT was not busy running guest code at the time of the call. */ | |
2007 | #define VINF_GVM_NOT_BUSY_IN_GC 3902 | |
2008 | /** RTThreadYield was called during a GVMMR0SchedPoll call. */ | |
2009 | #define VINF_GVM_YIELDED 3903 | |
2010 | /** @} */ | |
2011 | ||
2012 | ||
2013 | /** @name VBox VMX Status Codes | |
2014 | * @{ | |
2015 | */ | |
2016 | /** VMXON failed; possibly because it was already run before. */ | |
2017 | #define VERR_VMX_VMXON_FAILED (-4000) | |
2018 | /** Invalid VMCS pointer. | |
2019 | * (Can be OR'ed with VERR_VMX_INVALID_VMCS_FIELD.) */ | |
2020 | #define VERR_VMX_INVALID_VMCS_PTR (-4001) | |
2021 | /** Invalid VMCS index or write to read-only element. */ | |
2022 | #define VERR_VMX_INVALID_VMCS_FIELD (-4002) | |
2023 | /** Reserved for future status code that we wish to OR with | |
2024 | * VERR_VMX_INVALID_VMCS_PTR and VERR_VMX_INVALID_VMCS_FIELD. */ | |
2025 | #define VERR_VMX_RESERVED (-4003) | |
2026 | /** Invalid VMXON pointer. */ | |
2027 | #define VERR_VMX_INVALID_VMXON_PTR (-4004) | |
2028 | /** Unable to start VM execution. */ | |
2029 | #define VERR_VMX_UNABLE_TO_START_VM (-4005) | |
2030 | /** Unable to switch due to invalid host state. */ | |
2031 | #define VERR_VMX_INVALID_HOST_STATE (-4006) | |
2032 | /** IA32_FEATURE_CONTROL MSR not setup correcty (turn on VMX in the host system BIOS) */ | |
2033 | #define VERR_VMX_ILLEGAL_FEATURE_CONTROL_MSR (-4007) | |
2034 | /** Invalid CPU mode for VMX execution. */ | |
2035 | #define VERR_VMX_UNSUPPORTED_MODE (-4008) | |
2036 | /** VMX CPU extension not available */ | |
2037 | #define VERR_VMX_NO_VMX (-4009) | |
2038 | /** CPU was incorrectly left in VMX root mode; incompatible with VirtualBox */ | |
2039 | #define VERR_VMX_IN_VMX_ROOT_MODE (-4011) | |
2040 | /** Somebody cleared X86_CR4_VMXE in the CR4 register. */ | |
2041 | #define VERR_VMX_X86_CR4_VMXE_CLEARED (-4012) | |
2042 | /** Failed to enable and lock VT-x features. */ | |
2043 | #define VERR_VMX_MSR_LOCKING_FAILED (-4013) | |
2044 | /** Unable to switch due to invalid guest state. */ | |
2045 | #define VERR_VMX_INVALID_GUEST_STATE (-4014) | |
2046 | /** Unexpected VM exit. */ | |
2047 | #define VERR_VMX_UNEXPECTED_EXIT (-4015) | |
2048 | /** Unexpected VM exception. */ | |
2049 | #define VERR_VMX_UNEXPECTED_EXCEPTION (-4016) | |
2050 | /** Unexpected interruption exit type. */ | |
2051 | #define VERR_VMX_UNEXPECTED_INTERRUPTION_EXIT_TYPE (-4017) | |
2052 | /** CPU is not in VMX root mode; unexpected when leaving VMX root mode. */ | |
2053 | #define VERR_VMX_NOT_IN_VMX_ROOT_MODE (-4018) | |
2054 | /** Undefined VM exit code. */ | |
2055 | #define VERR_VMX_UNDEFINED_EXIT_CODE (-4019) | |
2056 | /** VMPTRLD failed; possibly because of invalid VMCS launch-state. */ | |
2057 | #define VERR_VMX_VMPTRLD_FAILED (-4021) | |
2058 | /** Invalid VMCS pointer passed to VMLAUNCH/VMRESUME. */ | |
2059 | #define VERR_VMX_INVALID_VMCS_PTR_TO_START_VM (-4022) | |
2060 | /** Internal VMX processing error no 1. */ | |
2061 | #define VERR_VMX_IPE_1 (-4023) | |
2062 | /** Internal VMX processing error no 2. */ | |
2063 | #define VERR_VMX_IPE_2 (-4024) | |
2064 | /** Internal VMX processing error no 3. */ | |
2065 | #define VERR_VMX_IPE_3 (-4025) | |
2066 | /** Internal VMX processing error no 4. */ | |
2067 | #define VERR_VMX_IPE_4 (-4026) | |
2068 | /** Internal VMX processing error no 5. */ | |
2069 | #define VERR_VMX_IPE_5 (-4027) | |
2070 | /** VT-x features for all modes (SMX and non-SMX) disabled by the BIOS. */ | |
2071 | #define VERR_VMX_MSR_ALL_VMX_DISABLED (-4028) | |
2072 | /** VT-x features disabled by the BIOS. */ | |
2073 | #define VERR_VMX_MSR_VMX_DISABLED (-4029) | |
2074 | /** VM-Entry Controls internal cache invalid. */ | |
2075 | #define VERR_VMX_ENTRY_CTLS_CACHE_INVALID (-4030) | |
2076 | /** VM-Exit Controls internal cache invalid. */ | |
2077 | #define VERR_VMX_EXIT_CTLS_CACHE_INVALID (-4031) | |
2078 | /** VM-Execution Pin-based Controls internal cache invalid. */ | |
2079 | #define VERR_VMX_PIN_EXEC_CTLS_CACHE_INVALID (-4032) | |
2080 | /** VM-Execution Primary Processor-based Controls internal cache | |
2081 | * invalid. */ | |
2082 | #define VERR_VMX_PROC_EXEC_CTLS_CACHE_INVALID (-4033) | |
2083 | /** VM-Execution Secondary Processor-based Controls internal | |
2084 | * cache invalid. */ | |
2085 | #define VERR_VMX_PROC_EXEC2_CTLS_CACHE_INVALID (-4034) | |
2086 | /** Failed to set VMXON enable bit while enabling VT-x through the MSR. */ | |
2087 | #define VERR_VMX_MSR_VMX_ENABLE_FAILED (-4035) | |
2088 | /** Failed to enable VMXON-in-SMX bit while enabling VT-x through the MSR. */ | |
2089 | #define VERR_VMX_MSR_SMX_VMX_ENABLE_FAILED (-4036) | |
2090 | /** @} */ | |
2091 | ||
2092 | ||
2093 | /** @name VBox SVM Status Codes | |
2094 | * @{ | |
2095 | */ | |
2096 | /** Unable to start VM execution. */ | |
2097 | #define VERR_SVM_UNABLE_TO_START_VM (-4050) | |
2098 | /** AMD-V bit not set in K6_EFER MSR */ | |
2099 | #define VERR_SVM_ILLEGAL_EFER_MSR (-4051) | |
2100 | /** AMD-V CPU extension not available. */ | |
2101 | #define VERR_SVM_NO_SVM (-4052) | |
2102 | /** AMD-V CPU extension disabled (by BIOS). */ | |
2103 | #define VERR_SVM_DISABLED (-4053) | |
2104 | /** AMD-V CPU extension in-use. */ | |
2105 | #define VERR_SVM_IN_USE (-4054) | |
2106 | /** Invalid pVMCB. */ | |
2107 | #define VERR_SVM_INVALID_PVMCB (-4055) | |
2108 | /** Unexpected SVM exit. */ | |
2109 | #define VERR_SVM_UNEXPECTED_EXIT (-4056) | |
2110 | /** Unexpected SVM exception exit. */ | |
2111 | #define VERR_SVM_UNEXPECTED_XCPT_EXIT (-4057) | |
2112 | /** Unexpected SVM patch type. */ | |
2113 | #define VERR_SVM_UNEXPECTED_PATCH_TYPE (-4058) | |
2114 | /** Unable to start VM execution due to an invalid guest state. */ | |
2115 | #define VERR_SVM_INVALID_GUEST_STATE (-4059) | |
2116 | /** Unknown or unrecognized SVM exit. */ | |
2117 | #define VERR_SVM_UNKNOWN_EXIT (-4060) | |
2118 | /** Internal SVM processing error no 1. */ | |
2119 | #define VERR_SVM_IPE_1 (-4061) | |
2120 | /** Internal SVM processing error no 2. */ | |
2121 | #define VERR_SVM_IPE_2 (-4062) | |
2122 | /** Internal SVM processing error no 3. */ | |
2123 | #define VERR_SVM_IPE_3 (-4063) | |
2124 | /** Internal SVM processing error no 4. */ | |
2125 | #define VERR_SVM_IPE_4 (-4064) | |
2126 | /** Internal SVM processing error no 5. */ | |
2127 | #define VERR_SVM_IPE_5 (-4065) | |
2128 | /** @} */ | |
2129 | ||
2130 | ||
2131 | /** @name VBox HM Status Codes | |
2132 | * @{ | |
2133 | */ | |
2134 | /** Unable to start VM execution. */ | |
2135 | #define VERR_HM_UNKNOWN_CPU (-4100) | |
2136 | /** No CPUID support. */ | |
2137 | #define VERR_HM_NO_CPUID (-4101) | |
2138 | /** Host is about to go into suspend mode. */ | |
2139 | #define VERR_HM_SUSPEND_PENDING (-4102) | |
2140 | /** Conflicting CFGM values. */ | |
2141 | #define VERR_HM_CONFIG_MISMATCH (-4103) | |
2142 | /** Internal processing error in the HM init code. */ | |
2143 | #define VERR_HM_ALREADY_ENABLED_IPE (-4104) | |
2144 | /** Unexpected MSR in the auto-load/store area. */ | |
2145 | #define VERR_HM_UNEXPECTED_LD_ST_MSR (-4105) | |
2146 | /** No 32-bit to 64-bit switcher in place. */ | |
2147 | #define VERR_HM_NO_32_TO_64_SWITCHER (-4106) | |
2148 | /** HMR0Leave was called on the wrong CPU. */ | |
2149 | #define VERR_HM_WRONG_CPU (-4107) | |
2150 | /** Internal processing error \#1 in the HM code. */ | |
2151 | #define VERR_HM_IPE_1 (-4108) | |
2152 | /** Internal processing error \#2 in the HM code. */ | |
2153 | #define VERR_HM_IPE_2 (-4109) | |
2154 | /** Wrong 32/64-bit switcher. */ | |
2155 | #define VERR_HM_WRONG_SWITCHER (-4110) | |
2156 | /** Unknown I/O instruction. */ | |
2157 | #define VERR_HM_UNKNOWN_IO_INSTRUCTION (-4111) | |
2158 | /** Unsupported CPU feature combination. */ | |
2159 | #define VERR_HM_UNSUPPORTED_CPU_FEATURE_COMBO (-4112) | |
2160 | /** Internal processing error \#3 in the HM code. */ | |
2161 | #define VERR_HM_IPE_3 (-4113) | |
2162 | /** Internal processing error \#4 in the HM code. */ | |
2163 | #define VERR_HM_IPE_4 (-4114) | |
2164 | /** Internal processing error \#5 in the HM code. */ | |
2165 | #define VERR_HM_IPE_5 (-4115) | |
2166 | /** Invalid HM64ON32OP value. */ | |
2167 | #define VERR_HM_INVALID_HM64ON32OP (-4116) | |
2168 | /** Resume guest execution after injecting a double-fault. */ | |
2169 | #define VINF_HM_DOUBLE_FAULT 4117 | |
2170 | /** @} */ | |
2171 | ||
2172 | ||
2173 | /** @name VBox Disassembler Status Codes | |
2174 | * @{ | |
2175 | */ | |
2176 | /** Invalid opcode byte(s) */ | |
2177 | #define VERR_DIS_INVALID_OPCODE (-4200) | |
2178 | /** Generic failure during disassembly. */ | |
2179 | #define VERR_DIS_GEN_FAILURE (-4201) | |
2180 | /** No read callback. */ | |
2181 | #define VERR_DIS_NO_READ_CALLBACK (-4202) | |
2182 | /** Invalid Mod/RM. */ | |
2183 | #define VERR_DIS_INVALID_MODRM (-4203) | |
2184 | /** Invalid parameter index. */ | |
2185 | #define VERR_DIS_INVALID_PARAMETER (-4204) | |
2186 | /** The instruction is too long. */ | |
2187 | #define VERR_DIS_TOO_LONG_INSTR (-4206) | |
2188 | /** @} */ | |
2189 | ||
2190 | ||
2191 | /** @name VBox Webservice Status Codes | |
2192 | * @{ | |
2193 | */ | |
2194 | /** Authentication failed (ISessionManager::logon()) */ | |
2195 | #define VERR_WEB_NOT_AUTHENTICATED (-4300) | |
2196 | /** Invalid format of managed object reference */ | |
2197 | #define VERR_WEB_INVALID_MANAGED_OBJECT_REFERENCE (-4301) | |
2198 | /** Invalid session ID in managed object reference */ | |
2199 | #define VERR_WEB_INVALID_SESSION_ID (-4302) | |
2200 | /** Invalid object ID in managed object reference */ | |
2201 | #define VERR_WEB_INVALID_OBJECT_ID (-4303) | |
2202 | /** Unsupported interface for managed object reference */ | |
2203 | #define VERR_WEB_UNSUPPORTED_INTERFACE (-4304) | |
2204 | /** @} */ | |
2205 | ||
2206 | ||
2207 | /** @name VBox PARAV Status Codes | |
2208 | * @{ | |
2209 | */ | |
2210 | /** Switch back to host */ | |
2211 | #define VINF_PARAV_SWITCH_TO_HOST 4400 | |
2212 | ||
2213 | /** @} */ | |
2214 | ||
2215 | /** @name VBox Video HW Acceleration command status | |
2216 | * @{ | |
2217 | */ | |
2218 | /** command processing is pending, a completion handler will be called */ | |
2219 | #define VINF_VHWA_CMD_PENDING 4500 | |
2220 | ||
2221 | /** @} */ | |
2222 | ||
2223 | ||
2224 | /** @name VBox COM error codes | |
2225 | * | |
2226 | * @remarks Global::vboxStatusCodeToCOM and Global::vboxStatusCodeFromCOM uses | |
2227 | * these for conversion that is lossless with respect to important COM | |
2228 | * status codes. These methods should be moved to the glue library. | |
2229 | * @{ */ | |
2230 | /** Unexpected turn of events. */ | |
2231 | #define VERR_COM_UNEXPECTED (-4600) | |
2232 | /** The base of the VirtualBox COM status codes (the lower value) | |
2233 | * corresponding 1:1 to VBOX_E_XXX. This is the lowest value. */ | |
2234 | #define VERR_COM_VBOX_LOWEST (-4699) | |
2235 | /** Object corresponding to the supplied arguments does not exist. */ | |
2236 | #define VERR_COM_OBJECT_NOT_FOUND (VERR_COM_VBOX_LOWEST + 1) | |
2237 | /** Current virtual machine state prevents the operation. */ | |
2238 | #define VERR_COM_INVALID_VM_STATE (VERR_COM_VBOX_LOWEST + 2) | |
2239 | /** Virtual machine error occurred attempting the operation. */ | |
2240 | #define VERR_COM_VM_ERROR (VERR_COM_VBOX_LOWEST + 3) | |
2241 | /** File not accessible or erroneous file contents. */ | |
2242 | #define VERR_COM_FILE_ERROR (VERR_COM_VBOX_LOWEST + 4) | |
2243 | /** IPRT error. */ | |
2244 | #define VERR_COM_IPRT_ERROR (VERR_COM_VBOX_LOWEST + 5) | |
2245 | /** Pluggable Device Manager error. */ | |
2246 | #define VERR_COM_PDM_ERROR (VERR_COM_VBOX_LOWEST + 6) | |
2247 | /** Current object state prohibits operation. */ | |
2248 | #define VERR_COM_INVALID_OBJECT_STATE (VERR_COM_VBOX_LOWEST + 7) | |
2249 | /** Host operating system related error. */ | |
2250 | #define VERR_COM_HOST_ERROR (VERR_COM_VBOX_LOWEST + 8) | |
2251 | /** Requested operation is not supported. */ | |
2252 | #define VERR_COM_NOT_SUPPORTED (VERR_COM_VBOX_LOWEST + 9) | |
2253 | /** Invalid XML found. */ | |
2254 | #define VERR_COM_XML_ERROR (VERR_COM_VBOX_LOWEST + 10) | |
2255 | /** Current session state prohibits operation. */ | |
2256 | #define VERR_COM_INVALID_SESSION_STATE (VERR_COM_VBOX_LOWEST + 11) | |
2257 | /** Object being in use prohibits operation. */ | |
2258 | #define VERR_COM_OBJECT_IN_USE (VERR_COM_VBOX_LOWEST + 12) | |
2259 | /** Returned by callback methods which does not need to be called | |
2260 | * again because the client does not actually make use of them. */ | |
2261 | #define VERR_COM_DONT_CALL_AGAIN (VERR_COM_VBOX_LOWEST + 13) | |
2262 | /** @} */ | |
2263 | ||
2264 | /** @name VBox VMMDev Status codes | |
2265 | * @{ | |
2266 | */ | |
2267 | /** CPU hotplug events from VMMDev are not monitored by the guest. */ | |
2268 | #define VERR_VMMDEV_CPU_HOTPLUG_NOT_MONITORED_BY_GUEST (-4700) | |
2269 | /** @} */ | |
2270 | ||
2271 | /** @name VBox async I/O manager Status Codes | |
2272 | * @{ | |
2273 | */ | |
2274 | /** Async I/O task is pending, a completion handler will be called. */ | |
2275 | #define VINF_AIO_TASK_PENDING 4800 | |
2276 | /** @} */ | |
2277 | ||
2278 | /** @name VBox Virtual SCSI Status Codes | |
2279 | * @{ | |
2280 | */ | |
2281 | /** LUN type is not supported. */ | |
2282 | #define VERR_VSCSI_LUN_TYPE_NOT_SUPPORTED (-4900) | |
2283 | /** LUN is already/still attached to a device. */ | |
2284 | #define VERR_VSCSI_LUN_ATTACHED_TO_DEVICE (-4901) | |
2285 | /** The specified LUN is invalid. */ | |
2286 | #define VERR_VSCSI_LUN_INVALID (-4902) | |
2287 | /** The LUN is not attached to the device. */ | |
2288 | #define VERR_VSCSI_LUN_NOT_ATTACHED (-4903) | |
2289 | /** The LUN is still busy. */ | |
2290 | #define VERR_VSCSI_LUN_BUSY (-4904) | |
2291 | /** @} */ | |
2292 | ||
2293 | /** @name VBox FAM Status Codes | |
2294 | * @{ | |
2295 | */ | |
2296 | /** FAM failed to open a connection. */ | |
2297 | #define VERR_FAM_OPEN_FAILED (-5000) | |
2298 | /** FAM failed to add a file to the list to be monitored. */ | |
2299 | #define VERR_FAM_MONITOR_FILE_FAILED (-5001) | |
2300 | /** FAM failed to add a directory to the list to be monitored. */ | |
2301 | #define VERR_FAM_MONITOR_DIRECTORY_FAILED (-5002) | |
2302 | /** The connection to the FAM daemon was lost. */ | |
2303 | #define VERR_FAM_CONNECTION_LOST (-5003) | |
2304 | /** @} */ | |
2305 | ||
2306 | ||
2307 | /** @name PCI Passtrhough Status Codes | |
2308 | * @{ | |
2309 | */ | |
2310 | /** RamPreAlloc not set. | |
2311 | * RAM pre-allocation is currently a requirement for PCI passthrough. */ | |
2312 | #define VERR_PCI_PASSTHROUGH_NO_RAM_PREALLOC (-5100) | |
2313 | /** VT-x/AMD-V not active. | |
2314 | * PCI passthrough currently works only if VT-x/AMD-V is active. */ | |
2315 | #define VERR_PCI_PASSTHROUGH_NO_HM (-5101) | |
2316 | /** Nested paging not active. | |
2317 | * PCI passthrough currently works only if nested paging is active. */ | |
2318 | #define VERR_PCI_PASSTHROUGH_NO_NESTED_PAGING (-5102) | |
2319 | /** @} */ | |
2320 | ||
2321 | ||
2322 | /** @name GVMM Status Codes | |
2323 | * @{ | |
2324 | */ | |
2325 | /** Internal error obtaining the GVMM instance. */ | |
2326 | #define VERR_GVMM_INSTANCE (-5200) | |
2327 | /** GVMM does not support the range of CPUs present/possible on the host. */ | |
2328 | #define VERR_GVMM_HOST_CPU_RANGE (-5201) | |
2329 | /** GVMM ran into some broken IPRT code. */ | |
2330 | #define VERR_GVMM_BROKEN_IPRT (-5202) | |
2331 | /** Internal processing error \#1 in the GVMM code. */ | |
2332 | #define VERR_GVMM_IPE_1 (-5203) | |
2333 | /** Internal processing error \#2 in the GVMM code. */ | |
2334 | #define VERR_GVMM_IPE_2 (-5204) | |
2335 | /** @} */ | |
2336 | ||
2337 | ||
2338 | /** @name IEM Status Codes | |
2339 | * @{ */ | |
2340 | /** The instruction is not yet implemented by IEM. */ | |
2341 | #define VERR_IEM_INSTR_NOT_IMPLEMENTED (-5300) | |
2342 | /** Invalid operand size passed to an IEM function. */ | |
2343 | #define VERR_IEM_INVALID_OPERAND_SIZE (-5301) | |
2344 | /** Invalid address mode passed to an IEM function. */ | |
2345 | #define VERR_IEM_INVALID_ADDRESS_MODE (-5302) | |
2346 | /** Invalid effective segment register number passed to an IEM function. */ | |
2347 | #define VERR_IEM_INVALID_EFF_SEG (-5303) | |
2348 | /** Invalid instruction length passed to an IEM function. */ | |
2349 | #define VERR_IEM_INVALID_INSTR_LENGTH (-5304) | |
2350 | /** Internal status code for indicating that a selector isn't valid (LAR, LSL, | |
2351 | * VERR, VERW). This is not used outside the instruction implementations. */ | |
2352 | #define VINF_IEM_SELECTOR_NOT_OK (5305) | |
2353 | /** Restart the current instruction. For testing only. */ | |
2354 | #define VERR_IEM_RESTART_INSTRUCTION (-5389) | |
2355 | /** This particular aspect of the instruction is not yet implemented by IEM. */ | |
2356 | #define VERR_IEM_ASPECT_NOT_IMPLEMENTED (-5390) | |
2357 | /** Internal processing error \#1 in the IEM code. */ | |
2358 | #define VERR_IEM_IPE_1 (-5391) | |
2359 | /** Internal processing error \#2 in the IEM code. */ | |
2360 | #define VERR_IEM_IPE_2 (-5392) | |
2361 | /** Internal processing error \#3 in the IEM code. */ | |
2362 | #define VERR_IEM_IPE_3 (-5393) | |
2363 | /** Internal processing error \#4 in the IEM code. */ | |
2364 | #define VERR_IEM_IPE_4 (-5394) | |
2365 | /** Internal processing error \#5 in the IEM code. */ | |
2366 | #define VERR_IEM_IPE_5 (-5395) | |
2367 | /** Internal processing error \#6 in the IEM code. */ | |
2368 | #define VERR_IEM_IPE_6 (-5396) | |
2369 | /** Internal processing error \#7 in the IEM code. */ | |
2370 | #define VERR_IEM_IPE_7 (-5397) | |
2371 | /** Internal processing error \#8 in the IEM code. */ | |
2372 | #define VERR_IEM_IPE_8 (-5398) | |
2373 | /** Internal processing error \#9 in the IEM code. */ | |
2374 | #define VERR_IEM_IPE_9 (-5399) | |
2375 | /** @} */ | |
2376 | ||
2377 | ||
2378 | /** @name DBGC Status Codes | |
2379 | * @{ */ | |
2380 | /** Status that causes DBGC to quit. */ | |
2381 | #define VERR_DBGC_QUIT (-5400) | |
2382 | /** Async command pending. */ | |
2383 | #define VWRN_DBGC_CMD_PENDING 5401 | |
2384 | /** The command has already been registered. */ | |
2385 | #define VWRN_DBGC_ALREADY_REGISTERED 5402 | |
2386 | /** The command cannot be deregistered because has not been registered. */ | |
2387 | #define VERR_DBGC_COMMANDS_NOT_REGISTERED (-5403) | |
2388 | /** Unknown breakpoint. */ | |
2389 | #define VERR_DBGC_BP_NOT_FOUND (-5404) | |
2390 | /** The breakpoint already exists. */ | |
2391 | #define VERR_DBGC_BP_EXISTS (-5405) | |
2392 | /** The breakpoint has no command. */ | |
2393 | #define VINF_DBGC_BP_NO_COMMAND 5406 | |
2394 | /** Generic debugger command failure. */ | |
2395 | #define VERR_DBGC_COMMAND_FAILED (-5407) | |
2396 | /** Logic bug in the DBGC code. */ | |
2397 | #define VERR_DBGC_IPE (-5408) | |
2398 | ||
2399 | /** The lowest parse status code. */ | |
2400 | #define VERR_DBGC_PARSE_LOWEST (-5499) | |
2401 | /** Syntax error - too few arguments. */ | |
2402 | #define VERR_DBGC_PARSE_TOO_FEW_ARGUMENTS (VERR_DBGC_PARSE_LOWEST + 0) | |
2403 | /** Syntax error - too many arguments. */ | |
2404 | #define VERR_DBGC_PARSE_TOO_MANY_ARGUMENTS (VERR_DBGC_PARSE_LOWEST + 1) | |
2405 | /** Syntax error - too many arguments for static storage. */ | |
2406 | #define VERR_DBGC_PARSE_ARGUMENT_OVERFLOW (VERR_DBGC_PARSE_LOWEST + 2) | |
2407 | /** Syntax error - expected binary operator. */ | |
2408 | #define VERR_DBGC_PARSE_EXPECTED_BINARY_OP (VERR_DBGC_PARSE_LOWEST + 3) | |
2409 | ||
2410 | /** Syntax error - the argument does not allow a range to be specified. */ | |
2411 | #define VERR_DBGC_PARSE_NO_RANGE_ALLOWED (VERR_DBGC_PARSE_LOWEST + 5) | |
2412 | /** Syntax error - unbalanced quotes. */ | |
2413 | #define VERR_DBGC_PARSE_UNBALANCED_QUOTE (VERR_DBGC_PARSE_LOWEST + 6) | |
2414 | /** Syntax error - unbalanced parenthesis. */ | |
2415 | #define VERR_DBGC_PARSE_UNBALANCED_PARENTHESIS (VERR_DBGC_PARSE_LOWEST + 7) | |
2416 | /** Syntax error - an argument or subargument contains nothing useful. */ | |
2417 | #define VERR_DBGC_PARSE_EMPTY_ARGUMENT (VERR_DBGC_PARSE_LOWEST + 8) | |
2418 | /** Syntax error - invalid operator usage. */ | |
2419 | #define VERR_DBGC_PARSE_UNEXPECTED_OPERATOR (VERR_DBGC_PARSE_LOWEST + 9) | |
2420 | /** Syntax error - invalid numeric value. */ | |
2421 | #define VERR_DBGC_PARSE_INVALID_NUMBER (VERR_DBGC_PARSE_LOWEST + 10) | |
2422 | /** Syntax error - numeric overflow. */ | |
2423 | #define VERR_DBGC_PARSE_NUMBER_TOO_BIG (VERR_DBGC_PARSE_LOWEST + 11) | |
2424 | /** Syntax error - invalid operation attempted. */ | |
2425 | #define VERR_DBGC_PARSE_INVALID_OPERATION (VERR_DBGC_PARSE_LOWEST + 12) | |
2426 | /** Syntax error - function not found. */ | |
2427 | #define VERR_DBGC_PARSE_FUNCTION_NOT_FOUND (VERR_DBGC_PARSE_LOWEST + 13) | |
2428 | /** Syntax error - the specified function is not a function. */ | |
2429 | #define VERR_DBGC_PARSE_NOT_A_FUNCTION (VERR_DBGC_PARSE_LOWEST + 14) | |
2430 | /** Syntax error - out of scratch memory. */ | |
2431 | #define VERR_DBGC_PARSE_NO_SCRATCH (VERR_DBGC_PARSE_LOWEST + 15) | |
2432 | /** Syntax error - out of regular heap memory. */ | |
2433 | #define VERR_DBGC_PARSE_NO_MEMORY (VERR_DBGC_PARSE_LOWEST + 16) | |
2434 | /** Syntax error - incorrect argument type. */ | |
2435 | #define VERR_DBGC_PARSE_INCORRECT_ARG_TYPE (VERR_DBGC_PARSE_LOWEST + 17) | |
2436 | /** Syntax error - an undefined variable was referenced. */ | |
2437 | #define VERR_DBGC_PARSE_VARIABLE_NOT_FOUND (VERR_DBGC_PARSE_LOWEST + 18) | |
2438 | /** Syntax error - a type conversion failed. */ | |
2439 | #define VERR_DBGC_PARSE_CONVERSION_FAILED (VERR_DBGC_PARSE_LOWEST + 19) | |
2440 | /** Syntax error - you hit a debugger feature which isn't implemented yet. | |
2441 | * (Feel free to help implement it.) */ | |
2442 | #define VERR_DBGC_PARSE_NOT_IMPLEMENTED (VERR_DBGC_PARSE_LOWEST + 20) | |
2443 | /** Syntax error - Couldn't satisfy a request for a specific result type. */ | |
2444 | #define VERR_DBGC_PARSE_BAD_RESULT_TYPE (VERR_DBGC_PARSE_LOWEST + 21) | |
2445 | /** Syntax error - Cannot read symbol value, it is a set-only symbol. */ | |
2446 | #define VERR_DBGC_PARSE_WRITEONLY_SYMBOL (VERR_DBGC_PARSE_LOWEST + 22) | |
2447 | /** Syntax error - Invalid command name. */ | |
2448 | #define VERR_DBGC_PARSE_INVALD_COMMAND_NAME (VERR_DBGC_PARSE_LOWEST + 23) | |
2449 | /** Syntax error - Command not found. */ | |
2450 | #define VERR_DBGC_PARSE_COMMAND_NOT_FOUND (VERR_DBGC_PARSE_LOWEST + 24) | |
2451 | /** Syntax error - buggy parser. */ | |
2452 | #define VERR_DBGC_PARSE_BUG (VERR_DBGC_PARSE_LOWEST + 25) | |
2453 | /** @} */ | |
2454 | ||
2455 | ||
2456 | /** @name Support driver/library shared verification status codes. | |
2457 | * @{ */ | |
2458 | /** Process Verification Failure: The memory content does not match the image | |
2459 | * file. */ | |
2460 | #define VERR_SUP_VP_MEMORY_VS_FILE_MISMATCH (-5600) | |
2461 | /** Process Verification Failure: The memory protection of a image file section | |
2462 | * does not match what the section header prescribes. */ | |
2463 | #define VERR_SUP_VP_SECTION_PROTECTION_MISMATCH (-5601) | |
2464 | /** Process Verification Failure: One of the section in the image file is not | |
2465 | * mapped into memory. */ | |
2466 | #define VERR_SUP_VP_SECTION_NOT_MAPPED (-5602) | |
2467 | /** Process Verification Failure: One of the section in the image file is not | |
2468 | * fully mapped into memory. */ | |
2469 | #define VERR_SUP_VP_SECTION_NOT_FULLY_MAPPED (-5603) | |
2470 | /** Process Verification Failure: Bad file alignment value in image header. */ | |
2471 | #define VERR_SUP_VP_BAD_FILE_ALIGNMENT_VALUE (-5604) | |
2472 | /** Process Verification Failure: Bad image base in header. */ | |
2473 | #define VERR_SUP_VP_BAD_IMAGE_BASE (-5605) | |
2474 | /** Process Verification Failure: Bad image signature. */ | |
2475 | #define VERR_SUP_VP_BAD_IMAGE_SIGNATURE (-5606) | |
2476 | /** Process Verification Failure: Bad image size. */ | |
2477 | #define VERR_SUP_VP_BAD_IMAGE_SIZE (-5607) | |
2478 | /** Process Verification Failure: Bad new-header offset in the MZ header. */ | |
2479 | #define VERR_SUP_VP_BAD_MZ_OFFSET (-5608) | |
2480 | /** Process Verification Failure: Bad optional header field. */ | |
2481 | #define VERR_SUP_VP_BAD_OPTIONAL_HEADER (-5609) | |
2482 | /** Process Verification Failure: Bad section alignment value in image | |
2483 | * header. */ | |
2484 | #define VERR_SUP_VP_BAD_SECTION_ALIGNMENT_VALUE (-5610) | |
2485 | /** Process Verification Failure: Bad section raw data size. */ | |
2486 | #define VERR_SUP_VP_BAD_SECTION_FILE_SIZE (-5611) | |
2487 | /** Process Verification Failure: Bad virtual section address. */ | |
2488 | #define VERR_SUP_VP_BAD_SECTION_RVA (-5612) | |
2489 | /** Process Verification Failure: Bad virtual section size. */ | |
2490 | #define VERR_SUP_VP_BAD_SECTION_VIRTUAL_SIZE (-5613) | |
2491 | /** Process Verification Failure: Bad size of image header. */ | |
2492 | #define VERR_SUP_VP_BAD_SIZE_OF_HEADERS (-5614) | |
2493 | /** Process Verification Failure: The process is being debugged. */ | |
2494 | #define VERR_SUP_VP_DEBUGGED (-5615) | |
2495 | /** Process Verification Failure: A DLL was found more than once. */ | |
2496 | #define VERR_SUP_VP_DUPLICATE_DLL_MAPPING (-5616) | |
2497 | /** Process Verification Failure: Image section region is too large. */ | |
2498 | #define VERR_SUP_VP_EMPTY_REGION_TOO_LARGE (-5617) | |
2499 | /** Process Verification Failure: Executable file name and process image name | |
2500 | * does not match up. */ | |
2501 | #define VERR_SUP_VP_EXE_VS_PROC_NAME_MISMATCH (-5618) | |
2502 | /** Process Verification Failure: Found executable memory allocated in the | |
2503 | * process. There is only supposed be executable memory associated with | |
2504 | * image file mappings (DLLs & EXE). */ | |
2505 | #define VERR_SUP_VP_FOUND_EXEC_MEMORY (-5619) | |
2506 | /** Process Verification Failure: There is more than one known executable mapped | |
2507 | * into the process. */ | |
2508 | #define VERR_SUP_VP_FOUND_MORE_THAN_ONE_EXE_MAPPING (-5620) | |
2509 | /** Process Verification Failure: Error closing image file handle. */ | |
2510 | #define VERR_SUP_VP_IMAGE_FILE_CLOSE_ERROR (-5621) | |
2511 | /** Process Verification Failure: Error opening image file. */ | |
2512 | #define VERR_SUP_VP_IMAGE_FILE_OPEN_ERROR (-5622) | |
2513 | /** Process Verification Failure: Error reading image file header. */ | |
2514 | #define VERR_SUP_VP_IMAGE_HDR_READ_ERROR (-5623) | |
2515 | /** Process Verification Failure: Image mapping is bogus as the first region | |
2516 | * has different AllocationBase and BaseAddress values, indicating that a | |
2517 | * section was unmapped or otherwise tampered with. */ | |
2518 | #define VERR_SUP_VP_IMAGE_MAPPING_BASE_ERROR (-5624) | |
2519 | /** Process Verification Failure: Error reading process memory for comparing | |
2520 | * with disk data. */ | |
2521 | #define VERR_SUP_VP_MEMORY_READ_ERROR (-5625) | |
2522 | /** Process Verification Failure: Found no executable mapped into the process | |
2523 | * address space. */ | |
2524 | #define VERR_SUP_VP_NO_FOUND_NO_EXE_MAPPING (-5626) | |
2525 | /** Process Verification Failure: An image mapping failed to report a name. */ | |
2526 | #define VERR_SUP_VP_NO_IMAGE_MAPPING_NAME (-5627) | |
2527 | /** Process Verification Failure: No KERNE32.DLL mapping found. This is | |
2528 | * impossible. */ | |
2529 | #define VERR_SUP_VP_NO_KERNEL32_MAPPING (-5628) | |
2530 | /** Process Verification Failure: Error allocating memory. */ | |
2531 | #define VERR_SUP_VP_NO_MEMORY (-5629) | |
2532 | /** Process Verification Failure: Error allocating state memory or querying | |
2533 | * the system32 path. */ | |
2534 | #define VERR_SUP_VP_NO_MEMORY_STATE (-5630) | |
2535 | /** Process Verification Failure: No NTDLL.DLL mapping found. This is | |
2536 | * impossible. */ | |
2537 | #define VERR_SUP_VP_NO_NTDLL_MAPPING (-5631) | |
2538 | /** Process Verification Failure: A DLL residing outside System32 was found | |
2539 | * in the process. */ | |
2540 | #define VERR_SUP_VP_NON_SYSTEM32_DLL (-5632) | |
2541 | /** Process Verification Failure: An unknown and unwanted DLL was found loaded | |
2542 | * into the process. */ | |
2543 | #define VERR_SUP_VP_NOT_KNOWN_DLL_OR_EXE (-5633) | |
2544 | /** Process Verification Failure: The name of an image file changes between | |
2545 | * mapping regions. */ | |
2546 | #define VERR_SUP_VP_NT_MAPPING_NAME_CHANGED (-5634) | |
2547 | /** Process Verification Failure: Error querying process name. */ | |
2548 | #define VERR_SUP_VP_NT_QI_PROCESS_NM_ERROR (-5635) | |
2549 | /** Process Verification Failure: Error querying thread information. */ | |
2550 | #define VERR_SUP_VP_NT_QI_THREAD_ERROR (-5636) | |
2551 | /** Process Verification Failure: Error query virtual memory information. */ | |
2552 | #define VERR_SUP_VP_NT_QI_VIRTUAL_MEMORY_ERROR (-5637) | |
2553 | /** Process Verification Failure: Error query virtual memory mapping name. */ | |
2554 | #define VERR_SUP_VP_NT_QI_VIRTUAL_MEMORY_NM_ERROR (-5638) | |
2555 | /** Process Verification Failure: Error determining the full path of | |
2556 | * System32. */ | |
2557 | #define VERR_SUP_VP_SYSTEM32_PATH (-5639) | |
2558 | /** Process Verification Failure: The process has more than one thread. */ | |
2559 | #define VERR_SUP_VP_THREAD_NOT_ALONE (-5640) | |
2560 | /** Process Verification Failure: The image mapping is too large (>= 2GB). */ | |
2561 | #define VERR_SUP_VP_TOO_HIGH_REGION_RVA (-5641) | |
2562 | /** Process Verification Failure: The memory region is too large (>= 2GB). */ | |
2563 | #define VERR_SUP_VP_TOO_LARGE_REGION (-5642) | |
2564 | /** Process Verification Failure: There are too many DLLs loaded. */ | |
2565 | #define VERR_SUP_VP_TOO_MANY_DLLS_LOADED (-5643) | |
2566 | /** Process Verification Failure: An image has too many regions. */ | |
2567 | #define VERR_SUP_VP_TOO_MANY_IMAGE_REGIONS (-5644) | |
2568 | /** Process Verification Failure: The process has too many virtual memory | |
2569 | * regions. */ | |
2570 | #define VERR_SUP_VP_TOO_MANY_MEMORY_REGIONS (-5645) | |
2571 | /** Process Verification Failure: An image has too many sections. */ | |
2572 | #define VERR_SUP_VP_TOO_MANY_SECTIONS (-5646) | |
2573 | /** Process Verification Failure: An image is targeting an unexpected | |
2574 | * machine/CPU. */ | |
2575 | #define VERR_SUP_VP_UNEXPECTED_IMAGE_MACHINE (-5647) | |
2576 | /** Process Verification Failure: Unexpected section protection flag | |
2577 | * combination. */ | |
2578 | #define VERR_SUP_VP_UNEXPECTED_SECTION_FLAGS (-5648) | |
2579 | /** Process Verification Failure: Expected the process and exe to have forced | |
2580 | * integrity checking enabled (verifying signatures). */ | |
2581 | #define VERR_SUP_VP_EXE_MISSING_FORCE_INTEGRITY (-5649) | |
2582 | /** Process Verification Failure: Expected the process and exe to have dynamic | |
2583 | * base enabled. */ | |
2584 | #define VERR_SUP_VP_EXE_MISSING_DYNAMIC_BASE (-5650) | |
2585 | /** Process Verification Failure: Expected the process and exe to advertise | |
2586 | * NX compatibility. */ | |
2587 | #define VERR_SUP_VP_EXE_MISSING_NX_COMPAT (-5651) | |
2588 | /** Process Verification Failure: The DllCharacteristics of the process | |
2589 | * does not match the value in the optional header in the exe file. */ | |
2590 | #define VERR_SUP_VP_DLL_CHARECTERISTICS_MISMATCH (-5652) | |
2591 | /** Process Verification Failure: The ImageCharacteristics of the process | |
2592 | * does not match the value in the file header in the exe file. */ | |
2593 | #define VERR_SUP_VP_IMAGE_CHARECTERISTICS_MISMATCH (-5653) | |
2594 | /** Process Verification Failure: Error querying image information. */ | |
2595 | #define VERR_SUP_VP_NT_QI_PROCESS_IMG_INFO_ERROR (-5654) | |
2596 | /** Process Verification Failure: Error querying debug port. */ | |
2597 | #define VERR_SUP_VP_NT_QI_PROCESS_DBG_PORT_ERROR (-5655) | |
2598 | /** WinVerifyTrust failed with an unexpected status code when using the | |
2599 | * catalog-file approach. */ | |
2600 | #define VERR_SUP_VP_WINTRUST_CAT_FAILURE (-5656) | |
2601 | /** The image is required to be signed with the same certificate as the rest | |
2602 | * of VirtualBox. */ | |
2603 | #define VERR_SUP_VP_NOT_SIGNED_WITH_BUILD_CERT (-5657) | |
2604 | /** Internal processing error: Not build certificate. */ | |
2605 | #define VERR_SUP_VP_NOT_BUILD_CERT_IPE (-5658) | |
2606 | /** The image requires to be signed using the kernel-code signing process. */ | |
2607 | #define VERR_SUP_VP_NOT_VALID_KERNEL_CODE_SIGNATURE (-5659) | |
2608 | /** Unexpected number of valid paths. */ | |
2609 | #define VERR_SUP_VP_UNEXPECTED_VALID_PATH_COUNT (-5660) | |
2610 | /** The image is required to force integrity checks. */ | |
2611 | #define VERR_SUP_VP_SIGNATURE_CHECKS_NOT_ENFORCED (-5661) | |
2612 | /** Process Verification Failure: Symantec Endpoint Protection must be | |
2613 | * disabled for the VirtualBox VM processes. | |
2614 | * http://www.symantec.com/connect/articles/creating-application-control-exclusions-symantec-endpoint-protection-121 */ | |
2615 | #define VERR_SUP_VP_SYSFER_DLL (-5662) | |
2616 | /** Process Purification Failure: KERNE32.DLL already mapped into the initial | |
2617 | * process (suspended). */ | |
2618 | #define VERR_SUP_VP_KERNEL32_ALREADY_MAPPED (-5663) | |
2619 | /** Process Purification Failure: NtFreeVirtualMemory failed on a chunk of | |
2620 | * executable memory which shouldn't be present in the process. */ | |
2621 | #define VERR_SUP_VP_FREE_VIRTUAL_MEMORY_FAILED (-5664) | |
2622 | /** Process Purification Failure: Both NtUnmapViewOfSetion and | |
2623 | * NtProtectVirtualMemory failed to get rid of or passify an non-image | |
2624 | * executable mapping. */ | |
2625 | #define VERR_SUP_VP_UNMAP_AND_PROTECT_FAILED (-5665) | |
2626 | /** Process Purification Failure: Unknown memory type of executable memory. */ | |
2627 | #define VERR_SUP_VP_UNKOWN_MEM_TYPE (-5666) | |
2628 | /** The image file is not owned by TrustedInstaller is it should be. */ | |
2629 | #define VERR_SUP_VP_NOT_OWNED_BY_TRUSTED_INSTALLER (-5667) | |
2630 | /** The image is outside the expected range. */ | |
2631 | #define VERR_SUP_VP_IMAGE_TOO_BIG (-5668) | |
2632 | /** Stub process not found so it cannot be revalidated when vboxdrv is opened | |
2633 | * by the VM process. */ | |
2634 | #define VERR_SUP_VP_STUB_NOT_FOUND (-5669) | |
2635 | /** Error opening the stub process for revalidation when vboxdrv is opened by | |
2636 | * the VM process. */ | |
2637 | #define VERR_SUP_VP_STUB_OPEN_ERROR (-5670) | |
2638 | /** Stub process thread not found during revalidation upon vboxdrv opening by | |
2639 | * the VM process. */ | |
2640 | #define VERR_SUP_VP_STUB_THREAD_NOT_FOUND (-5671) | |
2641 | /** Error opening the stub process thread for revalidation when vboxdrv is | |
2642 | * opened by the VM process. */ | |
2643 | #define VERR_SUP_VP_STUB_THREAD_OPEN_ERROR (-5672) | |
2644 | /** Process Purification Failure: NtAllocateVirtualMemory failed to get us | |
2645 | * suitable replacement memory for a chunk of executable memory that | |
2646 | * shouldn't be present in our process. (You will only see this message if you | |
2647 | * got potentially fatally buggy anti-virus software installed.) */ | |
2648 | #define VERR_SUP_VP_REPLACE_VIRTUAL_MEMORY_FAILED (-5673) | |
2649 | /** Error getting the file mode. */ | |
2650 | #define VERR_SUP_VP_FILE_MODE_ERROR (-5674) | |
2651 | /** Error creating an event semaphore for used with asynchronous reads. */ | |
2652 | #define VERR_SUP_VP_CREATE_READ_EVT_SEM_FAILED (-5675) | |
2653 | ||
2654 | /** @} */ | |
2655 | ||
2656 | /** @name VBox Extension Pack Status Codes | |
2657 | * @{ | |
2658 | */ | |
2659 | /** The host is not supported. Uninstall the extension pack. | |
2660 | * Returned by the VBOXEXTPACKREG::pfnInstalled. */ | |
2661 | #define VERR_EXTPACK_UNSUPPORTED_HOST_UNINSTALL (-6000) | |
2662 | /** The VirtualBox version is not supported by one of the extension packs. | |
2663 | * | |
2664 | * You have probably upgraded VirtualBox recently. Please upgrade the | |
2665 | * extension packs to versions compatible with this VirtualBox release. | |
2666 | */ | |
2667 | #define VERR_EXTPACK_VBOX_VERSION_MISMATCH (-6001) | |
2668 | /** @} */ | |
2669 | ||
2670 | ||
2671 | /** @name VBox Guest Control Status Codes | |
2672 | * @{ | |
2673 | */ | |
2674 | /** Guest side reported an error. */ | |
2675 | #define VERR_GSTCTL_GUEST_ERROR (-6200) | |
2676 | /** A guest control object has changed its overall status. */ | |
2677 | #define VWRN_GSTCTL_OBJECTSTATE_CHANGED 6220 | |
2678 | /** Guest process is in a wrong state. */ | |
2679 | #define VERR_GSTCTL_PROCESS_WRONG_STATE (-6221) | |
2680 | /** Started guest process terminated with an exit code <> 0. */ | |
2681 | #define VWRN_GSTCTL_PROCESS_EXIT_CODE 6221 | |
2682 | /** @} */ | |
2683 | ||
2684 | ||
2685 | /** @name GIM Status Codes | |
2686 | * @{ | |
2687 | */ | |
2688 | /** No GIM provider is configured for this VM. */ | |
2689 | #define VERR_GIM_NOT_ENABLED (-6300) | |
2690 | /** GIM internal processing error \#1. */ | |
2691 | #define VERR_GIM_IPE_1 (-6301) | |
2692 | /** GIM internal processing error \#2. */ | |
2693 | #define VERR_GIM_IPE_2 (-6302) | |
2694 | /** GIM internal processing error \#3. */ | |
2695 | #define VERR_GIM_IPE_3 (-6303) | |
2696 | /** The GIM provider does not support any paravirtualized TSC. */ | |
2697 | #define VERR_GIM_PVTSC_NOT_AVAILABLE (-6304) | |
2698 | /** The guest has not setup use of the paravirtualized TSC. */ | |
2699 | #define VERR_GIM_PVTSC_NOT_ENABLED (-6305) | |
2700 | /** Unknown or invalid GIM provider. */ | |
2701 | #define VERR_GIM_INVALID_PROVIDER (-6306) | |
2702 | /** GIM generic operation failed. */ | |
2703 | #define VERR_GIM_OPERATION_FAILED (-6307) | |
2704 | /** The GIM provider does not support any hypercalls. */ | |
2705 | #define VERR_GIM_HYPERCALLS_NOT_AVAILABLE (-6308) | |
2706 | /** The guest has not setup use of the hypercalls. */ | |
2707 | #define VERR_GIM_HYPERCALLS_NOT_ENABLED (-6309) | |
2708 | /** The GIM device is not registered with GIM when it ought to be. */ | |
2709 | #define VERR_GIM_DEVICE_NOT_REGISTERED (-6310) | |
2710 | /** Hypercall cannot be enabled/performed due to access/permissions/CPL. */ | |
2711 | #define VERR_GIM_HYPERCALL_ACCESS_DENIED (-6311) | |
2712 | /** Failed to read to a memory region while performing a hypercall. */ | |
2713 | #define VERR_GIM_HYPERCALL_MEMORY_READ_FAILED (-6312) | |
2714 | /** Failed to write to a memory region while performing a hypercall. */ | |
2715 | #define VERR_GIM_HYPERCALL_MEMORY_WRITE_FAILED (-6313) | |
2716 | /** Generic hypercall operation failure. */ | |
2717 | #define VERR_GIM_HYPERCALL_FAILED (-6314) | |
2718 | /** No debug connection configured. */ | |
2719 | #define VERR_GIM_NO_DEBUG_CONNECTION (-6315) | |
2720 | /** Return to ring-3 to perform the hypercall there. */ | |
2721 | #define VINF_GIM_R3_HYPERCALL 6316 | |
2722 | /** Continuing hypercall at the same RIP, continue guest execution. */ | |
2723 | #define VINF_GIM_HYPERCALL_CONTINUING 6317 | |
2724 | /** Instruction that triggers the hypercall is invalid/unrecognized. */ | |
2725 | #define VERR_GIM_INVALID_HYPERCALL_INSTR (-6318) | |
2726 | /** @} */ | |
2727 | ||
2728 | ||
2729 | /** @name Main API Status Codes | |
2730 | * @{ | |
2731 | */ | |
2732 | /** The configuration constructor in main failed due to a COM error. Check | |
2733 | * the release log of the VM for further details. */ | |
2734 | #define VERR_MAIN_CONFIG_CONSTRUCTOR_COM_ERROR (-6400) | |
2735 | /** The configuration constructor in main failed due to an internal consistency | |
2736 | * error. Consult the release log of the VM for further details. */ | |
2737 | #define VERR_MAIN_CONFIG_CONSTRUCTOR_IPE (-6401) | |
2738 | /** @} */ | |
2739 | ||
2740 | ||
2741 | /** @name VBox Drag and Drop Status Codes | |
2742 | * @{ | |
2743 | */ | |
2744 | /** Guest side reported an error. */ | |
2745 | #define VERR_GSTDND_GUEST_ERROR (-6500) | |
2746 | /** @} */ | |
2747 | ||
2748 | ||
2749 | /** @name Audio Status Codes | |
2750 | * @{ | |
2751 | */ | |
2752 | /** Host backend couldn't be initialized. Happen if the audio server is not | |
2753 | * reachable, audio hardware is not available or similar. We should use the | |
2754 | * NULL audio driver. */ | |
2755 | #define VERR_AUDIO_BACKEND_INIT_FAILED (-6600) | |
2756 | /** No free input streams. */ | |
2757 | #define VERR_AUDIO_NO_FREE_INPUT_STREAMS (-6601) | |
2758 | /** No free output streams. */ | |
2759 | #define VERR_AUDIO_NO_FREE_OUTPUT_STREAMS (-6602) | |
2760 | /** Pending stream disable operation in progress. */ | |
2761 | #define VERR_AUDIO_STREAM_PENDING_DISABLE (-6603) | |
2762 | /** @} */ | |
2763 | ||
2764 | ||
2765 | /** @name APIC Status Codes | |
2766 | * @{ | |
2767 | */ | |
2768 | /** No pending interrupt. */ | |
2769 | #define VERR_APIC_INTR_NOT_PENDING (-6700) | |
2770 | /** Pending interrupt is masked by TPR. */ | |
2771 | #define VERR_APIC_INTR_MASKED_BY_TPR (-6701) | |
2772 | /** APIC did not accept the interrupt. */ | |
2773 | #define VERR_APIC_INTR_DISCARDED (-6702) | |
2774 | /** @} */ | |
2775 | ||
2776 | /* SED-END */ | |
2777 | ||
2778 | /** @} */ | |
2779 | ||
2780 | ||
2781 | #endif | |
2782 |