我正在尝试使用 gcc/g++ 的内联asm指令(我不得不说我之前一直在MSVC上使用 Intel 语法,这很容易)。我正在玩双值,以下my_func2似乎在执行后崩溃:
#include <iostream>
void my_func(const double *in, double *out) {
asm("mov %0, %%r8" : : "r"(in));
asm("movupd (%%r8), %%xmm0" :);
asm("movupd (%%r8), %%xmm1" :);
asm("addpd %%xmm1, %%xmm0" :);
asm("movupd %%xmm0, (%0)" : : "r"(out) : "%r8", "%xmm0", "%xmm1");
}
double my_func2(const double *in) {
double ret = 0.0;
asm("mov %0, %%r8" : : "r"(in));
asm("movupd (%%r8), %%xmm0" :);
asm("movupd (%%r8), %%xmm1" :);
asm("addpd %%xmm1, %%xmm0" :);
asm("movupd %%xmm0, %0" : "=m"(ret) : : "memory", "%r8", "%xmm0", "%xmm1");
return ret;
}
int main(int argc, char *argv[]) {
const double a = 1.0;
double b = 0.0;
my_func(&a, &b);
std::cout << "b:" << b << std::endl;
b = my_func2(&a);
std::cout << "b:" << b << std::endl;
}
我得到的错误具体是(当我使用gdb运行时):
程序收到信号 SIGBUS,总线错误。 0x00000000004008e1 in main (argc=<error reading variable: Cannot access memory at address 0x400ffffffffffffec>, argv=<错误读取变量:无法访问地址 0x400ffffffffffffe0>) at asm_test.cpp:28 28 b = my_func2(&a);
我究竟做错了什么?在my_func2的最后一行中,我已经指定内存也被破坏了,我不明白......我在哪里可以找到如何使用臭名昭著的 AT&T 语法的好指南?
我在 Ubuntu Linux scv 3.2.0-48-generic #74-Ubuntu SMP Thu Jun 6 19:43:26 UTC 2013 x86_64 x86_64 x86_64g++ -g -o asm_test asm_test.cpp
上编译: ,g++版本g++ (Ubuntu/Linaro 4.6.3-1ubuntu5) 4.6.3 GNU/Linux .
我找到了http://www.ibiblio.org/gferg/ldp/GCC-Inline-Assembly-HOWTO.html和http://www.delorie.com/djgpp/doc/brennan/brennan_att_inline_djgpp.html,有吗你会推荐更多的东西吗?
谢谢,
艾玛