origen_jtag 0.22.1 → 0.22.3

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: f2fc35840e8e533688ae4f9228d3136022e8ce7d117452d91d48a8b782bc2e5c
4
- data.tar.gz: e55c4dfebaa955af749c9219f7585c34568fe28fa2c976e4f75f6050278a43b7
3
+ metadata.gz: 1e408b1d8688221c536224742008b1e8816f175f7204a042f6227cfc92a3c938
4
+ data.tar.gz: 8038f326e6d212978e7f21404319b1178c89d3ee12a01fca74f5abbaa0b9536e
5
5
  SHA512:
6
- metadata.gz: 3f7a129c33e581c1e8eeaf7d4ffd2c2a9722f91f15ed95139565a5d88a2bed9ff83c22a35a0ee34b12737f6348cd7c0455e067309f933eb9d3e0b74a269e9963
7
- data.tar.gz: 0b97667c90159cddee69b72bb84819468ebf17767be8c47b3ce59301be6a15783b10c7f039c44950b3cc2217016baa4b488fe181a89f9d47b3a6a486fa12bfbd
6
+ metadata.gz: db3581cd8d7d7cababf02df48b7f8e3ad7478f657c9c88e8db68e7de88fa95693c107a06e0bc1bf6b7ad7bb0d4d47009283de60744d921db03a36f20347e4b3e
7
+ data.tar.gz: fa0a8fa73da0f59d2ea3f4fd23a352022b8498c925c901709b7fcc41ac18bc77ce8992aacb4a842eebfaf5803f11e729052d073775abad31eaf3bc3649dbbcfd
data/config/version.rb CHANGED
@@ -1,7 +1,7 @@
1
1
  module OrigenJTAG
2
2
  MAJOR = 0
3
3
  MINOR = 22
4
- BUGFIX = 1
4
+ BUGFIX = 3
5
5
  DEV = nil
6
6
  VERSION = [MAJOR, MINOR, BUGFIX].join(".") + (DEV ? ".pre#{DEV}" : '')
7
7
  end
@@ -416,7 +416,7 @@ module OrigenJTAG
416
416
  cc "#{options[:msg]}\n"
417
417
  end
418
418
  val = reg_or_val.respond_to?(:data) ? reg_or_val.data : reg_or_val
419
- shift_dr(write: val.to_hex) do
419
+ shift_dr(options.merge(write: val.to_hex)) do
420
420
  shift(reg_or_val, options)
421
421
  end
422
422
  end
@@ -449,7 +449,7 @@ module OrigenJTAG
449
449
  if options[:msg]
450
450
  cc "#{options[:msg]}\n"
451
451
  end
452
- 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
453
453
  shift(reg_or_val, options)
454
454
  end
455
455
  end
@@ -484,7 +484,7 @@ module OrigenJTAG
484
484
  if Origen.tester.respond_to?(:write_ir)
485
485
  Origen.tester.write_ir(reg_or_val, options)
486
486
  else
487
- shift_ir(write: val.to_hex) do
487
+ shift_ir(options.merge(write: val.to_hex)) do
488
488
  shift(reg_or_val, options)
489
489
  end
490
490
  end
@@ -568,7 +568,7 @@ module OrigenJTAG
568
568
  def extract_size(reg_or_val, options = {})
569
569
  size = options[:size]
570
570
  unless size
571
- if reg_or_val.is_a?(Fixnum) || !reg_or_val.respond_to?(:size)
571
+ if reg_or_val.is_a?(Integer) || !reg_or_val.respond_to?(:size)
572
572
  fail 'When suppling a value to JTAG::Driver#shift you must supply a :size in the options!'
573
573
  else
574
574
  size = reg_or_val.size
@@ -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
@@ -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
 
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.22.1
4
+ version: 0.22.3
5
5
  platform: ruby
6
6
  authors:
7
7
  - Stephen McGinty
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2020-02-03 00:00:00.000000000 Z
11
+ date: 2024-01-03 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: origen
@@ -89,8 +89,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
89
89
  - !ruby/object:Gem::Version
90
90
  version: 1.8.11
91
91
  requirements: []
92
- rubyforge_project:
93
- rubygems_version: 2.7.7
92
+ rubygems_version: 3.1.4
94
93
  signing_key:
95
94
  specification_version: 4
96
95
  summary: JTAG driver for the Origen SDK