簡體   English   中英

鏈表不能在所有遞歸函數調用中保留值?

[英]Linked List not retaining values across recursive function calls?

我正在嘗試實現一個鏈表,該鏈表在遇到調用/返回裝配指令時會存儲一個內存地址。 通過解析程序集的每一行,並且僅在遇到調用或返回指令時才中斷該函數,才能以遞歸方式工作。 到目前為止,這對調用指令有效,這意味着將返回地址保存在鏈表中的一個節點上,但是當嘗試在返回指令期間檢索此值時,數據丟失了(意味着鏈表現在為空)。 這是我正在使用的:

struct ret_addr {
    int address;
    struct ret_addr *nxt;
};

struct ret_addr *ret_data(cs_insn *insn, struct ret_addr **head) {
    struct ret_addr *r = malloc(sizeof(*r));
    r->address = insn->address + insn->size;
    r->nxt = (*head);
    (*head) = r;
    return r;
}

struct bb_data *disassemble_function_cfg(int startAddr, unsigned char *bytes, int end_section) {
    csh handle;
    cs_insn *insn;
    cs_detail *detail;
    cs_x86 *x86;
    size_t count;
    int stop_disasm = 0;
    struct bb_data *edges = NULL;
    struct ret_addr *ret_edge = NULL;

    count = cs_disasm(handle, bytes, end_section, startAddr, 1, &insn);

    detail = insn->detail;
    for(int n = 0; n < detail->groups_count; n++) {

        //break when encountering a call instruction
        if(detail->groups[n] == X86_GRP_CALL) {
            stop_disasm = 1;
            vector_new(edges);
            edges = call_insn(handle, x86, insn, vector_back(edges));
            ret_edge = ret_data(insn, &ret_edge);
        }

        //break when encountering a return instruction
        else if(detail->groups[n] == X86_GRP_RET) {
            stop_disasm = 1;
            vector_new(edges);
            edges = ret_insn(insn, edges, &ret_edge);
        }

    }

    if(!stop_disasm) {
        disassemble_function_cfg(insn->address + insn->size, bytes + insn->size, end_section);
    }
    else {
        return edges;
    }
}

您不會在遞歸調用之間保留列表。 您可能想做什么:

struct bb_data *disassemble_function_cfg(struct ret_addr **ret_edge, int startAddr, unsigned char *bytes, int end_section)
{
   ...
   if(*ret_edge == NULL) *ret_edge = ret_data(insn, ret_edge);
   ...
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM