- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何通过 DWARF 的引用获取我的变量地址?
例如我们有下一个结构:
struct sub_struct
{
int a, b;
sub_struct(int a, int b) : a(a), b(b) {}
}
struct main_struct
{
sub_struct & as_ref;
int c, d;
main_struct(sub_struct & ss) : as_ref(ss), c(0x100), d(0x101) {}
}
之后我们在全局环境中初始化这个结构:
sub_struct test_sub(0x10, 0x11);
main_struct test_inst(sub_struct);
在实践中,test_inst.as_ref 应该引用结构test_sub。我想获取存储在 as_ref 引用中的变量的位置。
如果我读取编译代码的 dwarf 文件,那么我将得到我创建的结构:
Compilation Unit @ offset 0x1a80bf:
Length: 0x11e (32-bit)
Version: 3
Abbrev Offset: 0xd3e6
Pointer Size: 4
<0><1a80ca>: Abbrev Number: 1 (DW_TAG_compile_unit)
<1a814d> DW_AT_stmt_list : 0x8e02a
<1a8151> DW_AT_macro_info : 0xc6fb
<1><1a819b>: Abbrev Number: 3 (DW_TAG_variable)
<1a819c> DW_AT_name : test_inst
<1a81ad> DW_AT_type : <0x1a7643>
<1a81b6> DW_AT_location : 5 byte block: 3 50 6e ff 1f (DW_OP_addr: 1fff6e50)
<1a81bc> Unknown AT value: 2768: 1
<1><1a81e0>: Abbrev Number: 0
Compilation Unit @ offset 0x1a829e:
Length: 0xb8 (32-bit)
Version: 3
Abbrev Offset: 0xd3e6
Pointer Size: 4
<0><1a82a9>: Abbrev Number: 1 (DW_TAG_compile_unit)
<1a832c> DW_AT_stmt_list : 0x8e02a
<1a8330> DW_AT_macro_info : 0xc6fb
<1><1a8334>: Abbrev Number: 3 (DW_TAG_variable)
<1a8335> DW_AT_name : test_sub
<1a834a> DW_AT_type : <0x1a761a>
<1a8352> DW_AT_location : 5 byte block: 3 48 7d ff 1f (DW_OP_addr: 1fff7d48)
<1a8358> Unknown AT value: 2768: 1
<1><1a8359>: Abbrev Number: 0
如您所见,test_inst 位于 0x1fff6e50 地址。 test_sub 位于 0x1fff6e48。这是对的。如果我们要检查内存,那么:
如果我在 as_ref 中只有引用,我想知道如何手动查找 0x1fff6e48 地址。
main_struct 的 Dwarf 信息是这样的:
<1><1a7643>: Abbrev Number: 40 (DW_TAG_structure_type)
<1a7644> DW_AT_sibling : <0x1a76cf>
<1a7648> DW_AT_name : test_struct
<1a7654> DW_AT_byte_size : 44
<2><1a7655>: Abbrev Number: 44 (DW_TAG_member)
<1a7656> DW_AT_type : <0x1a683a>
<1a7658> DW_AT_accessibility: 1 (public)
<1a7659> DW_AT_name : as_ref
<1a7660> DW_AT_data_member_location: 2 byte block: 23 0 (DW_OP_plus_uconst: 0)
<2><1a7663>: Abbrev Number: 44 (DW_TAG_member)
<1a7664> DW_AT_type : <0x1a6833>
<1a7666> DW_AT_accessibility: 1 (public)
<1a7667> DW_AT_name : c
<1a7669> DW_AT_data_member_location: 2 byte block: 23 4 (DW_OP_plus_uconst: 4)
<2><1a766c>: Abbrev Number: 44 (DW_TAG_member)
<1a766d> DW_AT_type : <0x1a6833>
<1a766f> DW_AT_accessibility: 1 (public)
<1a7670> DW_AT_name : d
<1a7672> DW_AT_data_member_location: 2 byte block: 23 8 (DW_OP_plus_uconst: 8)
<2><1a76ce>: Abbrev Number: 0
as_ref 类型是对此的引用:
<1><1a683a>: Abbrev Number: 5 (DW_TAG_reference_type)
<1a683b> DW_AT_type : <0x1a761a>
这将是对此的引用:
<1><1a761a>: Abbrev Number: 40 (DW_TAG_structure_type)
<1a761b> DW_AT_sibling : <0x1a7643>
<1a761f> DW_AT_name : sub_struct
<1a762f> DW_AT_byte_size : 8
<2><1a7630>: Abbrev Number: 44 (DW_TAG_member)
<1a7631> DW_AT_type : <0x1a6833>
<1a7633> DW_AT_accessibility: 1 (public)
<1a7634> DW_AT_name : a
<1a7636> DW_AT_data_member_location: 2 byte block: 23 0 (DW_OP_plus_uconst: 0)
<2><1a7639>: Abbrev Number: 44 (DW_TAG_member)
<1a763a> DW_AT_type : <0x1a6833>
<1a763c> DW_AT_accessibility: 1 (public)
<1a763d> DW_AT_name : b
<1a763f> DW_AT_data_member_location: 2 byte block: 23 4 (DW_OP_plus_uconst: 4)
<2><1a7642>: Abbrev Number: 0
最佳答案
TLDR:指针和引用在 hookd 下是一回事。 as_ref
包含引用的 sub_struct
的地址。
这告诉您 as_ref
位于偏移量 0(因此为 0x1fff6e50):
<2><1a7655>: Abbrev Number: 44 (DW_TAG_member)
<1a7656> DW_AT_type : <0x1a683a>
<1a7658> DW_AT_accessibility: 1 (public)
<1a7659> DW_AT_name : as_ref
<1a7660> DW_AT_data_member_location: 2 byte block: 23 0 (DW_OP_plus_uconst: 0)
它的类型由:
<1><1a683a>: Abbrev Number: 5 (DW_TAG_reference_type)
<1a683b> DW_AT_type : <0x1a761a>
这意味着它是对另一种类型的引用。引用和指针在本质上是一样的:它们包含另一个变量的地址。
进程内部:
void* main_struct_addr = 0x1fff6e50; // from DWARF
std::uint64_t as_ref_offset = 0; // from DWARF
void* main_as_ref_addr = (char*) main_struct_addr + as_ref_offset;
void as_addr = *(void**) main_a_ref_addr;
assert(as_adddr == (void*) 0x1fff6e48);
来自另一个进程:
std::uint64_t main_struct_addr = 0x1fff6e50; // from DWARF
std::uint64_t as_ref_offset = 0; // from DWARF
std::uint64_t main_as_ref_addr = main_struct_addr + as_ref_offset;
errno = 0;
void* as_addr = (void*) ptrace(PTRACE_PEEKDATA, pid, (void*) main_as_ref_addr, NULL);
if (errno) { ... }
assert(as_adddr == (void*) 0x1fff6e48);
关于c++ - 如何取消引用 DWARF 中的引用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36837241/
我想做的是让 JTextPane 在 JPanel 中占用尽可能多的空间。对于我使用的 UpdateInfoPanel: public class UpdateInfoPanel extends JP
我在 JPanel 中有一个 JTextArea,我想将其与 JScrollPane 一起使用。我正在使用 GridBagLayout。当我运行它时,框架似乎为 JScrollPane 腾出了空间,但
我想在 xcode 中实现以下功能。 我有一个 View Controller 。在这个 UIViewController 中,我有一个 UITabBar。它们下面是一个 UIView。将 UITab
有谁知道Firebird 2.5有没有类似于SQL中“STUFF”函数的功能? 我有一个包含父用户记录的表,另一个表包含与父相关的子用户记录。我希望能够提取用户拥有的“ROLES”的逗号分隔字符串,而
我想使用 JSON 作为 mirth channel 的输入和输出,例如详细信息保存在数据库中或创建 HL7 消息。 简而言之,输入为 JSON 解析它并输出为任何格式。 最佳答案 var objec
通常我会使用 R 并执行 merge.by,但这个文件似乎太大了,部门中的任何一台计算机都无法处理它! (任何从事遗传学工作的人的附加信息)本质上,插补似乎删除了 snp ID 的 rs 数字,我只剩
我有一个以前可能被问过的问题,但我很难找到正确的描述。我希望有人能帮助我。 在下面的代码中,我设置了varprice,我想添加javascript变量accu_id以通过rails在我的数据库中查找记
我有一个简单的 SVG 文件,在 Firefox 中可以正常查看 - 它的一些包装文本使用 foreignObject 包含一些 HTML - 文本包装在 div 中:
所以我正在为学校编写一个 Ruby 程序,如果某个值是 1 或 3,则将 bool 值更改为 true,如果是 0 或 2,则更改为 false。由于我有 Java 背景,所以我认为这段代码应该有效:
我做了什么: 我在这些账户之间创建了 VPC 对等连接 互联网网关也连接到每个 VPC 还配置了路由表(以允许来自双方的流量) 情况1: 当这两个 VPC 在同一个账户中时,我成功测试了从另一个 La
我有一个名为 contacts 的表: user_id contact_id 10294 10295 10294 10293 10293 10294 102
我正在使用 Magento 中的新模板。为避免重复代码,我想为每个产品预览使用相同的子模板。 特别是我做了这样一个展示: $products = Mage::getModel('catalog/pro
“for”是否总是检查协议(protocol)中定义的每个函数中第一个参数的类型? 编辑(改写): 当协议(protocol)方法只有一个参数时,根据该单个参数的类型(直接或任意)找到实现。当协议(p
我想从我的 PHP 代码中调用 JavaScript 函数。我通过使用以下方法实现了这一点: echo ' drawChart($id); '; 这工作正常,但我想从我的 PHP 代码中获取数据,我使
这个问题已经有答案了: Event binding on dynamically created elements? (23 个回答) 已关闭 5 年前。 我有一个动态表单,我想在其中附加一些其他 h
我正在尝试找到一种解决方案,以在 componentDidMount 中的映射项上使用 setState。 我正在使用 GraphQL连同 Gatsby返回许多 data 项目,但要求在特定的 pat
我在 ScrollView 中有一个 View 。只要用户按住该 View ,我想每 80 毫秒调用一次方法。这是我已经实现的: final Runnable vibrate = new Runnab
我用 jni 开发了一个 android 应用程序。我在 GetStringUTFChars 的 dvmDecodeIndirectRef 中得到了一个 dvmabort。我只中止了一次。 为什么会这
当我到达我的 Activity 时,我调用 FragmentPagerAdapter 来处理我的不同选项卡。在我的一个选项卡中,我想显示一个 RecyclerView,但他从未出现过,有了断点,我看到
当我按下 Activity 中的按钮时,会弹出一个 DialogFragment。在对话框 fragment 中,有一个看起来像普通 ListView 的 RecyclerView。 我想要的行为是当
我是一名优秀的程序员,十分优秀!