c - 如何在linux内核的memcpy函数中添加一个hook?

标签 c linux kernel hook memcpy

以下是我的步骤,但没有按预期工作。

linux-3.16-rc2\arch\x86\lib\memcpy_64.S:

改变了

ENTRY(__memcpy)
ENTRY(memcpy)
...
CFI_ENDPROC
ENDPROC(memcpy)
ENDPROC(__memcpy)

到:

ENTRY(__memcpy)
ENTRY(x86_memcpy)
...
CFI_ENDPROC
ENDPROC(x86_memcpy)
ENDPROC(__memcpy)

linux-3.16-rc2\lib\string.c:

改变了

#ifndef __HAVE_ARCH_MEMCPY
void *memcpy(void *dest, const void *src, size_t count)
{
    char *tmp = dest;
    const char *s = src;

    while (count--)
        *tmp++ = *s++;
    return dest;
}
#endif

到:

//#ifndef __HAVE_ARCH_MEMCPY
void *memcpy(void *dest, const void *src, size_t count)
{
    char *tmp = dest;
    const char *s = src;
    my_hook();
    while (count--)
            *tmp++ = *s++;
    return dest;
}
//#endif

删除 arch/x86/kernel/x8664_ksyms_64.c 中的 EXPORT_SYMBOL(memcpy)

在linux-3.16-rc2\mm\memcpy_test.c中添加测试代码:

#include <linux/mm.h>
#include <linux/kallsyms.h>
#include <linux/module.h>
int hook_value = -1;
int test_begin = 0;
void  my_test_begin(void)
{
    char src[128] = {0};
    char dst[128] = {1};
    test_begin = 1;
    mb();
    memcpy((char*)dst,(char*)src,50);
    test_begin = 0;
    mb();
    printk("hook value:%d\n",hook_value);
}

void  my_hook(void)
{
    if(test_begin)
            hook_value=1;
}

调用my_test_begin后,发现hook_value一直为-1,看来my_test_begin中的memcpy一直没有达到hook_value=1 谁能帮忙?谢谢!

最佳答案

感谢@Basile Starynkevitch 我解决了这个问题,是的,'Sometimes, the compiler is optimizing memcpy to __builtin_memcpy'

关于c - 如何在linux内核的memcpy函数中添加一个hook?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25409724/

相关文章:

c - 未知类型名称 C

linux - 让 linux 将内存更改持久保存到磁盘

linux - Linux 中的进程控制 block

linux - 为什么不是所有的库函数都不是系统调用?

c - 这是什么类型的排序算法?

c - 如何在 C 中将整数转换为十六进制字符串?

c - 如何检查特定目录中是否存在文件?

linux - 直到循环与 if 语句

linux - 如何加速 Linux 内核重建

c - 如果我使用两个 alloc_pages 进行检查,则 alloc_pages 返回的地址相同