Index: source/Expression/IRExecutionUnit.cpp =================================================================== --- source/Expression/IRExecutionUnit.cpp +++ source/Expression/IRExecutionUnit.cpp @@ -796,27 +796,28 @@ sc_list.GetContextAtIndex(si, candidate_sc); - const bool is_external = (candidate_sc.function) || - (candidate_sc.symbol && candidate_sc.symbol->IsExternal()); + if (candidate_sc.symbol) + { - load_address = candidate_sc.symbol->ResolveCallableAddress(*target); + load_address = candidate_sc.symbol->ResolveCallableAddress(*target); - if (load_address == LLDB_INVALID_ADDRESS) - if (target->GetProcessSP()) - load_address = candidate_sc.symbol->GetAddress().GetLoadAddress(target); - else - load_address = candidate_sc.symbol->GetAddress().GetFileAddress(); + if (load_address == LLDB_INVALID_ADDRESS) + if (target->GetProcessSP()) + load_address = candidate_sc.symbol->GetAddress().GetLoadAddress(target); + else + load_address = candidate_sc.symbol->GetAddress().GetFileAddress(); - if (load_address != LLDB_INVALID_ADDRESS) - { - if (is_external) - { - return true; - } - else if (best_internal_load_address == LLDB_INVALID_ADDRESS) + if (load_address != LLDB_INVALID_ADDRESS) { - best_internal_load_address = load_address; - load_address = LLDB_INVALID_ADDRESS; + if (candidate_sc.function || candidate_sc.symbol->IsExternal()) + { + return true; + } + else if (best_internal_load_address == LLDB_INVALID_ADDRESS) + { + best_internal_load_address = load_address; + load_address = LLDB_INVALID_ADDRESS; + } } } }