Anyone have a reference for the representation of va_list in the x86_64 ABI (the one used on Linux)? I'm trying to debug some code where the stack or arguments seem corrupt and it would really help to understand what I'm supposed to be seeing...
va_list is a complete object type suitable for holding the information needed by the macros va_start, va_copy, va_arg, and va_end. If a va_list instance is created, passed to another function, and used via va_arg in that function, then any subsequent use in the calling function should be preceded by a call to va_end.
fp_offset The element holds the offset in bytes from reg_save_area to the place where the next available floating point argument register is saved. In case all argument registers have been exhausted, it is set to the value 304 (6 * 8 + 16 * 16).
How va_list is defined is entirely up to your compiler, operating system and ABI. On some operating systems it can be defined by a struct or even a simple pointer to something, on others it is just internal compiler black magic that can't be expressed with a C struct.
The x86-64 System V ABi doc may help. It's a reference, albeit lightweight.
The Variable Argument List reference starts on page 54, then it goes on, page 56-57 documents va_list:
The
va_listTypeThe
va_listtype is an array containing a single element of one structure containing the necessary information to implement theva_argmacro. The C definition ofva_listtype is given in figure 3.34.Figure 3.34:
va_listType Declarationtypedef struct { unsigned int gp_offset; unsigned int fp_offset; void *overflow_arg_area; void *reg_save_area; } va_list[1];The
va_startMacroThe
va_startmacro initializes the structure as follows:
reg_save_areaThe element points to the start of the register save area.
overflow_arg_areaThis pointer is used to fetch arguments passed on the stack. It is initialized with the address of the first argument passed on the stack, if any, and then always updated to point to the start of the next argument on the stack.
gp_offsetThe element holds the offset in bytes fromreg_save_areato the place where the next available general purpose argument register is saved. In case all argument registers have been exhausted, it is set to the value 48 (6 * 8).
fp_offsetThe element holds the offset in bytes fromreg_save_areato the place where the next available floating point argument register is saved. In case all argument registers have been exhausted, it is set to the value 304 (6 * 8 + 16 * 16).
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With