内核中一段汇编源码,愿与大家一起交流分析

发布于 2022-10-15 05:52:11 字数 3706 浏览 14 评论 0

在内核中进行文件读写前,往往要对数据缓存地址进行检查,看是否可读写,下面这个宏就是用来从
addr处读一个byte到x中,但是下面的汇编代码只能看出大概(ldrdt,mov),求高手给予更多的
分析指点。
#define __get_user_asm_byte(x,addr,err)                                \
        __asm__ __volatile__(                                        \
        "1:        ldrbt        %1,[%2],#0\n"                                \
        "2:\n"                                                        \
        "        .section .fixup,\"ax\"\n"                        \
        "        .align        2\n"                                        \
        "3:        mov        %0, %3\n"                                \
        "        mov        %1, #0\n"                                \
        "        b        2b\n"                                        \
        "        .previous\n"                                        \
        "        .section __ex_table,\"a\"\n"                        \
        "        .align        3\n"                                        \
        "        .long        1b, 3b\n"                                \
        "        .previous"                                        \
        : "+r" (err), "=&r" (x)                                        \
        : "r" (addr), "i" (-EFAULT)                                \
        : "cc")

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文