ipxact-ruby 0.11.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/.autotest +15 -0
- data/.gitignore +2 -0
- data/README.html +89 -0
- data/README.mdown +91 -0
- data/Rakefile +31 -0
- data/VERSION +1 -0
- data/autotest/discover.rb +17 -0
- data/lib/ipxact.rb +263 -0
- data/lib/ipxact/component.rb +235 -0
- data/lib/ipxact/parser.rb +27 -0
- data/lib/ipxact/parser/bus_data_parser.rb +229 -0
- data/lib/ipxact/parser/component_data_parser.rb +309 -0
- data/lib/ipxact/parser/platform_data_parser.rb +63 -0
- data/lib/ipxact/pathfinder/graph_pathfinder.rb +191 -0
- data/lib/ipxact/platform.rb +43 -0
- data/schemas/abstractionDefinition.xsd +332 -0
- data/schemas/abstractor.xsd +156 -0
- data/schemas/autoConfigure.xsd +226 -0
- data/schemas/busDefinition.xsd +99 -0
- data/schemas/busInterface.xsd +640 -0
- data/schemas/commonStructures.xsd +189 -0
- data/schemas/component.xsd +253 -0
- data/schemas/configurable.xsd +82 -0
- data/schemas/constraints.xsd +283 -0
- data/schemas/design.xsd +105 -0
- data/schemas/designConfig.xsd +144 -0
- data/schemas/file.xsd +560 -0
- data/schemas/fileType.xsd +86 -0
- data/schemas/generator.xsd +240 -0
- data/schemas/identifier.xsd +93 -0
- data/schemas/index.xsd +67 -0
- data/schemas/memoryMap.xsd +1007 -0
- data/schemas/model.xsd +291 -0
- data/schemas/port.xsd +441 -0
- data/schemas/signalDrivers.xsd +220 -0
- data/schemas/simpleTypes.xsd +90 -0
- data/schemas/subInstances.xsd +256 -0
- data/spec/integration/bus_data_extraction_spec.rb +105 -0
- data/spec/integration/data_calculation_spec.rb +133 -0
- data/spec/integration/data_construction_spec.rb +52 -0
- data/spec/integration/general_spec.rb +121 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/PV/pv_initiator_port.h +135 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/PV/pv_initiator_port.tpp +247 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/PV/pv_initiator_port_base.h +189 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/PV/pv_router.h +205 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/PV/pv_router.tpp +278 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/PV/pv_slave_base.h +115 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/PV/pv_slave_base.tpp +126 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/PV/pv_target_port.h +168 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/PV/pv_target_port_base.h +133 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/PV/pv_tlm_if.h +280 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/PV/user_types.h +38 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM1/Leon2Platform/Leon2Platform.xml +77 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM1/Leon2Platform/design_Leon2Platform.xml +156 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM1/Leon2Platform/tlmsrc/Leon2Platform.h +149 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM1/apbSubSystem/apbSubSystem.xml +406 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM1/apbSubSystem/design_apbSubSystem.xml +135 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM1/apbSubSystem/tlmsrc/apbSubSystem.h +133 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM2/Leon2Platform/Leon2Platform.xml +77 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM2/Leon2Platform/design_Leon2Platform.xml +157 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM2/Leon2Platform/tlmsrc/Leon2Platform.h +150 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM2/apbSubSystem/apbSubSystem.xml +422 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM2/apbSubSystem/designConfig_apbSubSystem.xml +79 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM2/apbSubSystem/design_apbSubSystem.xml +184 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM2/apbSubSystem/tlmsrc/apbSubSystem.h +164 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM3/Leon2Platform/Leon2Platform.xml +105 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM3/Leon2Platform/design_Leon2Platform.xml +157 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM3/Leon2Platform/tlmsrc/Leon2Platform.h +152 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM3/apbSubSystem/apbSubSystem.xml +429 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM3/apbSubSystem/designConfig_apbSubSystem.xml +64 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM3/apbSubSystem/design_apbSubSystem.xml +150 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/SystemTLM3/apbSubSystem/tlmsrc/apbSubSystem.h +167 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/ahbbus/1.4/ahbbus22.xml +236 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/ahbbus/1.4/tlmsrc/ahbbus.h +52 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/ahbram/1.4/ahbram.xml +184 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/ahbram/1.4/tlmsrc/ahbram.cc +93 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/ahbram/1.4/tlmsrc/ahbram.h +77 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/apbbus/1.4/apbbus8.xml +544 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/apbbus/1.4/tlmsrc/apbbus.h +55 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/apbmst/1.4/apbmst.xml +209 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/apbmst/1.4/tlmsrc/apbmst.h +53 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/apbram/1.0/apbram.xml +395 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/apbram/1.0/hdlsrc/apbram.cc +89 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/apbram/1.0/hdlsrc/apbram.h +69 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/apbram/1.0/hdlsrc/apbram.v +82 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/apbram/1.0/hdlsrc/apbram.vhd +132 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/cgu/1.4/cgu.xml +686 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/cgu/1.4/tlmsrc/cgu.cc +121 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/cgu/1.4/tlmsrc/cgu.h +81 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/cgu/1.5/cgu.xml +707 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/cgu/1.5/tlmsrc/cgu.cc +121 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/cgu/1.5/tlmsrc/cgu.h +81 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/dma/1.4/dma.xml +272 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/dma/1.4/tlmsrc/dma.cc +230 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/dma/1.4/tlmsrc/dma.h +116 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/irqctrl/1.4/irqctrl.xml +530 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/irqctrl/1.4/tlmsrc/irqctrl.cc +211 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/irqctrl/1.4/tlmsrc/irqctrl.h +108 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/processor/1.4/processor.xml +423 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/processor/1.4/tlmsrc/processor.cc +331 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/processor/1.4/tlmsrc/processor.h +121 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/pv2apb/1.0/pv2apb.xml +240 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/pv2apb/1.0/tlmsrc/pv2apb.cc +153 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/pv2apb/1.0/tlmsrc/pv2apb.h +77 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/pv2tac/1.0/pv2tac.xml +154 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/pv2tac/1.0/tlmsrc/pv2tac.cc +114 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/pv2tac/1.0/tlmsrc/pv2tac.h +67 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/rgu/1.4/rgu.xml +766 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/rgu/1.4/tlmsrc/rgu.cc +126 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/rgu/1.4/tlmsrc/rgu.h +105 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/scmlAdaptor/1.0/scmlAdaptor.xml +154 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/scmlAdaptor/1.0/tlmsrc/scmladaptor.cc +100 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/scmlAdaptor/1.0/tlmsrc/scmladaptor.h +62 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/serial_device/1.0/serial_device.xml +151 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/serial_device/1.0/tlmsrc/serial_device.h +85 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/timers/1.4/timers.xml +460 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/timers/1.4/tlmsrc/timers.cc +201 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/timers/1.4/tlmsrc/timers.h +102 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_scml/1.0/tlmsrc/inc/uart.h +152 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_scml/1.0/tlmsrc/inc/uart_fifo.h +113 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_scml/1.0/tlmsrc/inc/uart_memory_map.h +96 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_scml/1.0/tlmsrc/inc/uart_types.h +60 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_scml/1.0/tlmsrc/src/uart.cc +125 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_scml/1.0/tlmsrc/src/uart_interrupt_handler.cc +136 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_scml/1.0/tlmsrc/src/uart_register_bank.cc +129 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_scml/1.0/tlmsrc/src/uart_serial_tx_rx.cc +145 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_scml/1.0/uart_scml.xml +372 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_tac/1.0/tlmsrc/include/Leon2_uart.h +216 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_tac/1.0/tlmsrc/include/def_Leon2_uart.h +34 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_tac/1.0/tlmsrc/include/tlm_field.h +72 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_tac/1.0/tlmsrc/include/tlm_register.h +129 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_tac/1.0/tlmsrc/include/tlmreg_Leon2_uart.h +133 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_tac/1.0/tlmsrc/src/Leon2_uart.cc +316 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_tac/1.0/tlmsrc/src/tlmreg_Leon2_uart.cc +197 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_tac/1.0/tlmsrc/src/user_specific_Leon2_uart.cc +146 -0
- data/spec/test_data/spiritconsortium.org/Leon2TLM/uart_tac/1.0/uart_tac.xml +222 -0
- data/spec/unit/component_spec.rb +98 -0
- data/spec/unit/graph_pathfinder_spec.rb +128 -0
- data/spec/unit/interconnect_spec.rb +177 -0
- data/spec/unit/ipxact_spec.rb +69 -0
- data/spec/unit/platform_spec.rb +34 -0
- metadata +225 -0
|
@@ -0,0 +1,278 @@
|
|
|
1
|
+
/* -*- C++ -*- */
|
|
2
|
+
/*****************************************************************************
|
|
3
|
+
Description: pv_router.tpp
|
|
4
|
+
Author: The SPIRIT Consortium
|
|
5
|
+
Revision: $Revision: 1506 $
|
|
6
|
+
Date: $Date: 2009-04-26 01:51:56 -0500 (Sun, 26 Apr 2009) $
|
|
7
|
+
|
|
8
|
+
Copyright (c) 2008, 2009 The SPIRIT Consortium.
|
|
9
|
+
|
|
10
|
+
This work forms part of a deliverable of The SPIRIT Consortium.
|
|
11
|
+
|
|
12
|
+
Use of these materials are governed by the legal terms and conditions
|
|
13
|
+
outlined in the disclaimer available from www.spiritconsortium.org.
|
|
14
|
+
|
|
15
|
+
This source file is provided on an AS IS basis. The SPIRIT
|
|
16
|
+
Consortium disclaims any warranty express or implied including
|
|
17
|
+
any warranty of merchantability and fitness for use for a
|
|
18
|
+
particular purpose.
|
|
19
|
+
|
|
20
|
+
The user of the source file shall indemnify and hold The SPIRIT
|
|
21
|
+
Consortium and its members harmless from any damages or liability.
|
|
22
|
+
Users are requested to provide feedback to The SPIRIT Consortium
|
|
23
|
+
using either mailto:feedback@lists.spiritconsortium.org or the forms at
|
|
24
|
+
http://www.spiritconsortium.org/about/contact_us/
|
|
25
|
+
|
|
26
|
+
This file may be copied, and distributed, with or without
|
|
27
|
+
modifications; but this notice must be included on any copy.
|
|
28
|
+
|
|
29
|
+
The following code is derived, directly or indirectly, from the SystemC
|
|
30
|
+
source code Copyright (c) 1996-2004 by all Contributors.
|
|
31
|
+
All Rights reserved.
|
|
32
|
+
|
|
33
|
+
The contents of this file are subject to the restrictions and limitations
|
|
34
|
+
set forth in the SystemC Open Source License Version 2.4 (the "License");
|
|
35
|
+
You may not use this file except in compliance with such restrictions and
|
|
36
|
+
limitations. You may obtain instructions on how to receive a copy of the
|
|
37
|
+
License at http://www.systemc.org/. Software distributed by Contributors
|
|
38
|
+
under the License is distributed on an "AS IS" basis, WITHOUT WARRANTY OF
|
|
39
|
+
ANY KIND, either express or implied. See the License for the specific
|
|
40
|
+
language governing rights and limitations under the License.
|
|
41
|
+
|
|
42
|
+
*****************************************************************************/
|
|
43
|
+
|
|
44
|
+
/*------------------------------------------------------------------------------
|
|
45
|
+
* Includes
|
|
46
|
+
*----------------------------------------------------------------------------*/
|
|
47
|
+
#include "pv_router.h"
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
|
|
51
|
+
//--------------
|
|
52
|
+
// Constructors
|
|
53
|
+
//--------------
|
|
54
|
+
template<typename ADDRESS,typename DATA>
|
|
55
|
+
pv_router<ADDRESS,DATA>::pv_router(sc_module_name module_name,
|
|
56
|
+
const char * map_filename
|
|
57
|
+
) :
|
|
58
|
+
sc_module(module_name),
|
|
59
|
+
initiator_port("initiator_port"),
|
|
60
|
+
target_port("target_port")
|
|
61
|
+
{
|
|
62
|
+
if (map_filename) m_map_filename = map_filename;
|
|
63
|
+
else m_map_filename = (std::string)(name()) + ".map";
|
|
64
|
+
|
|
65
|
+
target_port(*this);
|
|
66
|
+
|
|
67
|
+
std::cout << name() << " module created\n";
|
|
68
|
+
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
|
|
72
|
+
//-------------
|
|
73
|
+
// Destructor
|
|
74
|
+
//-------------
|
|
75
|
+
template<typename ADDRESS,typename DATA>
|
|
76
|
+
pv_router<ADDRESS,DATA>::~pv_router() {
|
|
77
|
+
for(typename std::vector<address_map_type *>::iterator map = m_address_map_list.begin();
|
|
78
|
+
map != m_address_map_list.end();
|
|
79
|
+
map ++) {
|
|
80
|
+
if ((*map)) delete (*map);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
//-------------------------------------------------
|
|
85
|
+
// sc_module method override
|
|
86
|
+
//-------------------------------------------------
|
|
87
|
+
|
|
88
|
+
// Called by elaboration_done
|
|
89
|
+
template<typename ADDRESS,typename DATA>
|
|
90
|
+
void pv_router<ADDRESS,DATA>::end_of_elaboration() {
|
|
91
|
+
if (load_mapfile(m_map_filename.c_str()))
|
|
92
|
+
std::cout << name() << ": End of Elaboration: "<< initiator_port.get_target_port_list().size() << " target(s) connected\n";
|
|
93
|
+
else sc_stop();
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
|
|
97
|
+
//-------------------------------------------------
|
|
98
|
+
// tlm_transport_if method implementation
|
|
99
|
+
//-------------------------------------------------
|
|
100
|
+
|
|
101
|
+
// Transfer of transaction
|
|
102
|
+
template<typename ADDRESS,typename DATA>
|
|
103
|
+
pv_response<DATA>
|
|
104
|
+
pv_router<ADDRESS,DATA>::transport(const request_type& request) {
|
|
105
|
+
|
|
106
|
+
response_type response;
|
|
107
|
+
request_type router_request(request); // Copy from input request
|
|
108
|
+
|
|
109
|
+
ADDRESS addr = request.get_address();
|
|
110
|
+
|
|
111
|
+
// Search address map and modify the address
|
|
112
|
+
address_map_type * map = decode(addr);
|
|
113
|
+
|
|
114
|
+
if (map) {
|
|
115
|
+
|
|
116
|
+
// Request modification: modified address and port ID added
|
|
117
|
+
router_request.set_address(addr);
|
|
118
|
+
|
|
119
|
+
// Send initiator request to the target
|
|
120
|
+
initiator_port.do_transport(router_request,response,(*map).get_target_port_rank());
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
response.get_status().set_error();
|
|
124
|
+
response.get_status().set_no_response();
|
|
125
|
+
std::cout << "ERROR\t" << name() << std::showbase << std::hex
|
|
126
|
+
<< ": No target at this address: " << request.get_address() << std::endl;
|
|
127
|
+
}
|
|
128
|
+
return(response);
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
/*
|
|
132
|
+
// Transfer of transaction
|
|
133
|
+
template<typename ADDRESS,typename DATA>
|
|
134
|
+
void
|
|
135
|
+
pv_router<ADDRESS,DATA>::transport(const request_type& request,response_type& response) {
|
|
136
|
+
|
|
137
|
+
request_type router_request(request); // Copy from input request
|
|
138
|
+
|
|
139
|
+
ADDRESS addr = request.get_address();
|
|
140
|
+
|
|
141
|
+
// Search address map and modify the address
|
|
142
|
+
address_map_type * map = decode(addr);
|
|
143
|
+
|
|
144
|
+
if (map) {
|
|
145
|
+
|
|
146
|
+
// Request modification: modified address and port ID added
|
|
147
|
+
router_request.set_address(addr);
|
|
148
|
+
|
|
149
|
+
// Send initiator request to the target
|
|
150
|
+
initiator_port.do_transport(router_request,response,(*map).get_target_port_rank());
|
|
151
|
+
}
|
|
152
|
+
else {
|
|
153
|
+
response.get_status().set_error();
|
|
154
|
+
response.get_status().set_no_response();
|
|
155
|
+
std::cout << "ERROR\t" << name() << std::showbase << std::hex
|
|
156
|
+
<< ": No target at this address: " << request.get_address();
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
*/
|
|
160
|
+
|
|
161
|
+
|
|
162
|
+
//-------------------------------------------------
|
|
163
|
+
// Load mapfile. Called at the end of elaboration
|
|
164
|
+
// Can be called again dirung the simulation -> remap
|
|
165
|
+
//-------------------------------------------------
|
|
166
|
+
template<typename ADDRESS,typename DATA>
|
|
167
|
+
bool
|
|
168
|
+
pv_router<ADDRESS,DATA>::load_mapfile(const char * filename) {
|
|
169
|
+
|
|
170
|
+
// Temporary address map lists
|
|
171
|
+
std::vector<address_map_type *> tmp_address_map_list;
|
|
172
|
+
|
|
173
|
+
// Parse the map file to fill the temporary address_map list
|
|
174
|
+
ifstream mapfile(filename);
|
|
175
|
+
if( !mapfile.is_open() ) {
|
|
176
|
+
std::cout << "ERROR\t" << name() << ": Opening mapfile \"" << m_map_filename << "\"\n";
|
|
177
|
+
return(false);
|
|
178
|
+
}
|
|
179
|
+
else {
|
|
180
|
+
std::cout << name() << ": mapfile \"" << m_map_filename << "\" loaded\n";
|
|
181
|
+
|
|
182
|
+
// Reads the map stream and fills the address map list
|
|
183
|
+
char line[1024];
|
|
184
|
+
while (mapfile.good()) {
|
|
185
|
+
memset(line,0,1024);
|
|
186
|
+
mapfile.getline(line,1024);
|
|
187
|
+
|
|
188
|
+
// If the current map line is not a comment, the parser retrieves
|
|
189
|
+
// the address map parameters and creates a new address map object
|
|
190
|
+
if ((line[0]) && (line[0] != ';') && (line[0] != ' ') && (line[0] != '\n') && (line[0] != '\t')) {
|
|
191
|
+
std::string port_name;
|
|
192
|
+
ADDRESS addr,size = 0;
|
|
193
|
+
std::stringstream linestream(line);
|
|
194
|
+
linestream >> hex >> port_name >> addr >> size; // Read addresses using HEX format
|
|
195
|
+
|
|
196
|
+
if (size == 0) // Ignore map entry with null size
|
|
197
|
+
std::cout << "WARNING\t" << name() << ":Null entry size for \"" << port_name.c_str() << "\" entry while parsing map input. This entry will be ignored\n";
|
|
198
|
+
else {
|
|
199
|
+
address_map_type * map = new address_map_type(port_name,addr,addr+(size-1));
|
|
200
|
+
tmp_address_map_list.push_back(map);
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
// For all the child objects of the module (search initiator ports)
|
|
206
|
+
for (int i=0;i<(int)this->get_child_objects().size();i++) {
|
|
207
|
+
initiator_port_type * port;
|
|
208
|
+
if ((port = dynamic_cast<initiator_port_type *>(this->get_child_objects()[i])) != NULL) {
|
|
209
|
+
for (unsigned int target_port_rank = 0;target_port_rank<port->get_target_port_list().size();target_port_rank++) {
|
|
210
|
+
target_port_type& target_port = *(static_cast<target_port_type * >(port->get_target_port_list()[target_port_rank]));
|
|
211
|
+
bool mapped = false; // Unmapped port detection flag
|
|
212
|
+
std::string port_name(target_port.name()); // Gets port name: target port in the list
|
|
213
|
+
|
|
214
|
+
// Check the temporary address map object list to find a matching port map
|
|
215
|
+
for(typename std::vector<address_map_type *>::iterator map = tmp_address_map_list.begin();
|
|
216
|
+
map != tmp_address_map_list.end();
|
|
217
|
+
map ++) {
|
|
218
|
+
std::string entry_name((*map)->get_entry_port_name().c_str()); // Gets mapfile target port entry name
|
|
219
|
+
if (port_name == entry_name) {// port name and entry name matches
|
|
220
|
+
|
|
221
|
+
// New address_map object initialized with mapfile entry
|
|
222
|
+
address_map_type * tmp_map = new address_map_type(*(*map));
|
|
223
|
+
// Add target_port rang information
|
|
224
|
+
tmp_map->set_target_port_rank(target_port_rank);
|
|
225
|
+
m_address_map_list.push_back(tmp_map); // Register address_map object in temporary map list
|
|
226
|
+
mapped = true;
|
|
227
|
+
#ifdef PV_ROUTER_DEBUG
|
|
228
|
+
std::cout << std::showbase << std::hex << name() << ": port \"" << target_port.name()
|
|
229
|
+
<< "\" identified - " << "Address range: "
|
|
230
|
+
<< (*map)->get_start_address() << " - " << (*map)->get_end_address() << std::endl;
|
|
231
|
+
#endif
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
// Error if a registered target port has no associated mapping information
|
|
235
|
+
if (!mapped) std::cout << "ERROR\t" << name() << ": port \"" << port_name.c_str()
|
|
236
|
+
<< "\" has no mapping defined in \"" << filename << "\"\n";
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
// Address map overlap detection
|
|
242
|
+
// For each registered address map object, the other address map objects are
|
|
243
|
+
// checked to detect mapping overlap
|
|
244
|
+
for(typename std::vector<address_map_type *>::iterator map = m_address_map_list.begin();
|
|
245
|
+
map != m_address_map_list.end();
|
|
246
|
+
map ++) {
|
|
247
|
+
|
|
248
|
+
for(typename std::vector<address_map_type *>::iterator other_map = map+1;
|
|
249
|
+
other_map != m_address_map_list.end();
|
|
250
|
+
other_map ++) {
|
|
251
|
+
|
|
252
|
+
if ( ( (*other_map)->decode((*map)->get_start_address() ) ) ||
|
|
253
|
+
( (*other_map)->decode((*map)->get_end_address() ) ) ||
|
|
254
|
+
( (*map)->decode((*other_map)->get_start_address() ) ) ||
|
|
255
|
+
( (*map)->decode((*other_map)->get_end_address() ) )
|
|
256
|
+
) {
|
|
257
|
+
// Print a Warning message if a map definition collision is detected
|
|
258
|
+
std::cout << "WARNING\t" << name() << ": "
|
|
259
|
+
<< std::showbase << std::hex << " \"" << (*other_map)->get_entry_port_name() << "\" map definition ("
|
|
260
|
+
<< (*other_map)->get_start_address() << " - " << (*other_map)->get_end_address() << ")"<< std::endl
|
|
261
|
+
<< "\t\toverlaps map defined for \"" << (*map)->get_entry_port_name() << "\" ("
|
|
262
|
+
<< (*map)->get_start_address() << " - " << (*map)->get_end_address() << ")" << std::endl;
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
|
|
267
|
+
// Cleanup temporary mapfile address map list
|
|
268
|
+
for(typename std::vector<address_map_type *>::iterator map = tmp_address_map_list.begin();
|
|
269
|
+
map != tmp_address_map_list.end();
|
|
270
|
+
map ++) {
|
|
271
|
+
if ((*map)) delete (*map);
|
|
272
|
+
}
|
|
273
|
+
return(true);
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
|
|
277
|
+
|
|
278
|
+
/* END of pv_router.tpp */
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
/*****************************************************************************
|
|
2
|
+
Description: pv_slave_base.h
|
|
3
|
+
Author: The SPIRIT Consortium
|
|
4
|
+
Revision: $Revision: 1506 $
|
|
5
|
+
Date: $Date: 2009-04-26 01:51:56 -0500 (Sun, 26 Apr 2009) $
|
|
6
|
+
|
|
7
|
+
Copyright (c) 2008, 2009 The SPIRIT Consortium.
|
|
8
|
+
|
|
9
|
+
This work forms part of a deliverable of The SPIRIT Consortium.
|
|
10
|
+
|
|
11
|
+
Use of these materials are governed by the legal terms and conditions
|
|
12
|
+
outlined in the disclaimer available from www.spiritconsortium.org.
|
|
13
|
+
|
|
14
|
+
This source file is provided on an AS IS basis. The SPIRIT
|
|
15
|
+
Consortium disclaims any warranty express or implied including
|
|
16
|
+
any warranty of merchantability and fitness for use for a
|
|
17
|
+
particular purpose.
|
|
18
|
+
|
|
19
|
+
The user of the source file shall indemnify and hold The SPIRIT
|
|
20
|
+
Consortium and its members harmless from any damages or liability.
|
|
21
|
+
Users are requested to provide feedback to The SPIRIT Consortium
|
|
22
|
+
using either mailto:feedback@lists.spiritconsortium.org or the forms at
|
|
23
|
+
http://www.spiritconsortium.org/about/contact_us/
|
|
24
|
+
|
|
25
|
+
This file may be copied, and distributed, with or without
|
|
26
|
+
modifications; but this notice must be included on any copy.
|
|
27
|
+
|
|
28
|
+
The following code is derived, directly or indirectly, from the SystemC
|
|
29
|
+
source code Copyright (c) 1996-2004 by all Contributors.
|
|
30
|
+
All Rights reserved.
|
|
31
|
+
|
|
32
|
+
The contents of this file are subject to the restrictions and limitations
|
|
33
|
+
set forth in the SystemC Open Source License Version 2.4 (the "License");
|
|
34
|
+
You may not use this file except in compliance with such restrictions and
|
|
35
|
+
limitations. You may obtain instructions on how to receive a copy of the
|
|
36
|
+
License at http://www.systemc.org/. Software distributed by Contributors
|
|
37
|
+
under the License is distributed on an "AS IS" basis, WITHOUT WARRANTY OF
|
|
38
|
+
ANY KIND, either express or implied. See the License for the specific
|
|
39
|
+
language governing rights and limitations under the License.
|
|
40
|
+
|
|
41
|
+
*****************************************************************************/
|
|
42
|
+
|
|
43
|
+
|
|
44
|
+
#ifndef _PV_SLAVE_BASE_H_
|
|
45
|
+
#define _PV_SLAVE_BASE_H_
|
|
46
|
+
|
|
47
|
+
/*------------------------------------------------------------------------------
|
|
48
|
+
* Includes
|
|
49
|
+
*----------------------------------------------------------------------------*/
|
|
50
|
+
#include <string>
|
|
51
|
+
|
|
52
|
+
#include "tlm.h"
|
|
53
|
+
|
|
54
|
+
#include "pv_tlm_if.h"
|
|
55
|
+
#include "pv_target_port.h"
|
|
56
|
+
|
|
57
|
+
|
|
58
|
+
//----------------------------------------------------------------------------
|
|
59
|
+
template<typename ADDRESS,typename DATA>
|
|
60
|
+
class pv_slave_base :
|
|
61
|
+
public virtual tlm::tlm_transport_if<pv_request<ADDRESS,DATA>,pv_response<DATA> >,
|
|
62
|
+
public virtual pv_tlm_if<ADDRESS,DATA> {
|
|
63
|
+
|
|
64
|
+
typedef pv_request<ADDRESS,DATA> request_type;
|
|
65
|
+
typedef pv_response<DATA> response_type;
|
|
66
|
+
|
|
67
|
+
typedef tlm::tlm_transport_if<request_type,response_type> interface_type;
|
|
68
|
+
|
|
69
|
+
typedef pv_target_port<ADDRESS,DATA> target_port_type;
|
|
70
|
+
|
|
71
|
+
public:
|
|
72
|
+
|
|
73
|
+
//---------------
|
|
74
|
+
// Constructor
|
|
75
|
+
//---------------
|
|
76
|
+
pv_slave_base(const char * module_name);
|
|
77
|
+
|
|
78
|
+
//-------------------------------------------------
|
|
79
|
+
// tlm_transport_if methods implementation
|
|
80
|
+
//-------------------------------------------------
|
|
81
|
+
virtual response_type transport(const request_type& request);
|
|
82
|
+
|
|
83
|
+
|
|
84
|
+
//--------------------------------------------------------
|
|
85
|
+
// Abstract class pv_tlm_if methods default implementation
|
|
86
|
+
//--------------------------------------------------------
|
|
87
|
+
|
|
88
|
+
virtual tlm::tlm_status read(const ADDRESS& address,
|
|
89
|
+
DATA& data,
|
|
90
|
+
const unsigned int byte_enable = tlm::NO_BE,
|
|
91
|
+
const tlm::tlm_mode mode = tlm::REGULAR,
|
|
92
|
+
const unsigned int export_id = 0);
|
|
93
|
+
|
|
94
|
+
virtual tlm::tlm_status write(const ADDRESS& address,
|
|
95
|
+
const DATA& data,
|
|
96
|
+
const unsigned int byte_enable = tlm::NO_BE,
|
|
97
|
+
const tlm::tlm_mode mode = tlm::REGULAR,
|
|
98
|
+
const unsigned int export_id = 0);
|
|
99
|
+
|
|
100
|
+
protected:
|
|
101
|
+
|
|
102
|
+
/// Slave name (used for debug and error messages: pv_slave_base is not a sc_object )
|
|
103
|
+
std::string m_slave_name;
|
|
104
|
+
|
|
105
|
+
};
|
|
106
|
+
|
|
107
|
+
|
|
108
|
+
// Class implementation
|
|
109
|
+
#include "./pv_slave_base.tpp"
|
|
110
|
+
|
|
111
|
+
|
|
112
|
+
|
|
113
|
+
#endif /* _PV_SLAVE_BASE_H_ */
|
|
114
|
+
|
|
115
|
+
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
/* -*- C++ -*- */
|
|
2
|
+
/*****************************************************************************
|
|
3
|
+
Description: pv_slave_base.tpp
|
|
4
|
+
Author: The SPIRIT Consortium
|
|
5
|
+
Revision: $Revision: 1506 $
|
|
6
|
+
Date: $Date: 2009-04-26 01:51:56 -0500 (Sun, 26 Apr 2009) $
|
|
7
|
+
|
|
8
|
+
Copyright (c) 2008, 2009 The SPIRIT Consortium.
|
|
9
|
+
|
|
10
|
+
This work forms part of a deliverable of The SPIRIT Consortium.
|
|
11
|
+
|
|
12
|
+
Use of these materials are governed by the legal terms and conditions
|
|
13
|
+
outlined in the disclaimer available from www.spiritconsortium.org.
|
|
14
|
+
|
|
15
|
+
This source file is provided on an AS IS basis. The SPIRIT
|
|
16
|
+
Consortium disclaims any warranty express or implied including
|
|
17
|
+
any warranty of merchantability and fitness for use for a
|
|
18
|
+
particular purpose.
|
|
19
|
+
|
|
20
|
+
The user of the source file shall indemnify and hold The SPIRIT
|
|
21
|
+
Consortium and its members harmless from any damages or liability.
|
|
22
|
+
Users are requested to provide feedback to The SPIRIT Consortium
|
|
23
|
+
using either mailto:feedback@lists.spiritconsortium.org or the forms at
|
|
24
|
+
http://www.spiritconsortium.org/about/contact_us/
|
|
25
|
+
|
|
26
|
+
This file may be copied, and distributed, with or without
|
|
27
|
+
modifications; but this notice must be included on any copy.
|
|
28
|
+
|
|
29
|
+
The following code is derived, directly or indirectly, from the SystemC
|
|
30
|
+
source code Copyright (c) 1996-2004 by all Contributors.
|
|
31
|
+
All Rights reserved.
|
|
32
|
+
|
|
33
|
+
The contents of this file are subject to the restrictions and limitations
|
|
34
|
+
set forth in the SystemC Open Source License Version 2.4 (the "License");
|
|
35
|
+
You may not use this file except in compliance with such restrictions and
|
|
36
|
+
limitations. You may obtain instructions on how to receive a copy of the
|
|
37
|
+
License at http://www.systemc.org/. Software distributed by Contributors
|
|
38
|
+
under the License is distributed on an "AS IS" basis, WITHOUT WARRANTY OF
|
|
39
|
+
ANY KIND, either express or implied. See the License for the specific
|
|
40
|
+
language governing rights and limitations under the License.
|
|
41
|
+
|
|
42
|
+
*****************************************************************************/
|
|
43
|
+
|
|
44
|
+
/*------------------------------------------------------------------------------
|
|
45
|
+
* Includes
|
|
46
|
+
*----------------------------------------------------------------------------*/
|
|
47
|
+
#include "pv_slave_base.h"
|
|
48
|
+
|
|
49
|
+
//---------------
|
|
50
|
+
// Constructor
|
|
51
|
+
//---------------
|
|
52
|
+
template<typename ADDRESS,typename DATA>
|
|
53
|
+
pv_slave_base<ADDRESS,DATA>::pv_slave_base(const char * module_name) :
|
|
54
|
+
m_slave_name(module_name) {
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
|
|
58
|
+
|
|
59
|
+
|
|
60
|
+
//-------------------------------------------------
|
|
61
|
+
// tlm_transport_if methods implementation
|
|
62
|
+
//-------------------------------------------------
|
|
63
|
+
template<typename ADDRESS,typename DATA>
|
|
64
|
+
pv_response<DATA>
|
|
65
|
+
pv_slave_base<ADDRESS,DATA>::transport(const request_type& request) {
|
|
66
|
+
|
|
67
|
+
response_type response;
|
|
68
|
+
|
|
69
|
+
switch(request.get_command()) {
|
|
70
|
+
|
|
71
|
+
case PV_READ:
|
|
72
|
+
|
|
73
|
+
response.set_data(request.get_data());
|
|
74
|
+
|
|
75
|
+
response.set_status(this->read(request.get_address(), response.get_data()));
|
|
76
|
+
break;
|
|
77
|
+
|
|
78
|
+
case PV_WRITE:
|
|
79
|
+
response.set_status(this->write(request.get_address(), request.get_data()));
|
|
80
|
+
break;
|
|
81
|
+
|
|
82
|
+
default:
|
|
83
|
+
std::cout << "ERROR\t" << m_slave_name << ": Unknown command \n";
|
|
84
|
+
break;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
return response;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
//---------------------
|
|
91
|
+
// Read access
|
|
92
|
+
template<typename ADDRESS,typename DATA>
|
|
93
|
+
tlm::tlm_status
|
|
94
|
+
pv_slave_base<ADDRESS,DATA>::read(const ADDRESS& address,
|
|
95
|
+
DATA& data,
|
|
96
|
+
const unsigned int byte_enable,
|
|
97
|
+
const tlm::tlm_mode mode,
|
|
98
|
+
const unsigned int export_id
|
|
99
|
+
) {
|
|
100
|
+
tlm::tlm_status status;
|
|
101
|
+
|
|
102
|
+
std::cout << "ERROR\t" << m_slave_name << ": Read is not implemented\n";
|
|
103
|
+
|
|
104
|
+
return(status);
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
//----------------------
|
|
108
|
+
// Write access
|
|
109
|
+
template<typename ADDRESS,typename DATA>
|
|
110
|
+
tlm::tlm_status
|
|
111
|
+
pv_slave_base<ADDRESS,DATA>::write(const ADDRESS& address,
|
|
112
|
+
const DATA& data,
|
|
113
|
+
const unsigned int byte_enable,
|
|
114
|
+
const tlm::tlm_mode mode,
|
|
115
|
+
const unsigned int export_id
|
|
116
|
+
) {
|
|
117
|
+
tlm::tlm_status status;
|
|
118
|
+
|
|
119
|
+
std::cout << "ERROR\t" << m_slave_name << ": Write is not implemented\n";
|
|
120
|
+
|
|
121
|
+
return(status);
|
|
122
|
+
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
/* END of pv_slave_base.tpp */
|
|
126
|
+
|