ruby-vpi 20.0.0 → 21.0.0
Sign up to get free protection for your applications and to get access to all the features.
- 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
Binary file
|
@@ -7,7 +7,7 @@ TEST_LOADER = "register_file_loader.rb"
|
|
7
7
|
# details) to source files and directories that contain source files. These
|
8
8
|
# source files will be loaded by the simulator before the simulation begins.
|
9
9
|
SIMULATOR_SOURCES = FileList[
|
10
|
-
'register_file.v'
|
10
|
+
'register_file.v'
|
11
11
|
]
|
12
12
|
|
13
13
|
# Command-line arguments for the simulator. These arguments can be
|
data/ext/Rakefile
CHANGED
@@ -21,16 +21,25 @@ task :default => 'Makefile' do |t|
|
|
21
21
|
end
|
22
22
|
|
23
23
|
file 'Makefile' => [:swig, 'extconf.rb'] do |t|
|
24
|
-
|
24
|
+
cflags = "#{ENV['CFLAGS']} -g -Werror"
|
25
|
+
|
26
|
+
# detect ruby version on behalf of C extension
|
27
|
+
v = RUBY_VERSION.split('.')
|
28
|
+
until v.empty?
|
29
|
+
cflags << " -DHAVE_RUBY_#{v.join '_'}"
|
30
|
+
v.pop
|
31
|
+
end
|
32
|
+
|
33
|
+
ruby t.prerequisites[1], "--with-cflags=#{cflags}", "--with-ldflags=#{ENV['LDFLAGS']}"
|
25
34
|
end
|
26
35
|
|
27
36
|
CLEAN.include 'Makefile', 'mkmf.log', '*.o', "*.#{Config::CONFIG['DLEXT']}"
|
28
37
|
|
29
38
|
|
30
39
|
desc 'Generate Ruby wrapper for VPI.'
|
31
|
-
task :swig => '
|
40
|
+
task :swig => 'swig.cin'
|
32
41
|
|
33
|
-
file '
|
42
|
+
file 'swig.cin' => 'swig_vpi.i' do |t|
|
34
43
|
sh %w[swig -Werror -w801 -ruby -o], t.name, t.prerequisites[0]
|
35
44
|
end
|
36
45
|
|
@@ -61,4 +70,4 @@ file 'swig_vpi.h' => 'vpi_user.h' do |t|
|
|
61
70
|
end
|
62
71
|
end
|
63
72
|
|
64
|
-
CLEAN.include '
|
73
|
+
CLEAN.include 'swig.cin', 'swig_vpi.h'
|
data/ext/binding.c
ADDED
@@ -0,0 +1,22 @@
|
|
1
|
+
/*
|
2
|
+
Copyright 2008 Suraj N. Kurapati
|
3
|
+
See the file named LICENSE for details.
|
4
|
+
*/
|
5
|
+
|
6
|
+
#include "binding.h"
|
7
|
+
#include "swig.cin" // SWIG generated bindings for VPI
|
8
|
+
|
9
|
+
void RubyVPI_binding_init()
|
10
|
+
{
|
11
|
+
Init_VPI();
|
12
|
+
|
13
|
+
// some compilers have trouble with pointers to the va_list
|
14
|
+
// type. See ext/Rakefile and the user manual for details
|
15
|
+
rb_define_alias(mVPI, "vpi_vprintf", "vpi_printf");
|
16
|
+
rb_define_alias(mVPI, "vpi_mcd_vprintf", "vpi_mcd_printf");
|
17
|
+
}
|
18
|
+
|
19
|
+
VALUE RubyVPI_binding_rubify_callback(p_cb_data aCallback)
|
20
|
+
{
|
21
|
+
return SWIG_NewPointerObj(aCallback, SWIGTYPE_p_t_cb_data, 0);
|
22
|
+
}
|
data/ext/binding.h
ADDED
@@ -0,0 +1,29 @@
|
|
1
|
+
/*
|
2
|
+
Copyright 2008 Suraj N. Kurapati
|
3
|
+
See the file named LICENSE for details.
|
4
|
+
*/
|
5
|
+
///\file Ruby bindings for the VPI library.
|
6
|
+
|
7
|
+
#ifndef BINDING_H
|
8
|
+
#define BINDING_H
|
9
|
+
|
10
|
+
#include "verilog.h"
|
11
|
+
#include <ruby.h>
|
12
|
+
|
13
|
+
///
|
14
|
+
/// Initializes the Ruby bindings.
|
15
|
+
///
|
16
|
+
/// This function must be called ONLY from the
|
17
|
+
/// main C process (NOT from inside a thread).
|
18
|
+
///
|
19
|
+
/// Also, this function must be called ONLY
|
20
|
+
/// after RubyVPI_roobee_init() has been called.
|
21
|
+
///
|
22
|
+
void RubyVPI_binding_init();
|
23
|
+
|
24
|
+
///
|
25
|
+
/// Converts the given VPI callback structure into a Ruby value.
|
26
|
+
///
|
27
|
+
VALUE RubyVPI_binding_rubify_callback(p_cb_data aCallback);
|
28
|
+
|
29
|
+
#endif
|
data/ext/extconf.rb
CHANGED
@@ -1,24 +1,31 @@
|
|
1
|
-
# Generates a makefile for buiding the extension.
|
1
|
+
# Generates a makefile for buiding the C extension.
|
2
2
|
#--
|
3
3
|
# Copyright 2006 Suraj N. Kurapati
|
4
4
|
# See the file named LICENSE for details.
|
5
5
|
|
6
6
|
require 'mkmf'
|
7
7
|
|
8
|
-
# check for POSIX threads library
|
9
|
-
hasPthread = have_library('pthread', 'pthread_create')
|
10
|
-
|
11
8
|
# check for ruby library
|
12
9
|
require 'rbconfig'
|
13
10
|
|
14
|
-
|
11
|
+
# possible names under which Ruby library is installed
|
12
|
+
rubyLibNames = Config::CONFIG.values.join(' ').
|
13
|
+
scan(/-l(ruby\S*)/).flatten.uniq
|
14
|
+
|
15
|
+
# possible places where Ruby library is installed
|
16
|
+
rubyLibPaths = Config::CONFIG.values.join(' ').
|
17
|
+
scan(/-L(\S+)/).flatten.
|
18
|
+
select {|f| File.exist? f }
|
19
|
+
|
20
|
+
RUBY_FUNC = 'ruby_init'
|
15
21
|
|
16
|
-
|
17
|
-
|
18
|
-
rubyLibNames.uniq!
|
22
|
+
hasRuby = rubyLibNames.any? do |libName|
|
23
|
+
have_library(libName, RUBY_FUNC) or
|
19
24
|
|
20
|
-
|
21
|
-
|
25
|
+
rubyLibPaths.any? do |libPath|
|
26
|
+
have_library(libName, RUBY_FUNC, libPath)
|
27
|
+
end
|
22
28
|
end
|
23
29
|
|
24
|
-
|
30
|
+
# generate the makefile
|
31
|
+
create_makefile 'ruby-vpi' if hasRuby
|
data/ext/host.c
ADDED
@@ -0,0 +1,75 @@
|
|
1
|
+
/*
|
2
|
+
Copyright 2008 Suraj N. Kurapati
|
3
|
+
See the file named LICENSE for details.
|
4
|
+
*/
|
5
|
+
|
6
|
+
#include "host.h"
|
7
|
+
#include "util.h"
|
8
|
+
#include "user.h"
|
9
|
+
#include "binding.h"
|
10
|
+
#include <ruby.h>
|
11
|
+
#include <stdlib.h>
|
12
|
+
|
13
|
+
VALUE RubyVPI_host_gProgName;
|
14
|
+
|
15
|
+
#ifdef RUBY_GLOBAL_SETUP
|
16
|
+
RUBY_GLOBAL_SETUP
|
17
|
+
#endif
|
18
|
+
|
19
|
+
PLI_INT32 RubyVPI_host_init(p_cb_data aCallback)
|
20
|
+
{
|
21
|
+
//
|
22
|
+
// ruby init
|
23
|
+
//
|
24
|
+
|
25
|
+
#ifdef RUBY_INIT_STACK
|
26
|
+
RubyVPI_util_debug("Host: RUBY_INIT_STACK");
|
27
|
+
RUBY_INIT_STACK;
|
28
|
+
#endif
|
29
|
+
|
30
|
+
RubyVPI_util_debug("Host: ruby_init()");
|
31
|
+
ruby_init();
|
32
|
+
|
33
|
+
// override Ruby's hooked handlers for $0 so that $0 can be
|
34
|
+
// treated as pure Ruby value (and modified without restriction)
|
35
|
+
RubyVPI_util_debug("Host: redefine $0 hooked variable");
|
36
|
+
RubyVPI_host_gProgName = rb_str_new2("ruby-vpi");
|
37
|
+
rb_define_variable("$0", &RubyVPI_host_gProgName);
|
38
|
+
rb_define_variable("$PROGRAM_NAME", &RubyVPI_host_gProgName);
|
39
|
+
|
40
|
+
RubyVPI_util_debug("Host: ruby_init_loadpath()");
|
41
|
+
ruby_init_loadpath();
|
42
|
+
|
43
|
+
#ifdef HAVE_RUBY_1_9
|
44
|
+
RubyVPI_util_debug("Host: ruby_init_gems(Qtrue)");
|
45
|
+
rb_const_set(rb_define_module("Gem"), rb_intern("Enable"), Qtrue);
|
46
|
+
|
47
|
+
RubyVPI_util_debug("Host: Init_prelude()");
|
48
|
+
Init_prelude();
|
49
|
+
#endif
|
50
|
+
|
51
|
+
|
52
|
+
//
|
53
|
+
// VPI bindings init
|
54
|
+
//
|
55
|
+
|
56
|
+
RubyVPI_util_debug("Host: VPI binding init");
|
57
|
+
RubyVPI_binding_init();
|
58
|
+
|
59
|
+
|
60
|
+
//
|
61
|
+
// ruby thread init
|
62
|
+
//
|
63
|
+
|
64
|
+
RubyVPI_util_debug("Host: user_init()");
|
65
|
+
RubyVPI_user_init();
|
66
|
+
}
|
67
|
+
|
68
|
+
PLI_INT32 RubyVPI_host_fini(p_cb_data aCallback)
|
69
|
+
{
|
70
|
+
RubyVPI_util_debug("Host: user fini");
|
71
|
+
RubyVPI_user_fini();
|
72
|
+
|
73
|
+
RubyVPI_util_debug("Host: ruby_finalize()");
|
74
|
+
ruby_finalize();
|
75
|
+
}
|
data/ext/host.h
ADDED
@@ -0,0 +1,17 @@
|
|
1
|
+
/*
|
2
|
+
Copyright 2008 Suraj N. Kurapati
|
3
|
+
See the file named LICENSE for details.
|
4
|
+
*/
|
5
|
+
|
6
|
+
#ifndef HOST_H
|
7
|
+
#define HOST_H
|
8
|
+
|
9
|
+
#include "verilog.h"
|
10
|
+
|
11
|
+
// should be called in vlog_startup_routines
|
12
|
+
PLI_INT32 RubyVPI_host_init(p_cb_data aCallback);
|
13
|
+
|
14
|
+
// should be called at end of simulation
|
15
|
+
PLI_INT32 RubyVPI_host_fini(p_cb_data aCallback);
|
16
|
+
|
17
|
+
#endif
|
data/ext/main.c
CHANGED
@@ -1,53 +1,60 @@
|
|
1
1
|
/*
|
2
|
-
Copyright 1999 Kazuhiro HIWADA
|
3
2
|
Copyright 2006 Suraj N. Kurapati
|
4
3
|
See the file named LICENSE for details.
|
5
4
|
*/
|
6
5
|
|
7
|
-
#include "
|
8
|
-
#include "
|
9
|
-
#include
|
10
|
-
#include
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
rb_define_alias(mVPI, "vpi_vprintf", "vpi_printf");
|
29
|
-
rb_define_alias(mVPI, "vpi_mcd_vprintf", "vpi_mcd_printf");
|
6
|
+
#include "util.h"
|
7
|
+
#include "verilog.h"
|
8
|
+
#include "host.h"
|
9
|
+
#include "user.h"
|
10
|
+
|
11
|
+
///
|
12
|
+
/// Registers a very basic VPI callback with reason and handler.
|
13
|
+
///
|
14
|
+
static void RubyVPI_main_register_callback(PLI_INT32 aReason, PLI_INT32 (*aHandler)(p_cb_data))
|
15
|
+
{
|
16
|
+
s_cb_data call;
|
17
|
+
|
18
|
+
call.reason = aReason;
|
19
|
+
call.cb_rtn = aHandler;
|
20
|
+
call.obj = 0;
|
21
|
+
call.time = 0;
|
22
|
+
call.value = 0;
|
23
|
+
call.user_data = 0;
|
24
|
+
|
25
|
+
vpi_free_object(vpi_register_cb(&call));
|
26
|
+
}
|
30
27
|
|
28
|
+
static void RubyVPI_main_init()
|
29
|
+
{
|
30
|
+
RubyVPI_util_debug("Main: at vlog startup");
|
31
31
|
|
32
|
-
|
33
|
-
|
32
|
+
// commence Ruby execution at the start of the simulation
|
33
|
+
RubyVPI_util_debug("Main: registering BEGIN simulation callback");
|
34
|
+
RubyVPI_main_register_callback(cbStartOfSimulation, RubyVPI_host_init);
|
34
35
|
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
ruby_run();
|
39
|
-
}
|
40
|
-
else {
|
41
|
-
common_printf("error: the RUBYVPI_BOOT_LOADER and RUBYVPI_TEST_LOADER environment variables must be defined.");
|
42
|
-
exit(EXIT_FAILURE);
|
43
|
-
}
|
36
|
+
// clean up this C extension at the end of the simulation
|
37
|
+
RubyVPI_util_debug("Main: registering END simulation callback");
|
38
|
+
RubyVPI_main_register_callback(cbEndOfSimulation, RubyVPI_host_fini);
|
44
39
|
}
|
45
40
|
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
41
|
+
///
|
42
|
+
/// Verilog simulator's bootstrap vector. The simulator
|
43
|
+
/// will invoke the functions in this array when it loads
|
44
|
+
/// the shared-object file compiled from this C extension.
|
45
|
+
///
|
46
|
+
void (*vlog_startup_routines[])() = { RubyVPI_main_init, 0 };
|
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
|
+
{
|
54
|
+
unsigned int i;
|
55
|
+
for (i = 0; vlog_startup_routines[i]; i++)
|
56
|
+
{
|
57
|
+
vlog_startup_routines[i]();
|
58
|
+
}
|
59
|
+
}
|
60
|
+
#endif
|
data/ext/swig_vpi.i
CHANGED
@@ -2,16 +2,16 @@
|
|
2
2
|
|
3
3
|
/* Parse the header file to generate wrappers */
|
4
4
|
%{
|
5
|
-
#include "swig_vpi.h"
|
5
|
+
#include "swig_vpi.h"
|
6
6
|
%}
|
7
7
|
%include "swig_vpi.h"
|
8
8
|
|
9
|
-
/*
|
9
|
+
/* Allow the VPI callback handler function to be set from Ruby:
|
10
10
|
|
11
|
-
data
|
12
|
-
data.cb_rtn = VPI::
|
11
|
+
data = S_cb_data.new
|
12
|
+
data.cb_rtn = VPI::RubyVPI_user_resume
|
13
13
|
*/
|
14
14
|
%{
|
15
|
-
#include "
|
15
|
+
#include "user.h"
|
16
16
|
%}
|
17
|
-
%constant PLI_INT32
|
17
|
+
%constant PLI_INT32 RubyVPI_user_resume(p_cb_data);
|
data/ext/user.c
ADDED
@@ -0,0 +1,95 @@
|
|
1
|
+
/*
|
2
|
+
Copyright 2008 Suraj N. Kurapati
|
3
|
+
See the file named LICENSE for details.
|
4
|
+
*/
|
5
|
+
|
6
|
+
#include "user.h"
|
7
|
+
#include "util.h"
|
8
|
+
#include "binding.h"
|
9
|
+
#include <ruby.h>
|
10
|
+
|
11
|
+
static VALUE RubyVPI_user_require_impl(VALUE aPath)
|
12
|
+
{
|
13
|
+
return rb_require((char*)aPath);
|
14
|
+
}
|
15
|
+
|
16
|
+
static VALUE RubyVPI_user_require(char* aPath)
|
17
|
+
{
|
18
|
+
int error = 0;
|
19
|
+
VALUE result = rb_protect(RubyVPI_user_require_impl, (VALUE)aPath, &error);
|
20
|
+
|
21
|
+
if (error)
|
22
|
+
{
|
23
|
+
RubyVPI_util_error("rb_require('%s') failed with status %d", aPath, error);
|
24
|
+
}
|
25
|
+
|
26
|
+
return result;
|
27
|
+
}
|
28
|
+
|
29
|
+
///
|
30
|
+
/// Body of the ruby thread which runs the user code.
|
31
|
+
///
|
32
|
+
static VALUE RubyVPI_user_body(char* aUserScript)
|
33
|
+
{
|
34
|
+
RubyVPI_util_debug("Ruby: BEGIN synchronized with simulator");
|
35
|
+
RubyVPI_user_require(aUserScript); // blocks until user script is finished
|
36
|
+
|
37
|
+
RubyVPI_util_debug("Ruby: END");
|
38
|
+
// don't wait for anyone to resume me anymore
|
39
|
+
}
|
40
|
+
|
41
|
+
void RubyVPI_user_init()
|
42
|
+
{
|
43
|
+
// mailbox init
|
44
|
+
RubyVPI_util_debug("User: mailbox init");
|
45
|
+
RubyVPI_user_require("ruby-vpi/boot/relay");
|
46
|
+
|
47
|
+
|
48
|
+
// ruby thread init
|
49
|
+
RubyVPI_util_debug("User: ruby thread init");
|
50
|
+
|
51
|
+
rb_thread_create(RubyVPI_user_body, "ruby-vpi/boot/loader");
|
52
|
+
|
53
|
+
|
54
|
+
// wait for thread to pause
|
55
|
+
RubyVPI_util_debug("User: calling RubyVPI.attach");
|
56
|
+
|
57
|
+
VALUE target = rb_const_get(rb_cObject, rb_intern("RubyVPI"));
|
58
|
+
ID method = rb_intern("attach");
|
59
|
+
rb_funcall(target, method, 0);
|
60
|
+
|
61
|
+
RubyVPI_util_debug("User: calling RubyVPI.attach DONE");
|
62
|
+
|
63
|
+
|
64
|
+
RubyVPI_util_debug("User: ruby thread is active & ran once");
|
65
|
+
}
|
66
|
+
|
67
|
+
void RubyVPI_user_fini()
|
68
|
+
{
|
69
|
+
// nothing to clean up; Ruby will garbage collect everything
|
70
|
+
}
|
71
|
+
|
72
|
+
PLI_INT32 RubyVPI_user_resume(p_cb_data aCallback)
|
73
|
+
{
|
74
|
+
RubyVPI_util_debug("Main: callback = %p", aCallback);
|
75
|
+
|
76
|
+
if (aCallback)
|
77
|
+
{
|
78
|
+
RubyVPI_util_debug("Main: callback.user_data = %p", aCallback->user_data);
|
79
|
+
}
|
80
|
+
else
|
81
|
+
{
|
82
|
+
RubyVPI_util_debug("Main: callback is NULL");
|
83
|
+
}
|
84
|
+
|
85
|
+
RubyVPI_util_debug("Main: ruby callback for %p =>", aCallback);
|
86
|
+
VALUE call = RubyVPI_binding_rubify_callback(aCallback);
|
87
|
+
|
88
|
+
VALUE target = rb_const_get(rb_cObject, rb_intern("RubyVPI"));
|
89
|
+
ID method = rb_intern("resume");
|
90
|
+
|
91
|
+
RubyVPI_util_debug("Main: calling RubyVPI.resume");
|
92
|
+
rb_funcall(target, method, 1, call); // pass callback to user code
|
93
|
+
|
94
|
+
return 0;
|
95
|
+
}
|