免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4015 | 回复: 1
打印 上一主题 下一主题

令人费解的find_first_bit的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-02-12 16:06 |只看该作者 |倒序浏览
内核代码中是这么定义的
static inline long
__find_first_bit(const unsigned long * addr, unsigned long size)
{
        long d0, d1;
        long res;

        __asm__ __volatile__(
                "   repe; scasq\n"
                "   jz 1f\n"
                "   subq $8,%%rdi\n"
                "   bsfq (%%rdi),%%rax\n"
                "1: subq %[addr],%%rdi\n"
                "   shlq $3,%%rdi\n"
                "   addq %%rdi,%%rax"
                :"=a" (res), "=&c" (d0), "=&D" (d1)
                :"0" (0ULL),
                 "1" ((size + 63) >> 6), "2" (addr),
                 [addr] "r" (addr) : "memory");
        return res;
}
我在MinGW中写了个程序测试了一些,却报错
test.c:In function `__find_first_bit':
test.c:138: error: impossible register constraint in `asm'
test.c:151: confused by earlier errors, bailing out
请大家指点我,函数中那段汇编是什么意思啊

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
2 [报告]
发表于 2009-02-12 16:09 |只看该作者
                 "1" ((size + 63) >> 6), "2" (addr),
                 [addr] "r" (addr) : "memory");

红色部分是代码中的吗?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP