ruby-vpi 20.0.0 → 21.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/LICENSE +2 -2
- data/Rakefile +2 -3
- data/bin/generate/runner.rake +1 -1
- data/doc/README +9 -0
- data/doc/Rakefile +21 -0
- data/doc/api/c/annotated.html +1 -1
- data/doc/api/c/binding_8c.html +76 -0
- data/doc/api/c/binding_8h.html +76 -0
- data/doc/api/c/files.html +9 -8
- data/doc/api/c/functions.html +1 -1
- data/doc/api/c/functions_vars.html +1 -1
- data/doc/api/c/globals.html +61 -11
- data/doc/api/c/globals_0x65.html +2 -8
- data/doc/api/c/globals_0x70.html +2 -8
- data/doc/api/c/globals_0x72.html +45 -25
- data/doc/api/c/globals_0x76.html +6 -35
- data/doc/api/c/globals_0x78.html +2 -8
- data/doc/api/c/globals_defs.html +2 -9
- data/doc/api/c/globals_defs_0x65.html +2 -3
- data/doc/api/c/globals_defs_0x70.html +2 -3
- data/doc/api/c/{globals_enum.html → globals_defs_0x72.html} +25 -7
- data/doc/api/c/globals_defs_0x76.html +4 -19
- data/doc/api/c/globals_defs_0x78.html +2 -3
- data/doc/api/c/globals_func.html +32 -37
- data/doc/api/c/globals_type.html +1 -3
- data/doc/api/c/globals_vars.html +5 -13
- data/doc/api/c/host_8c.html +93 -0
- data/doc/api/c/host_8h.html +69 -0
- data/doc/api/c/index.html +1 -1
- data/doc/api/c/main_8c.html +35 -33
- data/doc/api/c/structs__cb__data.html +1 -1
- data/doc/api/c/structs__vpi__delay.html +1 -1
- data/doc/api/c/structs__vpi__error__info.html +1 -1
- data/doc/api/c/structs__vpi__strengthval.html +1 -1
- data/doc/api/c/structs__vpi__systf__data.html +1 -1
- data/doc/api/c/structs__vpi__time.html +1 -1
- data/doc/api/c/structs__vpi__value.html +1 -1
- data/doc/api/c/structs__vpi__vecval.html +1 -1
- data/doc/api/c/structs__vpi__vlog__info.html +1 -1
- data/doc/api/c/user_8c.html +170 -0
- data/doc/api/c/user_8h.html +98 -0
- data/doc/api/c/util_8h.html +171 -0
- data/doc/api/c/verilog_8h.html +2 -158
- data/doc/api/c/vpi__user_8h.html +1 -1
- data/doc/api/ruby/classes/ERB.html +5 -5
- data/doc/api/ruby/classes/ERB.src/{M000025.html → M000026.html} +0 -0
- data/doc/api/ruby/classes/FileUtils.html +6 -6
- data/doc/api/ruby/classes/FileUtils.src/{M000026.html → M000027.html} +0 -0
- data/doc/api/ruby/classes/Float.html +6 -6
- data/doc/api/ruby/classes/Float.src/{M000020.html → M000021.html} +0 -0
- data/doc/api/ruby/classes/Integer.html +65 -65
- data/doc/api/ruby/classes/Integer.src/M000009.html +11 -4
- data/doc/api/ruby/classes/Integer.src/M000010.html +4 -4
- data/doc/api/ruby/classes/Integer.src/M000011.html +4 -4
- data/doc/api/ruby/classes/Integer.src/M000012.html +4 -4
- data/doc/api/ruby/classes/Integer.src/M000013.html +4 -4
- data/doc/api/ruby/classes/Integer.src/M000014.html +18 -0
- data/doc/api/ruby/classes/Integer.src/M000017.html +5 -11
- data/doc/api/ruby/classes/Integer.src/M000018.html +14 -8
- data/doc/api/ruby/classes/Integer.src/M000019.html +8 -13
- data/doc/api/ruby/classes/Integer.src/M000020.html +30 -0
- data/doc/api/ruby/classes/Kernel.html +143 -0
- data/doc/api/ruby/classes/Object.html +5 -0
- data/doc/api/ruby/classes/RDoc.html +5 -5
- data/doc/api/ruby/classes/RDoc.src/{M000541.html → M000546.html} +0 -0
- data/doc/api/ruby/classes/RubyVPI.html +148 -17
- data/doc/api/ruby/classes/RubyVPI.src/M000028.html +19 -0
- data/doc/api/ruby/classes/RubyVPI.src/M000029.html +19 -0
- data/doc/api/ruby/classes/RubyVPI.src/M000030.html +18 -0
- data/doc/api/ruby/classes/RubyVPI.src/M000031.html +18 -0
- data/doc/api/ruby/classes/RubyVPI.src/{M000027.html → M000032.html} +9 -1
- data/doc/api/ruby/classes/RubyVPI/SIMULATORS.html +5 -5
- data/doc/api/ruby/classes/RubyVPI/SIMULATORS.src/{M000028.html → M000033.html} +0 -0
- data/doc/api/ruby/classes/String.html +20 -20
- data/doc/api/ruby/classes/String.src/M000022.html +22 -4
- data/doc/api/ruby/classes/String.src/M000023.html +4 -4
- data/doc/api/ruby/classes/String.src/M000024.html +4 -27
- data/doc/api/ruby/classes/String.src/M000025.html +41 -0
- data/doc/api/ruby/classes/VPI.html +2066 -2066
- data/doc/api/ruby/classes/VPI.src/M000034.html +5 -12
- data/doc/api/ruby/classes/VPI.src/{M000030.html → M000035.html} +1 -1
- data/doc/api/ruby/classes/VPI.src/M000036.html +6 -3
- data/doc/api/ruby/classes/VPI.src/M000038.html +12 -3
- data/doc/api/ruby/classes/VPI.src/M000039.html +13 -3
- data/doc/api/ruby/classes/VPI.src/M000041.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000042.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000043.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000044.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000045.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000046.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000047.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000048.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000049.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000050.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000051.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000052.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000053.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000054.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000055.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000056.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000057.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000058.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000059.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000060.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000061.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000062.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000063.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000064.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000065.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000066.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000067.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000068.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000069.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000070.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000071.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000072.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000073.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000074.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000075.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000076.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000077.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000078.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000079.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000080.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000081.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000082.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000083.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000084.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000085.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000086.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000087.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000088.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000089.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000090.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000091.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000092.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000093.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000094.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000095.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000096.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000097.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000098.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000099.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000100.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000101.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000102.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000103.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000104.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000105.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000106.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000107.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000108.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000109.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000110.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000111.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000112.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000113.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000114.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000115.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000116.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000117.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000118.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000119.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000120.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000121.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000122.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000123.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000124.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000125.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000126.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000127.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000128.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000129.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000130.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000131.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000132.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000133.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000134.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000135.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000136.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000137.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000138.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000139.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000140.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000141.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000142.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000143.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000144.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000145.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000146.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000147.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000148.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000149.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000150.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000151.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000152.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000153.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000154.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000155.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000156.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000157.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000158.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000159.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000160.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000161.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000162.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000163.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000164.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000165.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000166.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000167.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000168.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000169.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000170.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000171.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000172.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000173.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000174.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000175.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000176.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000177.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000178.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000179.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000180.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000181.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000182.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000183.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000184.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000185.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000186.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000187.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000188.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000189.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000190.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000191.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000192.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000193.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000194.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000195.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000196.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000197.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000198.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000199.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000200.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000201.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000202.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000203.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000204.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000205.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000206.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000207.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000208.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000209.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000210.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000211.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000212.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000213.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000214.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000215.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000216.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000217.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000218.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000219.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000220.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000221.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000222.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000223.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000224.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000225.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000226.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000227.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000228.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000229.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000230.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000231.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000232.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000233.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000234.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000235.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000236.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000237.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000238.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000239.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000240.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000241.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000242.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000243.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000244.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000245.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000246.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000247.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000248.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000249.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000250.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000251.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000252.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000253.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000254.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000255.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000256.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000257.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000258.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000259.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000260.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000261.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000262.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000263.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000264.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000265.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000266.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000267.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000268.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000269.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000270.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000271.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000272.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000273.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000274.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000275.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000276.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000277.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000278.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000279.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000280.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000281.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000282.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000283.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000284.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000285.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000286.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000287.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000288.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000289.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000290.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000291.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000292.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000293.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000294.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000295.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000296.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000297.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000298.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000299.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000300.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000301.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000302.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000303.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000304.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000305.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000306.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000307.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000308.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000309.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000310.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000311.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000312.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000313.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000314.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000315.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000316.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000317.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000318.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000319.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000320.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000321.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000322.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000323.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000324.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000325.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000326.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000327.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000328.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000329.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000330.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000331.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000332.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000333.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000334.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000335.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000336.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000337.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000338.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000339.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000340.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000341.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000342.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000343.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000344.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000345.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000346.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000347.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000348.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000349.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000350.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000351.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000352.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000353.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000354.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000355.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000356.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000357.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000358.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000359.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000360.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000361.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000362.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000363.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000364.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000365.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000366.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000367.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000368.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000369.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000370.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000371.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000372.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000373.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000374.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000375.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000376.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000377.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000378.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000379.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000380.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000381.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000382.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000383.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000384.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000385.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000386.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000387.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000388.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000389.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000390.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000391.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000392.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000393.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000394.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000395.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000396.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000397.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000398.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000399.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000400.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000401.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000402.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000403.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000404.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000405.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000406.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000407.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000408.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000409.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000410.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000411.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000412.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000413.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000414.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000415.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000416.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000417.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000418.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000419.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000420.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000421.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000422.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000423.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000424.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000425.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000426.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000427.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000428.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000429.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000430.html +3 -3
- data/doc/api/ruby/classes/VPI.src/M000431.html +16 -0
- data/doc/api/ruby/classes/VPI.src/{M000040.html → M000432.html} +3 -3
- data/doc/api/ruby/classes/VPI.src/{M000037.html → M000433.html} +3 -3
- data/doc/api/ruby/classes/VPI.src/M000434.html +16 -0
- data/doc/api/ruby/classes/VPI.src/M000435.html +16 -0
- data/doc/api/ruby/classes/VPI/Handle.html +498 -498
- data/doc/api/ruby/classes/VPI/Handle.src/M000439.html +17 -4
- data/doc/api/ruby/classes/VPI/Handle.src/M000440.html +4 -4
- data/doc/api/ruby/classes/VPI/Handle.src/{M000436.html → M000441.html} +0 -0
- data/doc/api/ruby/classes/VPI/Handle.src/M000444.html +4 -4
- data/doc/api/ruby/classes/VPI/Handle.src/{M000435.html → M000445.html} +4 -4
- data/doc/api/ruby/classes/VPI/Handle.src/M000448.html +4 -4
- data/doc/api/ruby/classes/VPI/Handle.src/{M000443.html → M000449.html} +4 -4
- data/doc/api/ruby/classes/VPI/Handle.src/M000452.html +4 -4
- data/doc/api/ruby/classes/VPI/Handle.src/{M000447.html → M000453.html} +4 -4
- data/doc/api/ruby/classes/VPI/Handle.src/M000456.html +4 -4
- data/doc/api/ruby/classes/VPI/Handle.src/M000457.html +18 -0
- data/doc/api/ruby/classes/VPI/Handle.src/{M000455.html → M000460.html} +0 -0
- data/doc/api/ruby/classes/VPI/Handle.src/M000461.html +4 -7
- data/doc/api/ruby/classes/VPI/Handle.src/M000464.html +10 -5
- data/doc/api/ruby/classes/VPI/Handle.src/M000466.html +7 -4
- data/doc/api/ruby/classes/VPI/Handle.src/M000467.html +14 -4
- data/doc/api/ruby/classes/VPI/Handle.src/M000468.html +31 -11
- data/doc/api/ruby/classes/VPI/Handle.src/M000469.html +5 -4
- data/doc/api/ruby/classes/VPI/Handle.src/M000470.html +5 -4
- data/doc/api/ruby/classes/VPI/Handle.src/M000471.html +4 -26
- data/doc/api/ruby/classes/VPI/Handle.src/M000472.html +4 -4
- data/doc/api/ruby/classes/VPI/Handle.src/M000473.html +15 -6
- data/doc/api/ruby/classes/VPI/Handle.src/M000474.html +5 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000475.html +5 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000476.html +27 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000477.html +5 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000478.html +8 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000479.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000480.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000481.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000482.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000483.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000484.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000485.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000486.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000487.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000488.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000489.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000490.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000491.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000492.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000493.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000494.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000495.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000496.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000497.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000498.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000499.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000500.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000501.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000502.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000503.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000504.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000505.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000506.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000507.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000508.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000509.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000510.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000511.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000512.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000513.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000514.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000515.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000516.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000517.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000518.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000519.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000520.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000521.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000522.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000523.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000524.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000525.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000526.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000527.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000528.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000529.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000530.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000531.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000532.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000533.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000534.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000535.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000536.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000537.html +3 -3
- data/doc/api/ruby/classes/VPI/Handle.src/M000538.html +16 -0
- data/doc/api/ruby/classes/VPI/Handle.src/M000539.html +16 -0
- data/doc/api/ruby/classes/VPI/Handle.src/M000540.html +16 -0
- data/doc/api/ruby/classes/VPI/Handle.src/M000541.html +16 -0
- data/doc/api/ruby/classes/VPI/Handle.src/M000542.html +16 -0
- data/doc/api/ruby/classes/VPI/S_vpi_time.html +16 -16
- data/doc/api/ruby/classes/VPI/S_vpi_time.src/{M000538.html → M000543.html} +0 -0
- data/doc/api/ruby/classes/VPI/S_vpi_time.src/{M000539.html → M000544.html} +0 -0
- data/doc/api/ruby/classes/VPI/S_vpi_value.html +15 -15
- data/doc/api/ruby/classes/VPI/S_vpi_value.src/{M000431.html → M000436.html} +1 -1
- data/doc/api/ruby/classes/VPI/S_vpi_value.src/{M000432.html → M000437.html} +0 -0
- data/doc/api/ruby/classes/VPI/S_vpi_value.src/{M000433.html → M000438.html} +0 -0
- data/doc/api/ruby/classes/VerilogParser.html +5 -5
- data/doc/api/ruby/classes/VerilogParser.src/{M000003.html → M000004.html} +0 -0
- data/doc/api/ruby/classes/VerilogParser/Module.html +5 -5
- data/doc/api/ruby/classes/VerilogParser/Module.src/{M000004.html → M000005.html} +0 -0
- data/doc/api/ruby/classes/VerilogParser/Module/Port.html +15 -15
- data/doc/api/ruby/classes/VerilogParser/Module/Port.src/M000006.html +9 -4
- data/doc/api/ruby/classes/VerilogParser/Module/Port.src/M000007.html +4 -4
- data/doc/api/ruby/classes/VerilogParser/Module/Port.src/M000008.html +18 -0
- data/doc/api/ruby/created.rid +1 -1
- data/doc/api/ruby/files/bin/convert_rb.html +1 -1
- data/doc/api/ruby/files/bin/generate_rb.html +1 -1
- data/doc/api/ruby/files/bin/ruby-vpi.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi/boot/loader_rb.html +149 -0
- data/doc/api/ruby/files/lib/ruby-vpi/boot/loader_rb.src/M000003.html +17 -0
- data/doc/api/ruby/files/lib/ruby-vpi/boot/relay_rb.html +114 -0
- data/doc/api/ruby/files/lib/ruby-vpi/core/callback_rb.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi/core/edge-methods_rb.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi/core/edge_rb.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi/core/handle_rb.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi/core/scheduler_rb.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi/core/struct_rb.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi/core_rb.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi/erb_rb.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi/float_rb.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi/integer_rb.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi/rake_rb.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi/rcov_rb.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi/rdoc_rb.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi/runner_boot_loader_rb.html +3 -13
- data/doc/api/ruby/files/lib/ruby-vpi/runner_boot_loader_rb.src/M000002.html +3 -3
- data/doc/api/ruby/files/lib/ruby-vpi/runner_proxy_rb.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi/runner_rb.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi/util_rb.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi/verilog_parser_rb.html +1 -1
- data/doc/api/ruby/files/lib/ruby-vpi_rb.html +1 -1
- data/doc/api/ruby/files/ruby-vpi-dynamic_rb.html +1 -1
- data/doc/api/ruby/fr_class_index.html +1 -0
- data/doc/api/ruby/fr_file_index.html +2 -0
- data/doc/api/ruby/fr_method_index.html +544 -539
- data/doc/guide.erb +37 -50
- data/doc/guide.html +322 -255
- data/doc/images/feed-icon-28x28.png +0 -0
- data/examples/register_file/register_file_runner.rake +1 -1
- data/ext/Rakefile +13 -4
- data/ext/binding.c +22 -0
- data/ext/binding.h +29 -0
- data/ext/extconf.rb +18 -11
- data/ext/host.c +75 -0
- data/ext/host.h +17 -0
- data/ext/main.c +50 -43
- data/ext/swig_vpi.i +6 -6
- data/ext/user.c +95 -0
- data/ext/user.h +23 -0
- data/ext/util.h +55 -0
- data/ext/verilog.h +5 -52
- data/lib/ruby-vpi.rb +11 -3
- data/lib/ruby-vpi/boot/loader.rb +162 -0
- data/lib/ruby-vpi/boot/relay.rb +47 -0
- data/lib/ruby-vpi/core.rb +0 -8
- data/lib/ruby-vpi/core/callback.rb +21 -28
- data/lib/ruby-vpi/core/handle.rb +14 -4
- data/lib/ruby-vpi/core/scheduler.rb +5 -13
- data/lib/ruby-vpi/core/struct.rb +1 -1
- data/lib/ruby-vpi/runner.rb +10 -2
- data/lib/ruby-vpi/runner_boot_loader.rb +127 -85
- data/lib/ruby-vpi/runner_proxy.rb +8 -8
- metadata +67 -67
- data/doc/api/c/common_8h.html +0 -143
- data/doc/api/c/globals_0x63.html +0 -120
- data/doc/api/c/globals_0x66.html +0 -58
- data/doc/api/c/globals_0x6d.html +0 -65
- data/doc/api/c/globals_0x74.html +0 -58
- data/doc/api/c/globals_eval.html +0 -44
- data/doc/api/c/main_8h.html +0 -105
- data/doc/api/c/relay_8c.html +0 -174
- data/doc/api/c/relay_8h.html +0 -102
- data/doc/api/c/vlog_8c.html +0 -157
- data/doc/api/c/vlog_8h.html +0 -80
- data/doc/api/ruby/classes/Integer.src/M000008.html +0 -25
- data/doc/api/ruby/classes/Integer.src/M000016.html +0 -25
- data/doc/api/ruby/classes/String.src/M000021.html +0 -36
- data/doc/api/ruby/classes/VPI.src/M000029.html +0 -19
- data/doc/api/ruby/classes/VPI.src/M000031.html +0 -19
- data/doc/api/ruby/classes/VPI.src/M000033.html +0 -25
- data/doc/api/ruby/classes/VPI/Handle.src/M000434.html +0 -31
- data/doc/api/ruby/classes/VPI/Handle.src/M000451.html +0 -18
- data/doc/api/ruby/classes/VPI/Handle.src/M000459.html +0 -24
- data/doc/api/ruby/classes/VPI/Handle.src/M000462.html +0 -28
- data/doc/api/ruby/classes/VPI/Handle.src/M000463.html +0 -50
- data/doc/api/ruby/classes/VPI/Handle.src/M000465.html +0 -19
- data/doc/api/ruby/classes/VerilogParser/Module/Port.src/M000005.html +0 -23
- data/examples/pipelined_alu/Hw5UnitModel.rb +0 -114
- data/examples/pipelined_alu/README +0 -152
- data/examples/pipelined_alu/Rakefile +0 -1
- data/examples/pipelined_alu/TestHw5UnitModel.rb +0 -72
- data/examples/pipelined_alu/hw5_unit.v +0 -128
- data/examples/pipelined_alu/hw5_unit_design.rb +0 -45
- data/examples/pipelined_alu/hw5_unit_loader.rb +0 -1
- data/examples/pipelined_alu/hw5_unit_proto.rb +0 -4
- data/examples/pipelined_alu/hw5_unit_runner.rake +0 -48
- data/examples/pipelined_alu/hw5_unit_spec.rb +0 -64
- data/examples/pipelined_alu/int_gen.rb +0 -45
- data/ext/common.h +0 -46
- data/ext/main.h +0 -30
- data/ext/relay.c +0 -41
- data/ext/relay.h +0 -31
- data/ext/vlog.c +0 -57
- data/ext/vlog.h +0 -26
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
# Simulates the design under test for one clock cycle.
|
|
2
|
-
def DUT.cycle!
|
|
3
|
-
clk.t!
|
|
4
|
-
advance_time
|
|
5
|
-
|
|
6
|
-
clk.f!
|
|
7
|
-
advance_time
|
|
8
|
-
end
|
|
9
|
-
|
|
10
|
-
# Brings the design under test into a blank state.
|
|
11
|
-
def DUT.reset!
|
|
12
|
-
reset.t!
|
|
13
|
-
5.times { cycle! }
|
|
14
|
-
reset.f!
|
|
15
|
-
end
|
|
16
|
-
|
|
17
|
-
OPERATIONS = (DUT.OP_NOP.intVal .. DUT.OP_MULT.intVal).to_a
|
|
18
|
-
|
|
19
|
-
# Represents an ALU operation.
|
|
20
|
-
class Operation
|
|
21
|
-
attr_accessor :type, :tag, :arg1, :arg2, :result
|
|
22
|
-
|
|
23
|
-
def initialize(type, tag, arg1 = 0, arg2 = 0)
|
|
24
|
-
raise ArgumentError unless OPERATIONS.include? type
|
|
25
|
-
|
|
26
|
-
@type = type
|
|
27
|
-
@tag = tag
|
|
28
|
-
@arg1 = arg1
|
|
29
|
-
@arg2 = arg2
|
|
30
|
-
end
|
|
31
|
-
|
|
32
|
-
# Computes the result of this operation.
|
|
33
|
-
def compute
|
|
34
|
-
case @type
|
|
35
|
-
when DUT.OP_ADD.intVal
|
|
36
|
-
@arg1 + @arg2
|
|
37
|
-
|
|
38
|
-
when DUT.OP_SUB.intVal
|
|
39
|
-
@arg1 - @arg2
|
|
40
|
-
|
|
41
|
-
when DUT.OP_MULT.intVal
|
|
42
|
-
@arg1 * @arg2
|
|
43
|
-
end
|
|
44
|
-
end
|
|
45
|
-
end
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
RubyVPI.load_test("hw5_unit", "hw5_unit_design.rb", "hw5_unit_proto.rb", "hw5_unit_spec.rb")
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
# Path to a Ruby script that will be invoked before the Verilog
|
|
2
|
-
# simulation begins. This script shall then load the appropriate
|
|
3
|
-
# tests to exercise the desired designs in the Verilog simulation.
|
|
4
|
-
TEST_LOADER = "hw5_unit_loader.rb"
|
|
5
|
-
|
|
6
|
-
# Array of paths and shell globs (see the Dir.glob method's documentation for
|
|
7
|
-
# details) to source files and directories that contain source files. These
|
|
8
|
-
# source files will be loaded by the simulator before the simulation begins.
|
|
9
|
-
SIMULATOR_SOURCES = FileList[
|
|
10
|
-
'hw5_unit.v',
|
|
11
|
-
]
|
|
12
|
-
|
|
13
|
-
# Command-line arguments for the simulator. These arguments can be
|
|
14
|
-
# specified as a string or an array of strings, as demonstrated below:
|
|
15
|
-
#
|
|
16
|
-
# :cver => "this is a single string argument",
|
|
17
|
-
# :cver => ["these", "are", "separate", "arguments"],
|
|
18
|
-
# :cver => %w[these are also separate arguments],
|
|
19
|
-
#
|
|
20
|
-
SIMULATOR_ARGUMENTS = {
|
|
21
|
-
# GPL Cver
|
|
22
|
-
:cver => "",
|
|
23
|
-
|
|
24
|
-
# Icarus Verilog
|
|
25
|
-
:ivl => "",
|
|
26
|
-
|
|
27
|
-
# Cadence NC-Sim
|
|
28
|
-
:ncsim => "",
|
|
29
|
-
|
|
30
|
-
# Synopsys VCS
|
|
31
|
-
:vcs => "",
|
|
32
|
-
|
|
33
|
-
# Mentor Modelsim
|
|
34
|
-
:vsim => "hw5_unit",
|
|
35
|
-
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
# This task is invoked before the simulator runs. It
|
|
39
|
-
# can be used to make preprations, such as converting
|
|
40
|
-
# Verilog header files into Ruby, for the simulation.
|
|
41
|
-
task :setup do
|
|
42
|
-
# To learn how to write Rake tasks, please see:
|
|
43
|
-
# http://docs.rubyrake.org/read/chapter/4#page16
|
|
44
|
-
end
|
|
45
|
-
|
|
46
|
-
# This command loads the Ruby-VPI runner template,
|
|
47
|
-
# which runs the simulator using the above parameters.
|
|
48
|
-
require 'ruby-vpi/runner'
|
|
@@ -1,64 +0,0 @@
|
|
|
1
|
-
require 'test/unit'
|
|
2
|
-
require 'int_gen'
|
|
3
|
-
|
|
4
|
-
class A_hw5_unit_when_reset < Test::Unit::TestCase
|
|
5
|
-
# Number of input sequences to test.
|
|
6
|
-
NUM_TESTS = 4000
|
|
7
|
-
|
|
8
|
-
# Bitmask capable of capturing ALU result.
|
|
9
|
-
ALU_RESULT_MASK = (2 ** DUT.WIDTH.intVal) - 1
|
|
10
|
-
|
|
11
|
-
# Upper limit of values allowed for an operation's tag.
|
|
12
|
-
OPERATION_TAG_LIMIT = 2 ** DUT.DATABITS.intVal
|
|
13
|
-
|
|
14
|
-
def setup
|
|
15
|
-
DUT.reset!
|
|
16
|
-
@intGen = IntegerGenerator.new(DUT.WIDTH.intVal)
|
|
17
|
-
end
|
|
18
|
-
|
|
19
|
-
def test_pipeline
|
|
20
|
-
issuedOps = []
|
|
21
|
-
numIssued = numVerified = 0
|
|
22
|
-
|
|
23
|
-
until numVerified == NUM_TESTS
|
|
24
|
-
# issue a new operation
|
|
25
|
-
if numIssued < NUM_TESTS
|
|
26
|
-
op = Operation.new(
|
|
27
|
-
OPERATIONS[rand(OPERATIONS.size)],
|
|
28
|
-
numIssued % OPERATION_TAG_LIMIT,
|
|
29
|
-
@intGen.random,
|
|
30
|
-
@intGen.random
|
|
31
|
-
)
|
|
32
|
-
|
|
33
|
-
DUT.a.intVal = op.arg1
|
|
34
|
-
DUT.b.intVal = op.arg2
|
|
35
|
-
DUT.in_op.intVal = op.type
|
|
36
|
-
DUT.in_databits.intVal = op.tag
|
|
37
|
-
|
|
38
|
-
issuedOps << op
|
|
39
|
-
numIssued += 1
|
|
40
|
-
end
|
|
41
|
-
|
|
42
|
-
DUT.cycle!
|
|
43
|
-
|
|
44
|
-
# verify result of finished operation
|
|
45
|
-
unless DUT.out_databits.x?
|
|
46
|
-
finishedOp = Operation.new(
|
|
47
|
-
DUT.out_op.intVal,
|
|
48
|
-
DUT.out_databits.intVal
|
|
49
|
-
)
|
|
50
|
-
finishedOp.result = DUT.res.intVal & ALU_RESULT_MASK
|
|
51
|
-
|
|
52
|
-
expectedOp = issuedOps.shift
|
|
53
|
-
assert_equal expectedOp.type, finishedOp.type, "incorrect operation"
|
|
54
|
-
assert_equal expectedOp.tag, finishedOp.tag, "incorrect tag"
|
|
55
|
-
|
|
56
|
-
unless finishedOp.type == DUT.OP_NOP.intVal
|
|
57
|
-
assert_equal expectedOp.compute & ALU_RESULT_MASK, finishedOp.result, "incorrect result"
|
|
58
|
-
end
|
|
59
|
-
|
|
60
|
-
numVerified += 1
|
|
61
|
-
end
|
|
62
|
-
end
|
|
63
|
-
end
|
|
64
|
-
end
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
# Library for generating integers.
|
|
2
|
-
#--
|
|
3
|
-
# Copyright 2006 Suraj N. Kurapati
|
|
4
|
-
# See the file named LICENSE for details.
|
|
5
|
-
|
|
6
|
-
# Generates random integers of configurable length.
|
|
7
|
-
class IntegerGenerator
|
|
8
|
-
# the first 1000 prime numbers, gotten from <http://en.wikipedia.org/wiki/List_of_prime_numbers#The_first_1000_prime_numbers>
|
|
9
|
-
PRIMES = [
|
|
10
|
-
2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97, 101, 103, 107, 109, 113, 127, 131, 137, 139, 149, 151, 157, 163, 167, 173, 179, 181, 191, 193, 197, 199, 211, 223, 227, 229, 233, 239, 241, 251, 257, 263, 269, 271, 277, 281, 283, 293, 307, 311, 313, 317, 331, 337, 347, 349, 353, 359, 367, 373, 379, 383, 389, 397, 401, 409, 419, 421, 431, 433, 439, 443, 449, 457, 461, 463, 467, 479, 487, 491, 499, 503, 509, 521, 523, 541, 547, 557, 563, 569, 571, 577, 587, 593, 599, 601, 607, 613, 617, 619, 631, 641, 643, 647, 653, 659, 661, 673, 677, 683, 691, 701, 709, 719, 727, 733, 739, 743, 751, 757, 761, 769, 773, 787, 797, 809, 811, 821, 823, 827, 829, 839, 853, 857, 859, 863, 877, 881, 883, 887, 907, 911, 919, 929, 937, 941, 947, 953, 967, 971, 977, 983, 991, 997, 1009, 1013, 1019, 1021, 1031, 1033, 1039, 1049, 1051, 1061, 1063, 1069, 1087, 1091, 1093, 1097, 1103, 1109, 1117, 1123, 1129, 1151, 1153, 1163, 1171, 1181, 1187, 1193, 1201, 1213, 1217, 1223, 1229, 1231, 1237, 1249, 1259, 1277, 1279, 1283, 1289, 1291, 1297, 1301, 1303, 1307, 1319, 1321, 1327, 1361, 1367, 1373, 1381, 1399, 1409, 1423, 1427, 1429, 1433, 1439, 1447, 1451, 1453, 1459, 1471, 1481, 1483, 1487, 1489, 1493, 1499, 1511, 1523, 1531, 1543, 1549, 1553, 1559, 1567, 1571, 1579, 1583, 1597, 1601, 1607, 1609, 1613, 1619, 1621, 1627, 1637, 1657, 1663, 1667, 1669, 1693, 1697, 1699, 1709, 1721, 1723, 1733, 1741, 1747, 1753, 1759, 1777, 1783, 1787, 1789, 1801, 1811, 1823, 1831, 1847, 1861, 1867, 1871, 1873, 1877, 1879, 1889, 1901, 1907, 1913, 1931, 1933, 1949, 1951, 1973, 1979, 1987, 1993, 1997, 1999, 2003, 2011, 2017, 2027, 2029, 2039, 2053, 2063, 2069, 2081, 2083, 2087, 2089, 2099, 2111, 2113, 2129, 2131, 2137, 2141, 2143, 2153, 2161, 2179, 2203, 2207, 2213, 2221, 2237, 2239, 2243, 2251, 2267, 2269, 2273, 2281, 2287, 2293, 2297, 2309, 2311, 2333, 2339, 2341, 2347, 2351, 2357, 2371, 2377, 2381, 2383, 2389, 2393, 2399, 2411, 2417, 2423, 2437, 2441, 2447, 2459, 2467, 2473, 2477, 2503, 2521, 2531, 2539, 2543, 2549, 2551, 2557, 2579, 2591, 2593, 2609, 2617, 2621, 2633, 2647, 2657, 2659, 2663, 2671, 2677, 2683, 2687, 2689, 2693, 2699, 2707, 2711, 2713, 2719, 2729, 2731, 2741, 2749, 2753, 2767, 2777, 2789, 2791, 2797, 2801, 2803, 2819, 2833, 2837, 2843, 2851, 2857, 2861, 2879, 2887, 2897, 2903, 2909, 2917, 2927, 2939, 2953, 2957, 2963, 2969, 2971, 2999, 3001, 3011, 3019, 3023, 3037, 3041, 3049, 3061, 3067, 3079, 3083, 3089, 3109, 3119, 3121, 3137, 3163, 3167, 3169, 3181, 3187, 3191, 3203, 3209, 3217, 3221, 3229, 3251, 3253, 3257, 3259, 3271, 3299, 3301, 3307, 3313, 3319, 3323, 3329, 3331, 3343, 3347, 3359, 3361, 3371, 3373, 3389, 3391, 3407, 3413, 3433, 3449, 3457, 3461, 3463, 3467, 3469, 3491, 3499, 3511, 3517, 3527, 3529, 3533, 3539, 3541, 3547, 3557, 3559, 3571, 3581, 3583, 3593, 3607, 3613, 3617, 3623, 3631, 3637, 3643, 3659, 3671, 3673, 3677, 3691, 3697, 3701, 3709, 3719, 3727, 3733, 3739, 3761, 3767, 3769, 3779, 3793, 3797, 3803, 3821, 3823, 3833, 3847, 3851, 3853, 3863, 3877, 3881, 3889, 3907, 3911, 3917, 3919, 3923, 3929, 3931, 3943, 3947, 3967, 3989, 4001, 4003, 4007, 4013, 4019, 4021, 4027, 4049, 4051, 4057, 4073, 4079, 4091, 4093, 4099, 4111, 4127, 4129, 4133, 4139, 4153, 4157, 4159, 4177, 4201, 4211, 4217, 4219, 4229, 4231, 4241, 4243, 4253, 4259, 4261, 4271, 4273, 4283, 4289, 4297, 4327, 4337, 4339, 4349, 4357, 4363, 4373, 4391, 4397, 4409, 4421, 4423, 4441, 4447, 4451, 4457, 4463, 4481, 4483, 4493, 4507, 4513, 4517, 4519, 4523, 4547, 4549, 4561, 4567, 4583, 4591, 4597, 4603, 4621, 4637, 4639, 4643, 4649, 4651, 4657, 4663, 4673, 4679, 4691, 4703, 4721, 4723, 4729, 4733, 4751, 4759, 4783, 4787, 4789, 4793, 4799, 4801, 4813, 4817, 4831, 4861, 4871, 4877, 4889, 4903, 4909, 4919, 4931, 4933, 4937, 4943, 4951, 4957, 4967, 4969, 4973, 4987, 4993, 4999, 5003, 5009, 5011, 5021, 5023, 5039, 5051, 5059, 5077, 5081, 5087, 5099, 5101, 5107, 5113, 5119, 5147, 5153, 5167, 5171, 5179, 5189, 5197, 5209, 5227, 5231, 5233, 5237, 5261, 5273, 5279, 5281, 5297, 5303, 5309, 5323, 5333, 5347, 5351, 5381, 5387, 5393, 5399, 5407, 5413, 5417, 5419, 5431, 5437, 5441, 5443, 5449, 5471, 5477, 5479, 5483, 5501, 5503, 5507, 5519, 5521, 5527, 5531, 5557, 5563, 5569, 5573, 5581, 5591, 5623, 5639, 5641, 5647, 5651, 5653, 5657, 5659, 5669, 5683, 5689, 5693, 5701, 5711, 5717, 5737, 5741, 5743, 5749, 5779, 5783, 5791, 5801, 5807, 5813, 5821, 5827, 5839, 5843, 5849, 5851, 5857, 5861, 5867, 5869, 5879, 5881, 5897, 5903, 5923, 5927, 5939, 5953, 5981, 5987, 6007, 6011, 6029, 6037, 6043, 6047, 6053, 6067, 6073, 6079, 6089, 6091, 6101, 6113, 6121, 6131, 6133, 6143, 6151, 6163, 6173, 6197, 6199, 6203, 6211, 6217, 6221, 6229, 6247, 6257, 6263, 6269, 6271, 6277, 6287, 6299, 6301, 6311, 6317, 6323, 6329, 6337, 6343, 6353, 6359, 6361, 6367, 6373, 6379, 6389, 6397, 6421, 6427, 6449, 6451, 6469, 6473, 6481, 6491, 6521, 6529, 6547, 6551, 6553, 6563, 6569, 6571, 6577, 6581, 6599, 6607, 6619, 6637, 6653, 6659, 6661, 6673, 6679, 6689, 6691, 6701, 6703, 6709, 6719, 6733, 6737, 6761, 6763, 6779, 6781, 6791, 6793, 6803, 6823, 6827, 6829, 6833, 6841, 6857, 6863, 6869, 6871, 6883, 6899, 6907, 6911, 6917, 6947, 6949, 6959, 6961, 6967, 6971, 6977, 6983, 6991, 6997, 7001, 7013, 7019, 7027, 7039, 7043, 7057, 7069, 7079, 7103, 7109, 7121, 7127, 7129, 7151, 7159, 7177, 7187, 7193, 7207, 7211, 7213, 7219, 7229, 7237, 7243, 7247, 7253, 7283, 7297, 7307, 7309, 7321, 7331, 7333, 7349, 7351, 7369, 7393, 7411, 7417, 7433, 7451, 7457, 7459, 7477, 7481, 7487, 7489, 7499, 7507, 7517, 7523, 7529, 7537, 7541, 7547, 7549, 7559, 7561, 7573, 7577, 7583, 7589, 7591, 7603, 7607, 7621, 7639, 7643, 7649, 7669, 7673, 7681, 7687, 7691, 7699, 7703, 7717, 7723, 7727, 7741, 7753, 7757, 7759, 7789, 7793, 7817, 7823, 7829, 7841, 7853, 7867, 7873, 7877, 7879, 7883, 7901, 7907, 7919
|
|
11
|
-
]
|
|
12
|
-
|
|
13
|
-
attr_reader :bits
|
|
14
|
-
|
|
15
|
-
# Generates random integers that are representable by the given number of
|
|
16
|
-
# bits.
|
|
17
|
-
def initialize aBits
|
|
18
|
-
@bits = aBits
|
|
19
|
-
@limit = 2 ** @bits
|
|
20
|
-
@primes = PRIMES.select {|i| i < @limit}
|
|
21
|
-
end
|
|
22
|
-
|
|
23
|
-
# Returns a random integer.
|
|
24
|
-
def random
|
|
25
|
-
choices = [
|
|
26
|
-
0,
|
|
27
|
-
1,
|
|
28
|
-
prime,
|
|
29
|
-
power_of_two,
|
|
30
|
-
rand(@limit),
|
|
31
|
-
]
|
|
32
|
-
|
|
33
|
-
choices[rand(choices.length)]
|
|
34
|
-
end
|
|
35
|
-
|
|
36
|
-
# Returns a random prime integer.
|
|
37
|
-
def prime
|
|
38
|
-
@primes[rand(@primes.length)]
|
|
39
|
-
end
|
|
40
|
-
|
|
41
|
-
# Returns a random power-of-two integer.
|
|
42
|
-
def power_of_two
|
|
43
|
-
2 ** rand(@bits)
|
|
44
|
-
end
|
|
45
|
-
end
|
data/ext/common.h
DELETED
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
Copyright 2006 Suraj N. Kurapati
|
|
3
|
-
See the file named LICENSE for details.
|
|
4
|
-
*/
|
|
5
|
-
/**\file
|
|
6
|
-
Things common to all Ruby-VPI code.
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
#ifndef COMMON_H
|
|
10
|
-
#define COMMON_H
|
|
11
|
-
|
|
12
|
-
#include <stddef.h>
|
|
13
|
-
#include "verilog.h"
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
A wrapper for vpi_printf() which marks the given message as being emitted
|
|
18
|
-
from Ruby-VPI and ends the message with a new line.
|
|
19
|
-
|
|
20
|
-
@param ... Arguments to vpi_printf()
|
|
21
|
-
*/
|
|
22
|
-
#define common_printf(...) vpi_printf("Ruby-VPI: "); vpi_printf(__VA_ARGS__); vpi_printf("\n");
|
|
23
|
-
|
|
24
|
-
/**
|
|
25
|
-
A wrapper for common_printf() which marks the given message as being
|
|
26
|
-
debugging output.
|
|
27
|
-
*/
|
|
28
|
-
#ifdef DEBUG
|
|
29
|
-
#define common_debug(...) vpi_printf("(%s:%d) ", __FILE__, __LINE__); common_printf(__VA_ARGS__);
|
|
30
|
-
#else
|
|
31
|
-
#define common_debug(...)
|
|
32
|
-
#endif
|
|
33
|
-
|
|
34
|
-
/**
|
|
35
|
-
A boolean variable with two possible values: true and false. Pass aroung
|
|
36
|
-
this value instead of zero and non-zero integers.
|
|
37
|
-
*/
|
|
38
|
-
typedef enum { false = 0, true = 1 } bool;
|
|
39
|
-
|
|
40
|
-
/**
|
|
41
|
-
Returns the string "true" if the given boolean expression is true. Otherwise
|
|
42
|
-
returns the string "false".
|
|
43
|
-
*/
|
|
44
|
-
#define common_boolToStr(aBoolExpr) ( (aBoolExpr) ? "true" : "false" )
|
|
45
|
-
|
|
46
|
-
#endif
|
data/ext/main.h
DELETED
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
Copyright 2006 Suraj N. Kurapati
|
|
3
|
-
See the file named LICENSE for details.
|
|
4
|
-
*/
|
|
5
|
-
/**\file
|
|
6
|
-
The C extension for Ruby-VPI.
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
#ifndef MAIN_H
|
|
10
|
-
#define MAIN_H
|
|
11
|
-
|
|
12
|
-
#include "common.h"
|
|
13
|
-
#include <ruby.h>
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
Runs the test bench.
|
|
17
|
-
*/
|
|
18
|
-
void main_init();
|
|
19
|
-
|
|
20
|
-
/**
|
|
21
|
-
Transfers control from Ruby to Verilog.
|
|
22
|
-
*/
|
|
23
|
-
VALUE main_relay_verilog(VALUE arSelf);
|
|
24
|
-
|
|
25
|
-
/**
|
|
26
|
-
Gets the reason (Vpi::S_cb_data) why Verilog relayed to Ruby.
|
|
27
|
-
*/
|
|
28
|
-
VALUE main_relay_ruby_reason(VALUE arSelf);
|
|
29
|
-
|
|
30
|
-
#endif
|
data/ext/relay.c
DELETED
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
Copyright 1999 Kazuhiro HIWADA
|
|
3
|
-
Copyright 2006 Suraj N. Kurapati
|
|
4
|
-
See the file named LICENSE for details.
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
#include "relay.h"
|
|
8
|
-
#include "main.h"
|
|
9
|
-
#include <pthread.h>
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
pthread_t relay__rubyThread;
|
|
13
|
-
pthread_mutex_t relay__rubyLock;
|
|
14
|
-
pthread_mutex_t relay__verilogLock;
|
|
15
|
-
|
|
16
|
-
// body of the ruby thread
|
|
17
|
-
void* relay_ruby_thread(void* dummy) {
|
|
18
|
-
main_init();
|
|
19
|
-
return NULL;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
void relay_init() {
|
|
23
|
-
pthread_mutex_init(&relay__rubyLock, NULL);
|
|
24
|
-
pthread_mutex_lock(&relay__rubyLock);
|
|
25
|
-
pthread_mutex_init(&relay__verilogLock, NULL);
|
|
26
|
-
pthread_mutex_lock(&relay__verilogLock);
|
|
27
|
-
|
|
28
|
-
// begin by putting the ruby thread in control
|
|
29
|
-
pthread_create(&relay__rubyThread, NULL, relay_ruby_thread, NULL);
|
|
30
|
-
pthread_mutex_lock(&relay__verilogLock);
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
void relay_ruby() {
|
|
34
|
-
pthread_mutex_unlock(&relay__rubyLock);
|
|
35
|
-
pthread_mutex_lock(&relay__verilogLock);
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
void relay_verilog() {
|
|
39
|
-
pthread_mutex_unlock(&relay__verilogLock);
|
|
40
|
-
pthread_mutex_lock(&relay__rubyLock);
|
|
41
|
-
}
|
data/ext/relay.h
DELETED
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
Copyright 1999 Kazuhiro HIWADA
|
|
3
|
-
Copyright 2006 Suraj N. Kurapati
|
|
4
|
-
See the file named LICENSE for details.
|
|
5
|
-
*/
|
|
6
|
-
/**\file
|
|
7
|
-
Logic for transferring control between Ruby and Verilog.
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
#ifndef RELAY_H
|
|
11
|
-
#define RELAY_H
|
|
12
|
-
|
|
13
|
-
#include "common.h"
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
Initialize the relay mechanism, which enables Verilog to
|
|
17
|
-
transfer control to Ruby and vice versa, and start Ruby.
|
|
18
|
-
*/
|
|
19
|
-
void relay_init();
|
|
20
|
-
|
|
21
|
-
/**
|
|
22
|
-
Transfers control to Ruby.
|
|
23
|
-
*/
|
|
24
|
-
void relay_ruby();
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
Transfers control to Verilog.
|
|
28
|
-
*/
|
|
29
|
-
void relay_verilog();
|
|
30
|
-
|
|
31
|
-
#endif
|
data/ext/vlog.c
DELETED
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
Copyright 1999 Kazuhiro HIWADA
|
|
3
|
-
Copyright 2006 Suraj N. Kurapati
|
|
4
|
-
See the file named LICENSE for details.
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
#include "vlog.h"
|
|
8
|
-
#include "relay.h"
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
s_cb_data* vlog__relayReason = NULL;
|
|
12
|
-
|
|
13
|
-
verilog_cb_funcSig(vlog_relay_init) {
|
|
14
|
-
relay_init();
|
|
15
|
-
verilog_cb_funcReturn(0);
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
verilog_cb_funcSig(vlog_relay_ruby) {
|
|
19
|
-
vlog__relayReason = aCallbackData;
|
|
20
|
-
relay_ruby();
|
|
21
|
-
|
|
22
|
-
verilog_cb_funcReturn(0);
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
s_cb_data* vlog_relay_ruby_reason() {
|
|
26
|
-
return vlog__relayReason;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
/**
|
|
31
|
-
Registers a callback at start of simulation to vlog_relay_main();
|
|
32
|
-
*/
|
|
33
|
-
void vlog_startup() {
|
|
34
|
-
s_cb_data call;
|
|
35
|
-
|
|
36
|
-
call.reason = cbStartOfSimulation;
|
|
37
|
-
call.cb_rtn = vlog_relay_init;
|
|
38
|
-
call.obj = NULL;
|
|
39
|
-
call.time = NULL;
|
|
40
|
-
call.value = NULL;
|
|
41
|
-
call.user_data = NULL;
|
|
42
|
-
|
|
43
|
-
vpi_free_object(vpi_register_cb(&call));
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
void (*vlog_startup_routines[])() = { vlog_startup, NULL };
|
|
47
|
-
|
|
48
|
-
#if defined(PRAGMATIC_CVER) || defined(SYNOPSYS_VCS) || defined(CADENCE_NCSIM)
|
|
49
|
-
/**
|
|
50
|
-
Invokes each routine specified in the vlog_startup_routines array.
|
|
51
|
-
*/
|
|
52
|
-
void vlog_startup_routines_bootstrap() {
|
|
53
|
-
unsigned i;
|
|
54
|
-
for (i = 0; vlog_startup_routines[i] != NULL; i++)
|
|
55
|
-
vlog_startup_routines[i]();
|
|
56
|
-
}
|
|
57
|
-
#endif
|
data/ext/vlog.h
DELETED
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
Copyright 2006 Suraj N. Kurapati
|
|
3
|
-
See the file named LICENSE for details.
|
|
4
|
-
*/
|
|
5
|
-
/**\file
|
|
6
|
-
Interface between C and Verilog code.
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
#ifndef VLOG_H
|
|
10
|
-
#define VLOG_H
|
|
11
|
-
|
|
12
|
-
#include "common.h"
|
|
13
|
-
#include "verilog.h"
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
Relays control from Verilog to Ruby.
|
|
17
|
-
*/
|
|
18
|
-
verilog_cb_funcSig(vlog_relay_ruby);
|
|
19
|
-
|
|
20
|
-
/**
|
|
21
|
-
Returns the data corresponding to the callback
|
|
22
|
-
that caused the relay from Verilog to Ruby.
|
|
23
|
-
*/
|
|
24
|
-
s_cb_data* vlog_relay_ruby_reason();
|
|
25
|
-
|
|
26
|
-
#endif
|