mirror of
https://github.com/specht/champ.git
synced 2025-01-19 17:29:54 +00:00
added time series for one-dimensional watches
This commit is contained in:
parent
1ff45ca1aa
commit
8756f8f5fe
29
champ.rb
29
champ.rb
@ -172,6 +172,7 @@ class Champ
|
|||||||
frame_cycles = []
|
frame_cycles = []
|
||||||
@cycles_per_function = {}
|
@cycles_per_function = {}
|
||||||
@calls_per_function = {}
|
@calls_per_function = {}
|
||||||
|
@max_cycle_count = 0
|
||||||
call_stack = []
|
call_stack = []
|
||||||
last_call_stack_cycles = 0
|
last_call_stack_cycles = 0
|
||||||
Open3.popen2("./p65c02 #{@record_frames ? '' : '--no-screen'} --hide-log --start-pc #{start_pc} #{File.join(temp_dir, 'disk_image')}") do |stdin, stdout, thread|
|
Open3.popen2("./p65c02 #{@record_frames ? '' : '--no-screen'} --hide-log --start-pc #{start_pc} #{File.join(temp_dir, 'disk_image')}") do |stdin, stdout, thread|
|
||||||
@ -193,6 +194,7 @@ class Champ
|
|||||||
if parts.first == 'jsr'
|
if parts.first == 'jsr'
|
||||||
pc = parts[1].to_i(16)
|
pc = parts[1].to_i(16)
|
||||||
cycles = parts[2].to_i
|
cycles = parts[2].to_i
|
||||||
|
@max_cycle_count = cycles
|
||||||
@calls_per_function[pc] ||= 0
|
@calls_per_function[pc] ||= 0
|
||||||
@calls_per_function[pc] += 1
|
@calls_per_function[pc] += 1
|
||||||
unless call_stack.empty?
|
unless call_stack.empty?
|
||||||
@ -203,6 +205,7 @@ class Champ
|
|||||||
call_stack << pc
|
call_stack << pc
|
||||||
elsif parts.first == 'rts'
|
elsif parts.first == 'rts'
|
||||||
cycles = parts[1].to_i
|
cycles = parts[1].to_i
|
||||||
|
@max_cycle_count = cycles
|
||||||
unless call_stack.empty?
|
unless call_stack.empty?
|
||||||
@cycles_per_function[call_stack.last] ||= 0
|
@cycles_per_function[call_stack.last] ||= 0
|
||||||
@cycles_per_function[call_stack.last] += cycles - last_call_stack_cycles
|
@cycles_per_function[call_stack.last] += cycles - last_call_stack_cycles
|
||||||
@ -211,14 +214,18 @@ class Champ
|
|||||||
call_stack.pop
|
call_stack.pop
|
||||||
elsif parts.first == 'watch'
|
elsif parts.first == 'watch'
|
||||||
watch_index = parts[2].to_i
|
watch_index = parts[2].to_i
|
||||||
|
cycles = parts[3].to_i
|
||||||
|
@max_cycle_count = cycles
|
||||||
@watch_called_from_subroutine[watch_index] ||= Set.new()
|
@watch_called_from_subroutine[watch_index] ||= Set.new()
|
||||||
@watch_called_from_subroutine[watch_index] << parts[1].to_i(16)
|
@watch_called_from_subroutine[watch_index] << parts[1].to_i(16)
|
||||||
@watch_values[watch_index] ||= []
|
@watch_values[watch_index] ||= []
|
||||||
@watch_values[watch_index] << parts[3, parts.size - 3].map { |x| x.to_i }
|
watch_value_tuple = parts[4, parts.size - 4].map { |x| x.to_i }
|
||||||
|
@watch_values[watch_index] << {:tuple => watch_value_tuple, :cycles => cycles}
|
||||||
elsif parts.first == 'screen'
|
elsif parts.first == 'screen'
|
||||||
@frame_count += 1
|
@frame_count += 1
|
||||||
print "\rFrames: #{@frame_count}, Cycles: #{cycle_count}"
|
print "\rFrames: #{@frame_count}, Cycles: #{cycle_count}"
|
||||||
this_frame_cycles = parts[1].to_i
|
this_frame_cycles = parts[1].to_i
|
||||||
|
@max_cycle_count = this_frame_cycles
|
||||||
frame_cycles << this_frame_cycles
|
frame_cycles << this_frame_cycles
|
||||||
if @record_frames
|
if @record_frames
|
||||||
data = parts[2, parts.size - 2].map { |x| x.to_i }
|
data = parts[2, parts.size - 2].map { |x| x.to_i }
|
||||||
@ -240,6 +247,7 @@ class Champ
|
|||||||
end
|
end
|
||||||
elsif parts.first == 'cycles'
|
elsif parts.first == 'cycles'
|
||||||
cycle_count = parts[1].to_i
|
cycle_count = parts[1].to_i
|
||||||
|
@max_cycle_count = cycle_count
|
||||||
print "\rFrames: #{@frame_count}, Cycles: #{cycle_count}"
|
print "\rFrames: #{@frame_count}, Cycles: #{cycle_count}"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -335,7 +343,10 @@ class Champ
|
|||||||
]
|
]
|
||||||
@watch_values[index].each do |item|
|
@watch_values[index].each do |item|
|
||||||
normalized_item = []
|
normalized_item = []
|
||||||
item.each.with_index do |x, i|
|
if item[:tuple].size == 1
|
||||||
|
normalized_item << (item[:cycles] * 255 / @max_cycle_count).to_i
|
||||||
|
end
|
||||||
|
item[:tuple].each.with_index do |x, i|
|
||||||
if watch[:components][i][:type] == 's8'
|
if watch[:components][i][:type] == 's8'
|
||||||
x += 128
|
x += 128
|
||||||
elsif watch[:components][i][:type] == 'u16'
|
elsif watch[:components][i][:type] == 'u16'
|
||||||
@ -352,7 +363,7 @@ class Champ
|
|||||||
|
|
||||||
histogram_max = histogram.values.max
|
histogram_max = histogram.values.max
|
||||||
width = 276
|
width = 276
|
||||||
height = (watch[:components].size == 1) ? 158 : 286
|
height = (watch[:components].size == 1) ? 286 : 286
|
||||||
canvas_top = 20
|
canvas_top = 20
|
||||||
canvas_left = 40
|
canvas_left = 40
|
||||||
canvas_width = width - 60
|
canvas_width = width - 60
|
||||||
@ -364,13 +375,6 @@ class Champ
|
|||||||
y = (((key ^ 0xff) >> 8) & 0xff)
|
y = (((key ^ 0xff) >> 8) & 0xff)
|
||||||
x = (x * canvas_width) / 255 + canvas_left
|
x = (x * canvas_width) / 255 + canvas_left
|
||||||
y = (y * canvas_height) / 255 + canvas_top
|
y = (y * canvas_height) / 255 + canvas_top
|
||||||
ymin = y
|
|
||||||
ymax = y
|
|
||||||
if watch[:components].size == 1
|
|
||||||
ymin = canvas_top + canvas_height - 1 - (value.to_f * (canvas_height - 1) / histogram_max).to_i
|
|
||||||
ymax = canvas_top + canvas_height - 1
|
|
||||||
end
|
|
||||||
(ymin..ymax).each do |y|
|
|
||||||
(0..6).each do |dy|
|
(0..6).each do |dy|
|
||||||
py = y + dy - 3
|
py = y + dy - 3
|
||||||
if py >= 0 && py < height
|
if py >= 0 && py < height
|
||||||
@ -384,7 +388,6 @@ class Champ
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
|
||||||
pixels[y * width + x] = (((value.to_f / histogram_max) ** 0.5) * 63).to_i
|
pixels[y * width + x] = (((value.to_f / histogram_max) ** 0.5) * 63).to_i
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -418,7 +421,7 @@ class Champ
|
|||||||
end
|
end
|
||||||
labels.each do |label|
|
labels.each do |label|
|
||||||
s = label[1]
|
s = label[1]
|
||||||
if component_index == 0
|
if component_index == 0 && watch[:components].size == 2
|
||||||
x = (label[0] * canvas_width).to_i + canvas_left
|
x = (label[0] * canvas_width).to_i + canvas_left
|
||||||
print_s(pixels, width, height,
|
print_s(pixels, width, height,
|
||||||
(x - s.size * (6 * label[0])).to_i,
|
(x - s.size * (6 * label[0])).to_i,
|
||||||
@ -437,7 +440,7 @@ class Champ
|
|||||||
end
|
end
|
||||||
(0..1).each do |offset|
|
(0..1).each do |offset|
|
||||||
component_label = component[:name]
|
component_label = component[:name]
|
||||||
if component_index == 0
|
if component_index == 0 && watch[:components].size == 2
|
||||||
print_s(pixels, width, height,
|
print_s(pixels, width, height,
|
||||||
(canvas_left + canvas_width * 0.5 - component_label.size * 3 + offset).to_i,
|
(canvas_left + canvas_width * 0.5 - component_label.size * 3 + offset).to_i,
|
||||||
canvas_top + canvas_height + 18,
|
canvas_top + canvas_height + 18,
|
||||||
|
4
p65c02.c
4
p65c02.c
@ -1003,10 +1003,10 @@ void handle_watch(uint16_t pc, uint8_t post)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (old_index == -1)
|
if (old_index == -1)
|
||||||
printf("watch 0x%04x %d", watch_in_subroutine, watch->index);
|
printf("watch 0x%04x %d %d", watch_in_subroutine, watch->index, cpu.total_cycles);
|
||||||
else
|
else
|
||||||
if (old_index != watch->index)
|
if (old_index != watch->index)
|
||||||
printf("\nwatch 0x%04x %d", watch_in_subroutine, watch->index);
|
printf("\nwatch 0x%04x %d %d", watch_in_subroutine, watch->index, cpu.total_cycles);
|
||||||
|
|
||||||
old_index = watch->index;
|
old_index = watch->index;
|
||||||
int32_t value = 0;
|
int32_t value = 0;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
load:
|
load:
|
||||||
0x6000: plot3d/plot3d242.s
|
0x6000: plot3d/plot3d242c.s
|
||||||
0x1200: plot3d/multtab.s
|
0x1200: plot3d/multtab.s
|
||||||
0x8400: plot3d/ldrwtab.s
|
0x8400: plot3d/ldrwtab.s
|
||||||
0x8900: plot3d/SINETABLE
|
0x8900: plot3d/SINETABLE
|
||||||
|
Loading…
x
Reference in New Issue
Block a user