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

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

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


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

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


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

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


在Linux中创建一个系统调用

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


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

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


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

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


linux kernel - Linux系统调用

我能够获得系统调用的执行,并在Kernel中处理。 但是很少有事情我不清楚。 进入swi例程后,内核将用户模式寄存器保存在堆栈中。 问题是- 谁的筹码是?(由于swi处理和相应的系统调用例程需要栈帧工作) 如果是内核自己的堆栈,从哪里得到堆栈分配..? 它会开始使用当前的堆栈吗? 如果是,那么当前可以是在内核中可能正在执行的任何进程。 这不是耗尽电流的堆栈吗? 如果它在swi处理程序中…



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

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


linux kernel - 用MADV_SEQUENTIAL调用madvise系统调用需要很长时间才能完成

在我的代码中,我使用了一个外部的C库,而且这个库调用了MADV_SEQUENTIAL选项,这个选项需要很长时间才能完成。 在我看来,只有用MADV_SEQUENTIAL调用madvise对我们的工作来说已经足够了。 我的第一个问题是,为什么要进行多个疯狂的系统调用,有没有一个按顺序调用不同选项的逻辑? 我的第二个问题是,你有什么想法,为什么madvise与MADV_SEQUENTIAL需要太长,…


如何在ARM64中实现系统调用?

我正在使用arm64汇编代码,我想用svc指令来实现系统调用。 我找不到任何在线工作的arm64系统调用。另外,我找不到arm64的系统调用列表。 另外说明实施。…




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