origen_jtag 0.21.1 → 0.22.2

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 2f63bbad6eac9c0d88a2e7970a16d2746375a25575bbae735b2f2626a457ebf4
4
- data.tar.gz: 8ba113303e5906a9da5c739663600828a57cb74a8953f0d1a967bb655848d6f1
3
+ metadata.gz: cc6050891bc69e2a38991157a3423a8765284b257a56d68c2fb87a8b5844f98b
4
+ data.tar.gz: 4e491ddb526412da9761cd1d5a6886a7a17a009e60ea2736db46365035cf94e2
5
5
  SHA512:
6
- metadata.gz: 9488fbea2784700dd849ce1eff4c279ff413f7c006dbb358a3cdcd1e7a8955ce42851aea7873c2818eb20821ad3f181f74c556801e6540dec93ec00462f606b2
7
- data.tar.gz: 37709e182313b91c0e4da8464a39e0161e5d89a287ed1eee632ebef60c744f22eb3b875b8a4262b97b15ac50ffb5944d522de2ec5aaa3e83ac5747b89f0fbd3d
6
+ metadata.gz: dbb5ac9d278793a4994d8a50079bb587f326186701ed760edc119824b899cb29bb0551693d4d8f7f72e7eaff2fefc2c7fd2e6fd4f4563ed2049b208f63b6b8a6
7
+ data.tar.gz: 93668e735cb0c23de2788bb6be7bb057a2e58a41bfff14a3a204de7c6a33f1ab6b2aaee427804869f62c9bf474fd888e6e82ab85ecf2b764a2f193c63db16f5d
data/config/version.rb CHANGED
@@ -1,8 +1,7 @@
1
1
  module OrigenJTAG
2
2
  MAJOR = 0
3
- MINOR = 21
4
- BUGFIX = 1
3
+ MINOR = 22
4
+ BUGFIX = 2
5
5
  DEV = nil
6
-
7
6
  VERSION = [MAJOR, MINOR, BUGFIX].join(".") + (DEV ? ".pre#{DEV}" : '')
8
7
  end
@@ -35,7 +35,8 @@ module OrigenJTAG
35
35
  alias_method :tclk_format, :tck_format
36
36
  alias_method :tclk_format=, :tck_format=
37
37
 
38
- attr_reader :tdo_strobe
38
+ attr_accessor :tdo_strobe
39
+ attr_accessor :tdo_store_cycle
39
40
 
40
41
  # Set true to print out debug comments about all state transitions
41
42
  attr_accessor :verbose
@@ -57,7 +58,7 @@ module OrigenJTAG
57
58
  end
58
59
 
59
60
  @cycle_callback = options[:cycle_callback]
60
- validate_pins(options) unless @cycle_callback
61
+ @given_options = options.dup # Save these for later use in the pins method
61
62
 
62
63
  # Fallback defaults
