Data Representation | Program Representation | |||||
| string int x[3] char x 0x9cd0f0ad 01101011 |
![]() |
Objects Arrays Primitive types Addresses bits |
Java code C++ code C code x86 code IBCM hexadecimal |
![]() |
High-level language Low-level language Assembly language Machine code |
|
|
|
|
Directives
|
|
|
Incorrect: (why?)
|
|
Memory:
| |||||||||||||||||||||||||||||||||||||||||||||||
C/C++ code: |
Assembly code: |
This is just before the call opcode is invoked.
| ↑ | value of rdi | ← rsp | ||
| To higher addresses | ||||
| (to 0xffffffff) | ||||
| To lower addresses | ||||
| (to 0x00000000) | ||||
| ↓ |
This is just after the call opcode is invoked.
| ↑ | value of rdi | |||
| To higher addresses | return address | ← rsp | ||
| (to 0xffffffff) | ||||
| To lower addresses | ||||
| (to 0x00000000) | ||||
| ↓ |
THEN, perform body of the function
This is just after the caller invokes the call opcode.
| ↑ | value of rdi | |||
| To higher addresses | return address | ← rsp | ||
| (to 0xffffffff) | ||||
| To lower addresses | ||||
| (to 0x00000000) | ||||
| ↓ |
This is just after the callee invokes the sub rsp, 8 opcode.
| ↑ | value of rdi | |||
| To higher addresses | return address | |||
| (to 0xffffffff) | local var (result) | ← rsp | ||
| To lower addresses | ||||
| (to 0x00000000) | ||||
| ↓ |
This is after the myFunc() prologue is completed.
| ↑ | value of rdi | |||
| To higher addresses | return address | |||
| (to 0xffffffff) | local var (result) | ← [rsp+16] | ||
| value of rbx | ← [rsp+8] | |||
| value of rbp | ← [rsp] | |||
| To lower addresses | ||||
| (to 0x00000000) | ||||
| ↓ |
|
|
||||||||||||||||||||||||||||||||||||||||
|
|
void security_hole() {
char buffer[12];
scanf ("%s", buffer); // how C handles input
}
The stack looks like (with sizes in parenthesis):
| rsi (8) | rdi (8) | buffer (12) | ret addr (8) |