- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 Intel 处理器的 FPU 单元的汇编程序在 C 接口(interface)内执行不同的操作。要执行的操作是:
43.001 * 0.00751
0.00000001 * 1.4142135623730951
0.1 + 0.1 + 0.1 − 0.3
这是带有汇编接口(interface)的 C 代码:
#include <stdio.h>
int main(void)
{
double r;
double s;
const double a = 1;
const double b = 0.1;
const double c = 43.001;
const double d = 0.00751;
const double e = 0.00000001;
const double f = 1.4142135623730951;
const double g = 0.3;
__asm__ ("fldl %1;" //cargo a
"fldl %2;" //cargo b
"fldl %3;" //cargo c
"fldl %4;" //cargo d
"faddp;" // suma a con b y lo guarda en st(0)
"fmul st2,st3" // c*d y lo guarda en st(2)
"fstl %0;" : "=m" (r) : "m" (a), "m" (b)
"fstl %1;" : "=m" (s) : "m" (c), "m" (d) //acá creí que se se podia hacer la multiplicación
);
printf("%.16e\n", r);
printf("%.16e\n", s);
return 0;
}
这个想法是每个操作的结果存储在堆栈位置中,但我无法做到这一点,因为我不确定例如 fmul st2, st3 的语法是否正确。如何将每个操作存储在堆栈位置然后打印结果?
最佳答案
嗯,我想我找到了。
我编写了这段代码,在独立的 asm block 中执行操作。
int main(void)
{
double result_mult1;
double result_mult2;
double result_resta;
const double a = 43.001;
const double b = 0.00751;
const double c = 0.00000001;
const double d = 1.4142135623730951;
const double e = 0.1;
const double f = e+e+e;
const double g = 0.3;
__asm__ ("fldl %1;" //Carga a
"fldl %2;" //Carga b
"fmulp;"
"fstl %0;" : "=m" (result_mult1) : "m" (a), "m" (b) );
__asm__ ("fldl %1;" //Carga c
"fldl %2;" //Carga d
"fmulp;"
"fstl %0;" : "=m" (result_mult2) : "m" (c), "m" (d) );
__asm__("fldl %1;" //Carga g
"fldl %2;" //Carga f
"fsubp;" //Resta g con f y lo guarda en st(0)
"fstl %0;" : "=m" (result_resta) : "m" (g), "m" (f));
printf("%.16e\n", result_mult1);
printf("%.16e\n", result_mult2);
printf("%.16e\n", result_resta);
return 0;
}
关于c - 使用汇编器和 C 接口(interface)执行多项操作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52892697/
某些 AMD64/x86 命令需要立即值作为操作数(例如 imm8)。是否可以使用存储在某个寄存器中的值(例如 ah)来代替这个硬编码值? 例如: 如果我想移动 xmm 寄存器,可以使用 pslldq
您好,我正在修改汇编级编程。我有以下代码 mov al, 'H' call my_function my_function: mov ah,0x0e ;
x86 汇编程序例程通常以以下序言开始: push ebp ; Save ebp mov ebp, esp ; Set
这个问题已经有答案了: What is the purpose of XORing a register with itself? [duplicate] (7 个回答) 已关闭 2 年前。 我们有时
如果您不了解二进制,我知道 BCD 是更直观的数据类型。但我不知道为什么要使用这种编码,它好像没有多大意义,因为它浪费以 4 位表示(当表示大于 9 时)。 另外,我认为 x86 仅支持直接添加和替换
x86 汇编程序例程通常以以下序言开始: push ebp ; Save ebp mov ebp, esp ; Set
var a int[1]; var aa int[1]; aa = a; 假设我们想在 java jvm 中编译这样的东西。看起来人们只会做一个 ldc 1 newarray int astor
是否有任何编写 MIPS 汇编器的引用指南或教程? 最佳答案 如果您希望实际编写汇编程序,您需要知道您正在编写的平台的可执行文件的格式(例如 ELF ),那么您需要使用 MIPS instructio
我想写一个简单的 M.A.R.I.E.计算表达式 A x B + C x D 的程序. 现在,关于 Marie 汇编语言的信息并不多。我不确定是否有乘法?如果没有,我是否必须循环或其他东西才能使其成倍
我想知道为 NASM 编写汇编代码的格式是什么。有什么地方教的吗?我尝试在 NASM 上运行 MASM32 文件,但我认为它无法识别指令。 最佳答案 总是有 the manual . 关于linux
我想要的是类似 g++ 的东西,我可以在其中输入: compiler_name my_assembly_code.extention ...并让它编译我的汇编代码。它是 32 位还是 64 位并不重要
我正在为 8086 开发一个汇编程序。我的问题是如何将十六进制操作码转换为可执行文件,如 .EXE、.ELF、.COM、a.out 等。为此寻找链接/资源,汇编程序应该执行链接过程还是由操作系统自动?
我想编写 64 位 Windows 程序集(最好使用 NASM)。我在谷歌上看起来很不错,但似乎找不到 64 位 Windows 编译器。一些站点提到了 ml64,但它似乎不再包含在 VC++ 中。我
使用 GNU Binutils 声明汇编代码时,例如: .long MY_Label .long MY_Second_label 即使操作码和其他信息在地址空间中将它们分开,也可以在进行十六进制转储时
似乎单元测试这些天变得风靡一时,我知道你们中的许多人会想:“那么为什么不直接使用语言 X 和框架 Y 呢?”但我提出这个想法更多是为了证明概念,或者是出于对我早年计算机编程的怀念。 我正在研究使用 N
作为编译器项目的一部分,我必须为 x86 编写 GNU 汇编器代码来比较浮点值。我试图找到有关如何在线执行此操作的资源,据我了解,它的工作原理如下: 假设我要比较的两个值是浮点堆栈上的唯一值,则 fc
操作系统:Windows 10 CPU:英特尔酷睿 i5-5300U 架构:x64 我刚刚开始学习汇编语言。我使用了在线编译器,但今天我下载了NASM。我尝试编写这个将 10 乘以 15 的简单代码:
查看以下代码: (ebp-0x8 -> int) (ebp-0x4 -> int*) => 0x80483f3 : mov DWORD PTR [ebp-0x8],0x0 0x80483
我需要编写一个类似 CorFlags 的应用程序。如果我有程序集文件的路径,我该如何读取它的 CorFlags? 我特别需要知道程序集是 Any-CPU 还是仅 x86 我想避免使用反射加载程序集,因
查看以下代码: (ebp-0x8 -> int) (ebp-0x4 -> int*) => 0x80483f3 : mov DWORD PTR [ebp-0x8],0x0 0x80483
我是一名优秀的程序员,十分优秀!