gem5
[DEVELOP-FOR-23.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
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
q
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
y
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
l
m
n
o
p
r
s
t
u
v
w
Typedefs
a
b
c
d
g
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
systemc
tests
tlm
static_extensions
gp2ext
my_extension.h
Go to the documentation of this file.
1
/*****************************************************************************
2
3
Licensed to Accellera Systems Initiative Inc. (Accellera) under one or
4
more contributor license agreements. See the NOTICE file distributed
5
with this work for additional information regarding copyright ownership.
6
Accellera licenses this file to you under the Apache License, Version 2.0
7
(the "License"); you may not use this file except in compliance with the
8
License. You may obtain a copy of the License at
9
10
http://www.apache.org/licenses/LICENSE-2.0
11
12
Unless required by applicable law or agreed to in writing, software
13
distributed under the License is distributed on an "AS IS" BASIS,
14
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
15
implied. See the License for the specific language governing
16
permissions and limitations under the License.
17
18
*****************************************************************************/
19
20
#ifndef __MY_EXTENSION_H__
21
#define __MY_EXTENSION_H__
22
23
#include "tlm.h"
24
#include <cassert>
25
26
class
my_extension
:
27
public
tlm::tlm_extension
<my_extension>
28
{
29
public
:
30
my_extension
()
31
:
m_data
(0)
32
{}
33
tlm_extension_base*
clone
()
const
34
{
35
return
new
my_extension
(*
this
);
36
}
37
void
free
()
38
{
39
delete
this
;
40
}
41
void
copy_from
(tlm_extension_base
const
&
e
)
42
{
43
sc_assert
(
typeid
(
this
) ==
typeid
(
e
));
44
m_data
=
static_cast<
my_extension
const
&
>
(
e
).
m_data
;
45
}
46
47
int
m_data
;
48
};
49
50
struct
my_extended_payload_types
51
{
52
typedef
tlm::tlm_base_protocol_types::tlm_payload_type
tlm_payload_type
;
53
typedef
tlm::tlm_base_protocol_types::tlm_phase_type
tlm_phase_type
;
54
};
55
56
#endif
my_extended_payload_types::tlm_phase_type
tlm::tlm_base_protocol_types::tlm_phase_type tlm_phase_type
Definition:
my_extension.h:53
tlm::tlm_phase
Definition:
phase.hh:47
gem5::ArmISA::e
Bitfield< 9 > e
Definition:
misc_types.hh:65
sc_assert
#define sc_assert(expr)
Definition:
sc_report_handler.hh:135
my_extension::m_data
int m_data
Definition:
my_extension.h:64
my_extension::clone
tlm_extension_base * clone() const
Definition:
my_extension.h:50
tlm::tlm_generic_payload
Definition:
gp.hh:133
my_extension::my_extension
my_extension()
Definition:
my_extension.h:47
my_extension::copy_from
void copy_from(tlm_extension_base const &e)
Definition:
my_extension.h:58
tlm::tlm_extension
Definition:
gp.hh:83
my_extended_payload_types
Definition:
my_extension.h:50
my_extension::free
void free()
Definition:
my_extension.h:54
my_extended_payload_types::tlm_payload_type
tlm::tlm_base_protocol_types::tlm_payload_type tlm_payload_type
Definition:
my_extension.h:52
my_extension
Definition:
my_extension.h:26
Generated on Sun Jul 30 2023 01:57:03 for gem5 by
doxygen
1.8.17