gem5
v21.0.1.0
systemc
tlm_bridge
sc_ext.cc
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2015, University of Kaiserslautern
3
* Copyright (c) 2016, Dresden University of Technology (TU Dresden)
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:
9
*
10
* 1. Redistributions of source code must retain the above copyright notice,
11
* this list of conditions and the following disclaimer.
12
*
13
* 2. Redistributions in binary form must reproduce the above copyright
14
* notice, this list of conditions and the following disclaimer in the
15
* documentation and/or other materials provided with the distribution.
16
*
17
* 3. Neither the name of the copyright holder nor the names of its
18
* contributors may be used to endorse or promote products derived from
19
* this software without specific prior written permission.
20
*
21
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
23
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
24
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER
25
* OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
26
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
27
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
28
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
29
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
30
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
31
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32
*/
33
34
#include "
systemc/tlm_bridge/sc_ext.hh
"
35
36
#include "
systemc/ext/utils/sc_report_handler.hh
"
37
38
namespace
Gem5SystemC
39
{
40
41
Gem5Extension::Gem5Extension
(
PacketPtr
_packet)
42
{
43
packet
= _packet;
44
}
45
46
Gem5Extension
&
47
Gem5Extension::getExtension
(
const
tlm::tlm_generic_payload
*payload)
48
{
49
Gem5Extension
*result = NULL;
50
payload->
get_extension
(result);
51
sc_assert
(result != NULL);
52
return
*result;
53
}
54
55
Gem5Extension
&
56
Gem5Extension::getExtension
(
const
tlm::tlm_generic_payload
&payload)
57
{
58
return
Gem5Extension::getExtension
(&payload);
59
}
60
61
PacketPtr
62
Gem5Extension::getPacket
()
63
{
64
return
packet
;
65
}
66
67
tlm::tlm_extension_base
*
68
Gem5Extension::clone
()
const
69
{
70
return
new
Gem5Extension
(
packet
);
71
}
72
73
void
74
Gem5Extension::copy_from
(
const
tlm::tlm_extension_base
&
ext
)
75
{
76
const
Gem5Extension
&cpyFrom =
static_cast<
const
Gem5Extension
&
>
(
ext
);
77
packet
= cpyFrom.
packet
;
78
}
79
80
}
// namespace Gem5SystemC
sc_ext.hh
Gem5SystemC::Gem5Extension::getPacket
PacketPtr getPacket()
Definition:
sc_ext.cc:62
sc_assert
#define sc_assert(expr)
Definition:
sc_report_handler.hh:135
Gem5SystemC::Gem5Extension::Gem5Extension
Gem5Extension(PacketPtr _packet)
Definition:
sc_ext.cc:41
Gem5SystemC
Definition:
sc_ext.cc:38
tlm::tlm_extension_base
Definition:
gp.hh:65
ArmISA::ext
Bitfield< 12 > ext
Definition:
miscregs_types.hh:422
Gem5SystemC::Gem5Extension::clone
virtual tlm_extension_base * clone() const
Definition:
sc_ext.cc:68
tlm::tlm_generic_payload::get_extension
void get_extension(T *&ext) const
Definition:
gp.hh:381
sc_report_handler.hh
tlm::tlm_generic_payload
Definition:
gp.hh:133
Gem5SystemC::Gem5Extension::getExtension
static Gem5Extension & getExtension(const tlm::tlm_generic_payload *payload)
Definition:
sc_ext.cc:47
Packet
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
Definition:
packet.hh:258
Gem5SystemC::Gem5Extension
Definition:
sc_ext.hh:43
Gem5SystemC::Gem5Extension::copy_from
virtual void copy_from(const tlm_extension_base &ext)
Definition:
sc_ext.cc:74
Gem5SystemC::Gem5Extension::packet
PacketPtr packet
Definition:
sc_ext.hh:58
Generated on Tue Jun 22 2021 15:28:33 for gem5 by
doxygen
1.8.17