ruby-vpi 13.0.0 → 14.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (123) hide show
  1. data/Rakefile +6 -1
  2. data/bin/generate_test_tpl/bench.rb +84 -1
  3. data/bin/generate_test_tpl/bench.v +8 -17
  4. data/bin/generate_test_tpl/proto.rb +1 -1
  5. data/doc/common.css +14 -41
  6. data/doc/common.tpl +1 -1
  7. data/doc/figures/figures.dia +274 -753
  8. data/doc/figures/organization_detailed.png +0 -0
  9. data/doc/figures/ruby_relay.png +0 -0
  10. data/doc/history.html +363 -276
  11. data/doc/history.yml +40 -0
  12. data/doc/intro.inc +37 -15
  13. data/doc/lib/doc_proxy.rb +24 -4
  14. data/doc/manual.doc +345 -196
  15. data/doc/manual.html +741 -497
  16. data/doc/memo.doc +15 -15
  17. data/doc/memo.html +28 -27
  18. data/doc/readme.doc +2 -2
  19. data/doc/readme.html +51 -15
  20. data/doc/rss.erb +1 -1
  21. data/doc/rss.xml +1624 -31
  22. data/ext/Rakefile +1 -6
  23. data/ext/main.c +8 -3
  24. data/ext/main.h +5 -0
  25. data/ext/relay.c +12 -12
  26. data/ext/relay.h +1 -6
  27. data/ext/swig_vpi.i +2 -2
  28. data/ext/swig_wrap.cin +37 -20
  29. data/ext/verilog.h +2 -2
  30. data/ext/vlog.c +10 -3
  31. data/ext/vlog.h +4 -4
  32. data/lib/ruby-vpi/vpi.rb +114 -0
  33. data/lib/ruby-vpi.rb +21 -59
  34. data/ref/c/annotated.html +1 -1
  35. data/ref/c/common_8h.html +1 -1
  36. data/ref/c/files.html +1 -1
  37. data/ref/c/functions.html +1 -1
  38. data/ref/c/functions_vars.html +1 -1
  39. data/ref/c/globals.html +1 -1
  40. data/ref/c/globals_0x63.html +1 -1
  41. data/ref/c/globals_0x65.html +1 -1
  42. data/ref/c/globals_0x66.html +1 -1
  43. data/ref/c/globals_0x6d.html +3 -2
  44. data/ref/c/globals_0x70.html +1 -1
  45. data/ref/c/globals_0x72.html +4 -5
  46. data/ref/c/globals_0x73.html +1 -1
  47. data/ref/c/globals_0x74.html +1 -1
  48. data/ref/c/globals_0x76.html +4 -2
  49. data/ref/c/globals_0x78.html +1 -1
  50. data/ref/c/globals_defs.html +1 -1
  51. data/ref/c/globals_defs_0x65.html +1 -1
  52. data/ref/c/globals_defs_0x70.html +1 -1
  53. data/ref/c/globals_defs_0x76.html +1 -1
  54. data/ref/c/globals_defs_0x78.html +1 -1
  55. data/ref/c/globals_enum.html +1 -1
  56. data/ref/c/globals_eval.html +1 -1
  57. data/ref/c/globals_func.html +8 -7
  58. data/ref/c/globals_type.html +1 -1
  59. data/ref/c/globals_vars.html +3 -2
  60. data/ref/c/index.html +1 -1
  61. data/ref/c/main_8c.html +26 -1
  62. data/ref/c/main_8h.html +26 -1
  63. data/ref/c/relay_8c.html +11 -35
  64. data/ref/c/relay_8h.html +3 -27
  65. data/ref/c/structt__cb__data.html +1 -1
  66. data/ref/c/structt__vpi__delay.html +1 -1
  67. data/ref/c/structt__vpi__error__info.html +1 -1
  68. data/ref/c/structt__vpi__strengthval.html +1 -1
  69. data/ref/c/structt__vpi__systf__data.html +1 -1
  70. data/ref/c/structt__vpi__time.html +1 -1
  71. data/ref/c/structt__vpi__value.html +1 -1
  72. data/ref/c/structt__vpi__vecval.html +1 -1
  73. data/ref/c/structt__vpi__vlog__info.html +1 -1
  74. data/ref/c/verilog_8h.html +5 -5
  75. data/ref/c/vlog_8c.html +44 -6
  76. data/ref/c/vlog_8h.html +7 -8
  77. data/ref/c/vpi__user_8h.html +1 -1
  78. data/ref/ruby/classes/RDoc.html +5 -5
  79. data/ref/ruby/classes/RDoc.src/{M000041.html → M000045.html} +0 -0
  80. data/ref/ruby/classes/RubyVpi.html +10 -28
  81. data/ref/ruby/classes/RubyVpi.src/M000029.html +101 -124
  82. data/ref/ruby/classes/Vpi/Handle.html +56 -56
  83. data/ref/ruby/classes/Vpi/Handle.src/M000034.html +5 -9
  84. data/ref/ruby/classes/Vpi/Handle.src/M000035.html +5 -31
  85. data/ref/ruby/classes/Vpi/Handle.src/M000036.html +5 -74
  86. data/ref/ruby/classes/Vpi/Handle.src/M000037.html +5 -17
  87. data/ref/ruby/classes/Vpi/Handle.src/M000038.html +9 -11
  88. data/ref/ruby/classes/Vpi/Handle.src/M000039.html +44 -0
  89. data/ref/ruby/classes/Vpi/Handle.src/M000040.html +74 -55
  90. data/ref/ruby/classes/Vpi/Handle.src/M000041.html +30 -0
  91. data/ref/ruby/classes/Vpi/Handle.src/M000042.html +24 -0
  92. data/ref/ruby/classes/Vpi/Handle.src/M000044.html +68 -0
  93. data/ref/ruby/classes/Vpi.html +149 -0
  94. data/ref/ruby/classes/Vpi.src/M000030.html +28 -0
  95. data/ref/ruby/classes/Vpi.src/M000031.html +18 -0
  96. data/ref/ruby/classes/Vpi.src/M000032.html +39 -0
  97. data/ref/ruby/classes/Vpi.src/M000033.html +22 -0
  98. data/ref/ruby/created.rid +1 -1
  99. data/ref/ruby/files/lib/ruby-vpi/vpi_rb.html +1 -1
  100. data/ref/ruby/files/lib/ruby-vpi_rb.html +2 -2
  101. data/ref/ruby/fr_method_index.html +18 -14
  102. data/samp/counter/counter_rspec_bench.rb +81 -1
  103. data/samp/counter/counter_rspec_bench.v +5 -12
  104. data/samp/counter/counter_rspec_design.rb +1 -2
  105. data/samp/counter/counter_rspec_proto.rb +1 -1
  106. data/samp/counter/counter_rspec_spec.rb +3 -3
  107. data/samp/counter/counter_xunit_bench.rb +81 -1
  108. data/samp/counter/counter_xunit_bench.v +5 -12
  109. data/samp/counter/counter_xunit_design.rb +1 -2
  110. data/samp/counter/counter_xunit_proto.rb +1 -1
  111. data/samp/counter/counter_xunit_spec.rb +3 -3
  112. data/samp/pipelined_alu/hw5_unit_test_bench.rb +81 -1
  113. data/samp/pipelined_alu/hw5_unit_test_bench.v +11 -18
  114. data/samp/pipelined_alu/hw5_unit_test_design.rb +1 -1
  115. data/samp/pipelined_alu/hw5_unit_test_proto.rb +1 -1
  116. data/samp/pipelined_alu/hw5_unit_test_spec.rb +1 -1
  117. metadata +12 -9
  118. data/doc/figures/ruby_init.png +0 -0
  119. data/ext/swig_vpi.h +0 -924
  120. data/ref/ruby/classes/Vpi/Handle.src/M000030.html +0 -18
  121. data/ref/ruby/classes/Vpi/Handle.src/M000031.html +0 -18
  122. data/ref/ruby/classes/Vpi/Handle.src/M000032.html +0 -18
  123. data/ref/ruby/classes/Vpi/Handle.src/M000033.html +0 -18
data/doc/rss.xml CHANGED
@@ -4,218 +4,1792 @@
4
4
  <title>Ruby-VPI</title>
5
5
  <link>http://ruby-vpi.rubyforge.org</link>
6
6
  <description>Ruby-VPI is a Ruby interface to IEEE 1364-2005 Verilog VPI. It lets you create complex Verilog test benches easily and wholly in Ruby.</description>
7
+ <item>
8
+ <title>Version 14.0.0 released</title>
9
+ <link>http://ruby-vpi.rubyforge.org/doc/history.html#14.0.0</link>
10
+ <guid>http://ruby-vpi.rubyforge.org/doc/history.html#14.0.0</guid>
11
+ <description>&lt;h1 id=&quot;14.0.0&quot;&gt;Version 14.0.0 (2006-12-30)&lt;/h1&gt;
12
+
13
+
14
+ &lt;h2&gt;Summary&lt;/h2&gt;
15
+
16
+
17
+ &lt;p&gt;This release adds support for simulation callbacks, renders Verilog benches &lt;em&gt;fully simplified&lt;/em&gt;, and revises the user manual to reflect major changes.&lt;/p&gt;
18
+
19
+
20
+ &lt;h2&gt;Notice&lt;/h2&gt;
21
+
22
+
23
+ &lt;ul&gt;
24
+ &lt;li&gt;The &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::relay_verilog&lt;/code&gt; method has been replaced by &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::simulate&lt;/code&gt;.
25
+
26
+ &lt;p&gt;Please update you tests accordingly, because invoking the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::relay_verilog&lt;/code&gt; method directly will cause your tests to freeze/hang.&lt;/p&gt;&lt;/li&gt;
27
+ &lt;/ul&gt;
28
+
29
+
30
+ &lt;ul&gt;
31
+ &lt;li&gt;Verilog benches no longer contain any clock generation code. They are now mere skeletons, whose &lt;em&gt;only&lt;/em&gt; purpose is to instantiate the design under test.
32
+
33
+ &lt;p&gt;The clock generation code is now contained in the Ruby bench.&lt;/p&gt;&lt;/li&gt;
34
+ &lt;/ul&gt;
35
+
36
+
37
+ &lt;h3&gt;New features&lt;/h3&gt;
38
+
39
+
40
+ &lt;ul&gt;
41
+ &lt;li&gt;The &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;RubyVpi&lt;/span&gt;::init_bench&lt;/code&gt; method now gives you &lt;em&gt;complete control&lt;/em&gt; over performing a clock/operation/whatever cycle for your design. This feature allows you to work with multi-clocked designs.&lt;/li&gt;
42
+ &lt;/ul&gt;
43
+
44
+
45
+ &lt;ul&gt;
46
+ &lt;li&gt;Callbacks are now supported through the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::vpi_register_cb&lt;/code&gt; method. See &lt;a href=&quot;manual.html#usage.vpi.callbacks&quot;&gt;the callbacks section in the user manual&lt;/a&gt; for details.&lt;/li&gt;
47
+ &lt;/ul&gt;
48
+
49
+
50
+ &lt;ul&gt;
51
+ &lt;li&gt;Added the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::advance_time&lt;/code&gt; method, which makes the Verilog simulator simulate a given number of time steps.&lt;/li&gt;
52
+ &lt;/ul&gt;
53
+
54
+
55
+ &lt;ul&gt;
56
+ &lt;li&gt;Added the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::simulation_time&lt;/code&gt; method, which gives you the current simulation time as a 64-bit integer.&lt;/li&gt;
57
+ &lt;/ul&gt;
58
+
59
+
60
+ &lt;h2&gt;Details&lt;/h2&gt;
61
+
62
+
63
+ &lt;ul&gt;
64
+ &lt;li&gt;Removed the monkey patch for the &lt;span class=&quot;caps&quot;&gt;SWIG&lt;/span&gt; &lt;code class=&quot;code&quot;&gt;va_list&lt;/code&gt; problem&amp;#8212;it no longer occurs.&lt;/li&gt;
65
+ &lt;/ul&gt;
66
+
67
+
68
+ &lt;ul&gt;
69
+ &lt;li&gt;Cleansed the appearance of the user documentation.
70
+ &lt;ul&gt;
71
+ &lt;li&gt;Added indices to section headings, just like LaTeX.&lt;/li&gt;
72
+ &lt;li&gt;Admonition boxes no longer interfere with surrounding text, and they don&amp;#8217;t have big gap above them.&lt;/li&gt;
73
+ &lt;li&gt;Navigation menu is now elastic (fluid layout).&lt;/li&gt;
74
+ &lt;/ul&gt;&lt;/li&gt;
75
+ &lt;/ul&gt;
76
+
77
+
78
+ &lt;ul&gt;
79
+ &lt;li&gt;Revised the user manual and added new content.
80
+ &lt;ul&gt;
81
+ &lt;li&gt;Moved &amp;#8220;VPI utility layer&amp;#8221; section from background chapter into usage chapter in user manual.&lt;/li&gt;
82
+ &lt;li&gt;Added a nice introduction to entire manual with links to reference documentation.&lt;/li&gt;
83
+ &lt;/ul&gt;&lt;/li&gt;
84
+ &lt;/ul&gt;</description>
85
+ <pubDate>Sat, 30 Dec 2006 00:00:00 PST</pubDate>
86
+ </item>
7
87
  <item>
8
88
  <title>Version 13.0.0 released</title>
9
89
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#13.0.0</link>
10
90
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#13.0.0</guid>
11
- <description>&lt;p&gt;This release fixes a &lt;em&gt;major&lt;/em&gt; instability bug, simplifies generated Verilog benches, and purifies the &lt;span class=&quot;caps&quot;&gt;API&lt;/span&gt; reference documentation.&lt;/p&gt;</description>
91
+ <description>&lt;h1 id=&quot;13.0.0&quot;&gt;Version 13.0.0 (2006-12-27)&lt;/h1&gt;
92
+
93
+
94
+ &lt;h2&gt;Summary&lt;/h2&gt;
95
+
96
+
97
+ &lt;p&gt;This release fixes a &lt;em&gt;major&lt;/em&gt; instability bug, simplifies generated Verilog benches, and purifies the &lt;span class=&quot;caps&quot;&gt;API&lt;/span&gt; reference documentation.&lt;/p&gt;
98
+
99
+
100
+ &lt;h2&gt;Notice&lt;/h2&gt;
101
+
102
+
103
+ &lt;ul&gt;
104
+ &lt;li&gt;The &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#d70; font-weight:bold&quot;&gt;$ruby_init&lt;/span&gt;&lt;/code&gt; and &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#d70; font-weight:bold&quot;&gt;$ruby_relay&lt;/span&gt;&lt;/code&gt; system task/functions have been removed. Generated Verilog benches no longer use them.
105
+ &lt;ul&gt;
106
+ &lt;li&gt;To pass your own command-line options to Ruby, set the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;RUBYOPT&lt;/span&gt;&lt;/code&gt; environment variable before running a test.&lt;/li&gt;
107
+ &lt;/ul&gt;&lt;/li&gt;
108
+ &lt;/ul&gt;
109
+
110
+
111
+ &lt;h3&gt;New features&lt;/h3&gt;
112
+
113
+
114
+ &lt;ul&gt;
115
+ &lt;li&gt;You can now choose when &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::relay_verilog&lt;/code&gt; is triggered: upon positive/negative edge of the clock signal, or any other criteria. This is done by passing a block to the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;RubyVpi&lt;/span&gt;::init_bench&lt;/code&gt; method (see &lt;a href=&quot;../ref/ruby/classes/RubyVpi.html&quot;&gt;the &lt;span class=&quot;caps&quot;&gt;API&lt;/span&gt; reference documentation&lt;/a&gt; for details).&lt;/li&gt;
116
+ &lt;/ul&gt;
117
+
118
+
119
+ &lt;h2&gt;Details&lt;/h2&gt;
120
+
121
+
122
+ &lt;ul&gt;
123
+ &lt;li&gt;Fixed a major instability bug that was randomly causing segmentation faults and pthread assertion failures.
124
+
125
+ &lt;p&gt;The problem was that the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#d70; font-weight:bold&quot;&gt;$ruby_init&lt;/span&gt;&lt;/code&gt; system task/function was mischeviously unlocking a pthread mutex. From then onward, all code assumed that the mutex was still locked&amp;#8212;but in reality, the mutex was already unlocked.&lt;/p&gt;&lt;/li&gt;
126
+ &lt;/ul&gt;
127
+
128
+
129
+ &lt;ul&gt;
130
+ &lt;li&gt;Replaced the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#d70; font-weight:bold&quot;&gt;$ruby_init&lt;/span&gt;&lt;/code&gt; and &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#d70; font-weight:bold&quot;&gt;$ruby_relay&lt;/span&gt;&lt;/code&gt; system task/functions with callbacks.&lt;/li&gt;
131
+ &lt;/ul&gt;
132
+
133
+
134
+ &lt;ul&gt;
135
+ &lt;li&gt;Excluded internal stuff from the &lt;span class=&quot;caps&quot;&gt;API&lt;/span&gt; reference documentation for Ruby.&lt;/li&gt;
136
+ &lt;/ul&gt;
137
+
138
+
139
+ &lt;ul&gt;
140
+ &lt;li&gt;Removed system-dependent path &lt;tt&gt;/usr/bin/ruby&lt;/tt&gt; from the tools.&lt;/li&gt;
141
+ &lt;/ul&gt;</description>
12
142
  <pubDate>Wed, 27 Dec 2006 00:00:00 PST</pubDate>
