gem5
v21.2.1.1
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
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
l
m
n
o
p
r
s
t
u
v
w
x
Enumerations
_
a
b
c
d
e
f
g
h
i
k
l
m
o
p
q
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
k
l
m
n
o
p
q
r
s
t
u
v
w
x
Functions
a
b
c
d
e
f
g
h
i
l
m
n
o
p
s
t
v
Variables
a
b
c
d
e
f
g
h
i
m
n
o
p
r
s
t
v
w
Typedefs
a
b
c
d
h
i
l
m
r
s
t
u
w
Enumerations
b
h
i
o
p
Enumerator
h
i
o
Macros
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
•
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Modules
Pages
base
match.cc
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2019 The Regents of the University of California
3
* Copyright (c) 2004-2005 The Regents of The University of Michigan
4
* All rights reserved.
5
*
6
* Redistribution and use in source and binary forms, with or without
7
* modification, are permitted provided that the following conditions are
8
* met: redistributions of source code must retain the above copyright
9
* notice, this list of conditions and the following disclaimer;
10
* redistributions in binary form must reproduce the above copyright
11
* notice, this list of conditions and the following disclaimer in the
12
* documentation and/or other materials provided with the distribution;
13
* neither the name of the copyright holders nor the names of its
14
* contributors may be used to endorse or promote products derived from
15
* this software without specific prior written permission.
16
*
17
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28
*/
29
30
#include "
base/match.hh
"
31
32
#include "
base/str.hh
"
33
34
namespace
gem5
35
{
36
37
ObjectMatch::ObjectMatch
()
38
{
39
}
40
41
ObjectMatch::ObjectMatch
(
const
std::string &expr)
42
{
43
setExpression
(expr);
44
}
45
46
void
47
ObjectMatch::add
(
const
ObjectMatch
&other)
48
{
49
tokens
.insert(
tokens
.end(), other.
tokens
.begin(), other.
tokens
.end());
50
}
51
52
void
53
ObjectMatch::setExpression
(
const
std::string &expr)
54
{
55
tokens
.resize(1);
56
tokenize
(
tokens
[0], expr,
'.'
);
57
}
58
59
void
60
ObjectMatch::setExpression
(
const
std::vector<std::string>
&expr)
61
{
62
if
(expr.empty()) {
63
tokens
.resize(0);
64
}
else
{
65
tokens
.resize(expr.size());
66
for
(
std::vector<std::string>::size_type
i
= 0;
i
< expr.size(); ++
i
)
67
tokenize
(
tokens
[
i
], expr[
i
],
'.'
);
68
}
69
}
70
75
bool
76
ObjectMatch::domatch
(
const
std::string &
name
)
const
77
{
78
std::vector<std::string>
name_tokens;
79
tokenize
(name_tokens,
name
,
'.'
);
80
int
ntsize = name_tokens.size();
81
82
int
num_expr =
tokens
.size();
83
for
(
int
i
= 0;
i
< num_expr; ++
i
) {
84
const
std::vector<std::string>
&
token
=
tokens
[
i
];
85
int
jstop =
token
.size();
86
87
bool
match
=
true
;
88
for
(
int
j
= 0;
j
< jstop; ++
j
) {
89
if
(
j
>= ntsize)
90
break
;
91
92
const
std::string &var =
token
[
j
];
93
if
(var !=
"*"
&& var != name_tokens[
j
]) {
94
match
=
false
;
95
break
;
96
}
97
}
98
99
if
(
match
)
100
return
true
;
101
}
102
103
return
false
;
104
}
105
106
std::vector<std::vector<std::string>
>
107
ObjectMatch::getExpressions
()
108
{
109
std::vector<std::vector<std::string>
> to_return;
110
for
(
const
auto
&expression:
tokens
) {
111
std::vector<std::string>
to_add;
112
to_add.insert(to_add.end(), expression.begin(), expression.end());
113
to_return.push_back(to_add);
114
}
115
116
return
to_return;
117
}
118
119
}
// namespace gem5
gem5::ObjectMatch
ObjectMatch contains a vector of expressions.
Definition:
match.hh:56
gem5::ObjectMatch::match
bool match(const std::string &name) const
Definition:
match.hh:69
gem5::ObjectMatch::domatch
bool domatch(const std::string &name) const
Definition:
match.cc:76
gem5::ObjectMatch::getExpressions
std::vector< std::vector< std::string > > getExpressions()
Definition:
match.cc:107
gem5::ObjectMatch::tokens
std::vector< std::vector< std::string > > tokens
Definition:
match.hh:59
std::vector< std::string >
gem5::ArmISA::i
Bitfield< 7 > i
Definition:
misc_types.hh:67
gem5::scmi::token
token
Definition:
scmi_platform.hh:81
str.hh
gem5::ArmISA::j
Bitfield< 24 > j
Definition:
misc_types.hh:57
match.hh
gem5::ObjectMatch::ObjectMatch
ObjectMatch()
Definition:
match.cc:37
gem5::tokenize
void tokenize(std::vector< std::string > &v, const std::string &s, char token, bool ignore)
Definition:
str.cc:68
gem5::ObjectMatch::setExpression
void setExpression(const std::string &expression)
Definition:
match.cc:53
name
const std::string & name()
Definition:
trace.cc:49
gem5
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Definition:
tlb.cc:60
gem5::ObjectMatch::add
void add(const ObjectMatch &other)
Definition:
match.cc:47
Generated on Wed May 4 2022 12:13:52 for gem5 by
doxygen
1.8.17