-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathVendorScripts_Visualizer.tcl
362 lines (313 loc) · 11.9 KB
/
VendorScripts_Visualizer.tcl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
# File Name: VendorScripts_Visualizer.tcl
# Purpose: Scripts for running simulations
# Revision: OSVVM MODELS STANDARD VERSION
#
# Maintainer: Jim Lewis email: jim@synthworks.com
# Contributor(s):
# Jim Lewis email: jim@synthworks.com
#
# Description
# Tcl procedures with the intent of making running
# compiling and simulations tool independent
#
# Developed by:
# SynthWorks Design Inc.
# VHDL Training Classes
# OSVVM Methodology and Model Library
# 11898 SW 128th Ave. Tigard, Or 97223
# http://www.SynthWorks.com
#
# Revision History:
# Date Version Description
# 7/2024 2024.07 Initial. Derived from VendorScripts_Siemens
#
#
# This file is part of OSVVM.
#
# Copyright (c) 2018 - 2024 by SynthWorks Design Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
package require fileutil
# -------------------------------------------------
# Tool Settings
#
variable ToolType "simulator"
variable ToolVendor "Siemens"
if {![catch {vsimVersionString} msg]} {
set VersionString [vsimVersionString]
} else {
set VersionString [exec vsim -version]
}
if {[info exists ::ToolName]} {
variable ToolName $::ToolName
} else {
variable ToolName "Visualizer"
}
variable simulator $ToolName ; # Variable simulator is deprecated. Use ToolName instead
if {![catch {batch_mode} msg]} {
variable shell ""
variable SiemensSimulateOptions ""
if {[batch_mode]} {
variable ToolArgs $argv
variable NoGui "true"
variable SiemensSimulateOptions "-batch"
variable DebugOptions "-debug"
} else {
variable ToolArgs "-gui"
variable NoGui "false"
variable SiemensSimulateOptions "-visualizer"
variable DebugOptions "-debug,livesim"
}
} else {
# Started from Shell
variable shell "exec"
variable ToolArgs "none"
variable NoGui "true"
variable SiemensSimulateOptions "-batch"
variable DebugOptions "-debug"
}
if {![catch {vsimId} msg]} {
variable ToolVersion [vsimId]
} else {
variable ToolVersion tbd
}
SetVHDLVersion 2019
# Set if not set
if {![info exists ::VoptArgs]} {
set ::VoptArgs " "
}
if {![info exists ::VsimArgs]} {
set ::VsimArgs " "
}
# variable ToolVersion [vsimVersion]
variable ToolNameVersion ${ToolName}-${ToolVersion}
# puts $ToolNameVersion
# -------------------------------------------------
# StartTranscript / StopTranscxript
#
proc vendor_StartTranscript {FileName} {
variable NoGui
# puts "NoGui: $NoGui"
if {$NoGui} {
DefaultVendor_StartTranscript $FileName
} else {
transcript file ""
echo transcript file $FileName
transcript file $FileName
}
}
proc vendor_StopTranscript {FileName} {
variable NoGui
# FileName not used here
# transcript file ""
if {$NoGui} {
DefaultVendor_StopTranscript $FileName
} else {
transcript file ""
}
}
# -------------------------------------------------
# IsVendorCommand
#
proc IsVendorCommand {LineOfText} {
return [regexp {^vlib |^vmap |^vcom |^vlog |^vsim |^run |^coverage |^vcover } $LineOfText]
}
# -------------------------------------------------
# SetCoverageAnalyzeOptions
# SetCoverageCoverageOptions
#
proc vendor_SetCoverageAnalyzeDefaults {} {
variable CoverageAnalyzeOptions
# set CoverageAnalyzeOptions "+cover=bcesft"
set CoverageAnalyzeOptions "+cover=bsf"
}
proc vendor_SetCoverageSimulateDefaults {} {
variable CoverageSimulateOptions
set CoverageSimulateOptions "-coverage"
}
# -------------------------------------------------
# Library
#
proc vendor_library {LibraryName PathToLib} {
set PathAndLib [::fileutil::relative [pwd] ${PathToLib}/${LibraryName}]
if {![file exists ${PathAndLib}]} {
puts "vlib ${PathAndLib} "
eval $::osvvm::shell vlib ${PathAndLib}
}
puts "vmap $LibraryName ${PathAndLib}"
eval $::osvvm::shell vmap $LibraryName ${PathAndLib}
}
proc vendor_LinkLibrary {LibraryName PathToLib} {
set PathAndLib [::fileutil::relative [pwd] ${PathToLib}/${LibraryName}]
if {[file exists ${PathAndLib}]} {
set ResolvedLib ${PathAndLib}
} else {
set ResolvedLib ${PathToLib}
}
puts "vmap $LibraryName ${ResolvedLib}"
eval $::osvvm::shell vmap $LibraryName ${ResolvedLib}
}
proc vendor_UnlinkLibrary {LibraryName PathToLib} {
eval $::osvvm::shell vmap -del ${LibraryName}
}
# -------------------------------------------------
# analyze
#
proc vendor_analyze_vhdl {LibraryName FileName args} {
variable VhdlVersion
set AnalyzeOptions [concat -${VhdlVersion} -work ${LibraryName} {*}${args} ${FileName}]
# puts "vcom $AnalyzeOptions"
eval $::osvvm::shell vcom {*}$AnalyzeOptions
}
proc vendor_analyze_verilog {LibraryName FileName args} {
set AnalyzeOptions [concat [CreateVerilogLibraryParams "-L "] -work ${LibraryName} {*}${args} ${FileName}]
# puts "vlog $AnalyzeOptions"
eval $::osvvm::shell vlog {*}$AnalyzeOptions
}
# -------------------------------------------------
# End Previous Simulation
#
proc vendor_end_previous_simulation {} {
global SourceMap
variable NoGui
# close junk in source window
if {! $NoGui} {
catch {noview source}
catch {noview source}
}
puts "quit -sim"
quit -sim
}
# -------------------------------------------------
# vendor_simulate
#
# Note about ignored vsim warnings:
# During simulation OSVVM suppresses QuestaSim/ModelSim messages 8683 and 8684.
# These are warnings about potential issues with port drivers due to QuestaSim/ModelSim
# using non-VHDL compliant optimizations. The potential issues these warn about
# do not occur with OSVVM interfaces. As a result, these warnings are suppressed
# because they consume significant time at the startup of simulations.
#
# You can learn more about these messages by doing “verror 8683” or “verror 8684”
# from within the tool GUI.
#
# verror 8683
# ------------------------------------------
#
# An output port has no default expression in its declaration and has no drivers.
# The VHDL LRM-compliant value it propagates to higher-level connected signals may
# not be what is desired. In particular, this behavior might not correspond to
# the synthesis view of initialization. The vsim switch "-defaultstdlogicinittoz"
# or "-forcestdlogicinittoz" may be useful in this situation.
#
# OSVVM Analysis of Message # 8683
# ------------------------------------------
#
# OSVVM interfaces that is used to connect VC to the test sequencer (TestCtrl) use
# minimum as a resolution function. Driving the default value (type'left) on a
# signal has no negative impact. Hence, OSVVM disables this warning since it does
# not apply.
#
# verror 8684
# ------------------------------------------
#
# An output port having no drivers has been combined with a higher-level connected
# signal. The port will get its initial value from this higher-level connected
# signal; this is not compliant with the behavior required by the VHDL LRM.
#
# LRM compliant behavior would require the port's initial value come from its
# declaration, however, since it was combined or collapsed with the port or signal
# higher in the hierarchy, the initial value came from that port or signal.
#
# LRM compliant behavior can be obtained by preventing the collapsing of these ports
# with the vsim switch -donotcollapsepartiallydriven. If the port is collapsed to a
# port or signal with the same initialization (as is often the case of default
# initializations being applied), there is no problem and the proper initialization
# is done and the simulation is LRM compliant.
#
# OSVVM Analysis of Message # 8684
# ------------------------------------------
#
# Older OSVVM VC use records whose elements are std_logic_vector. These VC
# initialize port values to 'Z'. QuestaSim non-VHDL compliant optimizations, such as
# port collapsing, remove these values. If you are using older OSVVM verification
# components, you can avoid any impact of this non compliant behavior if you initialize
# the transaction interface signal in the test harness to all 'Z'.
#
# Hence, OSVVM disables this warning since it does not apply if you use the due
# care recommended above.
#
# OSVVM recommends that you migrate older interfaces to the newer that uses types
# and resolution functions defined in ResolutionPkg such as std_logic_max,
# std_logic_vector_max, or std_logic_vector_max_c rather than std_logic or
# std_logic_vector. ResolutionPkg supports a richer set of types, such as
# integer_max, real_max, ...
#
proc vendor_simulate {LibraryName LibraryUnit args} {
variable OsvvmScriptDirectory
variable SimulateTimeUnits
variable TestSuiteName
variable TestCaseFileName
if {($::osvvm::NoGui) || !($::osvvm::Debug)} {
set OptimizeOptions $::osvvm::DebugOptions
} else {
set OptimizeOptions " "
}
set OptimizeOptions [concat $::VoptArgs $OptimizeOptions -work ${LibraryName} -L ${LibraryName} ${LibraryUnit} ${::osvvm::SecondSimulationTopLevel} -o ${LibraryUnit}_opt ]
set LocalTestSuiteDirectory [file join ${::osvvm::CurrentSimulationDirectory} ${::osvvm::ReportsDirectory} ${::osvvm::TestSuiteName}]
puts "vopt {*}${OptimizeOptions} -designfile [file join ${LocalTestSuiteDirectory} ${TestCaseFileName}_design.bin]"
eval $::osvvm::shell vopt {*}${OptimizeOptions} -quiet -designfile [file join ${LocalTestSuiteDirectory} ${TestCaseFileName}_design.bin]
if {$::osvvm::SaveWaves} {
set WaveOptions "-qwavedb=+signals+wavefile=[file join ${LocalTestSuiteDirectory} ${TestCaseFileName}_qwave.db]"
} else {
set WaveOptions ""
}
set SimulateOptions [concat $::VsimArgs $::osvvm::SiemensSimulateOptions -t $SimulateTimeUnits -lib ${LibraryName} ${LibraryUnit}_opt ${::osvvm::SecondSimulationTopLevel} {*}${args} {*}${::osvvm::GenericOptions} -suppress 8683 -suppress 8684]
puts "vsim {*}${SimulateOptions} ${WaveOptions}"
eval $::osvvm::shell vsim {*}${SimulateOptions} ${WaveOptions}
# Historical name. Must be run with "do" for actions to work
if {[file exists ${OsvvmScriptDirectory}/Siemens.do]} {
do ${OsvvmScriptDirectory}/Siemens.do
}
SimulateRunScripts ${LibraryUnit}
run -all
if {$::osvvm::CoverageEnable && $::osvvm::CoverageSimulateEnable} {
coverage save ${::osvvm::CoverageDirectory}/${TestSuiteName}/${TestCaseFileName}.ucdb
}
}
# -------------------------------------------------
proc vendor_generic {Name Value} {
return "-g${Name}=${Value}"
}
# -------------------------------------------------
# Merge Coverage
#
proc vendor_MergeCodeCoverage {TestSuiteName CoverageDirectory BuildName} {
set CoverageFileBaseName [file join ${CoverageDirectory} ${BuildName} ${TestSuiteName}]
set CovFiles [glob -nocomplain ${CoverageDirectory}/${TestSuiteName}/*.ucdb]
if {$CovFiles ne ""} {
eval $::osvvm::shell vcover merge ${CoverageFileBaseName}.ucdb {*}$CovFiles
}
}
proc vendor_ReportCodeCoverage {TestSuiteName CodeCoverageDirectory} {
set CodeCovResultsDir ${CodeCoverageDirectory}/${TestSuiteName}_code_cov
if {[file exists $CodeCovResultsDir]} {
file delete -force -- $CodeCovResultsDir
}
eval $::osvvm::shell vcover report -html -annotate -details -verbose -output ${CodeCovResultsDir} ${CodeCoverageDirectory}/${TestSuiteName}.ucdb
}
proc vendor_GetCoverageFileName {TestName} {
set CoverageFileName ${TestName}_code_cov/index.html
return $CoverageFileName
}