13
143
  </item>
14
144
  <item>
15
145
  <title>Version 12.1.0 released</title>
16
146
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#12.1.0</link>
17
147
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#12.1.0</guid>
18
- <description>&lt;p&gt;This release adds interactive debugging support, adds new sections to the user manual, and cleanses some internals.&lt;/p&gt;</description>
148
+ <description>&lt;h1 id=&quot;12.1.0&quot;&gt;Version 12.1.0 (2006-12-22)&lt;/h1&gt;
149
+
150
+
151
+ &lt;h2&gt;Summary&lt;/h2&gt;
152
+
153
+
154
+ &lt;p&gt;This release adds interactive debugging support, adds new sections to the user manual, and cleanses some internals.&lt;/p&gt;
155
+
156
+
157
+ &lt;h2&gt;Notice&lt;/h2&gt;
158
+
159
+
160
+ &lt;ul&gt;
161
+ &lt;li&gt;The &lt;tt&gt;lib/ruby-vpi/rspec.rb&lt;/tt&gt; and &lt;tt&gt;lib/ruby-vpi/xx.rb&lt;/tt&gt; files have been removed because they are no longer necessary.&lt;/li&gt;
162
+ &lt;/ul&gt;
163
+
164
+
165
+ &lt;ul&gt;
166
+ &lt;li&gt;rSpec 0.7.0 or newer is now required because the sample tests utilize the &lt;code class=&quot;code&quot;&gt;should ==&lt;/code&gt; syntax.&lt;/li&gt;
167
+ &lt;/ul&gt;
168
+
169
+
170
+ &lt;h3&gt;New features&lt;/h3&gt;
171
+
172
+
173
+ &lt;ul&gt;
174
+ &lt;li&gt;Test runners now support the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;DEBUG&lt;/span&gt;&lt;/code&gt; environment variable, which enables the interactive debugger (ruby-debug) in &lt;a href=&quot;http://www.datanoise.com/articles/2006/12/20/post-mortem-debugging&quot;&gt;post-mortem debugging mode&lt;/a&gt;.
175
+ &lt;ul&gt;
176
+ &lt;li&gt;The &lt;code class=&quot;code&quot;&gt;debugger&lt;/code&gt; command can also be used when the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;DEBUG&lt;/span&gt;&lt;/code&gt; environment variable is not activated.&lt;/li&gt;
177
+ &lt;/ul&gt;&lt;/li&gt;
178
+ &lt;/ul&gt;
179
+
180
+
181
+ &lt;ul&gt;
182
+ &lt;li&gt;Status messages, which are shown during initialization of a Ruby bench, now appear in your simulator&amp;#8217;s log files.&lt;/li&gt;
183
+ &lt;/ul&gt;
184
+
185
+
186
+ &lt;h2&gt;Details&lt;/h2&gt;
187
+
188
+
189
+ &lt;ul&gt;
190
+ &lt;li&gt;ruby-debug is now a gem dependency for Ruby-VPI.&lt;/li&gt;
191
+ &lt;/ul&gt;
192
+
193
+
194
+ &lt;ul&gt;
195
+ &lt;li&gt;Added documentation about &lt;a href=&quot;manual.html#usage.test-runner&quot;&gt;test runners&lt;/a&gt; and the &lt;a href=&quot;manual.html#usage.debugger&quot;&gt;interactive debugger&lt;/a&gt; in the user manual.&lt;/li&gt;
196
+ &lt;/ul&gt;
197
+
198
+
199
+ &lt;ul&gt;
200
+ &lt;li&gt;Added a &lt;tt&gt;README&lt;/tt&gt; file with hint about where to find the user manual.&lt;/li&gt;
201
+ &lt;/ul&gt;
202
+
203
+
204
+ &lt;ul&gt;
205
+ &lt;li&gt;Removed code that wasn&amp;#8217;t being used, according to code coverage analysis, from the pipelined &lt;span class=&quot;caps&quot;&gt;ALU&lt;/span&gt; sample.&lt;/li&gt;
206
+ &lt;/ul&gt;</description>
19
207
  <pubDate>Fri, 22 Dec 2006 00:00:00 PST</pubDate>
20
208
  </item>
21
209
  <item>
22
210
  <title>Version 12.0.2 released</title>
23
211
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#12.0.2</link>
24
212
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#12.0.2</guid>
25
- <description>&lt;p&gt;This release fixes a problem in the 12.0.1 gem, where the &lt;strong&gt;generate_test.rb&lt;/strong&gt; and &lt;strong&gt;header_to_ruby.rb&lt;/strong&gt; tools were not being installed properly.&lt;/p&gt;</description>
213
+ <description>&lt;h1 id=&quot;12.0.2&quot;&gt;Version 12.0.2 (2006-12-18)&lt;/h1&gt;
214
+
215
+
216
+ &lt;h2&gt;Summary&lt;/h2&gt;
217
+
218
+
219
+ &lt;p&gt;This release fixes a problem in the 12.0.1 gem, where the &lt;strong&gt;generate_test.rb&lt;/strong&gt; and &lt;strong&gt;header_to_ruby.rb&lt;/strong&gt; tools were not being installed properly.&lt;/p&gt;</description>
26
220
  <pubDate>Mon, 18 Dec 2006 00:00:00 PST</pubDate>
27
221
  </item>
28
222
  <item>
29
223
  <title>Version 12.0.1 released</title>
30
224
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#12.0.1</link>
31
225
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#12.0.1</guid>
32
- <description>&lt;p&gt;This release fixes a problem in code coverage analysis.&lt;/p&gt;</description>
226
+ <description>&lt;h1 id=&quot;12.0.1&quot;&gt;Version 12.0.1 (2006-12-18)&lt;/h1&gt;
227
+
228
+
229
+ &lt;h2&gt;Summary&lt;/h2&gt;
230
+
231
+
232
+ &lt;p&gt;This release fixes a problem in code coverage analysis.&lt;/p&gt;
233
+
234
+
235
+ &lt;h2&gt;Acknowledgment&lt;/h2&gt;
236
+
237
+
238
+ &lt;p&gt;Thanks to Mauricio Fernandez for helping me solve the problem.&lt;/p&gt;
239
+
240
+
241
+ &lt;h2&gt;Details&lt;/h2&gt;
242
+
243
+
244
+ &lt;p&gt;Previously, code coverage reports were not providing any useful information because they were being generated &lt;em&gt;before&lt;/em&gt; the test had a chance to run. This problem has been fixed&amp;#8212;code coverage reports are now generated &lt;em&gt;after&lt;/em&gt; the test has finished running.&lt;/p&gt;
245
+
246
+
247
+ &lt;p&gt;This problem occurred because I had forgotten that &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Kernel&lt;/span&gt;.at_exit&lt;/code&gt; invokes the blocks passed to it in &lt;em&gt;reverse&lt;/em&gt; order. So, the coverage report was being generated before Test::Unit had a chance to run (it also uses &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Kernel&lt;/span&gt;.at_exit&lt;/code&gt;).&lt;/p&gt;</description>
33
248
  <pubDate>Mon, 18 Dec 2006 00:00:00 PST</pubDate>
34
249
  </item>
35
250
  <item>
36
251
  <title>Version 12.0.0 released</title>
37
252
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#12.0.0</link>
38
253
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#12.0.0</guid>
39
- <description>&lt;p&gt;This release adds support for the &lt;a href=&quot;http://chneukirchen.org/blog/archive/2006/10/announcing-test-spec-0-2-a-bdd-interface-for-test-unit.html&quot;&gt;test/spec&lt;/a&gt; library, fixes some bugs, and improves the user manual and generated tests.&lt;/p&gt;</description>
254
+ <description>&lt;h1 id=&quot;12.0.0&quot;&gt;Version 12.0.0 (2006-12-07)&lt;/h1&gt;
255
+
256
+
257
+ &lt;h2&gt;Summary&lt;/h2&gt;
258
+
259
+
260
+ &lt;p&gt;This release adds support for the &lt;a href=&quot;http://chneukirchen.org/blog/archive/2006/10/announcing-test-spec-0-2-a-bdd-interface-for-test-unit.html&quot;&gt;test/spec&lt;/a&gt; library, fixes some bugs, and improves the user manual and generated tests.&lt;/p&gt;
261
+
262
+
263
+ &lt;h2&gt;Notice&lt;/h2&gt;
264
+
265
+
266
+ &lt;ul&gt;
267
+ &lt;li&gt;Icarus Verilog 0.8 has been demoted to a &lt;a href=&quot;manual.html#setup.reqs&quot;&gt;mostly acceptable&lt;/a&gt; status.&lt;/li&gt;
268
+ &lt;/ul&gt;
269
+
270
+
271
+ &lt;ul&gt;
272
+ &lt;li&gt;Generated Verilog benches no longer supply the &lt;tt&gt;-w&lt;/tt&gt; option to the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#d70; font-weight:bold&quot;&gt;$ruby_init&lt;/span&gt;&lt;/code&gt; task.&lt;/li&gt;
273
+ &lt;/ul&gt;
274
+
275
+
276
+ &lt;ul&gt;
277
+ &lt;li&gt;The &lt;code class=&quot;code&quot;&gt;ruby-vpi/runner_proxy&lt;/code&gt; library now invokes test runners
278
+ &lt;ul&gt;
279
+ &lt;li&gt;just before exiting. Thus, you can invoke tasks in the main &lt;tt&gt;Rakefile&lt;/tt&gt; before the test runners are invoked.&lt;/li&gt;
280
+ &lt;li&gt;located within any directory that is a descendant of the current working directory.&lt;/li&gt;
281
+ &lt;/ul&gt;&lt;/li&gt;
282
+ &lt;/ul&gt;
283
+
284
+
285
+ &lt;ul&gt;
286
+ &lt;li&gt;The &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;SIMULATOR_ARGS&lt;/span&gt;&lt;/code&gt; parameter of generated runners has been renamed to &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;SIMULATOR_ARGUMENTS&lt;/span&gt;&lt;/code&gt; for clarity.&lt;/li&gt;
287
+ &lt;/ul&gt;
288
+
289
+
290
+ &lt;ul&gt;
291
+ &lt;li&gt;The automated test generator
292
+ &lt;ul&gt;
293
+ &lt;li&gt;no longer displays the &lt;strong&gt;backup&lt;/strong&gt; status indicator.&lt;/li&gt;
294
+ &lt;li&gt;now supplies a third argument to the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;MERGER&lt;/span&gt;&lt;/code&gt; command.&lt;/li&gt;
295
+ &lt;li&gt;no longer replaces existing files with newly generated content during the &lt;strong&gt;update&lt;/strong&gt; action. Instead, it now writes the newly generated output to a &lt;tt&gt;.new&lt;/tt&gt; file and then invokes the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;MERGER&lt;/span&gt;&lt;/code&gt; command.&lt;/li&gt;
296
+ &lt;/ul&gt;&lt;/li&gt;
297
+ &lt;/ul&gt;
298
+
299
+
300
+ &lt;h2&gt;Details&lt;/h2&gt;
301
+
302
+
303
+ &lt;ul&gt;
304
+ &lt;li&gt;The &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;&lt;/code&gt; class has two new methods: &lt;code class=&quot;code&quot;&gt;x!&lt;/code&gt; and &lt;code class=&quot;code&quot;&gt;z!&lt;/code&gt;, which set the handle&amp;#8217;s logic value to &lt;em&gt;unknown&lt;/em&gt; and &lt;em&gt;high impedance&lt;/em&gt; respectively.&lt;/li&gt;
305
+ &lt;/ul&gt;
306
+
307
+
308
+ &lt;ul&gt;
309
+ &lt;li&gt;The tests for the simple up-counter example were randomly failing because the specifications were not asserting the design&amp;#8217;s &lt;code class=&quot;code&quot;&gt;reset&lt;/code&gt; signal long enough. So the design was getting into weird states and behaving in a non-deterministic way. This problem has been fixed.&lt;/li&gt;
310
+ &lt;/ul&gt;
311
+
312
+
313
+ &lt;ul&gt;
314
+ &lt;li&gt;The user manual has been revised and some minor issues have been fixed.&lt;/li&gt;
315
+ &lt;/ul&gt;
316
+
317
+
318
+ &lt;h3&gt;Test generation&lt;/h3&gt;
319
+
320
+
321
+ &lt;ul&gt;
322
+ &lt;li&gt;The automated test generator accepts new command-line options:
323
+ &lt;ul&gt;
324
+ &lt;li&gt;&lt;tt&gt;--test-unit&lt;/tt&gt;&lt;/li&gt;
325
+ &lt;li&gt;&lt;tt&gt;--test-spec&lt;/tt&gt;&lt;/li&gt;
326
+ &lt;li&gt;&lt;tt&gt;--tspec&lt;/tt&gt;&lt;/li&gt;
327
+ &lt;/ul&gt;&lt;/li&gt;
328
+ &lt;/ul&gt;
329
+
330
+
331
+ &lt;ul&gt;
332
+ &lt;li&gt;The automated test generator was crashing when parsing module parameters of an input file which did not have any module parameters. This has been fixed.&lt;/li&gt;
333
+ &lt;/ul&gt;
334
+
335
+
336
+ &lt;ul&gt;
337
+ &lt;li&gt;Generated Verilog benches now contain simpler clock generation code.&lt;/li&gt;
338
+ &lt;/ul&gt;
339
+
340
+
341
+ &lt;ul&gt;
342
+ &lt;li&gt;Generated runners now contain
343
+ &lt;ul&gt;
344
+ &lt;li&gt;a &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#A60&quot;&gt;:setup&lt;/span&gt;&lt;/code&gt; task which is invoked before the simulator runs. It can be used to make preprations, such as converting Verilog header files into Ruby, for the simulation.&lt;/li&gt;
345
+ &lt;li&gt;better explanations to accomodate new users.&lt;/li&gt;
346
+ &lt;/ul&gt;&lt;/li&gt;
347
+ &lt;/ul&gt;
348
+
349
+
350
+ &lt;ul&gt;
351
+ &lt;li&gt;Specifications generated in the &lt;strong&gt;generic&lt;/strong&gt; format no longer contain a class that is instantiated in the generated Ruby bench.&lt;/li&gt;
352
+ &lt;/ul&gt;</description>
40
353
  <pubDate>Thu, 07 Dec 2006 00:00:00 PST</pubDate>
41
354
  </item>
42
355
  <item>
43
356
  <title>Version 11.1.1 released</title>
44
357
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#11.1.1</link>
45
358
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#11.1.1</guid>
46
- <description>&lt;p&gt;This release fixes a bug in the automated test generator, unifies the user manual and the website into a single documentation system, and adds support for rSpec 0.7.2.&lt;/p&gt;</description>
359
+ <description>&lt;h1 id=&quot;11.1.1&quot;&gt;Version 11.1.1 (2006-11-15)&lt;/h1&gt;
360
+
361
+
362
+ &lt;h2&gt;Summary&lt;/h2&gt;
363
+
364
+
365
+ &lt;p&gt;This release fixes a bug in the automated test generator, unifies the user manual and the website into a single documentation system, and adds support for rSpec 0.7.2.&lt;/p&gt;
366
+
367
+
368
+ &lt;h2&gt;Acknowledgment&lt;/h2&gt;
369
+
370
+
371
+ &lt;p&gt;Thanks to John Burr for finding the bug in the automated test generator.&lt;/p&gt;
372
+
373
+
374
+ &lt;h2&gt;Notice&lt;/h2&gt;
375
+
376
+
377
+ &lt;ul&gt;
378
+ &lt;li&gt;The user manual is now available &lt;em&gt;only&lt;/em&gt; in &lt;span class=&quot;caps&quot;&gt;HTML&lt;/span&gt; format. If you still wish to have a plain-text version, you can use a text-based browser, such as &lt;a href=&quot;http://lynx.browser.org/&quot;&gt;lynx&lt;/a&gt;, to perform the necessary conversion.&lt;/li&gt;
379
+ &lt;/ul&gt;
380
+
381
+
382
+ &lt;h2&gt;Details&lt;/h2&gt;
383
+
384
+
385
+ &lt;ul&gt;
386
+ &lt;li&gt;The automated test generator no longer crashes when parsing a Verilog module declaration that contains multiple module parameters.&lt;/li&gt;
387
+ &lt;/ul&gt;
388
+
389
+
390
+ &lt;ul&gt;
391
+ &lt;li&gt;The user manual and the website are now written using a custom documentation system based on RedCloth and &lt;span class=&quot;caps&quot;&gt;ERB&lt;/span&gt; instead of DocBook-XML. This makes it easier to edit the user manual and reuse its content in other areas of the website.&lt;/li&gt;
392
+ &lt;/ul&gt;</description>
47
393
  <pubDate>Wed, 15 Nov 2006 00:00:00 PST</pubDate>