63
64
  options = {
@@ -211,7 +212,7 @@ module OrigenJTAG
211
212
  overlay_options = {}
212
213
  if tester.respond_to?(:source_memory) && !cycle_callback?
213
214
  if ovl_reg[i] && ovl_reg[i].has_overlay? && !Origen.mode.simulation?
214
- overlay_options[:pins] = @pins[:tdi]
215
+ overlay_options[:pins] = pins[:tdi]
215
216
  if global_ovl
216
217
  overlay_options[:overlay_str] = global_ovl
217
218
  else
@@ -280,7 +281,7 @@ module OrigenJTAG
280
281
  overlay_options[:change_data] = false # data change only on first cycle if overlay
281
282
  end
282
283
  end
283
- @pins[:tdo].dont_care unless cycle_callback?
284
+ pins[:tdo].dont_care unless cycle_callback?
284
285
  else
285
286
  @deferred_compare = true
286
287
  @deferred_store = true if store_tdo_this_tck
@@ -323,7 +324,7 @@ module OrigenJTAG
323
324
 
324
325
  # If TDO is already suspended (by an application) then don't do the
325
326
  # suspends below since the resume will clear the application's suspend
326
- tdo_already_suspended = !cycle_callback? && @pins[:tdo].suspended? && !@tdo_suspended_by_driver
327
+ tdo_already_suspended = !cycle_callback? && pins[:tdo].suspended? && !@tdo_suspended_by_driver
327
328
 
328
329
  @tck_multiple.times do |i|
329
330
  # 50% duty cycle if @tck_multiple is even, otherwise slightly off
@@ -332,26 +333,26 @@ module OrigenJTAG
332
333
 
333
334
  if i < (@tck_multiple + 1) / 2
334
335
  # first half of cycle
335
- @pins[:tck].drive(@tck_vals ? @tck_vals[:on] : tck_val)
336
+ pins[:tck].drive(@tck_vals ? @tck_vals[:on] : tck_val)
336
337
  unless tdo_already_suspended
337
338
  if mask_tdo_half0
338
339
  @tdo_suspended_by_driver = true
339
- @pins[:tdo].suspend
340
+ pins[:tdo].suspend
340
341
  else
341
342
  @tdo_suspended_by_driver = false
342
- @pins[:tdo].resume
343
+ pins[:tdo].resume
343
344
  end
344
345
  end
345
346
  else
346
347
  # second half of cycle
347
- @pins[:tck].drive(@tck_vals ? @tck_vals[:off] : (1 - tck_val))
348
+ pins[:tck].drive(@tck_vals ? @tck_vals[:off] : (1 - tck_val))
348
349
  unless tdo_already_suspended
349
350
  if mask_tdo_half1
350
351
  @tdo_suspended_by_driver = true
351
- @pins[:tdo].suspend
352
+ pins[:tdo].suspend
352
353
  else
353
354
  @tdo_suspended_by_driver = false
354
- @pins[:tdo].resume
355
+ pins[:tdo].resume
355
356
  end
356
357
  end
357
358
  end
@@ -359,7 +360,7 @@ module OrigenJTAG
359
360
  end
360
361
  if @tdo_suspended_by_driver
361
362
  @tdo_suspended_by_driver = false
362
- @pins[:tdo].resume
363
+ pins[:tdo].resume
363
364
  end
364
365
  end
365
366
  end
@@ -415,7 +416,7 @@ module OrigenJTAG
415
416
  cc "#{options[:msg]}\n"
416
417
  end
417
418
  val = reg_or_val.respond_to?(:data) ? reg_or_val.data : reg_or_val
418
- shift_dr(write: val.to_hex) do
419
+ shift_dr(options.merge(write: val.to_hex)) do
419
420
  shift(reg_or_val, options)
420
421
  end
421
422
  end
@@ -448,7 +449,7 @@ module OrigenJTAG
448
449
  if options[:msg]
449
450
  cc "#{options[:msg]}\n"
450
451
  end
451
- shift_dr(read: Origen::Utility.read_hex(reg_or_val)) do
452
+ shift_dr(options.merge(read: Origen::Utility.read_hex(reg_or_val))) do
452
453
  shift(reg_or_val, options)
453
454
  end
454
455
  end
@@ -475,19 +476,19 @@ module OrigenJTAG
475
476
  # a msg to be written out prior to shifting in IR data. Will not write comment only if write
476
477
  # occurs.
477
478
  def write_ir(reg_or_val, options = {})
478
- if Origen.tester.respond_to?(:write_ir)
479
- Origen.tester.write_ir(reg_or_val, options)
480
- else
481
- val = reg_or_val.respond_to?(:data) ? reg_or_val.data : reg_or_val
482
- if val != ir_value || options[:force]
483
- if options[:msg]
484
- cc "#{options[:msg]}\n"
485
- end
486
- shift_ir(write: val.to_hex) do
479
+ val = reg_or_val.respond_to?(:data) ? reg_or_val.data : reg_or_val
480
+ if val != ir_value || options[:force]
481
+ if options[:msg]
482
+ cc "#{options[:msg]}\n"
483
+ end
484
+ if Origen.tester.respond_to?(:write_ir)
485
+ Origen.tester.write_ir(reg_or_val, options)
486
+ else
487
+ shift_ir(options.merge(write: val.to_hex)) do
487
488
  shift(reg_or_val, options)
488
489
  end
489
- @ir_value = val
490
490
  end
491
+ @ir_value = val
491
492
  end
492
493
  end
493
494
 
@@ -548,10 +549,10 @@ module OrigenJTAG
548
549
  if cycle_callback?
549
550
  @owner.send(@cycle_callback, @actions, options)
550
551
  else
551
- apply_action(@pins[:tms], @actions[:tms])
552
- apply_action(@pins[:tdi], @actions[:tdi])
553
- apply_action(@pins[:tdo], @actions[:tdo])
554
- tester.store_next_cycle(@pins[:tdo]) if @actions[:store]
552
+ apply_action(pins[:tms], @actions[:tms])
553
+ apply_action(pins[:tdi], @actions[:tdi])
554
+ apply_action(pins[:tdo], @actions[:tdo])
555
+ tester.store_next_cycle(pins[:tdo]) if @actions[:store]
555
556
  tester.cycle(options)
556
557
  end
557
558
  clear_actions
@@ -665,30 +666,42 @@ module OrigenJTAG
665
666
  tdo
666
667
  end
667
668
 
668
- # Validates that the parent object (the owner) has defined the necessary
669
- # pins to implement the JTAG
670
- def validate_pins(options)
671
- @pins = {}
672
- @pins[:tck] = options[:tck_pin]
673
- @pins[:tdi] = options[:tdi_pin]
674
- @pins[:tdo] = options[:tdo_pin]
675
- @pins[:tms] = options[:tms_pin]
676
-
677
- # Support legacy implementation where tck was incorrectly called tclk, in case of both being
678
- # defined then :tck has priority
679
- @pins[:tck] ||= @owner.pin(:tck) if @owner.has_pin?(:tck)
680
- @pins[:tck] ||= @owner.pin(:tclk)
681
- @pins[:tdi] ||= @owner.pin(:tdi)
682
- @pins[:tdo] ||= @owner.pin(:tdo)
683
- @pins[:tms] ||= @owner.pin(:tms)
669
+ def to_pin(pin_or_id)
670
+ if pin_or_id
671
+ if pin_or_id.is_a?(Symbol) || pin_or_id.is_a?(String)
672
+ @owner.pin(pin_or_id)
673
+ else
674
+ pin_or_id
675
+ end
676
+ end
677
+ end
678
+
679
+ def pins
680
+ @pins ||= begin
681
+ pins = {}
682
+ pins[:tck] = to_pin(@given_options[:tck_pin])
683
+ pins[:tdi] = to_pin(@given_options[:tdi_pin])
684
+ pins[:tdo] = to_pin(@given_options[:tdo_pin])
685
+ pins[:tms] = to_pin(@given_options[:tms_pin])
686
+
687
+ # Support legacy implementation where tck was incorrectly called tclk, in case of both being
688
+ # defined then :tck has priority
689
+ pins[:tck] ||= @owner.pin(:tck) if @owner.has_pin?(:tck)
690
+ pins[:tck] ||= @owner.pin(:tclk)
691
+ pins[:tdi] ||= @owner.pin(:tdi)
692
+ pins[:tdo] ||= @owner.pin(:tdo)
693
+ pins[:tms] ||= @owner.pin(:tms)
694
+
695
+ pins
696
+ end
684
697
  rescue
685
698
  puts 'Missing JTAG pins!'
686
699
  puts "In order to use the JTAG driver your #{owner.class} class must either define"
687
700
  puts 'the following pins (an alias is fine):'
688
701
  puts REQUIRED_PINS
689
702
  puts '-- or --'
690
- puts 'Pass the pins in the initialization options:'
691
- puts "sub_block :jtag, class_name: 'OrigenJTAG::Driver', tck_pin: dut.pin(:tck), tdi_pin: dut.pin(:tdi), tdo_pin: dut.pin(:tdo), tms_pin: dut.pin(:tms)"
703
+ puts 'Pass the pin IDs to be used instead in the initialization options:'
704
+ puts "sub_block :jtag, class_name: 'OrigenJTAG::Driver', tck_pin: :clk, tdi_pin: :gpio1, tdo_pin: :gpio2, tms_pin: :gpio3"
692
705
  raise 'JTAG driver error!'
693
706
  end
694
707
  end
@@ -4,22 +4,22 @@ module OrigenJTAG
4
4
  module TAPController
5
5
  # Map of internal state symbols to human readable names
6
6
  STATES = {
7
- reset: 'Test-Logic-Reset',
8
- idle: 'Run-Test/Idle',
9
- select_dr: 'Select-DR',
10
- capture_dr: 'Capture-DR',
11
- shift_dr: 'Shift-DR',
12
- exit1_dr: 'Exit1-DR',
13
- pause_dr: 'Pause-DR',
14
- exit2_dr: 'Exit2-DR',
15
- update_dr: 'Update-DR',
16
- select_ir: 'Select-IR',
17
- capture_ir: 'Capture-IR',
18
- shift_ir: 'Shift-IR',
19
- exit1_ir: 'Exit1-IR',
20
- pause_ir: 'Pause-IR',
21
- exit2_ir: 'Exit2-IR',
22
- update_ir: 'Update-IR'
7
+ reset: 'Test-Logic-Reset',
8
+ idle: 'Run-Test/Idle',
9
+ select_dr_scan: 'Select-DR-Scan',
10
+ capture_dr: 'Capture-DR',
11
+ shift_dr: 'Shift-DR',
12
+ exit1_dr: 'Exit1-DR',
13
+ pause_dr: 'Pause-DR',
14
+ exit2_dr: 'Exit2-DR',
15
+ update_dr: 'Update-DR',
16
+ select_ir_scan: 'Select-IR-Scan',
17
+ capture_ir: 'Capture-IR',
18
+ shift_ir: 'Shift-IR',
19
+ exit1_ir: 'Exit1-IR',
20
+ pause_ir: 'Pause-IR',
21
+ exit2_ir: 'Exit2-IR',
22
+ update_ir: 'Update-IR'
23
23
  }
24
24
 
25
25
  # Returns the current state of the JTAG TAP Controller
@@ -50,11 +50,27 @@ module OrigenJTAG
50
50
  # end
51
51
  # # State is Run-Test/Idle
52
52
  def shift_dr(options = {})
53
- validate_state(:idle, :pause_dr)
53
+ options = {
54
+ start_state: :idle, # Allowed start states: :idle, :select_dr_scan, :update_ir, :update_dr
55
+ end_state: :idle # Allowed end states: :idle, :update_dr
56
+ }.merge(options)
57
+
58
+ if options[:start_state] == :idle # allow for pause_dr state also if called from pause_dr block
59
+ validate_state(:idle, :pause_dr)
60
+ elsif options[:state_state] == :select_dr_scan
61
+ validate_state(:select_dr_scan, :pause_dr)
62
+ elsif options[:state_state] == :update_dr
63
+ validate_state(:update_dr, :pause_dr)
64
+ elsif options[:state_state] == :update_ir
65
+ validate_state(:update_ir, :pause_dr)
66
+ end
54
67
  log 'Transition to Shift-DR...'
55
- if state == :idle
56
- tms!(1) # => Select-DR-Scan
57
- update_state :select_dr_scan
68
+ if state == :idle || state == :select_dr_scan || state == :update_ir || state == :update_dr
69
+ # Non-pause states
70
+ unless state == :select_dr_scan
71
+ tms!(1) # => Select-DR-Scan
72
+ update_state :select_dr_scan
73
+ end
58
74
  tms!(0) # => Capture-DR
59
75
  update_state :capture_dr
60
76
  tms!(0) # => Shift-DR
@@ -78,8 +94,10 @@ module OrigenJTAG
78
94
  end
79
95
  tms!(1) # => Update-DR
80
96
  update_state :update_dr
81
- tms!(0) # => Run-Test/Idle
82
- update_state :idle
97
+ if options[:end_state] == :idle
98
+ tms!(0) # => Run-Test/Idle
99
+ update_state :idle
100
+ end
83
101
  else # :pause_dr
84
102
  tms!(1) # => Exit2-DR
85
103
  update_state :exit2_dr
@@ -175,13 +193,23 @@ module OrigenJTAG
175
193
  # end
176
194
  # # State is Run-Test/Idle
177
195
  def shift_ir(options = {})
178
- validate_state(:idle, :pause_ir)
196
+ options = {
197
+ start_state: :idle, # Allowed start states: :idle, :select_ir_scan
198
+ end_state: :idle # Allowed end states: :idle, :update_ir, :select_dr_scan
199
+ }.merge(options)
200
+ if options[:start_state] == :idle
201
+ validate_state(:idle, :pause_ir)
202
+ else
203
+ validate_state(:select_ir_scan, :pause_ir)
204
+ end
179
205
  log 'Transition to Shift-IR...'
180
- if state == :idle
181
- tms!(1) # => Select-DR-Scan
182
- update_state :select_dr_scan
183
- tms!(1) # => Select-IR-Scan
184
- update_state :select_ir_scan
206
+ if state == :idle || state == :select_ir_scan
207
+ unless state == :select_ir_scan
208
+ tms!(1) # => Select-DR-Scan
209
+ update_state :select_dr_scan
210
+ tms!(1) # => Select-IR-Scan
211
+ update_state :select_ir_scan
212
+ end
185
213
  tms!(0) # => Capture-IR
186
214
  update_state :capture_ir
187
215
  tms!(0) # => Shift-IR
@@ -195,7 +223,13 @@ module OrigenJTAG
195
223
  end
196
224
  log msg, always: true do
197
225
  yield
198
- log 'Transition to Run-Test/Idle...'
226
+ if options[:end_state] == :idle
227
+ log 'Transition to Run-Test/Idle...'
228
+ elsif options[:end_state] == :update_ir
229
+ log 'Transition to Update-IR...'
230
+ elsif options[:end_state] == :select_dr_scan
231
+ log 'Transition to Select-DR-Scan...'
232
+ end
199
233
  if @last_data_vector_shifted
200
234
  @last_data_vector_shifted = false
201
235
  else
@@ -205,8 +239,13 @@ module OrigenJTAG
205
239
  end
206
240
  tms!(1) # => Update-IR
207
241
  update_state :update_ir
208
- tms!(0) # => Run-Test/Idle
209
- update_state :idle
242
+ if options[:end_state] == :idle
243
+ tms!(0) # => Run-Test/Idle
244
+ update_state :idle
245
+ elsif options[:end_state] == :select_dr_scan
246
+ tms!(1) # => Select-DR-Scan
247
+ update_state :select_dr_scan
248
+ end
210
249
  else # :pause_ir
211
250
  tms!(1) # => Exit2-IR
212
251
  update_state :exit2_ir
@@ -30,7 +30,8 @@ module OrigenJTAGDev
30
30
  instantiate_pins(options)
31
31
  sub_block :jtag, { class_name: 'OrigenJTAG::Driver' }.merge(@jtag_config)
32
32
  if options[:extra_port]
33
- sub_block :jtag2, { class_name: 'OrigenJTAG::Driver', tck_pin: pin(:tck_2), tdi_pin: pin(:tdi_2), tdo_pin: pin(:tdo_2), tms_pin: pin(:tms_2) }.merge(@jtag_config)
33
+ # Test supplying both pin IDs (recommended) and pin objects (legacy)
34
+ sub_block :jtag2, { class_name: 'OrigenJTAG::Driver', tck_pin: :tck_2, tdi_pin: :tdi_2, tdo_pin: pin(:tdo_2), tms_pin: pin(:tms_2) }.merge(@jtag_config)
34
35
  end
35
36
  end
36
37
 
@@ -0,0 +1,26 @@
1
+ Pattern.create do
2
+ def test(msg)
3
+ ss "Test - #{msg}"
4
+ end
5
+
6
+ jtag = $dut.jtag
7
+ reg16 = $dut.reg(:test16)
8
+ reg32 = $dut.reg(:test32)
9
+
10
+
11
+ test 'Shift register into TDI with overlay'
12
+
13
+
14
+ cc 'Full register (16 bits)'
15
+ reg16.overlay('write_overlay16')
16
+ reg16.write!
17
+ # tester.cycle # Give a padding cycle as a place for the subroutine call to go
18
+ # jtag.shift reg, cycle_last: true
19
+
20
+ cc 'Full register with additional size (32 bits)'
21
+ reg32.overlay('write_overlay32')
22
+ reg32.write!
23
+ # tester.cycle # Give a padding cycle as a place for the subroutine call to go
24
+ # jtag.shift reg, cycle_last: true, size: 32
25
+
26
+ end
@@ -193,7 +193,13 @@ Pattern.create(options = { name: pat_name }) do
193
193
 
194
194
  test 'Unless forced'
195
195
  jtag.write_ir 0xF, size: 4, force: true
196
-
196
+
197
+ test 'Write IR, starting with Idle, leave in Select-DR-Scan state'
198
+ jtag.write_ir(0x7, size: 8, end_state: :select_dr_scan, force: true)
199
+
200
+ test 'Write DR starting with Select-DR-Scan state, end with Idle'
201
+ jtag.write_dr(0x12345678, size: 32, start_state: :select_dr_scan)
202
+
197
203
  test 'Reset'
198
204
  jtag.reset
199
205
 
@@ -0,0 +1,56 @@
1
+ Pattern.create do
2
+ def test(msg)
3
+ ss "Test - #{msg}"
4
+ end
5
+
6
+ def subroutine(name, options = {})
7
+ options = {
8
+ compress: false,
9
+ }.merge(options)
10
+
11
+ tester.start_subroutine(name)
12
+ # $tester.set_timeset('intram', 40)
13
+ # $dut.init_pins_for_first_vector
14
+ # $dut.pin(:RESET_B).drive(1)
15
+ # $dut.pin(:JTAG_TRST_B).drive(1)
16
+
17
+
18
+ if options[:compress]
19
+ yield options
20
+ else
21
+ tester.dont_compress do
22
+ yield options
23
+ end
24
+ end
25
+ tester.end_subroutine(options)
26
+ end
27
+ def write_partial(thing_to_shift, options = {})
28
+ options = {
29
+ read: false,
30
+ length: false, # Set to the number of bits you want to shift when supplying a data value
31
+ includes_last_bit: false,
32
+ cycle_last: true
33
+ }.merge(options)
34
+
35
+ dut.jtag.shift thing_to_shift, size: options[:length], cycle_last: options[:cycle_last], includes_last_bit: options[:includes_last_bit], read: options[:read]
36
+ end
37
+
38
+
39
+ jtag = $dut.jtag
40
+ reg16 = $dut.reg(:test16)
41
+ reg32 = $dut.reg(:test32)
42
+
43
+ test 'Shift register into TDI with overlay'
44
+
45
+ subroutine 'write_overlay16' do
46
+ # write_partial(0, length: 16, includes_last_bit: true)
47
+ dut.jtag.shift 0, size: 16, cycle_last: true, includes_last_bit: true, read: false
48
+ end
49
+
50
+ subroutine 'write_overlay32' do
51
+ # write_partial(5, length: 32, includes_last_bit: true)
52
+ dut.jtag.shift 0, size: 32, cycle_last: true, includes_last_bit: false
53
+ end
54
+
55
+
56
+ end
@@ -89,10 +89,10 @@ class MyApp::MyDUT
89
89
  tck_multiple: 2,
90
90
  tdo_strobe: :tck_high,
91
91
  tdo_store_cycle: 1,
92
- tck_pin: pin(:tck2),
93
- tdi_pin: pin(:tdi2),
94
- tdo_pin: pin(:tdo2),
95
- tms_pin: pin(:tms2)
92
+ tck_pin: :tck2,
93
+ tdi_pin: :tdi2,
94
+ tdo_pin: :tdo2,
95
+ tms_pin: :tms2
96
96
  end
97
97
  end
98
98
 
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: origen_jtag
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.21.1
4
+ version: 0.22.2
5
5
  platform: ruby
6
6
  authors:
7
7
  - Stephen McGinty
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2019-04-25 00:00:00.000000000 Z
11
+ date: 2022-04-28 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: origen
@@ -62,8 +62,10 @@ files:
62
62
  - lib/origen_jtag_dev/serial.rb
63
63
  - lib/origen_jtag_dev/top_level.rb
64
64
  - pattern/full_reg_ovly_cap.rb
65
+ - pattern/full_reg_subr_overlay.rb
65
66
  - pattern/global_label_test.rb
66
67
  - pattern/jtag_workout.rb
68
+ - pattern/overlay_subr.rb
67
69
  - pattern/rww_test.rb
68
70
  - pattern/two_port.rb
69
71
  - templates/web/index.md.erb
@@ -89,8 +91,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
89
91
  - !ruby/object:Gem::Version
90
92
  version: 1.8.11
91
93
  requirements: []
92
- rubyforge_project:
93
- rubygems_version: 2.7.7
94
+ rubygems_version: 3.1.4
94
95
  signing_key:
95
96
  specification_version: 4
96
97
  summary: JTAG driver for the Origen SDK