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,105 @@
|
|
|
1
|
+
# Copyright (C) 2010 TIMA Laboratory
|
|
2
|
+
#
|
|
3
|
+
# This program is free software: you can redistribute it and/or modify
|
|
4
|
+
# it under the terms of the GNU General Public License as published by
|
|
5
|
+
# the Free Software Foundation, either version 3 of the License, or
|
|
6
|
+
# (at your option) any later version.
|
|
7
|
+
#
|
|
8
|
+
# This program is distributed in the hope that it will be useful,
|
|
9
|
+
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
10
|
+
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
11
|
+
# GNU General Public License for more details.
|
|
12
|
+
#
|
|
13
|
+
# You should have received a copy of the GNU General Public License
|
|
14
|
+
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
15
|
+
#
|
|
16
|
+
|
|
17
|
+
require File.join File.dirname(__FILE__), 'general_spec'
|
|
18
|
+
|
|
19
|
+
describe 'IPXACT, when using the tools for bus data extraction' do
|
|
20
|
+
it "should be able to extract data from a mirrored slave bus interface" do
|
|
21
|
+
variables = {
|
|
22
|
+
"range_slv0_mirror" => "0x00040000",
|
|
23
|
+
"range_slv1_mirror" => "0x00009000",
|
|
24
|
+
"start_addr_slv0_mirror" => "0x0",
|
|
25
|
+
"start_addr_slv1_mirror" => "0x30000000"
|
|
26
|
+
}
|
|
27
|
+
components = IPXACT::load_components(PLATFORM_PATH)
|
|
28
|
+
|
|
29
|
+
ahbbus22_component = components[['ahbbus22', '1.4']]
|
|
30
|
+
mirrored_slave_0 = ahbbus22_component.xpath(".//spirit:busInterface") \
|
|
31
|
+
.select{|bus| bus.xpath("./spirit:name").first.text == 'AHB_MirroredSlave0'} \
|
|
32
|
+
.first
|
|
33
|
+
|
|
34
|
+
IPXACT::Parser::BusData::extract_bus_data(mirrored_slave_0, ahbbus22_component, variables).should \
|
|
35
|
+
eql([:mirrored_slave, {
|
|
36
|
+
:remap => {:address => "0x0", :id => "start_addr_slv0_mirror"},
|
|
37
|
+
:range => {:value => "0x00040000", :id => "range_slv0_mirror"}
|
|
38
|
+
}])
|
|
39
|
+
|
|
40
|
+
mirrored_slave_1 = ahbbus22_component.xpath(".//spirit:busInterface") \
|
|
41
|
+
.select{|bus| bus.xpath("./spirit:name").first.text == 'AHB_MirroredSlave1'} \
|
|
42
|
+
.first
|
|
43
|
+
|
|
44
|
+
IPXACT::Parser::BusData::extract_bus_data(mirrored_slave_1, ahbbus22_component, variables).should \
|
|
45
|
+
eql([:mirrored_slave, {
|
|
46
|
+
:remap => {:address => "0x30000000", :id => "start_addr_slv1_mirror"},
|
|
47
|
+
:range => {:value => "0x00009000", :id => "range_slv1_mirror"}
|
|
48
|
+
}])
|
|
49
|
+
end
|
|
50
|
+
|
|
51
|
+
it "should be able to extract data from a mirrored master bus interface" do
|
|
52
|
+
components = IPXACT::load_components(PLATFORM_PATH)
|
|
53
|
+
ahbbus22_component = components[['ahbbus22', '1.4']]
|
|
54
|
+
mirrored_master_0 = ahbbus22_component.xpath(".//spirit:busInterface") \
|
|
55
|
+
.select{|bus| bus.xpath("./spirit:name").first.text == 'AHB_MirroredMaster0'} \
|
|
56
|
+
.first
|
|
57
|
+
IPXACT::Parser::BusData::extract_bus_data(mirrored_master_0, ahbbus22_component, []).should \
|
|
58
|
+
eql([:mirrored_master, nil])
|
|
59
|
+
end
|
|
60
|
+
|
|
61
|
+
it "should be able to extract data from a master bus interface" do
|
|
62
|
+
components = IPXACT::load_components(PLATFORM_PATH)
|
|
63
|
+
dma_component = components[['dma', '1.4']]
|
|
64
|
+
master = dma_component.xpath(".//spirit:busInterface") \
|
|
65
|
+
.select{|bus| bus.xpath("./spirit:name").first.text == 'AHB_Master'} \
|
|
66
|
+
.first
|
|
67
|
+
IPXACT::Parser::BusData::extract_bus_data(master, dma_component, []).should \
|
|
68
|
+
eql([:master, {:address_space_name => 'AHB_AS', :range => '4G', :width => '32'}])
|
|
69
|
+
end
|
|
70
|
+
|
|
71
|
+
it "should be able to extract data from a slave bus interface" do
|
|
72
|
+
components = IPXACT::load_components(PLATFORM_PATH)
|
|
73
|
+
dma_component = components[['dma', '1.4']]
|
|
74
|
+
slave = dma_component.xpath(".//spirit:busInterface") \
|
|
75
|
+
.select{|bus| bus.xpath("./spirit:name").first.text == 'APB_Slave'} \
|
|
76
|
+
.first
|
|
77
|
+
IPXACT::Parser::BusData::extract_bus_data(slave, dma_component, []).should \
|
|
78
|
+
eql([:slave, {
|
|
79
|
+
:memory_map_name => 'APB_MM',
|
|
80
|
+
:base_address => '0',
|
|
81
|
+
:range => '16',
|
|
82
|
+
:width => '32',
|
|
83
|
+
:registers => [
|
|
84
|
+
{
|
|
85
|
+
:name => 'sourceAddress',
|
|
86
|
+
:offset => '0x0',
|
|
87
|
+
:size => '32',
|
|
88
|
+
:access => 'read-write'
|
|
89
|
+
},
|
|
90
|
+
{
|
|
91
|
+
:name => 'destinationAddress',
|
|
92
|
+
:offset => '0x4',
|
|
93
|
+
:size => '32',
|
|
94
|
+
:access => 'read-write'
|
|
95
|
+
},
|
|
96
|
+
{
|
|
97
|
+
:name => 'control',
|
|
98
|
+
:offset => '0x8',
|
|
99
|
+
:size => '32',
|
|
100
|
+
:access => 'read-write'
|
|
101
|
+
}
|
|
102
|
+
]
|
|
103
|
+
}])
|
|
104
|
+
end
|
|
105
|
+
end
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
# Copyright (C) 2010 TIMA Laboratory
|
|
2
|
+
#
|
|
3
|
+
# This program is free software: you can redistribute it and/or modify
|
|
4
|
+
# it under the terms of the GNU General Public License as published by
|
|
5
|
+
# the Free Software Foundation, either version 3 of the License, or
|
|
6
|
+
# (at your option) any later version.
|
|
7
|
+
#
|
|
8
|
+
# This program is distributed in the hope that it will be useful,
|
|
9
|
+
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
10
|
+
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
11
|
+
# GNU General Public License for more details.
|
|
12
|
+
#
|
|
13
|
+
# You should have received a copy of the GNU General Public License
|
|
14
|
+
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
15
|
+
#
|
|
16
|
+
|
|
17
|
+
require File.join File.dirname(__FILE__), 'general_spec'
|
|
18
|
+
|
|
19
|
+
describe "The data calculation functions of our IPXACT tool" do
|
|
20
|
+
it "should be able to find valid data paths when building a driver" do
|
|
21
|
+
expected_data_path = [
|
|
22
|
+
[
|
|
23
|
+
{
|
|
24
|
+
:component_instance => 'i_proc',
|
|
25
|
+
:port_name => "AHB_Master",
|
|
26
|
+
},
|
|
27
|
+
{
|
|
28
|
+
:component_instance => 'i_ahb',
|
|
29
|
+
:port_name => 'AHB_MirroredMaster0'
|
|
30
|
+
}
|
|
31
|
+
],
|
|
32
|
+
[
|
|
33
|
+
{
|
|
34
|
+
:component_instance => 'i_ahb',
|
|
35
|
+
:port_name => 'AHB_MirroredSlave1'
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
:component_instance => 'i_h2p',
|
|
39
|
+
:port_name => 'AHB_Slave'
|
|
40
|
+
}
|
|
41
|
+
],
|
|
42
|
+
[
|
|
43
|
+
{
|
|
44
|
+
:component_instance => 'i_h2p',
|
|
45
|
+
:port_name => 'APB_Master'
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
:component_instance => 'i_apb',
|
|
49
|
+
:port_name => 'APB_MirroredMaster'
|
|
50
|
+
}
|
|
51
|
+
],
|
|
52
|
+
[
|
|
53
|
+
{
|
|
54
|
+
:component_instance => 'i_apb',
|
|
55
|
+
:port_name => 'APB_MirroredSlave7'
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
:component_instance => 'i_dma',
|
|
59
|
+
:port_name => 'APB_Slave'
|
|
60
|
+
}
|
|
61
|
+
]
|
|
62
|
+
]
|
|
63
|
+
|
|
64
|
+
components = IPXACT::load_components(PLATFORM_PATH)
|
|
65
|
+
designs = IPXACT::load_designs(PLATFORM_PATH)
|
|
66
|
+
platform = IPXACT::Parser::PlatformData.parse_platform(["Leon2Platform", "1.1"], components, designs)
|
|
67
|
+
|
|
68
|
+
data_path = nil
|
|
69
|
+
lambda {
|
|
70
|
+
data_path = platform.resolve_data_path('i_proc', 'i_dma')
|
|
71
|
+
}.should_not raise_exception
|
|
72
|
+
data_path.should eql(expected_data_path)
|
|
73
|
+
end
|
|
74
|
+
|
|
75
|
+
it "should be able to assign instance variables to mirrored slave addresses and ranges" do
|
|
76
|
+
expected_values = {
|
|
77
|
+
"range_slv0_mirror" => "0x00040000",
|
|
78
|
+
"range_slv1_mirror" => "0x00009000",
|
|
79
|
+
"start_addr_slv0_mirror" => "0x0",
|
|
80
|
+
"start_addr_slv1_mirror" => "0x30000000"
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
components = IPXACT::load_components(PLATFORM_PATH)
|
|
84
|
+
designs = IPXACT::load_designs(PLATFORM_PATH)
|
|
85
|
+
platform = IPXACT::Parser::PlatformData.parse_platform(["Leon2Platform", "1.1"], components, designs)
|
|
86
|
+
|
|
87
|
+
nodes_with_mirrored_slaves = platform.components.values.select do |node|
|
|
88
|
+
node.ports.any?{|port| port[:type] == :mirrored_slave}
|
|
89
|
+
end
|
|
90
|
+
|
|
91
|
+
mirrored_slave_ports = nodes_with_mirrored_slaves.collect{|node|
|
|
92
|
+
node.ports.select{|port| port[:type] == :mirrored_slave}
|
|
93
|
+
}.flatten
|
|
94
|
+
|
|
95
|
+
expected_values.each do |expected_key, expected_value|
|
|
96
|
+
port = mirrored_slave_ports.select do | mirrored_s |
|
|
97
|
+
mirrored_s[:port_data] && (mirrored_s[:port_data][:remap][:id] == expected_key ||
|
|
98
|
+
mirrored_s[:port_data][:range][:id])
|
|
99
|
+
end.first
|
|
100
|
+
|
|
101
|
+
unless port.empty?
|
|
102
|
+
if port[:port_data][:remap][:id] == expected_key
|
|
103
|
+
port[:port_data][:remap][:address].should == expected_value
|
|
104
|
+
elsif port[:port_data][:range][:id] == expected_key
|
|
105
|
+
port[:port_data][:range][:value].should == expected_value
|
|
106
|
+
end
|
|
107
|
+
end
|
|
108
|
+
end
|
|
109
|
+
end
|
|
110
|
+
|
|
111
|
+
it "should be able to determine the dma component's base address from the interconnect path" do
|
|
112
|
+
# DMA remap address : 0x30000000 + 0x7000 = 0x30007000
|
|
113
|
+
components = IPXACT::load_components(PLATFORM_PATH)
|
|
114
|
+
designs = IPXACT::load_designs(PLATFORM_PATH)
|
|
115
|
+
platform = IPXACT::Parser::PlatformData.parse_platform(["Leon2Platform", "1.1"], components, designs)
|
|
116
|
+
data_path = platform.resolve_data_path('i_proc', 'i_dma')
|
|
117
|
+
|
|
118
|
+
base_address = platform.resolve_base_address(data_path)
|
|
119
|
+
base_address.should == 0x30007000 # AHB remap + APB remap (as defined in the apbSubsystem design file)
|
|
120
|
+
end
|
|
121
|
+
|
|
122
|
+
|
|
123
|
+
it "should be able to determine the cgu component's base address from the interconnect path" do
|
|
124
|
+
components = IPXACT::load_components(PLATFORM_PATH)
|
|
125
|
+
designs = IPXACT::load_designs(PLATFORM_PATH)
|
|
126
|
+
platform = IPXACT::Parser::PlatformData.parse_platform(["Leon2Platform", "1.2"], components, designs)
|
|
127
|
+
data_path = platform.resolve_data_path('i_proc', 'i_cgu')
|
|
128
|
+
|
|
129
|
+
base_address = platform.resolve_base_address(data_path)
|
|
130
|
+
base_address.should == 0x30004000
|
|
131
|
+
end
|
|
132
|
+
|
|
133
|
+
end
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
# Copyright (C) 2010 TIMA Laboratory
|
|
2
|
+
#
|
|
3
|
+
# This program is free software: you can redistribute it and/or modify
|
|
4
|
+
# it under the terms of the GNU General Public License as published by
|
|
5
|
+
# the Free Software Foundation, either version 3 of the License, or
|
|
6
|
+
# (at your option) any later version.
|
|
7
|
+
#
|
|
8
|
+
# This program is distributed in the hope that it will be useful,
|
|
9
|
+
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
10
|
+
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
11
|
+
# GNU General Public License for more details.
|
|
12
|
+
#
|
|
13
|
+
# You should have received a copy of the GNU General Public License
|
|
14
|
+
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
15
|
+
#
|
|
16
|
+
|
|
17
|
+
require File.join File.dirname(__FILE__), 'general_spec'
|
|
18
|
+
|
|
19
|
+
describe "The data construction functions of our IPXACT tool" do
|
|
20
|
+
it "should be able to create an interconnect list with valid component nodes" do
|
|
21
|
+
components = IPXACT::load_components(PLATFORM_PATH)
|
|
22
|
+
designs = IPXACT::load_designs(PLATFORM_PATH)
|
|
23
|
+
platform = IPXACT::Parser::PlatformData.parse_platform(["Leon2Platform", "1.1"], components, designs)
|
|
24
|
+
|
|
25
|
+
expected_nodes = ['i_ahb', 'i_mem', 'i_sub', 'i_cgu', 'i_dma', 'i_proc', 'i_rgu']
|
|
26
|
+
nodes = platform.components.keys
|
|
27
|
+
|
|
28
|
+
expected_nodes.each {|expected_node| nodes.should include(expected_node)}
|
|
29
|
+
nodes.each {|node| expected_nodes.should include(node)}
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
it "should be able to create an interconnect list with a valid connections list" do
|
|
33
|
+
components = IPXACT::load_components(PLATFORM_PATH)
|
|
34
|
+
designs = IPXACT::load_designs(PLATFORM_PATH)
|
|
35
|
+
platform = IPXACT::Parser::PlatformData.parse_platform(["Leon2Platform", "1.1"], components, designs)
|
|
36
|
+
|
|
37
|
+
platform.interconnections.values.should include(
|
|
38
|
+
[
|
|
39
|
+
{
|
|
40
|
+
:component_instance => "i_proc",
|
|
41
|
+
:port_name => "AHB_Master",
|
|
42
|
+
:port_type => :master
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
:component_instance => "i_ahb",
|
|
46
|
+
:port_name => "AHB_MirroredMaster0",
|
|
47
|
+
:port_type => :mirrored_master
|
|
48
|
+
}
|
|
49
|
+
]
|
|
50
|
+
)
|
|
51
|
+
end
|
|
52
|
+
end
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
# Copyright (C) 2010 TIMA Laboratory
|
|
2
|
+
#
|
|
3
|
+
# This program is free software: you can redistribute it and/or modify
|
|
4
|
+
# it under the terms of the GNU General Public License as published by
|
|
5
|
+
# the Free Software Foundation, either version 3 of the License, or
|
|
6
|
+
# (at your option) any later version.
|
|
7
|
+
#
|
|
8
|
+
# This program is distributed in the hope that it will be useful,
|
|
9
|
+
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
10
|
+
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
11
|
+
# GNU General Public License for more details.
|
|
12
|
+
#
|
|
13
|
+
# You should have received a copy of the GNU General Public License
|
|
14
|
+
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
15
|
+
#
|
|
16
|
+
|
|
17
|
+
require File.join(File.dirname(__FILE__), '../../lib/ipxact')
|
|
18
|
+
|
|
19
|
+
PLATFORM_PATH = File.join File.dirname(__FILE__) , '../test_data/spiritconsortium.org/Leon2TLM'
|
|
20
|
+
DESIGN_PATH = 'SystemTLM1/Leon2Platform/design_Leon2Platform.xml'
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
describe "IPXACT: the tools for building transformation data" do
|
|
24
|
+
|
|
25
|
+
context "component and design validation" do
|
|
26
|
+
it "should confirm that a design file is not a valid component" do
|
|
27
|
+
IPXACT::is_valid_component?(File.join(PLATFORM_PATH,DESIGN_PATH)).should be_false
|
|
28
|
+
end
|
|
29
|
+
|
|
30
|
+
it "should confirm the validity of a valid component" do
|
|
31
|
+
IPXACT::is_valid_component?(File.join(PLATFORM_PATH, 'SystemTLM1/Leon2Platform/Leon2Platform.xml')).should be_true
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
it "should raise an exception when given an invalid path" do
|
|
35
|
+
lambda{
|
|
36
|
+
IPXACT::is_valid_component?(3)
|
|
37
|
+
}.should raise_exception(ArgumentError)
|
|
38
|
+
|
|
39
|
+
lambda{
|
|
40
|
+
IPXACT::is_valid_design?(3)
|
|
41
|
+
}.should raise_exception(ArgumentError)
|
|
42
|
+
end
|
|
43
|
+
|
|
44
|
+
it "should confirm a design file's validity" do
|
|
45
|
+
IPXACT::is_valid_design?(File.join(PLATFORM_PATH,DESIGN_PATH)).should be_true
|
|
46
|
+
end
|
|
47
|
+
|
|
48
|
+
it "should confirm that a component is not a valid design" do
|
|
49
|
+
IPXACT::is_valid_design?(File.join(PLATFORM_PATH, 'SystemTLM1/Leon2Platform/Leon2Platform.xml')).should be_false
|
|
50
|
+
end
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
context "extracting a component's identifier" do
|
|
54
|
+
it "should be able to extract a design's identifier" do
|
|
55
|
+
IPXACT::identifier(File.join(PLATFORM_PATH,DESIGN_PATH)).should == {
|
|
56
|
+
:name => 'design_Leon2Platform',
|
|
57
|
+
:vendor => 'spiritconsortium.org',
|
|
58
|
+
:library => 'Leon2TLM',
|
|
59
|
+
:version => '1.1'
|
|
60
|
+
}
|
|
61
|
+
end
|
|
62
|
+
|
|
63
|
+
it "should be able to extract a component's identifier" do
|
|
64
|
+
IPXACT::identifier(File.join(PLATFORM_PATH,'SystemTLM1/Leon2Platform/Leon2Platform.xml')).should == {
|
|
65
|
+
:name => 'Leon2Platform',
|
|
66
|
+
:vendor => 'spiritconsortium.org',
|
|
67
|
+
:library => 'Leon2TLM',
|
|
68
|
+
:version => '1.1'
|
|
69
|
+
}
|
|
70
|
+
end
|
|
71
|
+
end
|
|
72
|
+
|
|
73
|
+
|
|
74
|
+
context "data loading" do
|
|
75
|
+
it "should be able to load all the design files for the Leon2 Platform" do
|
|
76
|
+
design_docs = IPXACT::load_designs(PLATFORM_PATH)
|
|
77
|
+
design_docs.should have(6).keys
|
|
78
|
+
end
|
|
79
|
+
|
|
80
|
+
it "should be able to load all the components from the Leon2 Platform" do
|
|
81
|
+
component_docs = IPXACT::load_components(PLATFORM_PATH)
|
|
82
|
+
component_docs.should have(21).keys
|
|
83
|
+
end
|
|
84
|
+
end
|
|
85
|
+
|
|
86
|
+
context "platform creation" do
|
|
87
|
+
it "should be able to create a new platform, based on the documents that were loaded" do
|
|
88
|
+
design_docs = IPXACT::load_designs(PLATFORM_PATH)
|
|
89
|
+
component_docs = IPXACT::load_components(PLATFORM_PATH)
|
|
90
|
+
|
|
91
|
+
platform = nil
|
|
92
|
+
lambda {
|
|
93
|
+
platform = IPXACT::Parser::PlatformData.parse_platform(["Leon2Platform", "1.1"], component_docs, design_docs)
|
|
94
|
+
}.should_not raise_exception
|
|
95
|
+
|
|
96
|
+
platform.should_not be_nil
|
|
97
|
+
platform.should have(10).interconnections
|
|
98
|
+
platform.should have(7).components
|
|
99
|
+
end
|
|
100
|
+
|
|
101
|
+
it "should be able to load the subcomponents of the platform" do
|
|
102
|
+
design_docs = IPXACT::load_designs(PLATFORM_PATH)
|
|
103
|
+
component_docs = IPXACT::load_components(PLATFORM_PATH)
|
|
104
|
+
platform = IPXACT::Parser::PlatformData.parse_platform(["Leon2Platform", "1.1"], component_docs, design_docs)
|
|
105
|
+
platform.components['i_ahb'].should have(0).subcomponents
|
|
106
|
+
platform.components['i_ahb'].should have(0).interconnections
|
|
107
|
+
platform.components['i_sub'].should have(4).subcomponents
|
|
108
|
+
platform.components['i_sub'].should have(5).interconnections
|
|
109
|
+
platform.components['i_sub'][:version].should == "1.1"
|
|
110
|
+
platform.should have(0).ports
|
|
111
|
+
end
|
|
112
|
+
|
|
113
|
+
it "should be able to load component ports" do
|
|
114
|
+
design_docs = IPXACT::load_designs(PLATFORM_PATH)
|
|
115
|
+
component_docs = IPXACT::load_components(PLATFORM_PATH)
|
|
116
|
+
platform = IPXACT::Parser::PlatformData.parse_platform(["Leon2Platform", "1.1"], component_docs, design_docs)
|
|
117
|
+
ahb = platform.components['i_ahb']
|
|
118
|
+
ahb.should have(4).ports
|
|
119
|
+
end
|
|
120
|
+
end
|
|
121
|
+
end
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
/*****************************************************************************
|
|
2
|
+
Revision: $Revision: 1506 $
|
|
3
|
+
Date: $Date: 2009-04-26 01:51:56 -0500 (Sun, 26 Apr 2009) $
|
|
4
|
+
|
|
5
|
+
Copyright (c) 2008, 2009 The SPIRIT Consortium.
|
|
6
|
+
|
|
7
|
+
This work forms part of a deliverable of The SPIRIT Consortium.
|
|
8
|
+
|
|
9
|
+
Use of these materials are governed by the legal terms and conditions
|
|
10
|
+
outlined in the disclaimer available from www.spiritconsortium.org.
|
|
11
|
+
|
|
12
|
+
This source file is provided on an AS IS basis. The SPIRIT
|
|
13
|
+
Consortium disclaims any warranty express or implied including
|
|
14
|
+
any warranty of merchantability and fitness for use for a
|
|
15
|
+
particular purpose.
|
|
16
|
+
|
|
17
|
+
The user of the source file shall indemnify and hold The SPIRIT
|
|
18
|
+
Consortium and its members harmless from any damages or liability.
|
|
19
|
+
Users are requested to provide feedback to The SPIRIT Consortium
|
|
20
|
+
using either mailto:feedback@lists.spiritconsortium.org or the forms at
|
|
21
|
+
http://www.spiritconsortium.org/about/contact_us/
|
|
22
|
+
|
|
23
|
+
This file may be copied, and distributed, with or without
|
|
24
|
+
modifications; but these notices must be included on any copy.
|
|
25
|
+
|
|
26
|
+
The following code is derived, directly or indirectly, from the SystemC
|
|
27
|
+
source code Copyright (c) 1996-2004 by all Contributors.
|
|
28
|
+
All Rights reserved.
|
|
29
|
+
|
|
30
|
+
The contents of this file are subject to the restrictions and limitations
|
|
31
|
+
set forth in the SystemC Open Source License Version 2.4 (the "License");
|
|
32
|
+
You may not use this file except in compliance with such restrictions and
|
|
33
|
+
limitations. You may obtain instructions on how to receive a copy of the
|
|
34
|
+
License at http://www.systemc.org/. Software distributed by Contributors
|
|
35
|
+
under the License is distributed on an "AS IS" basis, WITHOUT WARRANTY OF
|
|
36
|
+
ANY KIND, either express or implied. See the License for the specific
|
|
37
|
+
language governing rights and limitations under the License.
|
|
38
|
+
|
|
39
|
+
*****************************************************************************/
|
|
40
|
+
|
|
41
|
+
|
|
42
|
+
#ifndef _PV_INITIATOR_PORT_H_
|
|
43
|
+
#define _PV_INITIATOR_PORT_H_
|
|
44
|
+
|
|
45
|
+
/*------------------------------------------------------------------------------
|
|
46
|
+
* Includes
|
|
47
|
+
*----------------------------------------------------------------------------*/
|
|
48
|
+
#include <vector>
|
|
49
|
+
|
|
50
|
+
#include "systemc.h"
|
|
51
|
+
|
|
52
|
+
#include "tlm.h"
|
|
53
|
+
|
|
54
|
+
#include "pv_tlm_if.h"
|
|
55
|
+
#include "pv_initiator_port_base.h"
|
|
56
|
+
#include "pv_target_port.h"
|
|
57
|
+
|
|
58
|
+
//----------------------------------------------------------------------------
|
|
59
|
+
template<typename ADDRESS,typename DATA,int N = 1>
|
|
60
|
+
class pv_initiator_port :
|
|
61
|
+
public sc_port<tlm::tlm_transport_if<pv_request<ADDRESS,DATA>,pv_response<DATA> >, N>,
|
|
62
|
+
public pv_initiator_port_base,
|
|
63
|
+
public virtual pv_tlm_if<ADDRESS,DATA> {
|
|
64
|
+
|
|
65
|
+
typedef pv_request<ADDRESS,DATA> request_type;
|
|
66
|
+
typedef pv_response<DATA> response_type;
|
|
67
|
+
|
|
68
|
+
typedef tlm::tlm_transport_if<request_type,response_type> interface_type;
|
|
69
|
+
|
|
70
|
+
typedef sc_export<interface_type> sc_target_port_type;
|
|
71
|
+
typedef sc_port<interface_type,N> sc_initiator_port_type;
|
|
72
|
+
|
|
73
|
+
typedef pv_target_port<ADDRESS,DATA> pv_target_port_type;
|
|
74
|
+
typedef pv_initiator_port<ADDRESS,DATA,N> pv_initiator_port_type;
|
|
75
|
+
|
|
76
|
+
typedef pv_target_port_base target_port_base_type;
|
|
77
|
+
typedef pv_initiator_port_base initiator_port_base_type;
|
|
78
|
+
|
|
79
|
+
public:
|
|
80
|
+
|
|
81
|
+
//--------------
|
|
82
|
+
// Constructor
|
|
83
|
+
//--------------
|
|
84
|
+
pv_initiator_port(const char * port_name);
|
|
85
|
+
|
|
86
|
+
|
|
87
|
+
//---------------------------------------
|
|
88
|
+
// Execute the transaction transfer
|
|
89
|
+
void do_transport(request_type& request,
|
|
90
|
+
response_type& response,
|
|
91
|
+
unsigned int target_port_rank = 0);
|
|
92
|
+
|
|
93
|
+
//-------------------------------------------------------------------
|
|
94
|
+
//Abstract class pv_tlm_if methods implementation: used as convenience API
|
|
95
|
+
|
|
96
|
+
virtual tlm::tlm_status read(const ADDRESS& address,
|
|
97
|
+
DATA& data,
|
|
98
|
+
const unsigned int byte_enable = tlm::NO_BE,
|
|
99
|
+
const tlm::tlm_mode mode = tlm::REGULAR,
|
|
100
|
+
const unsigned int export_id = 0
|
|
101
|
+
);
|
|
102
|
+
|
|
103
|
+
virtual tlm::tlm_status write(const ADDRESS& address,
|
|
104
|
+
const DATA& data,
|
|
105
|
+
const unsigned int byte_enable = tlm::NO_BE,
|
|
106
|
+
const tlm::tlm_mode mode = tlm::REGULAR,
|
|
107
|
+
const unsigned int export_id = 0
|
|
108
|
+
);
|
|
109
|
+
|
|
110
|
+
//------------------
|
|
111
|
+
//Additional methods
|
|
112
|
+
void before_end_of_elaboration();
|
|
113
|
+
void end_of_elaboration();
|
|
114
|
+
|
|
115
|
+
void bind(pv_target_port_type&);
|
|
116
|
+
void operator() (pv_target_port_type&);
|
|
117
|
+
|
|
118
|
+
void bind(sc_port_b<interface_type>&);
|
|
119
|
+
void operator() (sc_port_b<interface_type>&);
|
|
120
|
+
|
|
121
|
+
void bind(interface_type&);
|
|
122
|
+
void operator() (interface_type&);
|
|
123
|
+
|
|
124
|
+
protected:
|
|
125
|
+
bool is_interface_bound_twice(sc_export_base&);
|
|
126
|
+
};
|
|
127
|
+
|
|
128
|
+
|
|
129
|
+
|
|
130
|
+
// Class implementation
|
|
131
|
+
#include "./pv_initiator_port.tpp"
|
|
132
|
+
|
|
133
|
+
#endif /* _PV_INITIATOR_PORT_H_ */
|
|
134
|
+
|
|
135
|
+
|