c - 我怎么能拦截Linux系统调用?

c - 我怎么能拦截Linux系统调用?

除了LD_PRELOAD技巧和Linux内核模块,用你提供的系统调用代替某个系统调用,有没有可能拦截一个系统调用(例如打开),以便在它到达实际打开之前首先通过你的函数?…


是否可以在Linux x86 GAS程序集中创建没有系统调用的线程?

在学习“汇编语言”(在使用GNU作为汇编程序的x86架构上的linux中)时,其中一个时刻就是使用系统调用的可能性。 这些系统调用非常方便,有时甚至是必需的,因为您的程序在用户空间中运行 。 但是,系统调用在性能方面相当昂贵,因为它们需要中断(当然还有系统调用),这意味着必须从用户空间中的当前活动程序到内核空间中运行的系统进行上下文切换。 我想说的是:我目前正在实现一个编译器(用于大学项目)…


linux kernel - Linux内核2.6.18中的sys_call_table

我想通过设置sys的退出调用变量 extern void*sys_call_table[]; real_sys_exit=sys_call_table[__NR_exit] 但是,当我尝试制作,控制台给我的错误 error: ‘__NR_exit’ undeclared(first use in this function) 任何提示将不胜感激:)谢谢…



c - Linux Kernel:系统调用挂钩示例

我正在尝试编写一些简单的测试代码作为挂钩系统调用表的演示。 “sys_call_table”不再导出2.6,所以我只是从System.map文件中获取地址,我可以看到它是正确的(通过我找到的地址查看内存,我可以看到指向系统调用)。 但是,当我尝试修改此表时,内核给出“Oops”,“无法在虚拟地址c061e4f4处理内核分页请求”并且机器重新启动。 这是运行2.6.18-164.10.1.e…


在Linux中创建一个系统调用

我们今天刚刚为我的“操作系统”课程获得了一个中期项目,我们被要求实现一个系统调用(我猜我认为我们必须编写一段代码来调用它)。 我知道我需要更新系统调用表(不记得名字,但没有biggie),以及创建一个表将指向的内核模块,但这是否意味着我将不得不重新编译整个内核,所以内核知道我的模块? 我已经看到可以劫持一个当前的系统调用,但是我怀疑如果我这样做,我不会得到我的任务的功劳。 只是想了解我将要…


在Linux中,在进入sys调用时,%eax中的值是多少?(不是orig_eax)

当一个系统调用返回时,我得到%eax中的系统调用返回值,但是在入口处我得到-38,这是十六进制的0xFFFFFFDA。 这是为了写/读。 这个数字是多少? 它可以用来安全区分出入口吗?…


c - 系统调用的历史是否已添加到Linux?

有什么地方我可以获得每个系统调用所需的Linux最低版本的完整列表吗? 我正在寻找表格问题的一般答案“如果我使用系统调用X,那么我的代码可以运行的Linux的最低版本是什么?”…


c - brk()系统调用是做什么的?

根据Linux程序员手册: brk()和sbrk()更改程序中断的位置,该中断定义了进程数据段的结尾。 数据段在这里意味着什么? 它只是数据段或数据,BSS和堆的组合? 根据维基: 有时数据,BSS和堆区统称为“数据段”。 我没有理由改变数据段的大小。 如果它是数据,BSS和堆集体然后它是有道理的,因为堆将获得更多的空间。 这让我想到了第二个问题。 在我读到的所有文章中,作者说,堆…


c - 在linux内核上寻找系统调用实现

我正在寻找open(),close(),write()和unlink(),但是我无法在任何地方找到它们! 我找到的每个函数都像sys_open,etc_open,etc_open...但没有与我们使用的接口。 你可以帮我吗? 我需要发现他们做了什么样的安全检查…


linux kernel - 进行系统调用以获取进程列表

我是新的模块编程,我需要进行系统调用来检索系统进程,并显示他们消耗多少CPU。 我怎样才能打这个电话?…




call过程 syscall syscall函数 系统调用过程 系统调用跟我学 linux系统api linux android linux系统调用列表 call