48
394
  </item>
49
395
  <item>
50
396
  <title>Version 11.1.0 released</title>
51
397
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#11.1.0</link>
52
398
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#11.1.0</guid>
53
- <description>&lt;p&gt;This release fixes a bug in generated benches, improves the &lt;a href=&quot;../ref/ruby/classes/Vpi/Handle.html&quot;&gt;the &lt;code&gt;Vpi::Handle&lt;/code&gt; class&lt;/a&gt;, and improves performance by roughly 20%.&lt;/p&gt;</description>
399
+ <description>&lt;h1 id=&quot;11.1.0&quot;&gt;Version 11.1.0 (2006-11-08)&lt;/h1&gt;
400
+
401
+
402
+ &lt;h2&gt;Summary&lt;/h2&gt;
403
+
404
+
405
+ &lt;p&gt;This release fixes a bug in generated benches, improves the &lt;a href=&quot;../ref/ruby/classes/Vpi/Handle.html&quot;&gt;the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;&lt;/code&gt; class&lt;/a&gt;, and improves performance by roughly 20%.&lt;/p&gt;
406
+
407
+
408
+ &lt;h2&gt;Acknowledgment&lt;/h2&gt;
409
+
410
+
411
+ &lt;p&gt;Thanks to Matt Fischler for finding the bug in generated benches (see below).&lt;/p&gt;
412
+
413
+
414
+ &lt;h2&gt;Notice&lt;/h2&gt;
415
+
416
+
417
+ &lt;ul&gt;
418
+ &lt;li&gt;A bug in generated Verilog and Ruby benches, which caused the &lt;pre&gt;ruby: no such file to load -- ruby-vpi (LoadError)&lt;/pre&gt; error, has been fixed. Please regenerate your tests to apply this bug fix to your tests.&lt;/li&gt;
419
+ &lt;/ul&gt;
420
+
421
+
422
+ &lt;h2&gt;Details&lt;/h2&gt;
423
+
424
+
425
+ &lt;ul&gt;
426
+ &lt;li&gt;The class &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;SWIG&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;TYPE_p_unsigned_int&lt;/span&gt;&lt;/code&gt; has been aliased as &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;&lt;/code&gt; for easier access.&lt;/li&gt;
427
+ &lt;/ul&gt;
428
+
429
+
430
+ &lt;ul&gt;
431
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;.to_s&lt;/code&gt; and &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;.inspect&lt;/code&gt; now produce more informative output. For example, what used to appear as &lt;pre&gt;#&amp;lt;SWIG::TYPE_p_unsigned_int:0x2aaab6574fa0&amp;gt;&lt;/pre&gt; now appears as &lt;pre&gt;#&amp;lt;Vpi::Handle vpiModule fullName=counter_rspec_bench, size=-1, file=counter_rspec_bench.v, lineNo=2&amp;gt;&lt;/pre&gt; in this release.
432
+ &lt;ul&gt;
433
+ &lt;li&gt;You can also provide a list of &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; properties, as names or integer constants, to those methods to see additional information in the output.&lt;/li&gt;
434
+ &lt;/ul&gt;&lt;/li&gt;
435
+ &lt;/ul&gt;
436
+
437
+
438
+ &lt;ul&gt;
439
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;&lt;/code&gt; now implements all methods from &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Enumerable&lt;/span&gt;&lt;/code&gt;, such as &lt;code class=&quot;code&quot;&gt;map&lt;/code&gt;, &lt;code class=&quot;code&quot;&gt;each&lt;/code&gt;, &lt;code class=&quot;code&quot;&gt;select&lt;/code&gt;, and so on. However, unlike their counterparts in &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Enumerable&lt;/span&gt;&lt;/code&gt;, these methods also accept a list of &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; properties, as names or integer constants. Thus, you are now able to write &lt;code class=&quot;code&quot;&gt;handle.select(&lt;span style=&quot;color:#A60&quot;&gt;:reg&lt;/span&gt;, &lt;span style=&quot;color:#A60&quot;&gt;:net&lt;/span&gt;) {|h| h.size &amp;gt; &lt;span style=&quot;color:#00D; font-weight:bold&quot;&gt;5&lt;/span&gt;}&lt;/code&gt; to obtain a list of child handles to registers and nets whose capacity is greater than 5 bits.&lt;/li&gt;
440
+ &lt;/ul&gt;
441
+
442
+
443
+ &lt;ul&gt;
444
+ &lt;li&gt;The &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;.[]&lt;/code&gt;, &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;.get_value&lt;/code&gt;, and &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;.put_value&lt;/code&gt; methods now accept names of &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; properties as well as their integer constants. Thus, you are now able to write &lt;code class=&quot;code&quot;&gt;handle[&lt;span style=&quot;color:#A60&quot;&gt;:reg&lt;/span&gt;, &lt;span style=&quot;color:#A60&quot;&gt;:net&lt;/span&gt;]&lt;/code&gt; to obtain a list of handles to all child registers and nets.&lt;/li&gt;
445
+ &lt;/ul&gt;
446
+
447
+
448
+ &lt;ul&gt;
449
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;.method_missing&lt;/code&gt; has been refactored to cache queries. There is now, approximately, 20% improvement in performance.&lt;/li&gt;
450
+ &lt;/ul&gt;
451
+
452
+
453
+ &lt;ul&gt;
454
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;.method_missing&lt;/code&gt; has been fixed to accept operations with multiple underscores. For example, before this release, you could not write &lt;code class=&quot;code&quot;&gt;handle.find_all_reg {|r| r.name =~ &lt;span style=&quot;background-color:#fff0ff&quot;&gt;&lt;span style=&quot;color:#404&quot;&gt;/&lt;/span&gt;&lt;span style=&quot;color:#808&quot;&gt;foo&lt;/span&gt;&lt;span style=&quot;color:#404&quot;&gt;/&lt;/span&gt;&lt;/span&gt;}&lt;/code&gt; because the &amp;#8220;find_all_reg&amp;#8221; method would be interpreted as the operation &amp;#8220;find&amp;#8221; and the &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; property &amp;#8220;all_reg&amp;#8221;.&lt;/li&gt;
455
+ &lt;/ul&gt;
456
+
457
+
458
+ &lt;ul&gt;
459
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;.method_missing&lt;/code&gt; no longer requires that the first letter of a method be lower case. For example, now you can now write &lt;code class=&quot;code&quot;&gt;handle.&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;IntVal&lt;/span&gt;&lt;/code&gt; in addition to &lt;code class=&quot;code&quot;&gt;handle.intVal&lt;/code&gt;.&lt;/li&gt;
460
+ &lt;/ul&gt;
461
+
462
+
463
+ &lt;ul&gt;
464
+ &lt;li&gt;The &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;IntegerGenerator&lt;/span&gt;&lt;/code&gt; class, in the pipelined &lt;span class=&quot;caps&quot;&gt;ALU&lt;/span&gt; example, has been fixed so that multiple instances do not interfere with the generation of each other&amp;#8217;s prime integers.&lt;/li&gt;
465
+ &lt;/ul&gt;
466
+
467
+
468
+ &lt;ul&gt;
469
+ &lt;li&gt;Due to a bug in the &lt;tt&gt;Rakefile&lt;/tt&gt;, the reference documentation was not included in the previous few releases. This has been fixed.&lt;/li&gt;
470
+ &lt;/ul&gt;</description>
54
471
  <pubDate>Wed, 08 Nov 2006 00:00:00 PST</pubDate>
55
472
  </item>
56
473
  <item>
57
474
  <title>Version 11.0.0 released</title>
58
475
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#11.0.0</link>
59
476
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#11.0.0</guid>
60
- <description>&lt;p&gt;This release shortens generated Ruby benches and uses the less confusing notation for defining &lt;a href=&quot;http://wiki.rubygarden.org/Ruby/page/show/SingletonTutorial&quot;&gt;singleton methods&lt;/a&gt; in generated designs and prototypes.&lt;/p&gt;</description>
477
+ <description>&lt;h1 id=&quot;11.0.0&quot;&gt;Version 11.0.0 (2006-11-05)&lt;/h1&gt;
478
+
479
+
480
+ &lt;h2&gt;Summary&lt;/h2&gt;
481
+
482
+
483
+ &lt;p&gt;This release shortens generated Ruby benches and uses the less confusing notation for defining &lt;a href=&quot;http://wiki.rubygarden.org/Ruby/page/show/SingletonTutorial&quot;&gt;singleton methods&lt;/a&gt; in generated designs and prototypes.&lt;/p&gt;
484
+
485
+
486
+ &lt;h2&gt;Notice&lt;/h2&gt;
487
+
488
+
489
+ &lt;ul&gt;
490
+ &lt;li&gt;The arguments for the &lt;a href=&quot;../ref/ruby/classes/RubyVpi.html&quot;&gt;&lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;RubyVPI&lt;/span&gt;.init_bench&lt;/code&gt; method&lt;/a&gt; have changed.&lt;/li&gt;
491
+ &lt;/ul&gt;
492
+
493
+
494
+ &lt;ul&gt;
495
+ &lt;li&gt;&lt;strong&gt;generate_test.rb&lt;/strong&gt; no longer emits undocumented status indicators: &lt;em&gt;name&lt;/em&gt; and &lt;em&gt;format&lt;/em&gt;.&lt;/li&gt;
496
+ &lt;/ul&gt;
497
+
498
+
499
+ &lt;ul&gt;
500
+ &lt;li&gt;The source code is no longer distributed as a &lt;strong&gt;zip&lt;/strong&gt; package, because it seems to be quite underutilized in comparison to the &lt;strong&gt;tgz&lt;/strong&gt; and &lt;strong&gt;gem&lt;/strong&gt; packages.&lt;/li&gt;
501
+ &lt;/ul&gt;
502
+
503
+
504
+ &lt;h2&gt;Details&lt;/h2&gt;
505
+
506
+
507
+ &lt;ul&gt;
508
+ &lt;li&gt;Generated Ruby benches have been shortened to just &lt;em&gt;one&lt;/em&gt; line of code!&lt;/li&gt;
509
+ &lt;/ul&gt;
510
+
511
+
512
+ &lt;ul&gt;
513
+ &lt;li&gt;The less confusing notation of &lt;pre class=&quot;code&quot;&gt;&lt;span style=&quot;color:#080; font-weight:bold&quot;&gt;def&lt;/span&gt; some_object.a_singleton_method
514
+ do_stuff
515
+ &lt;span style=&quot;color:#080; font-weight:bold&quot;&gt;end&lt;/span&gt;&lt;/pre&gt; is now used instead of the &lt;pre class=&quot;code&quot;&gt;&lt;span style=&quot;color:#080; font-weight:bold&quot;&gt;class&lt;/span&gt; &amp;lt;&amp;lt; &lt;span style=&quot;color:#B06; font-weight:bold&quot;&gt;some_object&lt;/span&gt;
516
+ &lt;span style=&quot;color:#080; font-weight:bold&quot;&gt;def&lt;/span&gt; &lt;span style=&quot;color:#06B; font-weight:bold&quot;&gt;a_singleton_method&lt;/span&gt;
517
+ do_stuff
518
+ &lt;span style=&quot;color:#080; font-weight:bold&quot;&gt;end&lt;/span&gt;
519
+ &lt;span style=&quot;color:#080; font-weight:bold&quot;&gt;end&lt;/span&gt;&lt;/pre&gt; notation.
520
+ &lt;ul&gt;
521
+ &lt;li&gt;The tutorial and examples have been updated accordingly.&lt;/li&gt;
522
+ &lt;/ul&gt;&lt;/li&gt;
523
+ &lt;/ul&gt;
524
+
525
+
526
+ &lt;ul&gt;
527
+ &lt;li&gt;The pipelined &lt;span class=&quot;caps&quot;&gt;ALU&lt;/span&gt; example now has an updated &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;IntegerGenerator&lt;/span&gt;&lt;/code&gt; class.&lt;/li&gt;
528
+ &lt;/ul&gt;</description>
61
529
  <pubDate>Sun, 05 Nov 2006 00:00:00 PST</pubDate>
62
530
  </item>
63
531
  <item>
64
532
  <title>Version 10.0.0 released</title>
65
533
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#10.0.0</link>
66
534
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#10.0.0</guid>
67
- <description>&lt;p&gt;This release adds the ability to access a handle&amp;#8217;s children and reduces the amount of code produced by the automated test generator.&lt;/p&gt;</description>
535
+ <description>&lt;h1 id=&quot;10.0.0&quot;&gt;Version 10.0.0 (2006-11-05)&lt;/h1&gt;
536
+
537
+
538
+ &lt;h2&gt;Summary&lt;/h2&gt;
539
+
540
+
541
+ &lt;p&gt;This release adds the ability to access a handle&amp;#8217;s children and reduces the amount of code produced by the automated test generator.&lt;/p&gt;
542
+
543
+
544
+ &lt;h2&gt;Acknowledgment&lt;/h2&gt;
545
+
546
+
547
+ &lt;p&gt;Thanks to Matt Fischler for finding the problem of misdirected compilation errors in Verilog benches.&lt;/p&gt;
548
+
549
+
550
+ &lt;h2&gt;Notice&lt;/h2&gt;
551
+
552
+
553
+ &lt;ul&gt;
554
+ &lt;li&gt;The way in which Ruby-VPI and generated tests interact has changed: the design is now a &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; handle object and the &lt;tt&gt;design.rb&lt;/tt&gt; and &lt;tt&gt;proto.rb&lt;/tt&gt; files define &lt;a href=&quot;http://wiki.rubygarden.org/Ruby/page/show/SingletonTutorial&quot;&gt;singleton methods&lt;/a&gt; for that object.
555
+ &lt;ul&gt;
556
+ &lt;li&gt;I suggest that you regenerate your existing tests (just run &lt;strong&gt;generate_test.rb&lt;/strong&gt; again) whilst employing the service of a text merging tool (see the user manual).&lt;/li&gt;
557
+ &lt;/ul&gt;&lt;/li&gt;
558
+ &lt;/ul&gt;
559
+
560
+
561
+ &lt;ul&gt;
562
+ &lt;li&gt;You can now access a handle&amp;#8217;s children by simply calling methods on it. In the event that a child handle has the same name as a &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; property, the child is given priority. However, you can always access &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; properties explicitly via the &lt;code class=&quot;code&quot;&gt;get_value&lt;/code&gt; and &lt;code class=&quot;code&quot;&gt;put_value&lt;/code&gt; methods.&lt;/li&gt;
563
+ &lt;/ul&gt;
564
+
565
+
566
+ &lt;ul&gt;
567
+ &lt;li&gt;&lt;strong&gt;generate_test.rb&lt;/strong&gt; no longer accepts the &lt;pre&gt;-s&lt;/pre&gt; and &lt;pre&gt;-u&lt;/pre&gt; options. Use their longer counterparts &lt;pre&gt;--rspec&lt;/pre&gt; and &lt;pre&gt;--xunit&lt;/pre&gt; instead.&lt;/li&gt;
568
+ &lt;/ul&gt;
569
+
570
+
571
+ &lt;h2&gt;Details&lt;/h2&gt;
572
+
573
+
574
+ &lt;h3&gt;Automated test generator&lt;/h3&gt;
575
+
576
+
577
+ &lt;ul&gt;
578
+ &lt;li&gt;Generated Verilog benches no longer divert compilation errors from Verilog design files. That is, if the Verilog simulator finds compilation errors in a Verilog design file, it will report that the Verilog design file is at fault (instead of reporting that the generated Verilog bench is at fault).&lt;/li&gt;
579
+ &lt;/ul&gt;
580
+
581
+
582
+ &lt;ul&gt;
583
+ &lt;li&gt;The user is now notified when a backup of an existing file is made.&lt;/li&gt;
584
+ &lt;/ul&gt;
585
+
586
+
587
+ &lt;ul&gt;
588
+ &lt;li&gt;Generated tests have been greatly simplified to reduce the amount of work for the user.
589
+ &lt;ul&gt;
590
+ &lt;li&gt;The design is now just a handle to the module in the Verilog bench.&lt;/li&gt;
591
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;include &lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;&lt;/code&gt; and &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#33B&quot;&gt;@design&lt;/span&gt;&lt;/code&gt; are no longer generated.&lt;/li&gt;
592
+ &lt;li&gt;The tutorial and examples have been updated accordingly.&lt;/li&gt;
593
+ &lt;/ul&gt;&lt;/li&gt;
594
+ &lt;/ul&gt;
595
+
596
+
597
+ &lt;h3&gt;User manual&lt;/h3&gt;
598
+
599
+
600
+ &lt;ul&gt;
601
+ &lt;li&gt;Revised the stylesheet to make disjoint sections readily distinguishable from each other, through generous spacing and minor coloring.&lt;/li&gt;
602
+ &lt;/ul&gt;
603
+
604
+
605
+ &lt;ul&gt;
606
+ &lt;li&gt;Added tips about &lt;tt&gt;ruby-vpi/runner_proxy&lt;/tt&gt;, &lt;pre&gt;rake -T&lt;/pre&gt;, and using &lt;strong&gt;kdiff3&lt;/strong&gt; with &lt;strong&gt;generate_test.rb&lt;/strong&gt;.&lt;/li&gt;
607
+ &lt;/ul&gt;
608
+
609
+
610
+ &lt;ul&gt;
611
+ &lt;li&gt;Moved installation information into a new &amp;#8220;setup&amp;#8221; chapter.&lt;/li&gt;
612
+ &lt;/ul&gt;</description>
68
613
  <pubDate>Sun, 05 Nov 2006 00:00:00 PST</pubDate>
69
614
  </item>
70
615
  <item>
71
616
  <title>Version 9.0.0 released</title>
72
617
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#9.0.0</link>
73
618
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#9.0.0</guid>
74
- <description>&lt;p&gt;This release improves the automated test generator and adds new content to the user manual.&lt;/p&gt;</description>
619
+ <description>&lt;h1 id=&quot;9.0.0&quot;&gt;Version 9.0.0 (2006-10-28)&lt;/h1&gt;
620
+
621
+
622
+ &lt;h2&gt;Summary&lt;/h2&gt;
623
+
624
+
625
+ &lt;p&gt;This release improves the automated test generator and adds new content to the user manual.&lt;/p&gt;
626
+
627
+
628
+ &lt;h2&gt;Acknowledgment&lt;/h2&gt;
629
+
630
+
631
+ &lt;p&gt;Thanks to Matt Fischler for helping test and debug the installation of Ruby-VPI on Windows.&lt;/p&gt;
632
+
633
+
634
+ &lt;h2&gt;Notice&lt;/h2&gt;
635
+
636
+
637
+ &lt;ul&gt;
638
+ &lt;li&gt;The command-line options for &lt;strong&gt;generate_test.rb&lt;/strong&gt; have changed. Run the command &lt;pre&gt;generate_test.rb --help&lt;/pre&gt; for details.&lt;/li&gt;
639
+ &lt;/ul&gt;
640
+
641
+
642
+ &lt;h2&gt;Details&lt;/h2&gt;
643
+
644
+
645
+ &lt;ul&gt;
646
+ &lt;li&gt;Test runners now attempt to resolve paths in &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;SIMULATOR_SOURCES&lt;/span&gt;&lt;/code&gt; by searching for them within the directories specified in &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;SIMULATOR_INCLUDES&lt;/span&gt;&lt;/code&gt;.&lt;/li&gt;
647
+ &lt;/ul&gt;
648
+
649
+
650
+ &lt;ul&gt;
651
+ &lt;li&gt;Synopsys &lt;span class=&quot;caps&quot;&gt;VCS&lt;/span&gt; is now used in a better way (via the &lt;pre&gt;-load&lt;/pre&gt; option).
652
+ &lt;ul&gt;
653
+ &lt;li&gt;The old &lt;span class=&quot;caps&quot;&gt;PLI&lt;/span&gt; table file (&lt;tt&gt;synopsys_vcs.tab&lt;/tt&gt;) has been removed.&lt;/li&gt;
654
+ &lt;li&gt;The C extension has been revised accordingly.&lt;/li&gt;
655
+ &lt;/ul&gt;&lt;/li&gt;
656
+ &lt;/ul&gt;
657
+
658
+
659
+ &lt;ul&gt;
660
+ &lt;li&gt;The C extension now compiles without errors in Cygwin.&lt;/li&gt;
661
+ &lt;/ul&gt;
662
+
663
+
664
+ &lt;ul&gt;
665
+ &lt;li&gt;The automated test generator now:
666
+ &lt;ul&gt;
667
+ &lt;li&gt;Only creates output files when necessary.&lt;/li&gt;
668
+ &lt;li&gt;Updates existing output files using &lt;a href=&quot;manual.html#setup.recom&quot;&gt;text merging tools&lt;/a&gt; if possible. (Refer to &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;MERGER&lt;/span&gt;&lt;/code&gt; in the help information of &lt;strong&gt;generate_test.rb&lt;/strong&gt;.)&lt;/li&gt;
669
+ &lt;li&gt;Emits progress information similar to Ruby on Rails.&lt;/li&gt;
670
+ &lt;/ul&gt;&lt;/li&gt;
671
+ &lt;/ul&gt;
672
+
673
+
674
+ &lt;ul&gt;
675
+ &lt;li&gt;The user manual now:
676
+ &lt;ul&gt;
677
+ &lt;li&gt;Includes instructions for installing on Windows (via Cygwin).&lt;/li&gt;
678
+ &lt;li&gt;Has a recommended software section, with links to text merging tools.&lt;/li&gt;
679
+ &lt;li&gt;Uses the term &lt;a href=&quot;http://en.wikipedia.org/wiki/XUnit&quot;&gt;xUnit&lt;/a&gt; instead of &amp;#8220;unit test&amp;#8221;.&lt;/li&gt;
680
+ &lt;li&gt;Correctly spells &amp;#8220;rSpec&amp;#8221;.&lt;/li&gt;
681
+ &lt;/ul&gt;&lt;/li&gt;
682
+ &lt;/ul&gt;</description>
75
683
  <pubDate>Sat, 28 Oct 2006 00:00:00 PDT</pubDate>
76
684
  </item>
77
685
  <item>
78
686
  <title>Version 8.2.0 released</title>
79
687
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#8.2.0</link>
80
688
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#8.2.0</guid>
81
- <description>&lt;p&gt;This release simplifies configuration of generated tests.&lt;/p&gt;</description>
689
+ <description>&lt;h1 id=&quot;8.2.0&quot;&gt;Version 8.2.0 (2006-10-24)&lt;/h1&gt;
690
+
691
+
692
+ &lt;h2&gt;Summary&lt;/h2&gt;
693
+
694
+
695
+ &lt;p&gt;This release simplifies configuration of generated tests.&lt;/p&gt;
696
+
697
+
698
+ &lt;h2&gt;Acknowledgment&lt;/h2&gt;
699
+
700
+
701
+ &lt;p&gt;Thanks to &lt;a href=&quot;http://www.soe.ucsc.edu/classes/cmpe126/Fall06/&quot;&gt;students in &lt;span class=&quot;caps&quot;&gt;CMPE&lt;/span&gt;-126&lt;/a&gt; for their comments.&lt;/p&gt;
702
+
703
+
704
+ &lt;h2&gt;Notice&lt;/h2&gt;
705
+
706
+
707
+ &lt;ul&gt;
708
+ &lt;li&gt;Generated runners now have a &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;SIMULATOR_INCLUDES&lt;/span&gt;&lt;/code&gt; array, whose entries specify places where Verilog source files, needed by the Verilog design, reside.&lt;/li&gt;
709
+ &lt;/ul&gt;
710
+
711
+
712
+ &lt;h2&gt;Details&lt;/h2&gt;
713
+
714
+
715
+ &lt;ul&gt;
716
+ &lt;li&gt;Generated Verilog benches now inherit all &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;background-color:#f0fff0&quot;&gt;&lt;span style=&quot;color:#161&quot;&gt;`&lt;/span&gt;&lt;span style=&quot;color:#2B2&quot;&gt;include&lt;/span&gt;&lt;/span&gt;&lt;/code&gt; and &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;background-color:#f0fff0&quot;&gt;&lt;span style=&quot;color:#161&quot;&gt;`&lt;/span&gt;&lt;span style=&quot;color:#2B2&quot;&gt;define&lt;/span&gt;&lt;/span&gt;&lt;/code&gt; directives from the Verilog design in a simpler manner.&lt;/li&gt;
717
+ &lt;li&gt;A generated test no longer requires its Verilog design to reside in the same directory.&lt;/li&gt;
718
+ &lt;li&gt;The sample tests have been updated accordingly.&lt;/li&gt;
719
+ &lt;/ul&gt;</description>
82
720
  <pubDate>Tue, 24 Oct 2006 00:00:00 PDT</pubDate>
83
721
  </item>
84
722
  <item>
85
723
  <title>Version 8.1.0 released</title>
86
724
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#8.1.0</link>
87
725
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#8.1.0</guid>
88
- <description>&lt;p&gt;This release adds an integer library and renames the vpi_util library.&lt;/p&gt;</description>
726
+ <description>&lt;h1 id=&quot;8.1.0&quot;&gt;Version 8.1.0 (2006-10-21)&lt;/h1&gt;
727
+
728
+
729
+ &lt;h2&gt;Summary&lt;/h2&gt;
730
+
731
+
732
+ &lt;p&gt;This release adds an integer library and renames the vpi_util library.&lt;/p&gt;
733
+
734
+
735
+ &lt;h2&gt;Notice&lt;/h2&gt;
736
+
737
+
738
+ &lt;ul&gt;
739
+ &lt;li&gt;The &lt;strong&gt;vpi_util&lt;/strong&gt; library has been renamed to &lt;strong&gt;vpi&lt;/strong&gt;. This change should not affect your code unless you explicitly imported this library via &lt;code class=&quot;code&quot;&gt;require &lt;span style=&quot;background-color:#fff0f0&quot;&gt;&lt;span style=&quot;color:#710&quot;&gt;'&lt;/span&gt;&lt;span style=&quot;color:#D20&quot;&gt;ruby-vpi/vpi_util&lt;/span&gt;&lt;span style=&quot;color:#710&quot;&gt;'&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;. In which case, you should update your code to use &lt;code class=&quot;code&quot;&gt;require &lt;span style=&quot;background-color:#fff0f0&quot;&gt;&lt;span style=&quot;color:#710&quot;&gt;'&lt;/span&gt;&lt;span style=&quot;color:#D20&quot;&gt;ruby-vpi/vpi&lt;/span&gt;&lt;span style=&quot;color:#710&quot;&gt;'&lt;/span&gt;&lt;/span&gt;&lt;/code&gt; accordingly.&lt;/li&gt;
740
+ &lt;/ul&gt;
741
+
742
+
743
+ &lt;h2&gt;Details&lt;/h2&gt;
744
+
745
+
746
+ &lt;ul&gt;
747
+ &lt;li&gt;An integer library has been added to simplify common tasks related to hardware and the binary number system. You can import this library for use via &lt;code class=&quot;code&quot;&gt;require &lt;span style=&quot;background-color:#fff0f0&quot;&gt;&lt;span style=&quot;color:#710&quot;&gt;'&lt;/span&gt;&lt;span style=&quot;color:#D20&quot;&gt;ruby-vpi/integer&lt;/span&gt;&lt;span style=&quot;color:#710&quot;&gt;'&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;.&lt;/li&gt;
748
+ &lt;/ul&gt;</description>
89
749
  <pubDate>Sat, 21 Oct 2006 00:00:00 PDT</pubDate>
90
750
  </item>
91
751
  <item>
92
752
  <title>Version 8.0.0 released</title>
93
753
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#8.0.0</link>
94
754
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#8.0.0</guid>
95
- <description>&lt;p&gt;This release renames some identifiers for consistency, updates the documentation, and improves integration with RubyGems.&lt;/p&gt;</description>
755
+ <description>&lt;h1 id=&quot;8.0.0&quot;&gt;Version 8.0.0 (2006-10-13)&lt;/h1&gt;
756
+
757
+
758
+ &lt;h2&gt;Summary&lt;/h2&gt;
759
+
760
+
761
+ &lt;p&gt;This release renames some identifiers for consistency, updates the documentation, and improves integration with RubyGems.&lt;/p&gt;
762
+
763
+
764
+ &lt;h2&gt;Notice&lt;/h2&gt;
765
+
766
+
767
+ &lt;ul&gt;
768
+ &lt;li&gt;The &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;RubyVPI&lt;/span&gt;&lt;/code&gt; module has been renamed to &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;RubyVpi&lt;/span&gt;&lt;/code&gt;.&lt;/li&gt;
769
+ &lt;/ul&gt;
770
+
771
+
772
+ &lt;ul&gt;
773
+ &lt;li&gt;The &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;PROTO&lt;/span&gt;&lt;/code&gt; environment variable has been renamed to &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;PROTOTYPE&lt;/span&gt;&lt;/code&gt;.
774
+ &lt;ul&gt;
775
+ &lt;li&gt;In addition to using &lt;strong&gt;unset&lt;/strong&gt;, you can now disable simulation of the prototype by assigning an empty value to this variable.&lt;/li&gt;
776
+ &lt;/ul&gt;&lt;/li&gt;
777
+ &lt;/ul&gt;
778
+
779
+
780
+ &lt;h2&gt;Details&lt;/h2&gt;
781
+
782
+
783
+ &lt;ul&gt;
784
+ &lt;li&gt;We now use &lt;a href=&quot;http://darcs.net&quot;&gt;Darcs&lt;/a&gt; for revision control, instead of Subversion. The source repository can now be accessed at &lt;a href=&quot;http://ruby-vpi.rubyforge.org/src/ruby-vpi&quot;&gt;http://ruby-vpi.rubyforge.org/src/ruby-vpi&lt;/a&gt;.&lt;/li&gt;
785
+ &lt;/ul&gt;
786
+
787
+
788
+ &lt;ul&gt;
789
+ &lt;li&gt;The source code is now distributed in tar.gz and zip form, in addition to gem.&lt;/li&gt;
790
+ &lt;/ul&gt;
791
+
792
+
793
+ &lt;ul&gt;
794
+ &lt;li&gt;Some identifiers have been renamed for better consistency.&lt;/li&gt;
795
+ &lt;/ul&gt;
796
+
797
+
798
+ &lt;ul&gt;
799
+ &lt;li&gt;The user manual now resides directly within the &lt;tt&gt;doc/&lt;/tt&gt; directory.
800
+ &lt;ul&gt;
801
+ &lt;li&gt;The integration of documentation in &lt;strong&gt;gem_server&lt;/strong&gt; has been improved.&lt;/li&gt;
802
+ &lt;/ul&gt;&lt;/li&gt;
803
+ &lt;/ul&gt;
804
+
805
+
806
+ &lt;ul&gt;
807
+ &lt;li&gt;The glossary and tutorial in the user manual have been revised.&lt;/li&gt;
808
+ &lt;/ul&gt;</description>
96
809
  <pubDate>Fri, 13 Oct 2006 00:00:00 PDT</pubDate>
97
810
  </item>
98
811
  <item>
99
812
  <title>Version 7.3.0 released</title>
100
813
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#7.3.0</link>
101
814
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#7.3.0</guid>
102
- <description>&lt;p&gt;This release fixes a bug in generated Verilog benches, includes parsed constants in generated tests, and adds new methods to handles.&lt;/p&gt;</description>
815
+ <description>&lt;h1 id=&quot;7.3.0&quot;&gt;Version 7.3.0 (2006-09-30)&lt;/h1&gt;
816
+
817
+
818
+ &lt;h2&gt;Summary&lt;/h2&gt;
819
+
820
+
821
+ &lt;p&gt;This release fixes a bug in generated Verilog benches, includes parsed constants in generated tests, and adds new methods to handles.&lt;/p&gt;
822
+
823
+
824
+ &lt;h2&gt;Notice&lt;/h2&gt;
825
+
826
+
827
+ &lt;ul&gt;
828
+ &lt;li&gt;Handles now have two new methods:
829
+ &lt;ul&gt;
830
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;handle.x?&lt;/code&gt; checks if the logic value is &amp;#8220;don&amp;#8217;t care&amp;#8221; &lt;/li&gt;
831
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;handle.z?&lt;/code&gt; checks if the logic value is high impedance&lt;/li&gt;
832
+ &lt;/ul&gt;&lt;/li&gt;
833
+ &lt;/ul&gt;
834
+
835
+
836
+ &lt;h2&gt;Details&lt;/h2&gt;
837
+
838
+
839
+ &lt;ul&gt;
840
+ &lt;li&gt;Module instantiation code in generated Verilog benches has been fixed. Whitespace between the module type and instance variable was missing.&lt;/li&gt;
841
+ &lt;/ul&gt;
842
+
843
+
844
+ &lt;ul&gt;
845
+ &lt;li&gt;The test generator tool now provides parsed Verilog constants and include-directives in generated Verilog benches; and parsed Verilog constants in generated Ruby designs.
846
+ &lt;ul&gt;
847
+ &lt;li&gt;The pipelined &lt;span class=&quot;caps&quot;&gt;ALU&lt;/span&gt; example has been revised accordingly.&lt;/li&gt;
848
+ &lt;/ul&gt;&lt;/li&gt;
849
+ &lt;/ul&gt;
850
+
851
+
852
+ &lt;ul&gt;
853
+ &lt;li&gt;A library for parsing Verilog source code has been added as &lt;tt&gt;lib/ruby-vpi/verilog_parser.rb&lt;/tt&gt;.&lt;/li&gt;
854
+ &lt;/ul&gt;</description>
103
855
  <pubDate>Sat, 30 Sep 2006 00:00:00 PDT</pubDate>
104
856
  </item>
105
857
  <item>
106
858
  <title>Version 7.2.0 released</title>
107
859
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#7.2.0</link>
108
860
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#7.2.0</guid>
109
- <description>&lt;p&gt;This release adds initial support for code coverage analysis via the &lt;a href=&quot;http://eigenclass.org/hiki.rb?rcov&quot;&gt;rcov library&lt;/a&gt;.&lt;/p&gt;</description>
861
+ <description>&lt;h1 id=&quot;7.2.0&quot;&gt;Version 7.2.0 (2006-09-15)&lt;/h1&gt;
862
+
863
+
864
+ &lt;h2&gt;Summary&lt;/h2&gt;
865
+
866
+
867
+ &lt;p&gt;This release adds initial support for code coverage analysis via the &lt;a href=&quot;http://eigenclass.org/hiki.rb?rcov&quot;&gt;rcov library&lt;/a&gt;.&lt;/p&gt;
868
+
869
+
870
+ &lt;h2&gt;Acknowledgment&lt;/h2&gt;
871
+
872
+
873
+ &lt;p&gt;Thanks to Mauricio Fernandez for helping me use rcov without its runner.&lt;/p&gt;
874
+
875
+
876
+ &lt;h2&gt;Details&lt;/h2&gt;
877
+
878
+
879
+ &lt;ul&gt;
880
+ &lt;li&gt;Added initial support (full capabilites of the rcov library, such as its various analysis modes, are not yet utilized) for code coverage analysis, which can be enabled by setting the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;COVERAGE&lt;/span&gt;&lt;/code&gt; environment variable to a non-empty value before running a test.
881
+ &lt;ul&gt;
882
+ &lt;li&gt;For example, you can run a test with the &lt;span class=&quot;caps&quot;&gt;GPL&lt;/span&gt; Cver simulator while enabling the generation of code coverage reports as follows: &lt;pre&gt;export COVERAGE=1; rake cver&lt;/pre&gt;&lt;/li&gt;
883
+ &lt;/ul&gt;&lt;/li&gt;
884
+ &lt;/ul&gt;
885
+
886
+
887
+ &lt;ul&gt;
888
+ &lt;li&gt;Coverage reports are generated in text and &lt;span class=&quot;caps&quot;&gt;HTML&lt;/span&gt; formats.&lt;/li&gt;
889
+ &lt;/ul&gt;</description>
110
890
  <pubDate>Fri, 15 Sep 2006 00:00:00 PDT</pubDate>
111
891
  </item>
112
892
  <item>
113
893
  <title>Version 7.1.0 released</title>
114
894
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#7.1.0</link>
115
895
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#7.1.0</guid>
116
- <description>&lt;p&gt;This release simplifies running of multiple tests, restores compatibility with Synopsys &lt;span class=&quot;caps&quot;&gt;VCS&lt;/span&gt;, and better integrates with RubyGems.&lt;/p&gt;</description>
896
+ <description>&lt;h1 id=&quot;7.1.0&quot;&gt;Version 7.1.0 (2006-08-29)&lt;/h1&gt;
897
+
898
+
899
+ &lt;h2&gt;Summary&lt;/h2&gt;
900
+
901
+
902
+ &lt;p&gt;This release simplifies running of multiple tests, restores compatibility with Synopsys &lt;span class=&quot;caps&quot;&gt;VCS&lt;/span&gt;, and better integrates with RubyGems.&lt;/p&gt;
903
+
904
+
905
+ &lt;h2&gt;Details&lt;/h2&gt;
906
+
907
+
908
+ &lt;ul&gt;
909
+ &lt;li&gt;Added &lt;tt&gt;lib/ruby-vpi/runner_proxy.rb&lt;/tt&gt; library which, when embedded into a Rakefile, runs all generated tests in the working directory with any specified arguments. For example, have a look at the &lt;tt&gt;samp/counter/Rakefile&lt;/tt&gt; file.&lt;/li&gt;
910
+ &lt;/ul&gt;
911
+
912
+
913
+ &lt;ul&gt;
914
+ &lt;li&gt;Fixed a bug that prevented one from running tests with Synopsys &lt;span class=&quot;caps&quot;&gt;VCS&lt;/span&gt;.&lt;/li&gt;
915
+ &lt;/ul&gt;
916
+
917
+
918
+ &lt;ul&gt;
919
+ &lt;li&gt;Ruby-VPI documentation is now available through RubyGems&amp;#8217; &lt;a href=&quot;http://docs.rubygems.org/read/chapter/2#page10&quot;&gt;&lt;strong&gt;gem_server&lt;/strong&gt; web interface&lt;/a&gt;.&lt;/li&gt;
920
+ &lt;/ul&gt;
921
+
922
+
923
+ &lt;ul&gt;
924
+ &lt;li&gt;The user manual now discusses how to determine the location of a Ruby-VPI installation.&lt;/li&gt;
925
+ &lt;/ul&gt;
926
+
927
+
928
+ &lt;ul&gt;
929
+ &lt;li&gt;The &lt;tt&gt;tpl/&lt;/tt&gt; directory has been removed.&lt;/li&gt;
930
+ &lt;/ul&gt;</description>
117
931
  <pubDate>Tue, 29 Aug 2006 00:00:00 PDT</pubDate>
118
932
  </item>
119
933
  <item>
120
934
  <title>Version 7.0.0 released</title>
121
935
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#7.0.0</link>
122
936
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#7.0.0</guid>
123
- <description>&lt;p&gt;This release distributes Ruby-VPI as a gem, improves portability of generated tests, and fixes a bug.&lt;/p&gt;</description>
937
+ <description>&lt;h1 id=&quot;7.0.0&quot;&gt;Version 7.0.0 (2006-08-29)&lt;/h1&gt;
938
+
939
+
940
+ &lt;h2&gt;Summary&lt;/h2&gt;
941
+
942
+
943
+ &lt;p&gt;This release distributes Ruby-VPI as a gem, improves portability of generated tests, and fixes a bug.&lt;/p&gt;
944
+
945
+
946
+ &lt;h2&gt;Notice&lt;/h2&gt;
947
+
948
+
949
+ &lt;ul&gt;
950
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;put_value()&lt;/code&gt; now accomodates register value overflows when verifying the value it has written.&lt;/li&gt;
951
+ &lt;/ul&gt;
952
+
953
+
954
+ &lt;ul&gt;
955
+ &lt;li&gt;The test generator&amp;#8217;s templates and the examples have been updated as follows:
956
+ &lt;ul&gt;
957
+ &lt;li&gt;Test runners no longer have to specify the path to Ruby-VPI installation directory. Instead, they simply &lt;code class=&quot;code&quot;&gt;require &lt;span style=&quot;background-color:#fff0f0&quot;&gt;&lt;span style=&quot;color:#710&quot;&gt;'&lt;/span&gt;&lt;span style=&quot;color:#D20&quot;&gt;ruby-vpi/runner&lt;/span&gt;&lt;span style=&quot;color:#710&quot;&gt;'&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;. Thus, you can run your tests on any machine with Ruby-VPI without having to know where it is installed.&lt;/li&gt;
958
+ &lt;li&gt;Ruby benches now invoke &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;RubyVPI&lt;/span&gt;.init_bench&lt;/code&gt; instead of &lt;code class=&quot;code&quot;&gt;require &lt;span style=&quot;background-color:#fff0f0&quot;&gt;&lt;span style=&quot;color:#710&quot;&gt;'&lt;/span&gt;&lt;span style=&quot;color:#D20&quot;&gt;bench&lt;/span&gt;&lt;span style=&quot;color:#710&quot;&gt;'&lt;/span&gt;&lt;/span&gt;; setup_bench&lt;/code&gt; to become initialized.&lt;/li&gt;
959
+ &lt;/ul&gt;&lt;/li&gt;
960
+ &lt;/ul&gt;
961
+
962
+
963
+ &lt;ul&gt;
964
+ &lt;li&gt;All Ruby libraries in the &lt;tt&gt;lib/&lt;/tt&gt; directory have been moved into &lt;tt&gt;lib/ruby-vpi/&lt;/tt&gt; to prevent load-path clashes with other gems. You should access these libraries by prefixing their path with &amp;#8220;ruby-vpi&amp;#8221;. For example, &lt;code class=&quot;code&quot;&gt;require &lt;span style=&quot;background-color:#fff0f0&quot;&gt;&lt;span style=&quot;color:#710&quot;&gt;'&lt;/span&gt;&lt;span style=&quot;color:#D20&quot;&gt;vpi_util&lt;/span&gt;&lt;span style=&quot;color:#710&quot;&gt;'&lt;/span&gt;&lt;/span&gt;&lt;/code&gt; should now be written as &lt;code class=&quot;code&quot;&gt;require &lt;span style=&quot;background-color:#fff0f0&quot;&gt;&lt;span style=&quot;color:#710&quot;&gt;'&lt;/span&gt;&lt;span style=&quot;color:#D20&quot;&gt;ruby-vpi/vpi_util&lt;/span&gt;&lt;span style=&quot;color:#710&quot;&gt;'&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;.&lt;/li&gt;
965
+ &lt;/ul&gt;
966
+
967
+
968
+ &lt;ul&gt;
969
+ &lt;li&gt;The &lt;tt&gt;src/&lt;/tt&gt; directory has been renamed to &lt;tt&gt;ext/&lt;/tt&gt; to follow RubyGems convention.&lt;/li&gt;
970
+ &lt;/ul&gt;
971
+
972
+
973
+ &lt;h2&gt;Details&lt;/h2&gt;
974
+
975
+
976
+ &lt;ul&gt;
977
+ &lt;li&gt;Ruby-VPI is now distributed only as a &lt;a href=&quot;http://www.rubygems.org&quot;&gt;source gem&lt;/a&gt;. You can decompress the gem without installing it onto your system by running the command &lt;pre&gt;gem install -i output_directory ruby-vpi-7.0.0.gem&lt;/pre&gt;. In addition, you can still obtain the source code directly from the Subversion repository.&lt;/li&gt;
978
+ &lt;/ul&gt;
979
+
980
+
981
+ &lt;ul&gt;
982
+ &lt;li&gt;The tools in &lt;tt&gt;bin/&lt;/tt&gt; become available in your system&amp;#8217;s &lt;tt&gt;bin/&lt;/tt&gt; directory when the gem is installed.
983
+ &lt;ul&gt;
984
+ &lt;li&gt;Usage and help information has been added to the &lt;strong&gt;header_to_ruby.rb&lt;/strong&gt; tool.&lt;/li&gt;
985
+ &lt;/ul&gt;&lt;/li&gt;
986
+ &lt;/ul&gt;
987
+
988
+
989
+ &lt;ul&gt;
990
+ &lt;li&gt;Incorrect spelling of &lt;span class=&quot;caps&quot;&gt;GPL&lt;/span&gt; Cver (v should be uncapitalized) has been fixed.&lt;/li&gt;
991
+ &lt;/ul&gt;
992
+
993
+
994
+ &lt;ul&gt;
995
+ &lt;li&gt;Incorrect link to &lt;span class=&quot;caps&quot;&gt;GPL&lt;/span&gt; Cver website has been fixed.&lt;/li&gt;
996
+ &lt;/ul&gt;
997
+
998
+
999
+ &lt;ul&gt;
1000
+ &lt;li&gt;The user manual has been updated according to all of the above changes.&lt;/li&gt;
1001
+ &lt;/ul&gt;</description>
124
1002
  <pubDate>Tue, 29 Aug 2006 00:00:00 PDT</pubDate>
125
1003
  </item>
126
1004
  <item>
127
1005
  <title>Version 6.3.0 released</title>
128
1006
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#6.3.0</link>
129
1007
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#6.3.0</guid>
130
- <description>&lt;p&gt;This release adds support for the &lt;span class=&quot;caps&quot;&gt;GPL&lt;/span&gt; Cver simulator, provides both binary and source packages, and explicitly defines the version numbering system.&lt;/p&gt;</description>
1008
+ <description>&lt;h1 id=&quot;6.3.0&quot;&gt;Version 6.3.0 (2006-08-27)&lt;/h1&gt;
1009
+
1010
+
1011
+ &lt;h2&gt;Summary&lt;/h2&gt;
1012
+
1013
+
1014
+ &lt;p&gt;This release adds support for the &lt;span class=&quot;caps&quot;&gt;GPL&lt;/span&gt; Cver simulator, provides both binary and source packages, and explicitly defines the version numbering system.&lt;/p&gt;
1015
+
1016
+
1017
+ &lt;h2&gt;Notice&lt;/h2&gt;
1018
+
1019
+
1020
+ &lt;ul&gt;
1021
+ &lt;li&gt;Ruby-VPI now only needs to be built once.
1022
+ &lt;ul&gt;
1023
+ &lt;li&gt;You can run tests with different Verilog simulators without having to re-compile Ruby-VPI.&lt;/li&gt;
1024
+ &lt;/ul&gt;&lt;/li&gt;
1025
+ &lt;/ul&gt;
1026
+
1027
+
1028
+ &lt;h2&gt;Details&lt;/h2&gt;
1029
+
1030
+
1031
+ &lt;ul&gt;
1032
+ &lt;li&gt;The &lt;span class=&quot;caps&quot;&gt;GPL&lt;/span&gt; Cver simulator is now supported.&lt;/li&gt;
1033
+ &lt;/ul&gt;
1034
+
1035
+
1036
+ &lt;ul&gt;
1037
+ &lt;li&gt;Release packages are now available in both source and binary form.&lt;/li&gt;
1038
+ &lt;/ul&gt;
1039
+
1040
+
1041
+ &lt;ul&gt;
1042
+ &lt;li&gt;The RSpec based specifications for the counter example now use the &lt;code class=&quot;code&quot;&gt;should_equal&lt;/code&gt; instead of the &lt;code class=&quot;code&quot;&gt;should_be&lt;/code&gt; assertion, because the latter ensures strict equivalence. For instance, it will fail when a Fixnum is compared to a Bignum.&lt;/li&gt;
1043
+ &lt;/ul&gt;
1044
+
1045
+
1046
+ &lt;ul&gt;
1047
+ &lt;li&gt;We now follow the RubyGems project&amp;#8217;s &lt;a href=&quot;http://www.rubygems.org/read/chapter/7&quot;&gt;rational versioning policy&lt;/a&gt;. The version numbers of previous releases have been revised accordingly:
1048
+ &lt;table&gt;
1049
+ &lt;tr&gt;
1050
+ &lt;th&gt;Release date &lt;/th&gt;
1051
+ &lt;th&gt;Original version number &lt;/th&gt;
1052
+ &lt;th&gt;New version number &lt;/th&gt;
1053
+ &lt;/tr&gt;
1054
+ &lt;tr&gt;
1055
+ &lt;td&gt; 1999-10-31 &lt;/td&gt;
1056
+ &lt;td&gt; 0.0 &lt;/td&gt;
1057
+ &lt;td&gt; 0.0.0 &lt;/td&gt;
1058
+ &lt;/tr&gt;
1059
+ &lt;tr&gt;
1060
+ &lt;td&gt; 2006-02-26 &lt;/td&gt;
1061
+ &lt;td&gt; 0.1 &lt;/td&gt;
1062
+ &lt;td&gt; 1.0.0 &lt;/td&gt;
1063
+ &lt;/tr&gt;
1064
+ &lt;tr&gt;
1065
+ &lt;td&gt; 2006-04-17 &lt;/td&gt;
1066
+ &lt;td&gt; 0.2 &lt;/td&gt;
1067
+ &lt;td&gt; 2.0.0 &lt;/td&gt;
1068
+ &lt;/tr&gt;
1069
+ &lt;tr&gt;
1070
+ &lt;td&gt; 2006-04-23 &lt;/td&gt;
1071
+ &lt;td&gt; 0.3 &lt;/td&gt;
1072
+ &lt;td&gt; 3.0.0 &lt;/td&gt;
1073
+ &lt;/tr&gt;
1074
+ &lt;tr&gt;
1075
+ &lt;td&gt; 2006-04-28 &lt;/td&gt;
1076
+ &lt;td&gt; 0.4 &lt;/td&gt;
1077
+ &lt;td&gt; 3.1.0 &lt;/td&gt;
1078
+ &lt;/tr&gt;
1079
+ &lt;tr&gt;
1080
+ &lt;td&gt; 2006-05-13 &lt;/td&gt;
1081
+ &lt;td&gt; 0.5 &lt;/td&gt;
1082
+ &lt;td&gt; 3.2.0 &lt;/td&gt;
1083
+ &lt;/tr&gt;
1084
+ &lt;tr&gt;
1085
+ &lt;td&gt; 2006-05-25 &lt;/td&gt;
1086
+ &lt;td&gt; 0.6 &lt;/td&gt;
1087
+ &lt;td&gt; 4.0.0 &lt;/td&gt;
1088
+ &lt;/tr&gt;
1089
+ &lt;tr&gt;
1090
+ &lt;td&gt; 2006-07-22 &lt;/td&gt;
1091
+ &lt;td&gt; 0.7 &lt;/td&gt;
1092
+ &lt;td&gt; 5.0.0 &lt;/td&gt;
1093
+ &lt;/tr&gt;
1094
+ &lt;tr&gt;
1095
+ &lt;td&gt; 2006-07-29 &lt;/td&gt;
1096
+ &lt;td&gt; 0.8 &lt;/td&gt;
1097
+ &lt;td&gt; 5.1.0 &lt;/td&gt;
1098
+ &lt;/tr&gt;
1099
+ &lt;tr&gt;
1100
+ &lt;td&gt; 2006-08-04 &lt;/td&gt;
1101
+ &lt;td&gt; 0.8.1 &lt;/td&gt;
1102
+ &lt;td&gt; 5.1.1 &lt;/td&gt;
1103
+ &lt;/tr&gt;
1104
+ &lt;tr&gt;
1105
+ &lt;td&gt; 2006-08-07 &lt;/td&gt;
1106
+ &lt;td&gt; 0.9 &lt;/td&gt;
1107
+ &lt;td&gt; 6.0.0 &lt;/td&gt;
1108
+ &lt;/tr&gt;
1109
+ &lt;tr&gt;
1110
+ &lt;td&gt; 2006-08-09 &lt;/td&gt;
1111
+ &lt;td&gt; 0.9.1 &lt;/td&gt;
1112
+ &lt;td&gt; 6.1.0 &lt;/td&gt;
1113
+ &lt;/tr&gt;
1114
+ &lt;tr&gt;
1115
+ &lt;td&gt; 2006-08-26 &lt;/td&gt;
1116
+ &lt;td&gt; 0.9.2 &lt;/td&gt;
1117
+ &lt;td&gt; 6.2.0 &lt;/td&gt;
1118
+ &lt;/tr&gt;
1119
+ &lt;/table&gt;&lt;/li&gt;
1120
+ &lt;/ul&gt;</description>
131
1121
  <pubDate>Sun, 27 Aug 2006 00:00:00 PDT</pubDate>
132
1122
  </item>
133
1123
  <item>
134
1124
  <title>Version 6.2.0 released</title>
135
1125
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#6.2.0</link>
136
1126
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#6.2.0</guid>
137
- <description>&lt;p&gt;This release beautifies generated tests, adds checks to find signal width bugs, and includes a new tool.&lt;/p&gt;</description>
1127
+ <description>&lt;h1 id=&quot;6.2.0&quot;&gt;Version 6.2.0 (2006-08-26)&lt;/h1&gt;
1128
+
1129
+
1130
+ &lt;h2&gt;Summary&lt;/h2&gt;
1131
+
1132
+
1133
+ &lt;p&gt;This release beautifies generated tests, adds checks to find signal width bugs, and includes a new tool.&lt;/p&gt;
1134
+
1135
+
1136
+ &lt;h2&gt;Notice&lt;/h2&gt;
1137
+
1138
+
1139
+ &lt;ul&gt;
1140
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;put_value()&lt;/code&gt; now returns the value it puts. Therefore, it is easier to chain together a series of assignments: &lt;code class=&quot;code&quot;&gt;foo.intVal = bar.intVal = baz.intVal = &lt;span style=&quot;color:#00D; font-weight:bold&quot;&gt;10&lt;/span&gt;&lt;/code&gt;&lt;/li&gt;
1141
+ &lt;/ul&gt;
1142
+
1143
+
1144
+ &lt;ul&gt;
1145
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;put_value()&lt;/code&gt; now verifies that the value it puts was written correctly. This helps to find bugs regarding invalid assumptions about the number of bits supported by a signal.&lt;/li&gt;
1146
+ &lt;/ul&gt;
1147
+
1148
+
1149
+ &lt;h2&gt;Details&lt;/h2&gt;
1150
+
1151
+
1152
+ &lt;ul&gt;
1153
+ &lt;li&gt;The test generator now uses &lt;span class=&quot;caps&quot;&gt;ERB&lt;/span&gt; templates which ensures nice indentation of generated output.&lt;/li&gt;
1154
+ &lt;/ul&gt;
1155
+
1156
+
1157
+ &lt;ul&gt;
1158
+ &lt;li&gt;The test generator now decouples Ruby-VPI paths from Verilog benches via the &lt;span class=&quot;caps&quot;&gt;RUBYLIB&lt;/span&gt; environment variable.&lt;/li&gt;
1159
+ &lt;/ul&gt;
1160
+
1161
+
1162
+ &lt;ul&gt;
1163
+ &lt;li&gt;A tool which converts Verilog headers into Ruby has been added.&lt;/li&gt;
1164
+ &lt;/ul&gt;
1165
+
1166
+
1167
+ &lt;ul&gt;
1168
+ &lt;li&gt;The source code is now indented with two spaces instead of one tab character.&lt;/li&gt;
1169
+ &lt;/ul&gt;</description>
138
1170
  <pubDate>Sat, 26 Aug 2006 00:00:00 PDT</pubDate>
139
1171
  </item>
140
1172
  <item>
141
1173
  <title>Version 6.1.0 released</title>
142
1174
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#6.1.0</link>
143
1175
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#6.1.0</guid>
144
- <description>&lt;p&gt;This release simplifies generated tests and fixes a bug.&lt;/p&gt;</description>
1176
+ <description>&lt;h1 id=&quot;6.1.0&quot;&gt;Version 6.1.0 (2006-08-09)&lt;/h1&gt;
1177
+
1178
+
1179
+ &lt;h2&gt;Summary&lt;/h2&gt;
1180
+
1181
+
1182
+ &lt;p&gt;This release simplifies generated tests and fixes a bug.&lt;/p&gt;
1183
+
1184
+
1185
+ &lt;h2&gt;Details&lt;/h2&gt;
1186
+
1187
+
1188
+ &lt;ul&gt;
1189
+ &lt;li&gt;The test generator now produces simpler Ruby benches and specifications.
1190
+ &lt;ul&gt;
1191
+ &lt;li&gt;A template used by generated specifications has been added.&lt;/li&gt;
1192
+ &lt;li&gt;The counter example and tutorial have also been simplified accordingly.&lt;/li&gt;
1193
+ &lt;/ul&gt;&lt;/li&gt;
1194
+ &lt;/ul&gt;
1195
+
1196
+
1197
+ &lt;ul&gt;
1198
+ &lt;li&gt;Boolean &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; property values are now correctly converted into Ruby truth values.&lt;/li&gt;
1199
+ &lt;/ul&gt;</description>
145
1200
  <pubDate>Wed, 09 Aug 2006 00:00:00 PDT</pubDate>
146
1201
  </item>
147
1202
  <item>
148
1203
  <title>Version 6.0.0 released</title>
149
1204
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#6.0.0</link>
150
1205
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#6.0.0</guid>
151
- <description>&lt;p&gt;This release adds support and documentation for rapid prototyping of Verilog designs in Ruby.&lt;/p&gt;</description>
1206
+ <description>&lt;h1 id=&quot;6.0.0&quot;&gt;Version 6.0.0 (2006-08-07)&lt;/h1&gt;
1207
+
1208
+
1209
+ &lt;h2&gt;Summary&lt;/h2&gt;
1210
+
1211
+
1212
+ &lt;p&gt;This release adds support and documentation for rapid prototyping of Verilog designs in Ruby.&lt;/p&gt;
1213
+
1214
+
1215
+ &lt;h2&gt;Notice&lt;/h2&gt;
1216
+
1217
+
1218
+ &lt;ul&gt;
1219
+ &lt;li&gt;The directory structure has been reorganized as follows:
1220
+ &lt;ul&gt;
1221
+ &lt;li&gt;&lt;tt&gt;ext&lt;/tt&gt; &amp;rarr; &lt;tt&gt;src&lt;/tt&gt;&lt;/li&gt;
1222
+ &lt;li&gt;&lt;tt&gt;tools&lt;/tt&gt; &amp;rarr; &lt;tt&gt;bin&lt;/tt&gt;&lt;/li&gt;
1223
+ &lt;li&gt;&lt;tt&gt;examples&lt;/tt&gt; &amp;rarr; &lt;tt&gt;samp&lt;/tt&gt;&lt;/li&gt;
1224
+ &lt;/ul&gt;&lt;/li&gt;
1225
+ &lt;/ul&gt;
1226
+
1227
+
1228
+ &lt;ul&gt;
1229
+ &lt;li&gt;All template files have been moved into the &lt;tt&gt;tpl&lt;/tt&gt; directory.&lt;/li&gt;
1230
+ &lt;/ul&gt;
1231
+
1232
+
1233
+ &lt;h2&gt;Details&lt;/h2&gt;
1234
+
1235
+
1236
+ &lt;ul&gt;
1237
+ &lt;li&gt;Support for prototyping designs in Ruby, before they are implemented in Verilog, has been added.
1238
+ &lt;ul&gt;
1239
+ &lt;li&gt;The &lt;em&gt;same&lt;/em&gt; specification can be used to verify both prototype &lt;em&gt;and&lt;/em&gt; design! :-)&lt;/li&gt;
1240
+ &lt;li&gt;The tutorial in the user manual has been updated to discuss prototyping.
1241
+ &lt;ul&gt;
1242
+ &lt;li&gt;Prototypes have been added to the counter example.&lt;/li&gt;
1243
+ &lt;/ul&gt;&lt;/li&gt;
1244
+ &lt;/ul&gt;&lt;/li&gt;
1245
+ &lt;/ul&gt;
1246
+
1247
+
1248
+ &lt;ul&gt;
1249
+ &lt;li&gt;The user manual has been revised for consistency.&lt;/li&gt;
1250
+ &lt;/ul&gt;</description>
152
1251
  <pubDate>Mon, 07 Aug 2006 00:00:00 PDT</pubDate>
153
1252
  </item>
154
1253
  <item>
155
1254
  <title>Version 5.1.1 released</title>
156
1255
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#5.1.1</link>
157
1256
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#5.1.1</guid>
158
- <description>&lt;p&gt;This release fixes unreadable syntax coloring in the user manual.&lt;/p&gt;</description>
1257
+ <description>&lt;h1 id=&quot;5.1.1&quot;&gt;Version 5.1.1 (2006-08-04)&lt;/h1&gt;
1258
+
1259
+
1260
+ &lt;h2&gt;Summary&lt;/h2&gt;
1261
+
1262
+
1263
+ &lt;p&gt;This release fixes unreadable syntax coloring in the user manual.&lt;/p&gt;
1264
+
1265
+
1266
+ &lt;h2&gt;Acknowledgment&lt;/h2&gt;
1267
+
1268
+
1269
+ &lt;ul&gt;
1270
+ &lt;li&gt;Thanks to Todd Nagengast and Matt Fischler for notifying me about unreadable text in the user manual.&lt;/li&gt;
1271
+ &lt;/ul&gt;
1272
+
1273
+
1274
+ &lt;h2&gt;Details&lt;/h2&gt;
1275
+
1276
+
1277
+ &lt;ul&gt;
1278
+ &lt;li&gt;Source code comments in the user manual are now readable.&lt;/li&gt;
1279
+ &lt;/ul&gt;
1280
+
1281
+
1282
+ &lt;ul&gt;
1283
+ &lt;li&gt;The &lt;tt&gt;README&lt;/tt&gt; and &lt;tt&gt;HISTORY&lt;/tt&gt; files have been converted to &lt;a href=&quot;http://www.textism.com/tools/textile/&quot;&gt;textile&lt;/a&gt; format.&lt;/li&gt;
1284
+ &lt;/ul&gt;</description>
159
1285
  <pubDate>Fri, 04 Aug 2006 00:00:00 PDT</pubDate>
160
1286
  </item>
161
1287
  <item>
162
1288
  <title>Version 5.1.0 released</title>
163
1289
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#5.1.0</link>
164
1290
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#5.1.0</guid>
165
- <description>&lt;p&gt;This release adds a tutorial to the user manual, and improves the tools and examples.&lt;/p&gt;</description>
1291
+ <description>&lt;h1 id=&quot;5.1.0&quot;&gt;Version 5.1.0 (2006-07-29)&lt;/h1&gt;
1292
+
1293
+
1294
+ &lt;h2&gt;Summary&lt;/h2&gt;
1295
+
1296
+
1297
+ &lt;p&gt;This release adds a tutorial to the user manual, and improves the tools and examples.&lt;/p&gt;
1298
+
1299
+
1300
+ &lt;h2&gt;Acknowledgment&lt;/h2&gt;
1301
+
1302
+
1303
+ &lt;ul&gt;
1304
+ &lt;li&gt;Thanks to Phil Tomson for correcting the &lt;span class=&quot;caps&quot;&gt;URL&lt;/span&gt; of the &lt;span class=&quot;caps&quot;&gt;RHDL&lt;/span&gt; website, in the user manual.&lt;/li&gt;
1305
+ &lt;/ul&gt;
1306
+
1307
+
1308
+ &lt;h2&gt;Details&lt;/h2&gt;
1309
+
1310
+
1311
+ &lt;h3&gt;User manual&lt;/h3&gt;
1312
+
1313
+
1314
+ &lt;ul&gt;
1315
+ &lt;li&gt;A tutorial, based on the counter example, has been added to the user manual.&lt;/li&gt;
1316
+ &lt;/ul&gt;
1317
+
1318
+
1319
+ &lt;ul&gt;
1320
+ &lt;li&gt;The user manual&amp;#8217;s appearance has been dramatically improved with syntax coloring for source code, and &lt;a href=&quot;http://tango.freedesktop.org&quot;&gt;graphics for admonitions and navigation&lt;/a&gt;.&lt;/li&gt;
1321
+ &lt;/ul&gt;
1322
+
1323
+
1324
+ &lt;h3&gt;Examples&lt;/h3&gt;
1325
+
1326
+
1327
+ &lt;ul&gt;
1328
+ &lt;li&gt;A specification, expressed in unit test format, has been added to the counter example.&lt;/li&gt;
1329
+ &lt;/ul&gt;
1330
+
1331
+
1332
+ &lt;ul&gt;
1333
+ &lt;li&gt;The &lt;pre&gt;--name&lt;/pre&gt; and &lt;pre&gt;-n&lt;/pre&gt; options, which lets you specify an identifier for a generated test, have been added to the &lt;strong&gt;generate_test.rb&lt;/strong&gt; tool.&lt;/li&gt;
1334
+ &lt;/ul&gt;
1335
+
1336
+
1337
+ &lt;ul&gt;
1338
+ &lt;li&gt;Running &lt;pre&gt;rake clobber&lt;/pre&gt; in an example directory no longer destroys documentation in the Ruby-VPI directory.&lt;/li&gt;
1339
+ &lt;/ul&gt;
1340
+
1341
+
1342
+ &lt;ul&gt;
1343
+ &lt;li&gt;The examples&amp;#8217; Rakefiles now invoke all tests present in the directory via the &lt;tt&gt;launcher_template.rake&lt;/tt&gt; template.&lt;/li&gt;
1344
+ &lt;/ul&gt;
1345
+
1346
+
1347
+ &lt;ul&gt;
1348
+ &lt;li&gt;The Rake template for test runners (generated by &lt;tt&gt;tools/generate_test.rb&lt;/tt&gt;) has moved from &lt;tt&gt;examples/template.rake&lt;/tt&gt; to &lt;tt&gt;examples/runner_template.rake&lt;/tt&gt;.&lt;/li&gt;
1349
+ &lt;/ul&gt;
1350
+
1351
+
1352
+ &lt;h3&gt;&lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; utility layer&lt;/h3&gt;
1353
+
1354
+
1355
+ &lt;ul&gt;
1356
+ &lt;li&gt;The value of a handle&amp;#8217;s boolean &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; property is treated as &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#038; font-weight:bold&quot;&gt;false&lt;/span&gt;&lt;/code&gt; if it is zero, because zero is &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#038; font-weight:bold&quot;&gt;false&lt;/span&gt;&lt;/code&gt; in the C language.&lt;/li&gt;
1357
+ &lt;/ul&gt;</description>
166
1358
  <pubDate>Sat, 29 Jul 2006 00:00:00 PDT</pubDate>
167
1359
  </item>
168
1360
  <item>
169
1361
  <title>Version 5.0.0 released</title>
170
1362
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#5.0.0</link>
171
1363
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#5.0.0</guid>
172
- <description>&lt;p&gt;This release enhances the &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; utility layer and adds new content to the user manual.&lt;/p&gt;</description>
1364
+ <description>&lt;h1 id=&quot;5.0.0&quot;&gt;Version 5.0.0 (2006-07-22)&lt;/h1&gt;
1365
+
1366
+
1367
+ &lt;h2&gt;Summary&lt;/h2&gt;
1368
+
1369
+
1370
+ &lt;p&gt;This release enhances the &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; utility layer and adds new content to the user manual.&lt;/p&gt;
1371
+
1372
+
1373
+ &lt;h2&gt;Acknowledgment&lt;/h2&gt;
1374
+
1375
+
1376
+ &lt;ul&gt;
1377
+ &lt;li&gt;Thanks to Jan Decaluwe for correcting the description of MyHDL in the user manual.&lt;/li&gt;
1378
+ &lt;/ul&gt;
1379
+
1380
+
1381
+ &lt;h2&gt;Notice&lt;/h2&gt;
1382
+
1383
+
1384
+ &lt;ul&gt;
1385
+ &lt;li&gt;&lt;span class=&quot;caps&quot;&gt;SWIG&lt;/span&gt; is no longer required for users because its output is included in the release package.&lt;/li&gt;
1386
+ &lt;/ul&gt;
1387
+
1388
+
1389
+ &lt;ul&gt;
1390
+ &lt;li&gt;The &lt;code class=&quot;code&quot;&gt;handle.value&lt;/code&gt; and &lt;code class=&quot;code&quot;&gt;handle.value=&lt;/code&gt; methods have been removed.&lt;/li&gt;
1391
+ &lt;/ul&gt;
1392
+
1393
+
1394
+ &lt;h2&gt;Details&lt;/h2&gt;
1395
+
1396
+
1397
+ &lt;ul&gt;
1398
+ &lt;li&gt;The &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; utility layer provides access to &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; properties of handles in a &lt;a href=&quot;manual.html#background.org.vpi&quot;&gt;simpler, more powerful way&lt;/a&gt;.&lt;/li&gt;
1399
+ &lt;/ul&gt;
1400
+
1401
+
1402
+ &lt;ul&gt;
1403
+ &lt;li&gt;All &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; properties, except delay values, are now accessible from a handle.&lt;/li&gt;
1404
+ &lt;/ul&gt;
1405
+
1406
+
1407
+ &lt;ul&gt;
1408
+ &lt;li&gt;The user manual has been revised and new content in the organization and usage sections has been added.&lt;/li&gt;
1409
+ &lt;/ul&gt;
1410
+
1411
+
1412
+ &lt;ul&gt;
1413
+ &lt;li&gt;This release was tested and developed using:
1414
+ &lt;ul&gt;
1415
+ &lt;li&gt;Ruby 1.8.4 and Icarus Verilog 0.8 on i686 &lt;span class=&quot;caps&quot;&gt;GNU&lt;/span&gt;/Linux&lt;/li&gt;
1416
+ &lt;li&gt;Ruby 1.8.4 and Mentor Modelsim 6.1d on x86_64 &lt;span class=&quot;caps&quot;&gt;GNU&lt;/span&gt;/Linux&lt;/li&gt;
1417
+ &lt;/ul&gt;&lt;/li&gt;
1418
+ &lt;/ul&gt;</description>
173
1419
  <pubDate>Sat, 22 Jul 2006 00:00:00 PDT</pubDate>
174
1420
  </item>
175
1421
  <item>
176
1422
  <title>Version 4.0.0 released</title>
177
1423
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#4.0.0</link>
178
1424
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#4.0.0</guid>
179
- <description>&lt;p&gt;This release adds a comprehensive user manual, upgrades from make to &lt;a href=&quot;http://rake.rubyforge.org&quot;&gt;Rake&lt;/a&gt;, and improves the test generation tool.&lt;/p&gt;</description>
1425
+ <description>&lt;h1 id=&quot;4.0.0&quot;&gt;Version 4.0.0 (2006-05-25)&lt;/h1&gt;
1426
+
1427
+
1428
+ &lt;h2&gt;Summary&lt;/h2&gt;
1429
+
1430
+
1431
+ &lt;p&gt;This release adds a comprehensive user manual, upgrades from make to &lt;a href=&quot;http://rake.rubyforge.org&quot;&gt;Rake&lt;/a&gt;, and improves the test generation tool.&lt;/p&gt;
1432
+
1433
+
1434
+ &lt;h2&gt;Acknowledgment&lt;/h2&gt;
1435
+
1436
+
1437
+ &lt;ul&gt;
1438
+ &lt;li&gt;Thanks to Jose Renau for solving the problem of strange delays that occurred whenever a design was reset.&lt;/li&gt;
1439
+ &lt;/ul&gt;
1440
+
1441
+
1442
+ &lt;h2&gt;Notice&lt;/h2&gt;
1443
+
1444
+
1445
+ &lt;ul&gt;
1446
+ &lt;li&gt;Rake has replaced the role of &lt;strong&gt;make&lt;/strong&gt;. All makefiles have been converted accordingly.&lt;/li&gt;
1447
+ &lt;/ul&gt;
1448
+
1449
+
1450
+ &lt;ul&gt;
1451
+ &lt;li&gt;The test generation tool now generates multiple files (runner, bench, design, spec) and makes backups of existing files. See its help information for details.&lt;/li&gt;
1452
+ &lt;/ul&gt;
1453
+
1454
+
1455
+ &lt;h2&gt;Details&lt;/h2&gt;
1456
+
1457
+
1458
+ &lt;ul&gt;
1459
+ &lt;li&gt;A comprehensive user manual, written in DocBook-XML, has been added.&lt;/li&gt;
1460
+ &lt;/ul&gt;
1461
+
1462
+
1463
+ &lt;ul&gt;
1464
+ &lt;li&gt;Support for RSpec 0.5.4 has been added.
1465
+ &lt;ul&gt;
1466
+ &lt;li&gt;The counter example now makes use of RSpec.&lt;/li&gt;
1467
+ &lt;/ul&gt;&lt;/li&gt;
1468
+ &lt;/ul&gt;
1469
+
1470
+
1471
+ &lt;ul&gt;
1472
+ &lt;li&gt;This release was tested and developed using:
1473
+ &lt;ul&gt;
1474
+ &lt;li&gt;Ruby 1.8.4 and Icarus Verilog 0.8 on i686 &lt;span class=&quot;caps&quot;&gt;GNU&lt;/span&gt;/Linux&lt;/li&gt;
1475
+ &lt;li&gt;Ruby 1.8.4 and Mentor Modelsim 6.1d on x86_64 &lt;span class=&quot;caps&quot;&gt;GNU&lt;/span&gt;/Linux&lt;/li&gt;
1476
+ &lt;/ul&gt;&lt;/li&gt;
1477
+ &lt;/ul&gt;</description>
180
1478
  <pubDate>Thu, 25 May 2006 00:00:00 PDT</pubDate>
181
1479
  </item>
182
1480
  <item>
183
1481
  <title>Version 3.2.0 released</title>
184
1482
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#3.2.0</link>
185
1483
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#3.2.0</guid>
186
- <description>&lt;p&gt;This release adds a tool which generates test benches, and adds support for &lt;a href=&quot;http://behaviour-driven.org&quot;&gt;Behavior Driven Development&lt;/a&gt; via the &lt;a href=&quot;http://rspec.rubyforge.org&quot;&gt;RSpec&lt;/a&gt; library.&lt;/p&gt;</description>
1484
+ <description>&lt;h1 id=&quot;3.2.0&quot;&gt;Version 3.2.0 (2006-05-13)&lt;/h1&gt;
1485
+
1486
+
1487
+ &lt;h2&gt;Summary&lt;/h2&gt;
1488
+
1489
+
1490
+ &lt;p&gt;This release adds a tool which generates test benches, and adds support for &lt;a href=&quot;http://behaviour-driven.org&quot;&gt;Behavior Driven Development&lt;/a&gt; via the &lt;a href=&quot;http://rspec.rubyforge.org&quot;&gt;RSpec&lt;/a&gt; library.&lt;/p&gt;
1491
+
1492
+
1493
+ &lt;h2&gt;Acknowledgment&lt;/h2&gt;
1494
+
1495
+
1496
+ &lt;ul&gt;
1497
+ &lt;li&gt;Thanks to Scott L Holmes for helping me &lt;a href=&quot;http://article.gmane.org/gmane.comp.lang.ruby.general/150087&quot;&gt;use the RSpec library without its runner&lt;/a&gt; program.&lt;/li&gt;
1498
+ &lt;/ul&gt;
1499
+
1500
+
1501
+ &lt;h2&gt;Details&lt;/h2&gt;
1502
+
1503
+
1504
+ &lt;ul&gt;
1505
+ &lt;li&gt;A tool, which generates most of a Ruby-VPI test bench from a Verilog 2001 module declaration, has been added.&lt;/li&gt;
1506
+ &lt;/ul&gt;
1507
+
1508
+
1509
+ &lt;ul&gt;
1510
+ &lt;li&gt;Ability to use RSpec in a test bench has been added.&lt;/li&gt;
1511
+ &lt;/ul&gt;
1512
+
1513
+
1514
+ &lt;ul&gt;
1515
+ &lt;li&gt;Ability to specify arbitrary command-line arguments to Verilog simulators has been added in the examples&amp;#8217; makefile template.&lt;/li&gt;
1516
+ &lt;/ul&gt;
1517
+
1518
+
1519
+ &lt;ul&gt;
1520
+ &lt;li&gt;This release was tested and developed using:
1521
+ &lt;ul&gt;
1522
+ &lt;li&gt;Ruby 1.8.4 and Icarus Verilog 0.8 on i686 &lt;span class=&quot;caps&quot;&gt;GNU&lt;/span&gt;/Linux&lt;/li&gt;
1523
+ &lt;li&gt;Ruby 1.8.4 and Mentor Modelsim 6.1d on x86_64 &lt;span class=&quot;caps&quot;&gt;GNU&lt;/span&gt;/Linux&lt;/li&gt;
1524
+ &lt;/ul&gt;&lt;/li&gt;
1525
+ &lt;/ul&gt;</description>
187
1526
  <pubDate>Sat, 13 May 2006 00:00:00 PDT</pubDate>
188
1527
  </item>
189
1528
  <item>
190
1529
  <title>Version 3.1.0 released</title>
191
1530
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#3.1.0</link>
192
1531
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#3.1.0</guid>
193
- <description>&lt;p&gt;This release adds simple ways of reading and writing values to &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; handles, adds documentation for the &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; utility layer, and fixes the pipelined &lt;span class=&quot;caps&quot;&gt;ALU&lt;/span&gt; example.&lt;/p&gt;</description>
1532
+ <description>&lt;h1 id=&quot;3.1.0&quot;&gt;Version 3.1.0 (2006-04-28)&lt;/h1&gt;
1533
+
1534
+
1535
+ &lt;h2&gt;Summary&lt;/h2&gt;
1536
+
1537
+
1538
+ &lt;p&gt;This release adds simple ways of reading and writing values to &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; handles, adds documentation for the &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; utility layer, and fixes the pipelined &lt;span class=&quot;caps&quot;&gt;ALU&lt;/span&gt; example.&lt;/p&gt;
1539
+
1540
+
1541
+ &lt;h2&gt;Notice&lt;/h2&gt;
1542
+
1543
+
1544
+ &lt;ul&gt;
1545
+ &lt;li&gt;The &lt;strong&gt;msim&lt;/strong&gt; Makefile target for Mentor Modelsim has been renamed back to &lt;strong&gt;vsim&lt;/strong&gt;.&lt;/li&gt;
1546
+ &lt;/ul&gt;
1547
+
1548
+
1549
+ &lt;h2&gt;Details&lt;/h2&gt;
1550
+
1551
+
1552
+ &lt;ul&gt;
1553
+ &lt;li&gt;Simple, consistent ways of reading and writing values to handles have been added to the &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; utility layer. These ways are described in the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;SWIG&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;TYPE_p_unsigned_int&lt;/span&gt;&lt;/code&gt; class&amp;#8217; documentation.&lt;/li&gt;
1554
+ &lt;/ul&gt;
1555
+
1556
+
1557
+ &lt;ul&gt;
1558
+ &lt;li&gt;The makefiles now use the &lt;strong&gt;rbconfig&lt;/strong&gt; library to determine the default compiler and linker flags for Ruby.&lt;/li&gt;
1559
+ &lt;/ul&gt;
1560
+
1561
+
1562
+ &lt;ul&gt;
1563
+ &lt;li&gt;A race condition in the pipelined &lt;span class=&quot;caps&quot;&gt;ALU&lt;/span&gt; example has been fixed. This example should now run successfully in all Verilog simulators.&lt;/li&gt;
1564
+ &lt;/ul&gt;
1565
+
1566
+
1567
+ &lt;ul&gt;
1568
+ &lt;li&gt;The project wiki has been abandoned in favor of RDoc.&lt;/li&gt;
1569
+ &lt;/ul&gt;
1570
+
1571
+
1572
+ &lt;ul&gt;
1573
+ &lt;li&gt;The project website is now generated by RDoc.&lt;/li&gt;
1574
+ &lt;/ul&gt;
1575
+
1576
+
1577
+ &lt;ul&gt;
1578
+ &lt;li&gt;This release was tested and developed using:
1579
+ &lt;ul&gt;
1580
+ &lt;li&gt;Ruby 1.8.4 and Icarus Verilog 0.8 on i686 &lt;span class=&quot;caps&quot;&gt;GNU&lt;/span&gt;/Linux&lt;/li&gt;
1581
+ &lt;li&gt;Ruby 1.8.4 and Mentor Modelsim 6.1d on x86_64 &lt;span class=&quot;caps&quot;&gt;GNU&lt;/span&gt;/Linux&lt;/li&gt;
1582
+ &lt;/ul&gt;&lt;/li&gt;
1583
+ &lt;/ul&gt;</description>
194
1584
  <pubDate>Fri, 28 Apr 2006 00:00:00 PDT</pubDate>
195
1585
  </item>
196
1586
  <item>
197
1587
  <title>Version 3.0.0 released</title>
198
1588
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#3.0.0</link>
199
1589
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#3.0.0</guid>
200
- <description>&lt;p&gt;This release adds support for the &lt;em&gt;entire&lt;/em&gt; &lt;a href=&quot;http://ieeexplore.ieee.org/xpl/standardstoc.jsp?isnumber=33945&quot;&gt;&lt;span class=&quot;caps&quot;&gt;IEEE&lt;/span&gt; Std. 1364-2005&lt;/a&gt; VPI interface, and updates the examples into unit tests.&lt;/p&gt;</description>
1590
+ <description>&lt;h1 id=&quot;3.0.0&quot;&gt;Version 3.0.0 (2006-04-23)&lt;/h1&gt;
1591
+
1592
+
1593
+ &lt;h2&gt;Summary&lt;/h2&gt;
1594
+
1595
+
1596
+ &lt;p&gt;This release adds support for the &lt;em&gt;entire&lt;/em&gt; &lt;a href=&quot;http://ieeexplore.ieee.org/xpl/standardstoc.jsp?isnumber=33945&quot;&gt;&lt;span class=&quot;caps&quot;&gt;IEEE&lt;/span&gt; Std. 1364-2005&lt;/a&gt; VPI interface, and updates the examples into unit tests.&lt;/p&gt;
1597
+
1598
+
1599
+ &lt;h2&gt;Acknowledgment&lt;/h2&gt;
1600
+
1601
+
1602
+ &lt;ul&gt;
1603
+ &lt;li&gt;Thanks to the &lt;a href=&quot;http://www.swig.org/guilty.html&quot;&gt;&lt;span class=&quot;caps&quot;&gt;SWIG&lt;/span&gt; developers&lt;/a&gt; for making this project &lt;em&gt;much&lt;/em&gt; easier! ;-)&lt;/li&gt;
1604
+ &lt;/ul&gt;
1605
+
1606
+
1607
+ &lt;h2&gt;Notice&lt;/h2&gt;
1608
+
1609
+
1610
+ &lt;ul&gt;
1611
+ &lt;li&gt;The &lt;strong&gt;vsim&lt;/strong&gt; Makefile target for Mentor Modelsim has been renamed to &lt;strong&gt;msim&lt;/strong&gt;.&lt;/li&gt;
1612
+ &lt;/ul&gt;
1613
+
1614
+
1615
+ &lt;h2&gt;Details&lt;/h2&gt;
1616
+
1617
+
1618
+ &lt;ul&gt;
1619
+ &lt;li&gt;The Ruby interface to &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; is now generated by &lt;a href=&quot;http://www.swig.org&quot;&gt;&lt;span class=&quot;caps&quot;&gt;SWIG&lt;/span&gt;&lt;/a&gt;.
1620
+ &lt;ul&gt;
1621
+ &lt;li&gt;The main &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;&lt;/code&gt; module has been renamed to &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Vpi&lt;/span&gt;&lt;/code&gt;.&lt;/li&gt;
1622
+ &lt;li&gt;The &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;&lt;/code&gt; class has been removed.&lt;/li&gt;
1623
+ &lt;li&gt;The &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::stop&lt;/code&gt;, &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::finish&lt;/code&gt;, and &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::reset&lt;/code&gt; methods have been removed.&lt;/li&gt;
1624
+ &lt;/ul&gt;&lt;/li&gt;
1625
+ &lt;/ul&gt;
1626
+
1627
+
1628
+ &lt;ul&gt;
1629
+ &lt;li&gt;The &lt;a href=&quot;http://www.boydtechinc.com/ptf/archive/ptf_2005/0737.html&quot;&gt;&lt;em&gt;final ballot&lt;/em&gt; version&lt;/a&gt; of the &lt;tt&gt;vpi_user.h&lt;/tt&gt; header file is now packaged along with and used by Ruby-VPI.&lt;/li&gt;
1630
+ &lt;/ul&gt;
1631
+
1632
+
1633
+ &lt;ul&gt;
1634
+ &lt;li&gt;The &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; module, its sub-classes, and its functionality have been replaced by the &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; utility layer (see &lt;tt&gt;src/vpi_util.rb&lt;/tt&gt;).&lt;/li&gt;
1635
+ &lt;/ul&gt;
1636
+
1637
+
1638
+ &lt;ul&gt;
1639
+ &lt;li&gt;The examples now make use of the &lt;strong&gt;test/unit&lt;/strong&gt; unit testing framework.&lt;/li&gt;
1640
+ &lt;/ul&gt;
1641
+
1642
+
1643
+ &lt;ul&gt;
1644
+ &lt;li&gt;The makefiles for the examples have been simplified through the use of a common template.&lt;/li&gt;
1645
+ &lt;/ul&gt;
1646
+
1647
+
1648
+ &lt;ul&gt;
1649
+ &lt;li&gt;This release was tested and developed using:
1650
+ &lt;ul&gt;
1651
+ &lt;li&gt;Ruby 1.8.4 and Icarus Verilog 0.8 on i686 &lt;span class=&quot;caps&quot;&gt;GNU&lt;/span&gt;/Linux&lt;/li&gt;
1652
+ &lt;li&gt;Ruby 1.8.4 and Mentor Modelsim 6.1d on x86_64 &lt;span class=&quot;caps&quot;&gt;GNU&lt;/span&gt;/Linux&lt;/li&gt;
1653
+ &lt;/ul&gt;&lt;/li&gt;
1654
+ &lt;/ul&gt;</description>
201
1655
  <pubDate>Sun, 23 Apr 2006 00:00:00 PDT</pubDate>
202
1656
  </item>
203
1657
  <item>
204
1658
  <title>Version 2.0.0 released</title>
205
1659
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#2.0.0</link>
206
1660
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#2.0.0</guid>
207
- <description>&lt;p&gt;This release fixes major bugs, adds support for Mentor Modelsim, and removes the &lt;code&gt;$ruby_task&lt;/code&gt; callback.&lt;/p&gt;</description>
1661
+ <description>&lt;h1 id=&quot;2.0.0&quot;&gt;Version 2.0.0 (2006-04-17)&lt;/h1&gt;
1662
+
1663
+
1664
+ &lt;h2&gt;Summary&lt;/h2&gt;
1665
+
1666
+
1667
+ &lt;p&gt;This release fixes major bugs, adds support for Mentor Modelsim, and removes the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#d70; font-weight:bold&quot;&gt;$ruby_task&lt;/span&gt;&lt;/code&gt; callback.&lt;/p&gt;
1668
+
1669
+
1670
+ &lt;h2&gt;Acknowledgment&lt;/h2&gt;
1671
+
1672
+
1673
+ &lt;ul&gt;
1674
+ &lt;li&gt;Thanks to Nobu Nakada for explaining the &lt;a href=&quot;http://article.gmane.org/gmane.comp.lang.ruby.general/146653&quot;&gt;cross-thread violation on rb_gc()&lt;/a&gt; error.&lt;/li&gt;
1675
+ &lt;/ul&gt;
1676
+
1677
+
1678
+ &lt;h2&gt;Notice&lt;/h2&gt;
1679
+
1680
+
1681
+ &lt;ul&gt;
1682
+ &lt;li&gt;Removed &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#d70; font-weight:bold&quot;&gt;$ruby_task&lt;/span&gt;&lt;/code&gt; callback and ability to dynamically register system tasks from Ruby because inter-process communication is complicated at present.&lt;/li&gt;
1683
+ &lt;/ul&gt;
1684
+
1685
+
1686
+ &lt;h2&gt;Details&lt;/h2&gt;
1687
+
1688
+
1689
+ &lt;ul&gt;
1690
+ &lt;li&gt;The &amp;#8220;cross-thread violation on rb_gc()&amp;#8221; error has been fixed.
1691
+ &lt;ul&gt;
1692
+ &lt;li&gt;The &amp;#8220;stack level too deep (SystemStackError)&amp;#8221; error has been fixed.&lt;/li&gt;
1693
+ &lt;li&gt;The test/unit library can be used in Ruby test bench.&lt;/li&gt;
1694
+ &lt;li&gt;Mentor Modelsim Verilog simulator works with Ruby-VPI.&lt;/li&gt;
1695
+ &lt;/ul&gt;&lt;/li&gt;
1696
+ &lt;/ul&gt;
1697
+
1698
+
1699
+ &lt;ul&gt;
1700
+ &lt;li&gt;Added piplelined &lt;span class=&quot;caps&quot;&gt;ALU&lt;/span&gt; example.&lt;/li&gt;
1701
+ &lt;/ul&gt;
1702
+
1703
+
1704
+ &lt;ul&gt;
1705
+ &lt;li&gt;This release was tested and developed using:
1706
+ &lt;ul&gt;
1707
+ &lt;li&gt;Ruby 1.8.4 and Icarus Verilog 0.8 on i686 &lt;span class=&quot;caps&quot;&gt;GNU&lt;/span&gt;/Linux&lt;/li&gt;
1708
+ &lt;li&gt;Ruby 1.8.4 and Modelsim 6.1d on x86_64 &lt;span class=&quot;caps&quot;&gt;GNU&lt;/span&gt;/Linux&lt;/li&gt;
1709
+ &lt;li&gt;Ruby 1.8.4 and Synopsys &lt;span class=&quot;caps&quot;&gt;VCS&lt;/span&gt;-MX X-2005.06-SP1 on &lt;span class=&quot;caps&quot;&gt;SPARC4&lt;/span&gt; SunOS 5.10&lt;/li&gt;
1710
+ &lt;/ul&gt;&lt;/li&gt;
1711
+ &lt;/ul&gt;</description>
208
1712
  <pubDate>Mon, 17 Apr 2006 00:00:00 PDT</pubDate>
209
1713
  </item>
210
1714
  <item>
211
1715
  <title>Version 1.0.0 released</title>
212
1716
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#1.0.0</link>
213
1717
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#1.0.0</guid>
214
- <description>This release adds enough Verilog &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; functionality to make Ruby-VPI usable for simple test benches:
1718
+ <description>&lt;h1 id=&quot;1.0.0&quot;&gt;Version 1.0.0 (2006-02-26)&lt;/h1&gt;
1719
+
1720
+
1721
+ &lt;h2&gt;Summary&lt;/h2&gt;
1722
+
1723
+
1724
+ This release adds enough Verilog &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; functionality to make Ruby-VPI usable for simple test benches:
215
1725
  &lt;ul&gt;
216
1726
  &lt;li&gt;access Verilog objects through &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; handles&lt;/li&gt;
217
1727
  &lt;li&gt;read and change &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; handle values&lt;/li&gt;
218
1728
  &lt;li&gt;stop, finish, restart the simulation&lt;/li&gt;
1729
+ &lt;/ul&gt;
1730
+
1731
+
1732
+ &lt;h2&gt;Acknowledgment&lt;/h2&gt;
1733
+
1734
+
1735
+ &lt;ul&gt;
1736
+ &lt;li&gt;Thanks to Jose Renau for helping me debug how Synopsys &lt;span class=&quot;caps&quot;&gt;VCS&lt;/span&gt; works with Verilog &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt;. The problem was that &lt;span class=&quot;caps&quot;&gt;VCS&lt;/span&gt; required calltf signatures to be &lt;code class=&quot;code&quot;&gt;void (*)(void)&lt;/code&gt;, whereas the Verilog standard defines a calltf signature as &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;PLI_INT32&lt;/span&gt; (*)(&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;PLI_BYTE8&lt;/span&gt;*)&lt;/code&gt;.&lt;/li&gt;
1737
+ &lt;/ul&gt;
1738
+
1739
+
1740
+ &lt;ul&gt;
1741
+ &lt;li&gt;Thanks to Ross Bamford, Eric Hodel, and Yukihiro Matsumoto for &lt;a href=&quot;http://blade.nagaokaut.ac.jp/cgi-bin/scat.rb/ruby/ruby-talk/180662&quot;&gt;helping me discover&lt;/a&gt; why the &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;SystemStackError&lt;/span&gt;&lt;/code&gt; was happening.&lt;/li&gt;
1742
+ &lt;/ul&gt;
1743
+
1744
+
1745
+ &lt;h2&gt;Details&lt;/h2&gt;
1746
+
1747
+
1748
+ &lt;ul&gt;
1749
+ &lt;li&gt;Implemented some Verilog &lt;span class=&quot;caps&quot;&gt;VPI&lt;/span&gt; functionality:
1750
+ &lt;ul&gt;
1751
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::handle_by_name(string, &lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;)&lt;/code&gt; &amp;rarr; &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;&lt;/code&gt;&lt;/li&gt;
1752
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::handle_by_name(string)&lt;/code&gt; &amp;rarr; &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;&lt;/code&gt;&lt;/li&gt;
1753
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;.put_value(integer)&lt;/code&gt;&lt;/li&gt;
1754
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;.value = integer&lt;/code&gt;&lt;/li&gt;
1755
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;.get_value&lt;/code&gt; &amp;rarr; &lt;code class=&quot;code&quot;&gt;integer&lt;/code&gt;&lt;/li&gt;
1756
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;.value&lt;/code&gt; &amp;rarr; &lt;code class=&quot;code&quot;&gt;integer&lt;/code&gt;&lt;/li&gt;
1757
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::stop&lt;/code&gt;&lt;/li&gt;
1758
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::finish&lt;/code&gt;&lt;/li&gt;
1759
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::reset&lt;/code&gt;&lt;/li&gt;
1760
+ &lt;/ul&gt;&lt;/li&gt;
1761
+ &lt;/ul&gt;
1762
+
1763
+
1764
+ &lt;ul&gt;
1765
+ &lt;li&gt;Implemented some additional functionality:
1766
+ &lt;ul&gt;
1767
+ &lt;li&gt;&lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::register_task(string, &amp;amp;proc)&lt;/code&gt;&lt;/li&gt;
1768
+ &lt;/ul&gt;&lt;/li&gt;
1769
+ &lt;/ul&gt;
1770
+
1771
+
1772
+ &lt;ul&gt;
1773
+ &lt;li&gt;Added ability to pass arbitrary command-line arguments to the Ruby interpreter (using &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#d70; font-weight:bold&quot;&gt;$ruby_init&lt;/span&gt;&lt;/code&gt;). Now you can invoke any Ruby script you want, instead of &lt;tt&gt;pli_init.rb&lt;/tt&gt;.&lt;/li&gt;
1774
+ &lt;/ul&gt;
1775
+
1776
+
1777
+ &lt;ul&gt;
1778
+ &lt;li&gt;Added ability to dynamically register system tasks from Ruby, using &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::register_task(&lt;span style=&quot;background-color:#fff0f0&quot;&gt;&lt;span style=&quot;color:#710&quot;&gt;&amp;quot;&lt;/span&gt;&lt;span style=&quot;color:#D20&quot;&gt;task name&lt;/span&gt;&lt;span style=&quot;color:#710&quot;&gt;&amp;quot;&lt;/span&gt;&lt;/span&gt;)&lt;/code&gt;, and call them from Verilog, using &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#d70; font-weight:bold&quot;&gt;$ruby_task&lt;/span&gt;(&lt;span style=&quot;background-color:#fff0f0&quot;&gt;&lt;span style=&quot;color:#710&quot;&gt;&amp;quot;&lt;/span&gt;&lt;span style=&quot;color:#D20&quot;&gt;task name&lt;/span&gt;&lt;span style=&quot;color:#710&quot;&gt;&amp;quot;&lt;/span&gt;&lt;/span&gt;)&lt;/code&gt;.&lt;/li&gt;
1779
+ &lt;/ul&gt;
1780
+
1781
+
1782
+ &lt;ul&gt;
1783
+ &lt;li&gt;Added &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;VPI&lt;/span&gt;::&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;Handle&lt;/span&gt;&lt;/code&gt; class which encapsulates a &lt;code class=&quot;code&quot;&gt;vpiHandle&lt;/code&gt; VPI object.&lt;/li&gt;
1784
+ &lt;/ul&gt;
1785
+
1786
+
1787
+ &lt;ul&gt;
1788
+ &lt;li&gt;This release was tested and developed using:
1789
+ &lt;ul&gt;
1790
+ &lt;li&gt;Ruby 1.8.2 and Icarus Verilog 0.8 on i686 &lt;span class=&quot;caps&quot;&gt;GNU&lt;/span&gt;/Linux&lt;/li&gt;
1791
+ &lt;li&gt;Ruby 1.8.4, Synopsys &lt;span class=&quot;caps&quot;&gt;VCS X&lt;/span&gt;-2005.06, and Mentor Modelsim 6.1b on i686 &lt;span class=&quot;caps&quot;&gt;GNU&lt;/span&gt;/Linux&lt;/li&gt;
1792
+ &lt;/ul&gt;&lt;/li&gt;
219
1793
  &lt;/ul&gt;</description>
220
1794
  <pubDate>Sun, 26 Feb 2006 00:00:00 PST</pubDate>
221
1795
  </item>
@@ -223,7 +1797,26 @@
223
1797
  <title>Version 0.0.0 released</title>
224
1798
  <link>http://ruby-vpi.rubyforge.org/doc/history.html#0.0.0</link>
225
1799
  <guid>http://ruby-vpi.rubyforge.org/doc/history.html#0.0.0</guid>
226
- <description>&lt;p&gt;This is Kazuhiro &lt;span class=&quot;caps&quot;&gt;HIWADA&lt;/span&gt;&amp;#8217;s initial testing release of Ruby-VPI. See its &lt;a href=&quot;http://www.ruby-talk.org/cgi-bin/scat.rb/ruby/ruby-list/18193&quot;&gt;original announcement&lt;/a&gt; and &lt;a href=&quot;http://easter.kuee.kyoto-u.ac.jp/~hiwada/ruby/memo/src/ruby-vpi-test.tgz&quot;&gt;source code&lt;/a&gt;.&lt;/p&gt;</description>
1800
+ <description>&lt;h1 id=&quot;0.0.0&quot;&gt;Version 0.0.0 (1999-10-31)&lt;/h1&gt;
1801
+
1802
+
1803
+ &lt;h2&gt;Summary&lt;/h2&gt;
1804
+
1805
+
1806
+ &lt;p&gt;This is Kazuhiro &lt;span class=&quot;caps&quot;&gt;HIWADA&lt;/span&gt;&amp;#8217;s initial testing release of Ruby-VPI. See its &lt;a href=&quot;http://www.ruby-talk.org/cgi-bin/scat.rb/ruby/ruby-list/18193&quot;&gt;original announcement&lt;/a&gt; and &lt;a href=&quot;http://easter.kuee.kyoto-u.ac.jp/~hiwada/ruby/memo/src/ruby-vpi-test.tgz&quot;&gt;source code&lt;/a&gt;.&lt;/p&gt;
1807
+
1808
+
1809
+ &lt;h2&gt;Details&lt;/h2&gt;
1810
+
1811
+
1812
+ &lt;ul&gt;
1813
+ &lt;li&gt;Added ability to relay control from Verilog test bench to Ruby (using &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#d70; font-weight:bold&quot;&gt;$ruby_callback&lt;/span&gt;&lt;/code&gt;) and vice versa (using &lt;code class=&quot;code&quot;&gt;&lt;span style=&quot;color:#036; font-weight:bold&quot;&gt;PLI&lt;/span&gt;::relay_Verilog&lt;/code&gt;).&lt;/li&gt;
1814
+ &lt;/ul&gt;
1815
+
1816
+
1817
+ &lt;ul&gt;
1818
+ &lt;li&gt;Tested and developed using Ruby 1.4 and Verilog-XL from Cadence systems, on a &lt;span class=&quot;caps&quot;&gt;SPARC&lt;/span&gt; machine running Solaris 2.6.&lt;/li&gt;
1819
+ &lt;/ul&gt;</description>
227
1820
  <pubDate>Sun, 31 Oct 1999 00:00:00 PDT</pubDate>
228
1821
  </item>
229
1822
  </channel>