- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在将 Delphi BASM32 代码移植到 FPC 时遇到问题:
program MulTest;
{$IFDEF FPC}
{$mode delphi}
{$asmmode intel}
{$ELSE}
{$APPTYPE CONSOLE}
{$ENDIF}
function Mul(A, B: LongWord): LongWord;
asm
MUL EAX,EDX
end;
begin
Writeln(Mul(10,20));
Readln;
end.
以上代码在 Delphi XE 中编译并按预期工作; FPC 在 MUL EAX,EDX
行输出编译时错误:
Error: Asm: [mul reg32,reg32] invalid combination of opcode and operands
我使用的是 Lazarus 1.4.4/FPC2.6.4 for Win32(当前稳定版)
有任何解决方法或解决问题的办法吗?
最佳答案
FreePascal 是正确的。 MUL
只有3种形式:
MUL r/m8
MUL r/m16
MUL r/m32
Performs an unsigned multiplication of the first operand (destination operand) and the second operand (source operand) and stores the result in the destination operand. The destination operand is an implied operand located in register AL, AX or EAX (depending on the size of the operand); the source operand is located in a general-purpose register or a memory location.
换句话说,第一个操作数(用于输入和输出)在AL
/AX
/EAX
中指定,而第二个输入操作数被明确指定为通用寄存器或内存地址。
所以,MUL EAX,EDX
确实是一个无效的汇编指令。
如果您在 Delphi 中编译此代码并使用调试器查看生成的程序集,您会看到对 Mul(10,20)
的调用生成了以下汇编代码:
// Mul(10,20)
mov edx,$00000014
mov eax,$0000000a
call Mul
//MUL EAX,EDX
mul edx
因此,如您所见,Delphi 正在实际解析您的源代码,发现第一个操作数是 EAX
并为您将其剥离,从而生成正确的程序集。 FreePascal 不会为您执行该步骤。
解决方法?首先编写正确的汇编代码。不要依赖编译器为您重新解释代码。
function Mul(A, B: LongWord): LongWord;
asm
MUL EDX
end;
或者,您可以不直接编写汇编代码,让编译器为您完成工作。它知道如何将两个 LongWord
值组合在一起:
function Mul(A, B: LongWord): LongWord;
begin
Result := A * B;
end;
虽然 Delphi 在这种情况下确实使用 IMUL
而不是 MUL
。来自德尔福的 documentation :
The value of
x / y
is of typeExtended
, regardless of the types ofx
andy
. For other arithmetic operators, the result is of typeExtended
whenever at least one operand is a real; otherwise, the result is of typeInt64
when at least one operand is of typeInt64
; otherwise, the result is of typeInteger
. If an operand's type is a subrange of an integer type, it is treated as if it were of the integer type.
除非禁用堆栈框架并启用优化,否则它还会使用一些难看的臃肿程序集。通过配置这两个选项,可以让 Mul()
生成单个 IMUL EDX
指令(当然还有 RET
指令) ).如果您不想在整个项目范围内更改选项,您可以使用 {$STACKFRAMES OFF}
/{ $W-}
和 {$OPTIMIZATION ON}
/{$O+}
编译指令。
{$IFOPT W+}{$W-}{$DEFINE SF_Was_On}{$ENDIF}
{$IFOPT O-}{$O+}{$DEFINE O_Was_Off}{$ENDIF}
function Mul(A, B: LongWord): LongWord;
begin
Result := A * B;
end;
{$IFDEF SF_Was_On}{W+}{$UNDEF SF_Was_On}{$ENDIF}
{$IFDEF O_Was_Off}{O-}{$UNDEF O_Was_Off}{$ENDIF}
生成:
imul edx
ret
关于delphi - FPC BASM32 MUL 错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34523936/
MUL CL CL 是 BYTE 大小,它等于 AX = AL * CL MUL BX BX 是 WORD 大小,它等于 DX:AX = AX * BX MUL EBX EBX 是 DWORD 大小,
我正在尝试学习 Tensor Flow,因此我遵循了 https://pythonprogramming.net/tensorflow-neural-network-session-machine-l
我的代码中有错误,我已经阅读了文档,但仍然错误,维度必须相等是什么意思?但实际上我已经在代码中添加了一些层 model.fit() 这是我的代码: # USAGE # python train_sim
假设我已经在汇编机中实现了所有ADD、AND、SHF、JUMP、BR、LDW、LDB(加载字加载字节...)......除了MUL(多个)指令。现在我想编写汇编代码来操作MUL指令,该指令接收存储在0
我正在为 ARMv7 处理器编写指令。我想知道为什么我不允许在 MUL 指令本身中有一个常量值?您可以使用 ADD 和 SUB 指令,为什么不使用 MUL? 干杯 最佳答案 如果您查看 instruc
我已经实现了Point3D结构: use std::ops; #[derive(Debug, PartialEq)] pub struct Point3D { pub x: f32,
这就是问题所在:在第二个 mul 时,溢出标志被设置为 1;乘法是一个简单的 120*(-6) = -720,它包含在 16 位中......我不明白为什么。 .model small
我有以下 assembly 线: ... MOV ECX, 0x36EE80 MOV EDX, 0x95217CB1 MUL EDX SHR EDX, 0x15 MOV DWORD PTR SS:[E
我正在使用一个 MySQL 查询,该查询对四个表执行三个表连接。其中两个连接位于一对 MUL key 上。第三个连接是在一对主键上。查询需要一整分钟才能获取 100 行。 我相信两对 MUL key
全部, 假设我有以下 mysql 表testtable: +----------+------------------------------+------+-----+---------+-----
我有一个现有的表,我通过一个脚本过夜填充该表,该脚本读取二进制格式文件并将其转换为通过管道传输到 mysql 的一系列 replace 语句。该脚本存在错误,并且对每个二进制文件循环两次,因此每个 r
我正在用 Rust 创建一个简单的矩阵结构,我正在尝试实现一些基本的运算符方法: use std::ops::Mul; struct Matrix { cols: i32, rows:
这个问题在这里已经有了答案: Automatically implement traits of enclosed type for Rust newtypes (tuple structs wit
这个问题在这里已经有了答案: x86 Multiplication with 3: IMUL vs SHL + ADD (1 个回答) 关闭 1 年前。 让我们考虑以下函数: #include u
我有一个时间索引的 DataFrame,其中只有一部分数据是有效的(出于某些“外部”原因)。 我已经为有效数据制作了一个时间索引的Series 1 和数据无效的 NaN,所以我可以使用这是我的 Dat
数据 1 import pandas as pd #data 01 df_products = pd.DataFrame([{'Product ID' : 4109,'Price' : 5.0,'Pr
我有这段代码,它使用了 PBC 库: element_t pk, pk_temp; element_init_G2(pk, pairing); element_init_G2(pk_temp, pai
我正在尝试对附加了单位的求解评估的输出进行舍入。 例如: solve(Eq(x, 22/7 * seconds), x)[0] 输出: 3.14285714285714*s 有没有办法在保留 s 的同
HLSL 的 mul( x, y) 的参数表示 here : 这么说 如果 x 是 vector ,则将其视为行 vector 。 如果 y 是 vector ,则将其视为列 vector 。 这是否
// main.rs #[derive(Clone, Copy)] struct A(f64, f64); impl Mul for A where f64: From, T: Cop
我是一名优秀的程序员,十分优秀!