LLVM抱怨汇编程序错误“内存操作数中的意外令牌”

时间:2011-09-27 15:09:29

标签: c assembly xcode4 llvm

我正在做一项研究工作,以测量我机器上的内存访问时间。 为了确定我们机器上的时钟周期,我们获得了以下C片段:

static inline void getcyclecount(uint64_t* cycles)
{
    __asm __volatile(
                     "cpuid            # force all previous instruction to complete\n\t"
                     "rdtsc            # TSC ->  edx:eax \n\t"
                     "movl %%edx, 4(0) # store edx\n\t"
                     "movl %%eax, 0(0) # store eax\n\t"
                     : : "r"(cycles) : "eax", "ebx", "ecx", "edx");
}

但是,当我尝试编译它(XCode 4,使用“Apple LLVM编译器2.1”)时,它会在rdtsc resp的“\ t”错误“内存操作数中的意外令牌”中产生两次。第一个movl指令行。

我知道基本汇编程序,但对C内联汇编程序格式没有任何线索。

你们中有谁知道这段代码会出现什么问题?

谢谢!

1 个答案:

答案 0 :(得分:5)

假设这是GCC内联汇编语法,你在内存操作数中缺少%

__asm __volatile(
                 "cpuid            # force all previous instruction to complete\n\t"
                 "rdtsc            # TSC ->  edx:eax \n\t"
                 "movl %%edx, 4(%0) # store edx\n\t"
                 "movl %%eax, 0(%0) # store eax\n\t"
                 : : "r"(cycles) : "eax", "ebx", "ecx", "edx");