VirtualBox

source: vbox/trunk/include/VBox/log.h@ 34054

Last change on this file since 34054 was 32536, checked in by vboxsync, 14 years ago

Storage/VBoxHDD: replace custom open flags with regular IPRT file open flags, introduce user-providable filesystem access interface, eliminate dependency on PGM geometry structure, change pvBuffer/cbBuffer parameter ordering to the usual conventions, eliminate the remains of the old I/O code, make more plugin methods optional to reduce redundancy, lots of cleanups

Storage/DrvVD+testcases,Main/Medium+Frontends: adapt to VBoxHDD changes, logging fixes

Storage/VDI+VMDK+DMG+Raw+VHD+Parallels+VCI: made as similar to each other as possible, added inline VFS wrappers to improve readability, full VFS support, VDI files are now 4K aligned, eliminate the remains of the old I/O code, various more or less severe bugfixes, code sort

Storage/iSCSI: support disks bigger than 2T, streamline the code to be more similar to the file-based backends, memory leak fix, error code usage like file-based backends, code sort

log+err: added new error codes/log groups and eliminated unused old ones

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 13.6 KB
Line 
1/** @file
2 * VirtualBox - Logging.
3 */
4
5/*
6 * Copyright (C) 2006-2007 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_log_h
27#define ___VBox_log_h
28
29/*
30 * Set the default loggroup.
31 */
32#ifndef LOG_GROUP
33# define LOG_GROUP LOG_GROUP_DEFAULT
34#endif
35
36#include <iprt/log.h>
37
38
39/** @defgroup grp_rt_vbox_log VirtualBox Logging
40 * @ingroup grp_rt_vbox
41 * @{
42 */
43
44/** PC port for debug output */
45#define RTLOG_DEBUG_PORT 0x504
46
47/**
48 * VirtualBox Logging Groups.
49 * (Remember to update LOGGROUP_NAMES!)
50 *
51 * @remark It should be pretty obvious, but just to have
52 * mentioned it, the values are sorted alphabetically (using the
53 * english alphabet) except for _DEFAULT which is always first.
54 *
55 * If anyone might be wondering what the alphabet looks like:
56 * A B C D E F G H I J K L M N O P Q R S T U V W X Y Z _
57 */
58typedef enum LOGGROUP
59{
60 /** The default VBox group. */
61 LOG_GROUP_DEFAULT = RTLOGGROUP_FIRST_USER,
62 /** CFGM group. */
63 LOG_GROUP_CFGM,
64 /** Core Dumper group. **/
65 LOG_GROUP_CORE_DUMPER,
66 /** CPUM group. */
67 LOG_GROUP_CPUM,
68 /** CSAM group. */
69 LOG_GROUP_CSAM,
70 /** Debug Console group. */
71 LOG_GROUP_DBGC,
72 /** DBGF group. */
73 LOG_GROUP_DBGF,
74 /** DBGF info group. */
75 LOG_GROUP_DBGF_INFO,
76 /** The debugger gui. */
77 LOG_GROUP_DBGG,
78 /** Generic Device group. */
79 LOG_GROUP_DEV,
80 /** ACPI Device group. */
81 LOG_GROUP_DEV_ACPI,
82 /** AHCI Device group. */
83 LOG_GROUP_DEV_AHCI,
84 /** APIC Device group. */
85 LOG_GROUP_DEV_APIC,
86 /** Audio Device group. */
87 LOG_GROUP_DEV_AUDIO,
88 /** BusLogic SCSI host adapter group. */
89 LOG_GROUP_DEV_BUSLOGIC,
90 /** DMA Controller group. */
91 LOG_GROUP_DEV_DMA,
92 /** Gigabit Ethernet Device group. */
93 LOG_GROUP_DEV_E1000,
94 /** Extensible Firmware Interface Device group. */
95 LOG_GROUP_DEV_EFI,
96 /** Floppy Controller Device group. */
97 LOG_GROUP_DEV_FDC,
98 /** High Precision Event Timer Device group. */
99 LOG_GROUP_DEV_HPET,
100 /** IDE Device group. */
101 LOG_GROUP_DEV_IDE,
102 /** The internal networking IP stack Device group. */
103 LOG_GROUP_DEV_INIP,
104 /** KeyBoard Controller Device group. */
105 LOG_GROUP_DEV_KBD,
106 /** Low Pin Count Device group. */
107 LOG_GROUP_DEV_LPC,
108 /** LsiLogic SCSI controller Device group. */
109 LOG_GROUP_DEV_LSILOGICSCSI,
110 /** NE2000 Device group. */
111 LOG_GROUP_DEV_NE2000,
112 /** Parallel Device group */
113 LOG_GROUP_DEV_PARALLEL,
114 /** PC Device group. */
115 LOG_GROUP_DEV_PC,
116 /** PC Architecture Device group. */
117 LOG_GROUP_DEV_PC_ARCH,
118 /** PC BIOS Device group. */
119 LOG_GROUP_DEV_PC_BIOS,
120 /** PCI Device group. */
121 LOG_GROUP_DEV_PCI,
122 /** PCNet Device group. */
123 LOG_GROUP_DEV_PCNET,
124 /** PIC Device group. */
125 LOG_GROUP_DEV_PIC,
126 /** PIT Device group. */
127 LOG_GROUP_DEV_PIT,
128 /** RTC Device group. */
129 LOG_GROUP_DEV_RTC,
130 /** Serial Device group */
131 LOG_GROUP_DEV_SERIAL,
132 /** System Management Controller Device group. */
133 LOG_GROUP_DEV_SMC,
134 /** USB Device group. */
135 LOG_GROUP_DEV_USB,
136 /** VGA Device group. */
137 LOG_GROUP_DEV_VGA,
138 /** Virtio PCI Device group. */
139 LOG_GROUP_DEV_VIRTIO,
140 /** Virtio Network Device group. */
141 LOG_GROUP_DEV_VIRTIO_NET,
142 /** VMM Device group. */
143 LOG_GROUP_DEV_VMM,
144 /** VMM Device group for backdoor logging. */
145 LOG_GROUP_DEV_VMM_BACKDOOR,
146 /** VMM Device group for logging guest backdoor logging to stderr. */
147 LOG_GROUP_DEV_VMM_STDERR,
148 /** Disassembler group. */
149 LOG_GROUP_DIS,
150 /** Generic driver group. */
151 LOG_GROUP_DRV,
152 /** ACPI driver group */
153 LOG_GROUP_DRV_ACPI,
154 /** Block driver group. */
155 LOG_GROUP_DRV_BLOCK,
156 /** Char driver group. */
157 LOG_GROUP_DRV_CHAR,
158 /** Disk integrity driver group. */
159 LOG_GROUP_DRV_DISK_INTEGRITY,
160 /** Floppy media driver group. */
161 LOG_GROUP_DRV_FLOPPY,
162 /** Host Base block driver group. */
163 LOG_GROUP_DRV_HOST_BASE,
164 /** Host DVD block driver group. */
165 LOG_GROUP_DRV_HOST_DVD,
166 /** Host floppy block driver group. */
167 LOG_GROUP_DRV_HOST_FLOPPY,
168 /** Host Parallel Driver group */
169 LOG_GROUP_DRV_HOST_PARALLEL,
170 /** Host Serial Driver Group */
171 LOG_GROUP_DRV_HOST_SERIAL,
172 /** The internal networking transport driver group. */
173 LOG_GROUP_DRV_INTNET,
174 /** ISO (CD/DVD) media driver group. */
175 LOG_GROUP_DRV_ISO,
176 /** Keyboard Queue driver group. */
177 LOG_GROUP_DRV_KBD_QUEUE,
178 /** lwIP IP stack driver group. */
179 LOG_GROUP_DRV_LWIP,
180 /** Mouse Queue driver group. */
181 LOG_GROUP_DRV_MOUSE_QUEUE,
182 /** Named Pipe stream driver group. */
183 LOG_GROUP_DRV_NAMEDPIPE,
184 /** NAT network transport driver group */
185 LOG_GROUP_DRV_NAT,
186 /** Raw image driver group */
187 LOG_GROUP_DRV_RAW_IMAGE,
188 /** SCSI driver group. */
189 LOG_GROUP_DRV_SCSI,
190 /** Host SCSI driver group. */
191 LOG_GROUP_DRV_SCSIHOST,
192 /** Async transport driver group */
193 LOG_GROUP_DRV_TRANSPORT_ASYNC,
194 /** TUN network transport driver group */
195 LOG_GROUP_DRV_TUN,
196 /** USB Proxy driver group. */
197 LOG_GROUP_DRV_USBPROXY,
198 /** VBoxHDD media driver group. */
199 LOG_GROUP_DRV_VBOXHDD,
200 /** VBox HDD container media driver group. */
201 LOG_GROUP_DRV_VD,
202 /** Virtual Switch transport driver group */
203 LOG_GROUP_DRV_VSWITCH,
204 /** VUSB driver group */
205 LOG_GROUP_DRV_VUSB,
206 /** EM group. */
207 LOG_GROUP_EM,
208 /** FTM group. */
209 LOG_GROUP_FTM,
210 /** GMM group. */
211 LOG_GROUP_GMM,
212 /** GUI group. */
213 LOG_GROUP_GUI,
214 /** GVMM group. */
215 LOG_GROUP_GVMM,
216 /** HGCM group */
217 LOG_GROUP_HGCM,
218 /** HWACCM group. */
219 LOG_GROUP_HWACCM,
220 /** IOM group. */
221 LOG_GROUP_IOM,
222 /** XPCOM IPC group. */
223 LOG_GROUP_IPC,
224 /** Main group. */
225 LOG_GROUP_MAIN,
226 /** Misc. group intended for external use only. */
227 LOG_GROUP_MISC,
228 /** MM group. */
229 LOG_GROUP_MM,
230 /** MM group. */
231 LOG_GROUP_MM_HEAP,
232 /** MM group. */
233 LOG_GROUP_MM_HYPER,
234 /** MM Hypervisor Heap group. */
235 LOG_GROUP_MM_HYPER_HEAP,
236 /** MM Physical/Ram group. */
237 LOG_GROUP_MM_PHYS,
238 /** MM Page pool group. */
239 LOG_GROUP_MM_POOL,
240 /** The NAT service group */
241 LOG_GROUP_NAT_SERVICE,
242 /** The network adaptor driver group. */
243 LOG_GROUP_NET_ADP_DRV,
244 /** The network filter driver group. */
245 LOG_GROUP_NET_FLT_DRV,
246 /** The common network service group */
247 LOG_GROUP_NET_SERVICE,
248 /** PATM group. */
249 LOG_GROUP_PATM,
250 /** PDM group. */
251 LOG_GROUP_PDM,
252 /** PDM Async completion group. */
253 LOG_GROUP_PDM_ASYNC_COMPLETION,
254 /** PDM Device group. */
255 LOG_GROUP_PDM_DEVICE,
256 /** PDM Driver group. */
257 LOG_GROUP_PDM_DRIVER,
258 /** PDM Loader group. */
259 LOG_GROUP_PDM_LDR,
260 /** PDM Loader group. */
261 LOG_GROUP_PDM_QUEUE,
262 /** PGM group. */
263 LOG_GROUP_PGM,
264 /** PGM dynamic mapping group. */
265 LOG_GROUP_PGM_DYNMAP,
266 /** PGM physical group. */
267 LOG_GROUP_PGM_PHYS,
268 /** PGM physical access group. */
269 LOG_GROUP_PGM_PHYS_ACCESS,
270 /** PGM shadow page pool group. */
271 LOG_GROUP_PGM_POOL,
272 /** PGM shared paging group. */
273 LOG_GROUP_PGM_SHARED,
274 /** REM group. */
275 LOG_GROUP_REM,
276 /** REM disassembly handler group. */
277 LOG_GROUP_REM_DISAS,
278 /** REM access handler group. */
279 LOG_GROUP_REM_HANDLER,
280 /** REM I/O port access group. */
281 LOG_GROUP_REM_IOPORT,
282 /** REM MMIO access group. */
283 LOG_GROUP_REM_MMIO,
284 /** REM Printf. */
285 LOG_GROUP_REM_PRINTF,
286 /** REM running group. */
287 LOG_GROUP_REM_RUN,
288 /** SELM group. */
289 LOG_GROUP_SELM,
290 /** Shared clipboard host service group. */
291 LOG_GROUP_SHARED_CLIPBOARD,
292 /** Chromium OpenGL host service group. */
293 LOG_GROUP_SHARED_CROPENGL,
294 /** Shared folders host service group. */
295 LOG_GROUP_SHARED_FOLDERS,
296 /** OpenGL host service group. */
297 LOG_GROUP_SHARED_OPENGL,
298 /** The internal networking service group. */
299 LOG_GROUP_SRV_INTNET,
300 /** SSM group. */
301 LOG_GROUP_SSM,
302 /** STAM group. */
303 LOG_GROUP_STAM,
304 /** SUP group. */
305 LOG_GROUP_SUP,
306 /** SUPport driver group. */
307 LOG_GROUP_SUP_DRV,
308 /** TM group. */
309 LOG_GROUP_TM,
310 /** TRPM group. */
311 LOG_GROUP_TRPM,
312 /** USB driver group. */
313 LOG_GROUP_USB_DRV,
314 /** USBFilter group. */
315 LOG_GROUP_USB_FILTER,
316 /** USB keyboard device group. */
317 LOG_GROUP_USB_KBD,
318 /** MSD USB device group. */
319 LOG_GROUP_USB_MSD,
320 /** Generic virtual disk layer. */
321 LOG_GROUP_VD,
322 /** iSCSI virtual disk backend. */
323 LOG_GROUP_VD_ISCSI,
324 /** Parallels HDD virtual disk backend. */
325 LOG_GROUP_VD_PARALLELS,
326 /** Raw virtual disk backend. */
327 LOG_GROUP_VD_RAW,
328 /** VDI virtual disk backend. */
329 LOG_GROUP_VD_VDI,
330 /** VHD virtual disk backend. */
331 LOG_GROUP_VD_VHD,
332 /** VMDK virtual disk backend. */
333 LOG_GROUP_VD_VMDK,
334 /** VM group. */
335 LOG_GROUP_VM,
336 /** VMM group. */
337 LOG_GROUP_VMM,
338 /** VRDP group */
339 LOG_GROUP_VRDP,
340 /** VSCSI group */
341 LOG_GROUP_VSCSI,
342 /** Webservice group. */
343 LOG_GROUP_WEBSERVICE
344 /* !!!ALPHABETICALLY!!! */
345} VBOX_LOGGROUP;
346
347
348/** @def VBOX_LOGGROUP_NAMES
349 * VirtualBox Logging group names.
350 *
351 * Must correspond 100% to LOGGROUP!
352 * Don't forget commas!
353 *
354 * @remark It should be pretty obvious, but just to have
355 * mentioned it, the values are sorted alphabetically (using the
356 * english alphabet) except for _DEFAULT which is always first.
357 *
358 * If anyone might be wondering what the alphabet looks like:
359 * a b c d e f g h i j k l m n o p q r s t u v w x y z
360 */
361#define VBOX_LOGGROUP_NAMES \
362{ \
363 RT_LOGGROUP_NAMES, \
364 "DEFAULT", \
365 "CFGM", \
366 "CORE_DUMPER", \
367 "CPUM", \
368 "CSAM", \
369 "DBGC", \
370 "DBGF", \
371 "DBGF_INFO", \
372 "DBGG", \
373 "DEV", \
374 "DEV_ACPI", \
375 "DEV_AHCI", \
376 "DEV_APIC", \
377 "DEV_AUDIO", \
378 "DEV_BUSLOGIC", \
379 "DEV_DMA", \
380 "DEV_E1000", \
381 "DEV_EFI", \
382 "DEV_FDC", \
383 "DEV_HPET", \
384 "DEV_IDE", \
385 "DEV_INIP", \
386 "DEV_KBD", \
387 "DEV_LPC", \
388 "DEV_LSILOGICSCSI", \
389 "DEV_NE2000", \
390 "DEV_PARALLEL", \
391 "DEV_PC", \
392 "DEV_PC_ARCH", \
393 "DEV_PC_BIOS", \
394 "DEV_PCI", \
395 "DEV_PCNET", \
396 "DEV_PIC", \
397 "DEV_PIT", \
398 "DEV_RTC", \
399 "DEV_SERIAL", \
400 "DEV_SMC", \
401 "DEV_USB", \
402 "DEV_VGA", \
403 "DEV_VIRTIO", \
404 "DEV_VIRTIO_NET", \
405 "DEV_VMM", \
406 "DEV_VMM_BACKDOOR", \
407 "DEV_VMM_STDERR",\
408 "DIS", \
409 "DRV", \
410 "DRV_ACPI", \
411 "DRV_BLOCK", \
412 "DRV_CHAR", \
413 "DRV_DISK_INTEGRITY", \
414 "DRV_FLOPPY", \
415 "DRV_HOST_BASE", \
416 "DRV_HOST_DVD", \
417 "DRV_HOST_FLOPPY", \
418 "DRV_HOST_PARALLEL", \
419 "DRV_HOST_SERIAL", \
420 "DRV_INTNET", \
421 "DRV_ISO", \
422 "DRV_KBD_QUEUE", \
423 "DRV_LWIP", \
424 "DRV_MOUSE_QUEUE", \
425 "DRV_NAMEDPIPE", \
426 "DRV_NAT", \
427 "DRV_RAW_IMAGE", \
428 "DRV_SCSI", \
429 "DRV_SCSIHOST", \
430 "DRV_TRANSPORT_ASYNC", \
431 "DRV_TUN", \
432 "DRV_USBPROXY", \
433 "DRV_VBOXHDD", \
434 "DRV_VD", \
435 "DRV_VSWITCH", \
436 "DRV_VUSB", \
437 "EM", \
438 "FTM", \
439 "GMM", \
440 "GUI", \
441 "GVMM", \
442 "HGCM", \
443 "HWACCM", \
444 "IOM", \
445 "IPC", \
446 "MAIN", \
447 "MISC", \
448 "MM", \
449 "MM_HEAP", \
450 "MM_HYPER", \
451 "MM_HYPER_HEAP",\
452 "MM_PHYS", \
453 "MM_POOL", \
454 "NAT_SERVICE", \
455 "NET_ADP_DRV", \
456 "NET_FLT_DRV", \
457 "NET_SERVICE", \
458 "PATM", \
459 "PDM", \
460 "PDM_ASYNC_COMPLETION", \
461 "PDM_DEVICE", \
462 "PDM_DRIVER", \
463 "PDM_LDR", \
464 "PDM_QUEUE", \
465 "PGM", \
466 "PGM_DYNMAP", \
467 "PGM_PHYS", \
468 "PGM_PHYS_ACCESS",\
469 "PGM_POOL", \
470 "PGM_SHARED", \
471 "REM", \
472 "REM_DISAS", \
473 "REM_HANDLER", \
474 "REM_IOPORT", \
475 "REM_MMIO", \
476 "REM_PRINTF", \
477 "REM_RUN", \
478 "SELM", \
479 "SHARED_CLIPBOARD",\
480 "SHARED_CROPENGL",\
481 "SHARED_FOLDERS",\
482 "SHARED_OPENGL",\
483 "SRV_INTNET", \
484 "SSM", \
485 "STAM", \
486 "SUP", \
487 "SUP_DRV", \
488 "TM", \
489 "TRPM", \
490 "USB_DRV", \
491 "USB_FILTER", \
492 "USB_KBD", \
493 "USB_MSD", \
494 "VD", \
495 "VD_ISCSI", \
496 "VD_PARALLELS", \
497 "VD_RAW", \
498 "VD_VDI", \
499 "VD_VHD", \
500 "VD_VMDK", \
501 "VM", \
502 "VMM", \
503 "VRDP", \
504 "VSCSI", \
505 "WEBSERVICE", \
506}
507
508/** @} */
509#endif
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette