new Vim convenience macro
Runs test under cursor and opens its trace.
This commit is contained in:
parent
f47066a7c2
commit
5ac0786623
|
@ -0,0 +1,7 @@
|
|||
#!/usr/bin/env zsh
|
||||
|
||||
export TEST_NAME=$2
|
||||
envsubst '$TEST_NAME' < run_one_test.subx > /tmp/run_one_test.subx
|
||||
|
||||
subx --debug translate [0-9]*.subx apps/subx-common.subx $1 /tmp/run_one_test.subx -o /tmp/a.elf
|
||||
subx --debug --trace run /tmp/a.elf
|
|
@ -0,0 +1,30 @@
|
|||
# run a single test
|
||||
|
||||
== code
|
||||
# instruction effective address register displacement immediate
|
||||
# . op subop mod rm32 base index scale r32
|
||||
# . 1-3 bytes 3 bits 2 bits 3 bits 3 bits 3 bits 2 bits 2 bits 0/1/2/4 bytes 0/1/2/4 bytes
|
||||
|
||||
Entry:
|
||||
# Heap = new-segment(64KB)
|
||||
# . . push args
|
||||
68/push Heap/imm32
|
||||
68/push 0x10000/imm32/64KB
|
||||
# . . call
|
||||
e8/call new-segment/disp32
|
||||
# . . discard args
|
||||
81 0/subop/add 3/mod/direct 4/rm32/ESP . . . . . 8/imm32 # add to ESP
|
||||
# initialize-trace-stream(256KB)
|
||||
# . . push args
|
||||
68/push 0x40000/imm32/256KB
|
||||
# . . call
|
||||
e8/call initialize-trace-stream/disp32
|
||||
# . . discard args
|
||||
81 0/subop/add 3/mod/direct 4/rm32/ESP . . . . . 4/imm32 # add to ESP
|
||||
# for debugging: run a single test
|
||||
e8/call $TEST_NAME/disp32
|
||||
8b/copy 0/mod/indirect 5/rm32/.disp32 . . 3/r32/EBX Num-test-failures/disp32 # copy *Num-test-failures to EBX
|
||||
b8/copy-to-EAX 1/imm32/exit
|
||||
cd/syscall 0x80/imm8
|
||||
|
||||
# . . vim:nowrap:textwidth=0
|
|
@ -76,3 +76,6 @@ endif
|
|||
" see https://github.com/akkartik/mu/blob/master/subx/Readme.md#a-few-hints-for-debugging
|
||||
" the '-a' is because traces can sometimes contain unprintable characters that bother grep
|
||||
command! -nargs=0 L exec "%!grep -a label |grep -v clear-stream:loop"
|
||||
|
||||
" run test cursor around cursor, then bring up its trace in a split window
|
||||
noremap <Leader>t {j0:exec "!run_one_test.sh ".expand("%")." <C-R><C-W>"<CR>:vert split last_run<CR><C-w>p<C-o>
|
||||
|
|
Loading…
Reference in New Issue