AWS2Exec - .dtors & .fini_array
[AD REMOVED]
.dtors
[!CAUTION] Nowadays is very weird to find a binary with a .dtors section.
The destructors are functions that are executed before program finishes (after the main
function returns).\
The addresses to these functions are stored inside the .dtors
section of the binary and therefore, if you manage to write the address to a shellcode in __DTOR_END__
, that will be executed before the programs ends.
Get the address of this section with:
Usually you will find the DTOR markers between the values ffffffff
and 00000000
. So if you just see those values, it means that there isn't any function registered. So overwrite the 00000000
with the address to the shellcode to execute it.
[!WARNING] Ofc, you first need to find a place to store the shellcode in order to later call it.
.fini_array
Essentially this is a structure with functions that will be called before the program finishes, like .dtors
. This is interesting if you can call your shellcode just jumping to an address, or in cases where you need to go back to main
again to exploit the vulnerability a second time.
objdump -s -j .fini_array ./greeting
./greeting: file format elf32-i386
Contents of section .fini_array:
8049934 a0850408
#Put your address in 0x8049934
Note that this won't create an eternal loop because when you get back to main the canary will notice, the end of the stack might be corrupted and the function won't be recalled again. So with this you will be able to have 1 more execution of the vuln.
[!CAUTION] Note that with Full RELRO, the section
.fini_array
is made read-only.
[AD REMOVED]