Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Printing "array" from .bss in gdb

my nasm x86 assembly code contains the following:

; The code should mimic the following C-code:
; int a[10];
; for (int i = 0; i < 10; i++){
;    a[i] = i;
; }

SECTION .data
    arraylen dd 10
SECTION .bss
    array RESD 10
SECTION .text
    global main
main:
    mov ecx, 0
    mov eax, 0
loop:
    inc ecx
    mov dword [array+eax*4], ecx
    inc eax
    cmp ecx, arraylen
    jl loop
end:
    mov ebx, 0
    mov eax, 1
    int 0x80

Now what i want is to check whether this code works in gdb. However, how do i print array?

print array only returns the $1 = 1.

print array + X unfortunately is an arithmetical operation, i.e. e.g. print array + 50 actually prints 1+50 = 51 and not the non-existent 51st array element.

like image 531
Alex Avatar asked Feb 10 '23 04:02

Alex


2 Answers

You can do:

(gdb) x/10 &array
0x8049618:      1       2       3       4
0x8049628:      5       6       7       8
0x8049638:      9       10

PS: Your code is broken, you need cmp ecx, [arraylen].

like image 159
Jester Avatar answered Feb 14 '23 23:02

Jester


; The code should mimic the following C-code:

In addition to wrong boundary noted by Jester, you also have the wrong initialization: your code is equivalent to:

 for (int i = 0; i < 10; i++) {
   a[i] = i + 1;  // different from stated goal of "a[i] = i;"
 }

However, how do i print array?

This is no different from printing array in C, when the source is compiled without debug info:

(gdb) p array
$1 = 0

(gdb) p {int[10]}&array
$2 = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9}

print array + X unfortunately is an arithmetical operation

You can then use:

(gdb) p $2[4]
$3 = 4
like image 32
Employed Russian Avatar answered Feb 15 '23 01:02

Employed Russian