1
0
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:
Michael Specht 2018-02-15 21:16:45 +01:00
parent 1ff45ca1aa
commit 8756f8f5fe
3 changed files with 28 additions and 25 deletions

View File

@ -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,

View File

@ -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;

View File

@ -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