gem5
v21.0.1.0
Main Page
Related Pages
Modules
Namespaces
Namespace List
Namespace Members
All
_
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
Functions
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
Variables
_
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
Typedefs
a
c
d
e
f
g
h
i
m
n
o
p
r
s
t
u
v
w
x
Enumerations
a
c
d
e
f
i
l
m
o
p
r
s
t
v
x
Enumerator
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
Classes
Class List
Class Index
Class Hierarchy
Class Members
All
:
_
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
~
Functions
_
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
~
Variables
_
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
Typedefs
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
y
Enumerations
a
b
c
d
e
f
g
h
i
l
m
n
o
p
r
s
t
u
w
Enumerator
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
Related Functions
:
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
Files
File List
File Members
All
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
Functions
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
z
Variables
_
a
b
c
d
e
f
g
h
i
j
l
m
n
o
p
r
s
t
u
v
Typedefs
_
a
b
c
d
e
f
g
h
i
l
m
n
o
p
q
r
s
t
u
v
w
Enumerations
_
a
b
c
d
e
f
g
h
i
l
m
o
p
q
r
s
t
v
Enumerator
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
Macros
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
•
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Modules
Pages
base
logging.cc
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2014, 2017 ARM Limited
3
* All rights reserved
4
*
5
* The license below extends only to copyright in the software and shall
6
* not be construed as granting a license to any other intellectual
7
* property including but not limited to intellectual property relating
8
* to a hardware implementation of the functionality of the software
9
* licensed hereunder. You may use the software subject to the license
10
* terms below provided that you ensure that this notice is replicated
11
* unmodified and in its entirety in all distributions of the software,
12
* modified or unmodified, in source code or in binary form.
13
*
14
* Copyright (c) 2002-2005 The Regents of The University of Michigan
15
* All rights reserved.
16
*
17
* Redistribution and use in source and binary forms, with or without
18
* modification, are permitted provided that the following conditions are
19
* met: redistributions of source code must retain the above copyright
20
* notice, this list of conditions and the following disclaimer;
21
* redistributions in binary form must reproduce the above copyright
22
* notice, this list of conditions and the following disclaimer in the
23
* documentation and/or other materials provided with the distribution;
24
* neither the name of the copyright holders nor the names of its
25
* contributors may be used to endorse or promote products derived from
26
* this software without specific prior written permission.
27
*
28
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
29
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
30
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
31
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
32
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
33
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
34
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
35
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
36
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
37
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
38
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
39
*/
40
41
#include "
base/logging.hh
"
42
43
#include <sstream>
44
45
#include "
base/hostinfo.hh
"
46
47
namespace
{
48
49
class
NormalLogger :
public
Logger
50
{
51
public
:
52
using
Logger::Logger
;
53
54
protected
:
55
void
log
(
const
Loc &loc, std::string
s
)
override
{ std::cerr <<
s
; }
56
};
57
58
class
ExitLogger :
public
NormalLogger
59
{
60
public
:
61
using
NormalLogger::NormalLogger;
62
63
protected
:
64
void
65
log(
const
Loc &loc, std::string
s
)
override
66
{
67
std::stringstream
ss
;
68
ccprintf
(
ss
,
"Memory Usage: %ld KBytes\n"
,
memUsage
());
69
NormalLogger::log(loc,
s
+
ss
.str());
70
}
71
};
72
73
class
FatalLogger :
public
ExitLogger
74
{
75
public
:
76
using
ExitLogger::ExitLogger;
77
78
protected
:
79
void
exit
()
override
{
::exit
(1); }
80
};
81
82
ExitLogger panicLogger(
"panic: "
);
83
FatalLogger fatalLogger(
"fatal: "
);
84
NormalLogger warnLogger(
"warn: "
);
85
NormalLogger infoLogger(
"info: "
);
86
NormalLogger hackLogger(
"hack: "
);
87
88
}
// anonymous namespace
89
90
Logger
&
Logger::getPanic
() {
return
panicLogger; }
91
Logger
&
Logger::getFatal
() {
return
fatalLogger; }
92
Logger
&
Logger::getWarn
() {
return
warnLogger; }
93
Logger
&
Logger::getInfo
() {
return
infoLogger; }
94
Logger
&
Logger::getHack
() {
return
hackLogger; }
X86ISA::exit
Bitfield< 3 > exit
Definition:
misc.hh:848
Logger::log
virtual void log(const Loc &loc, std::string s)=0
Logger::Logger
Logger(const char *prefix)
Definition:
logging.hh:86
Logger::getPanic
static Logger & getPanic()
Get a Logger for the specified type of message.
Definition:
logging.cc:78
ArmISA::ss
Bitfield< 21 > ss
Definition:
miscregs_types.hh:56
hostinfo.hh
Logger::getFatal
static Logger & getFatal()
Definition:
logging.cc:79
Logger::getInfo
static Logger & getInfo()
Definition:
logging.cc:81
ccprintf
void ccprintf(cp::Print &print)
Definition:
cprintf.hh:127
Logger
Definition:
logging.hh:51
logging.hh
memUsage
uint64_t memUsage()
Determine the simulator process' total virtual memory usage.
Definition:
hostinfo.cc:73
ArmISA::s
Bitfield< 4 > s
Definition:
miscregs_types.hh:556
Logger::getWarn
static Logger & getWarn()
Definition:
logging.cc:80
Logger::getHack
static Logger & getHack()
Definition:
logging.cc:82
Generated on Tue Jun 22 2021 15:28:25 for gem5 by
doxygen
1.8.17