我在库&中有glibc提供的相同的覆盖open().我首先在库中设置了LD_PRELOAD,因此当进程调用open()时,将调用库中定义的open.

问题:-glibc中还有其他几个函数,一旦示例为getpt(),就会调用open(),当getpt()调用open()时,将调用glibc中定义的open(),我将如何使getpt ()调用在我的library()中定义的open().

限制:-我没有选择编译glibc的选项.

解决方法:

正如tmcguire正确指出的那样,从posix_openpt到__open的调用是对内部符号的调用,并且不能插入.

实际上,glibc开发人员认为此调用是实现细节,您无需进行任何更改.

I am looking at compile time solution

你不能拥有它.

than run time solution cause run time solution will have performance impact.

运行时解决方案不必对性能有任何影响(除了调用open而不是glibcs​​的开销外).

我只知道库插入glibc内部调用的一种方式:运行时修补.这个想法是为了

>找到libc.so.6 open的地址(这是__open的别名),

>在运行时找到glibc .text节的边界

>扫描以查找__open指令

>对于任何此类指示

> mprotect它所在的页面可写

>计算一条名为CALL my_open的新指令,并将其修补为原始指令的“顶部”

> m保护页面回读和执行

这很丑陋,但在i * 86(32位)Linux上可以正常使用,在C *中,CALL可以“到达” 4GB地址空间内的任何其他指令.对于x86_64而言,它不起作用,其中CALL仍限于/ 2GB,但是从库到glibc的距离可能会更多.

在这种情况下,您需要在libc.so.6中找到一个合适的蹦床,您可以将原始的CALL重定向到该蹦床,并可以将寄存器间接JMP放置到最终的目的地.幸运的是,由于函数对齐,libc.so.6通常具有多个大小适当的未使用的NOP区域.

标签:gcc,override,glibc,ld,linux

来源: https://codeday.me/bug/20191121/2055603.html

linux下找不到libc 库,Linux-覆盖libc open()库函数相关推荐

  1. Linux下安装和使用boost库

    Linux下安装和使用boost库 2016-08-26 20:29:06 zhaomax 阅读数 349更多 分类专栏: C++ 用boost库中的serialization库.Boost库分为两个 ...

  2. spdlog linux编译出错,Linux下编写Makefile引入第三方库

    Linux下编写Makefile引入第三方库 前言:一直在使用CmakaList 生成Makefile文件,其实很少去写Makefile,但是最近帮朋友处理了一个Makefile引入第三方库的问题,就 ...

  3. Linux下V4L2框架基于SDL库本地USB摄像头监控

    Linux下V4L2框架基于SDL库本地USB摄像头监控 1.摄像头框架编程步骤 (1)打开摄像头设备(/dev/video0 ./dev/video1 ) (2)设置图像格式:VIDIOC_S_FM ...

  4. 如何在linux系统下修改mysql密码_如何在linux下修改mysql数据库密码?linux修改数据库密码的方法...

    本篇文章给大家带来的内容是介绍如何在linux下修改mysql数据库密码?linux修改数据库密码的方法.有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助. Linux下修改Mysql的 ...

  5. linux下的c 编程入门教程,Linux下的C编程入门教程.ppt

    <Linux下的C编程入门教程.ppt>由会员分享,可在线阅读,更多相关<Linux下的C编程入门教程.ppt(14页珍藏版)>请在装配图网上搜索. 1.Linux下c+编程, ...

  6. 过滤Linux下不同大小的文件,linux查找当前目录下 M/G 大小的文件,删除Linux下指定大小的文件

    过滤Linux下不同大小的文件,linux查找当前目录下 M/G 大小的文件,删除Linux下指定大小的文件 find ./ -type f -size +1G| xargs rm 在清理系统日志文件 ...

  7. linux下sort命令使用详解---linux将文本文件内容加以排序命令

    转载自:http://www.cnblogs.com/hitwtx/archive/2011/12/03/2274592.html linux下sort命令使用详解---linux将文本文件内容加以排 ...

  8. linux系统修改bond的ip,Linux下快速设定ip bond,linux设定ipbond

    Linux下快速设定ip bond,linux设定ipbond 在计算机网路普及的初期,很多OS系统都使用的为单网卡方式,即一个网卡使用一个IP地址.随着网络要求的不断提高,我们可以对多个网卡进行绑定 ...

  9. linux下查看进程的线程数,linux查看进程的线程数

    top -H -p $PID  #查看对应进程的那个线程占用CPU过高 1.top -H 手册中说:-H : Threads toggle 加上这个选项启动top,top一行显示一个线程.否则,它一行 ...

  10. linux下的磁盘配额简介暨 linux下加挂硬盘续

    linux下的磁盘配额简介暨 linux下加挂硬盘续 实验环境 VMware 6.5.2 +redhat Enterprise 5 as 以上是内核版本,还有方便起见加挂一块硬盘 这只是我的环境 实验 ...

最新文章

  1. 如何使用Nsight System?
  2. 编译型语言和解释型语言(转载)
  3. c语言是结构化 模块化,c语言是完全模块化和结构化的语言,怎么理解,什么是模块化和结构化...
  4. Lib详解--如何判断lib文件是静态库还是导入库
  5. MST(最小生成树)上的确定性和存在性问题
  6. c语言 文件加密头文件,[C语言]文件加密
  7. 【文章收藏】阿里云破了四个世界纪录
  8. 美图手机官方正式告别:年中关闭手机业务 手机品牌授权给小米
  9. bzoj 4002: [JLOI2015]有意义的字符串(特征根法+矩阵快速幂)
  10. Netty之Channel、NioEventLoopGroup、客户端connect方法总结
  11. java药品管理系统源代码,基于jsp的药品管理系统-JavaEE实现药品管理系统 - java项目源码...
  12. JUnit5学习之一:基本操作
  13. UML用例图讲解及画法
  14. 阿尔法贝塔阀原理_阿尔法(α)和贝塔(β)的通俗解释
  15. 职业规划是什么?应该怎么回答?
  16. element-ui tabs标签嵌套使用时 基础下划线不显示的问题
  17. 中国智能电饭煲行业市场供需与战略研究报告
  18. ROSIntegration ROSIntegrationVision与虚幻引擎4(Unreal Engine 4)的配置
  19. 高温不怕热,GVS智能家居为你打造夏日清爽雅居
  20. 12月给自己一个逆袭的机会,社科院与杜兰大学金融管理硕士项目期待你的加入

热门文章

  1. 使用Identity Server 4建立Authorization Server (1)
  2. 揭晓新版《Windows Sysinternals实战指南》读书积赞活动
  3. CoreCLR文档翻译 - GC的设计
  4. 使用Akka.net开发第一个分布式应用
  5. asp.net MVC 应用程序的生命周期
  6. php两个数组融合,php合并两个数组的方式有哪些
  7. 【BIM入门实战】Win11平台上Revit 2018_x64简体中文版图文安装与卸载完整教程
  8. 【ArcGIS Pro微课1000例】0007:ArcGIS Pro 2.5质量检查:拓扑创建与编辑案例教程
  9. Android之提示Cannot call this method while RecyclerView is computing a layout or scrolling
  10. 剑指offer之用链表实现栈(带头节点)