我在用用于ARM Cortex-M4的IAR编译器进行内联汇编时遇到问题。这是我的问题的一个简单例子;将以下代码放在一个名为test.c的文件中

void irqrestore(int flags)
{
  asm volatile(
      "tst    %0, #1\n"
      "bne    1f\n"
      "cpsie  i\n"
      "1:\n"
      :
      : "r" (flags)
      : "memory");
}


现在尝试使用IAR编译器进行编译:

$ iccarm --thumb test.c

   IAR ANSI C/C++ Compiler V6.40.2.53884/W32 for ARM
   Copyright 1999-2012 IAR Systems AB.

    asm volatile(
    ^
"C:\home\NuttX\nuttx\test.c",6  Error[Og010]: Inline assembler instruction
          does not have a unique size: "        bne    ?1_0"

Errors: 1
Warnings: none


任何想法出了什么问题?如果我将“ bne 1f \ n”更改为“ bne 1 \ n”,则可以正常编译,但是我不确定是否正确。

最佳答案

答:从IAR,我被告知(并已确认)以下是正确的语法:

  "bne.n  1f\n"


或在上下文中:

void irqrestore(int flags)
{
  asm volatile(
      "tst    %0, #1\n"
      "bne.n    1f\n"
      "cpsie  i\n"
      "1:\n"
      :
      : "r" (flags)
      : "memory");
}

10-01 13:04