[英]How to fix getting “sigsegv” when trying to debug a simple nasm assembly program
[英]how to debug an NASM assembly program requiring user input?
我将逐步学习 jeff令人惊叹的书籍汇编 ,并且在第8章中,他展示了一个汇编程序示例,该示例以这种方式从用户那里获取文件:
SECTION .bss ; Section containing uninitialized data
BUFFLEN equ 1024 ; Length of buffer
Buff: resb BUFFLEN ; Text buffer itself
它将文件文本读取到Buff
,并将所有大写形式的文本版本输出到另一个文件。
我想在调试模式下运行该程序以逐步执行它,以分析所有寄存器发生的情况。
我用INSIGHT在ubuntu上运行它。
我是一个完整的初学者。 我知道如何使用Insight进行操作,但是用户运行此程序的方式是:
myProgram > outputfile.txt < inputfile.txt
我如何在调试器中模仿它?
这是完整的源代码:
; Executable name : uppercaser2
; Version : 1.0
; Created date : 3/25/2009
; Last update : 3/25/2009
; Author : Jeff Duntemann
; Description : A simple program in assembly for Linux, using NASM 2.05,
; demonstrating simple text file I/O (through redirection) for reading an
; input file to a buffer in blocks, forcing lowercase characters to
; uppercase, and writing the modified buffer to an output file.
;
; Run it this way:
; uppercaser2 > (output file) < (input file)
;
; Build using these commands:
; nasm -f elf -g -F stabs uppercaser2.asm
; ld -o uppercaser2 uppercaser2.o
;
SECTION .bss ; Section containing uninitialized data
BUFFLEN equ 1024 ; Length of buffer
Buff: resb BUFFLEN ; Text buffer itself
SECTION .data ; Section containing initialised data
SECTION .text ; Section containing code
global _start ; Linker needs this to find the entry point!
_start:
nop ; This no-op keeps gdb happy...
; Read a buffer full of text from stdin:
read:
mov eax,3 ; Specify sys_read call
mov ebx,0 ; Specify File Descriptor 0: Standard Input
mov ecx,Buff ; Pass offset of the buffer to read to
mov edx,BUFFLEN ; Pass number of bytes to read at one pass
int 80h ; Call sys_read to fill the buffer
mov esi,eax ; Copy sys_read return value for safekeeping
cmp eax,0 ; If eax=0, sys_read reached EOF on stdin
je Done ; Jump If Equal (to 0, from compare)
; Set up the registers for the process buffer step:
mov ecx,esi ; Place the number of bytes read into ecx
mov ebp,Buff ; Place address of buffer into ebp
dec ebp ; Adjust count to offset
; Go through the buffer and convert lowercase to uppercase characters:
Scan:
cmp byte [ebp+ecx],61h ; Test input char against lowercase 'a'
jb Next ; If below 'a' in ASCII, not lowercase
cmp byte [ebp+ecx],7Ah ; Test input char against lowercase 'z'
ja Next ; If above 'z' in ASCII, not lowercase
; At this point, we have a lowercase char
sub byte [ebp+ecx],20h ; Subtract 20h to give uppercase...
Next: dec ecx ; Decrement counter
jnz Scan ; If characters remain, loop back
; Write the buffer full of processed text to stdout:
Write:
mov eax,4 ; Specify sys_write call
mov ebx,1 ; Specify File Descriptor 1: Standard output
mov ecx,Buff ; Pass offset of the buffer
mov edx,esi ; Pass the # of bytes of data in the buffer
int 80h ; Make kernel call
jmp read ; Loop back and load another buffer full
; All done! Let's end this party:
Done:
mov eax,1 ; Code for Exit Syscall
mov ebx,0 ; Return a code of zero
int 80H ; Make kernel call
听起来您想将流程附加到GDB。 你可以试试看。
shell$ gdb ./uppercaser2
gdb> list
gdb> break read
gdb> run > ouput.txt < input.txt
gdb> x/5i $eip
在shell提示符下,启动GDB并将uppercaser2附加到GDB。 调试符号应已加载,您可以使用列表进行检查以显示源。 通过行号或函数名称在所需位置创建一个断点。 使用GDB的运行以输入和输出文件启动程序。 在这里,您可以使用GDB命令分析寄存器并逐步访问内存。
在运行命令中,您可以这样设置用户输入:
shell$ gdb ./executable
gdb> break main
gdb> run user input
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.