Printing “array” from .bss in gdb

后端 未结 3 588
眼角桃花
眼角桃花 2021-01-19 10:08

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         


        
相关标签:
3条回答
  • 2021-01-19 10:43

    ARM example

    x86 should be analogous:

    .data:
    a1:
        .float 0.0, 0.1, 0.2, 0.3
    a2:
        .word 1, 2, 3, 4
    .text
        /* Register r1 contains the address of a1. */
        ldr r1, =a1
        ldr r2, =a2
    

    GDB session:

    (gdb) p (float[4])a1
    $1 = {0, 0.100000001, 0.200000003, 0.300000012}
    (gdb) p (int[4])a2
    $2 = {1, 2, 3, 4}
    (gdb) p (float[4])*$r1
    $5 = {0, 0.100000001, 0.200000003, 0.300000012}
    (gdb) p (int[4])*$r2
    $7 = {1, 2, 3, 4}
    

    Tested on GDB 8.1, Ubuntu 18.04.

    0 讨论(0)
  • 2021-01-19 10:51

    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].

    0 讨论(0)
  • 2021-01-19 10:54

    ; 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
    
    0 讨论(0)
提交回复
热议问题