VirtualBox

source: vbox/trunk/src/VBox/VMM/VMMR3/DBGFLog.cpp@ 80239

Last change on this file since 80239 was 80191, checked in by vboxsync, 5 years ago

VMM/r3: Refactored VMCPU enumeration in preparation that aCpus will be replaced with a pointer array. Removed two raw-mode offset members from the CPUM and CPUMCPU sub-structures. bugref:9217 bugref:9517

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id Revision
File size: 6.2 KB
Line 
1/* $Id: DBGFLog.cpp 80191 2019-08-08 00:36:57Z vboxsync $ */
2/** @file
3 * DBGF - Debugger Facility, Log Manager.
4 */
5
6/*
7 * Copyright (C) 2006-2019 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17
18
19/*********************************************************************************************************************************
20* Header Files *
21*********************************************************************************************************************************/
22#define VBOX_BUGREF_9217_PART_I
23#define LOG_GROUP LOG_GROUP_DBGF
24#include <VBox/vmm/vmapi.h>
25#include <VBox/vmm/vmm.h>
26#include <VBox/vmm/dbgf.h>
27#include <VBox/vmm/uvm.h>
28#include <VBox/vmm/vm.h>
29#include <VBox/log.h>
30#include <VBox/err.h>
31#include <iprt/assert.h>
32#include <iprt/param.h>
33#include <iprt/string.h>
34
35
36/**
37 * Checkes for logger prefixes and selects the right logger.
38 *
39 * @returns Target logger.
40 * @param ppsz Pointer to the string pointer.
41 */
42static PRTLOGGER dbgfR3LogResolvedLogger(const char **ppsz)
43{
44 PRTLOGGER pLogger;
45 const char *psz = *ppsz;
46 if (!strncmp(psz, RT_STR_TUPLE("release:")))
47 {
48 *ppsz += sizeof("release:") - 1;
49 pLogger = RTLogRelGetDefaultInstance();
50 }
51 else
52 {
53 if (!strncmp(psz, RT_STR_TUPLE("debug:")))
54 *ppsz += sizeof("debug:") - 1;
55 pLogger = RTLogDefaultInstance();
56 }
57 return pLogger;
58}
59
60
61/**
62 * EMT worker for DBGFR3LogModifyGroups.
63 *
64 * @returns VBox status code.
65 * @param pUVM The user mode VM handle.
66 * @param pszGroupSettings The group settings string. (VBOX_LOG)
67 */
68static DECLCALLBACK(int) dbgfR3LogModifyGroups(PUVM pUVM, const char *pszGroupSettings)
69{
70 PRTLOGGER pLogger = dbgfR3LogResolvedLogger(&pszGroupSettings);
71 if (!pLogger)
72 return VINF_SUCCESS;
73
74 int rc = RTLogGroupSettings(pLogger, pszGroupSettings);
75 if (RT_SUCCESS(rc) && pUVM->pVM)
76 {
77 VM_ASSERT_VALID_EXT_RETURN(pUVM->pVM, VERR_INVALID_VM_HANDLE);
78 rc = VMMR3UpdateLoggers(pUVM->pVM);
79 }
80 return rc;
81}
82
83
84/**
85 * Changes the logger group settings.
86 *
87 * @returns VBox status code.
88 * @param pUVM The user mode VM handle.
89 * @param pszGroupSettings The group settings string. (VBOX_LOG)
90 * By prefixing the string with \"release:\" the
91 * changes will be applied to the release log
92 * instead of the debug log. The prefix \"debug:\"
93 * is also recognized.
94 */
95VMMR3DECL(int) DBGFR3LogModifyGroups(PUVM pUVM, const char *pszGroupSettings)
96{
97 UVM_ASSERT_VALID_EXT_RETURN(pUVM, VERR_INVALID_VM_HANDLE);
98 AssertPtrReturn(pszGroupSettings, VERR_INVALID_POINTER);
99
100 return VMR3ReqPriorityCallWaitU(pUVM, VMCPUID_ANY, (PFNRT)dbgfR3LogModifyGroups, 2, pUVM, pszGroupSettings);
101}
102
103
104/**
105 * EMT worker for DBGFR3LogModifyFlags.
106 *
107 * @returns VBox status code.
108 * @param pUVM The user mode VM handle.
109 * @param pszFlagSettings The group settings string. (VBOX_LOG_FLAGS)
110 */
111static DECLCALLBACK(int) dbgfR3LogModifyFlags(PUVM pUVM, const char *pszFlagSettings)
112{
113 PRTLOGGER pLogger = dbgfR3LogResolvedLogger(&pszFlagSettings);
114 if (!pLogger)
115 return VINF_SUCCESS;
116
117 int rc = RTLogFlags(pLogger, pszFlagSettings);
118 if (RT_SUCCESS(rc) && pUVM->pVM)
119 {
120 VM_ASSERT_VALID_EXT_RETURN(pUVM->pVM, VERR_INVALID_VM_HANDLE);
121 rc = VMMR3UpdateLoggers(pUVM->pVM);
122 }
123 return rc;
124}
125
126
127/**
128 * Changes the logger flag settings.
129 *
130 * @returns VBox status code.
131 * @param pUVM The user mode VM handle.
132 * @param pszFlagSettings The group settings string. (VBOX_LOG_FLAGS)
133 * By prefixing the string with \"release:\" the
134 * changes will be applied to the release log
135 * instead of the debug log. The prefix \"debug:\"
136 * is also recognized.
137 */
138VMMR3DECL(int) DBGFR3LogModifyFlags(PUVM pUVM, const char *pszFlagSettings)
139{
140 UVM_ASSERT_VALID_EXT_RETURN(pUVM, VERR_INVALID_VM_HANDLE);
141 AssertPtrReturn(pszFlagSettings, VERR_INVALID_POINTER);
142
143 return VMR3ReqPriorityCallWaitU(pUVM, VMCPUID_ANY, (PFNRT)dbgfR3LogModifyFlags, 2, pUVM, pszFlagSettings);
144}
145
146
147/**
148 * EMT worker for DBGFR3LogModifyFlags.
149 *
150 * @returns VBox status code.
151 * @param pUVM The user mode VM handle.
152 * @param pszDestSettings The destination settings string. (VBOX_LOG_DEST)
153 */
154static DECLCALLBACK(int) dbgfR3LogModifyDestinations(PUVM pUVM, const char *pszDestSettings)
155{
156 PRTLOGGER pLogger = dbgfR3LogResolvedLogger(&pszDestSettings);
157 if (!pLogger)
158 return VINF_SUCCESS;
159
160 int rc = RTLogDestinations(NULL, pszDestSettings);
161 if (RT_SUCCESS(rc) && pUVM->pVM)
162 {
163 VM_ASSERT_VALID_EXT_RETURN(pUVM->pVM, VERR_INVALID_VM_HANDLE);
164 rc = VMMR3UpdateLoggers(pUVM->pVM);
165 }
166 return rc;
167}
168
169
170/**
171 * Changes the logger destination settings.
172 *
173 * @returns VBox status code.
174 * @param pUVM The user mode VM handle.
175 * @param pszDestSettings The destination settings string. (VBOX_LOG_DEST)
176 * By prefixing the string with \"release:\" the
177 * changes will be applied to the release log
178 * instead of the debug log. The prefix \"debug:\"
179 * is also recognized.
180 */
181VMMR3DECL(int) DBGFR3LogModifyDestinations(PUVM pUVM, const char *pszDestSettings)
182{
183 UVM_ASSERT_VALID_EXT_RETURN(pUVM, VERR_INVALID_VM_HANDLE);
184 AssertPtrReturn(pszDestSettings, VERR_INVALID_POINTER);
185
186 return VMR3ReqPriorityCallWaitU(pUVM, VMCPUID_ANY, (PFNRT)dbgfR3LogModifyDestinations, 2, pUVM, pszDestSettings);
187}
188
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