我有一个名为drv1的字符驱动程序,一个用户应用程序使用ioctl与它通信,这将传输参数struct file *filp。现在我想知道drv1代码段的地址,但我遇到了一些问题。
首先,我想struct file *filp可能很有用,所以我查看了源代码中的定义,并找到了一个指针struct inode *f_inode; /* cached value */。然后,我粗略地搜索了struct inode的定义(我不确定它是否正确,因为当tmpfs时我并不熟悉);一个名为struct address_space *i_mapping的指针似乎是我所需要的。但我不知道如何深入挖掘并陷入困境;struct address_space中有一些复杂的数据结构,如:
struct radix_tree_root page_tree; /* radix tree of all pages */和
struct rb_root i_mmap; /* tree of private and shared mappings */这是否意味着驱动程序drv1的数据是以radix_tree_root的形式组织的?还是说我错过了别的什么?
发布于 2016-05-25 04:04:30
对于构建为LKM的模块,内存似乎是在MODULES_VADDR和MODULES_END之间动态分配的(参见arch/($YOUR_ARCH)/kernel/module.c中的module.c )。我可以使用shell命令cat /proc/kallsyms获得其函数导出的起始地址,但是在我的代码中还没有一个很好的方法来实现它。
对于内置在内核映像中的模块,System.map文件将提供信息。不管怎样,我不知道如何在代码中动态地获取地址。
https://stackoverflow.com/questions/36761727
复制相似问题