以下代码计算 x 和 y 的乘积并将结果存储在内存中。数据类型 ll_t 被定义为等价于 long long。
typedef long long ll_t;
void store_prod(ll_t *dest, int x, ll_t y) {
*dest = x*y;
}
gcc 生成以下实现计算的汇编代码:dest at %ebp+8, x at %ebp+12, y at %ebp+16
1 movl 16(%ebp), %esi
2 movl 12(%ebp), %eax
3 movl %eax, %edx
4 sarl $31, %edx
5 movl 20(%ebp), %ecx
6 imull %eax, %ecx
7 movl %edx, %ebx
8 imull %esi, %ebx
9 addl %ebx, %ecx
10 mull %esi
11 leal (%ecx,%edx), %edx
12 movl 8(%ebp), %ecx
13 movl %eax, (%ecx)
14 movl %edx, 4(%ecx)
此代码使用三个乘法来实现在 32 位机器上实现 64 位算术所需的多精度算术。描述用于计算产品的算法,并注释汇编代码以显示它如何实现您的算法。
我不明白上面汇编代码中的第 8 行和第 9 行。任何人都可以帮忙吗?