任何人都可以参考va_listx86_64 ABI(在Linux上使用的)的表示形式?我正在尝试调试一些代码,这些代码中的堆栈或参数似乎已损坏,这确实有助于理解我 应该 看到的内容…
va_list
我发表了评论。
这可能会有所帮助。这是一个参考,尽管很轻巧( 编辑 :原始链接已失效;已替换Wayback Machine保留的链接)。
变量参数列表参考从第50页开始,然后在第52-53页的文档中继续va_list:
va_list类型 va_list类型是一个数组,其中包含一个结构的单个元素,该结构包含实现va_arg宏所需的信息。va_list类型的C定义在图3.34中给出
va_list类型
va_list类型是一个数组,其中包含一个结构的单个元素,该结构包含实现va_arg宏所需的信息。va_list类型的C定义在图3.34中给出
// Figure 3.34 typedef struct { unsigned int gp_offset; unsigned int fp_offset; void *overflow_arg_area; void *reg_save_area; } va_list[1];
va_start宏 va_start宏按如下所示初始化结构: reg_save_area 该元素指向寄存器保存区的开始。 overflow_arg_area该指针用于获取在堆栈上传递的参数。它使用在堆栈上传递的第一个参数的地址(如果有的话)进行初始化,然后始终更新以指向堆栈上下一个参数的开头。 gp_offset该元素保存从reg_save_area到保存下一个可用的通用参数寄存器的位置的字节偏移量。如果所有参数寄存器都已用尽,则将其设置为值48(6 * 8)。 fp_offset该元素保存从reg_save_area到保存下一个可用浮动点自变量寄存器的位置的字节偏移量。如果所有参数寄存器都已用尽,则将其设置为值304(6 * 8 + 16 * 16)。
va_start宏
va_start宏按如下所示初始化结构:
reg_save_area 该元素指向寄存器保存区的开始。
reg_save_area
overflow_arg_area该指针用于获取在堆栈上传递的参数。它使用在堆栈上传递的第一个参数的地址(如果有的话)进行初始化,然后始终更新以指向堆栈上下一个参数的开头。
overflow_arg_area
gp_offset该元素保存从reg_save_area到保存下一个可用的通用参数寄存器的位置的字节偏移量。如果所有参数寄存器都已用尽,则将其设置为值48(6 * 8)。
gp_offset
fp_offset该元素保存从reg_save_area到保存下一个可用浮动点自变量寄存器的位置的字节偏移量。如果所有参数寄存器都已用尽,则将其设置为值304(6 * 8 + 16 * 16)。
fp_offset