C 什么';“英特尔64 ISA”中的类型转换说明

C 什么';“英特尔64 ISA”中的类型转换说明,c,compiler-construction,x86-64,C,Compiler Construction,X86 64,英特尔64 ISA中的类型转换说明是什么 比如将长整型转换为双整型 我做了一些这样的测试: $ cat type_cast.c #include <stdio.h> #include <stdlib.h> int main() { long int a = 8l; double b; b = (double)a; printf("%f", b); return 0; } $ gcc -O0 -g -Wall type_

英特尔64 ISA中的类型转换说明是什么

比如将长整型转换为双整型

我做了一些这样的测试:

$ cat type_cast.c 
#include <stdio.h>
#include <stdlib.h>

int main()
{
    long int a = 8l;
    double b;

    b = (double)a;

    printf("%f", b);

    return 0;
}

$ gcc -O0 -g -Wall  type_cast.c  -o type_cast
$ objdump -S type_cast
$cat type\u cast.c
#包括
#包括
int main()
{
长整数a=8l;
双b;
b=(双)a;
printf(“%f”,b);
返回0;
}
$gcc-O0-g-墙型铸件。c-o型铸件
$objdump-S类型\U类型转换
主要部分是:

int main()
{
  4004c4: 55                    push   %rbp
  4004c5: 48 89 e5              mov    %rsp,%rbp
  4004c8: 48 83 ec 10           sub    $0x10,%rsp
    long int a = 8l;
  4004cc: 48 c7 45 f8 08 00 00  movq   $0x8,-0x8(%rbp)
  4004d3: 00 
    double b;

    b = (double)a;
  4004d4: f2 48 0f 2a 45 f8     cvtsi2sdq -0x8(%rbp),%xmm0
  4004da: f2 0f 11 45 f0        movsd  %xmm0,-0x10(%rbp)

    printf("%f", b);
  4004df: b8 f8 05 40 00        mov    $0x4005f8,%eax
  4004e4: f2 0f 10 45 f0        movsd  -0x10(%rbp),%xmm0
  4004e9: 48 89 c7              mov    %rax,%rdi
  4004ec: b8 01 00 00 00        mov    $0x1,%eax
  4004f1: e8 c2 fe ff ff        callq  4003b8 <printf@plt>

    return 0;
  4004f6: b8 00 00 00 00        mov    $0x0,%eax
}
intmain()
{
4004c4:55%推送rbp
4004c5:48 89 e5 mov%rsp,%rbp
4004c8:48 83 ec 10子$0x10,%rsp
长整数a=8l;
4004cc:48 c7 45 f8 08 00 movq$0x8,-0x8(%rbp)
4004d3:00
双b;
b=(双)a;
4004d4:F248 0f 2a 45 f8 cvtsi2sdq-0x8(%rbp),%xmm0
4004da:f2 0f 11 45 f0 movsd%xmm0,-0x10(%rbp)
printf(“%f”,b);
4004df:b8 f8 05 40 00 mov$0x4005f8,%eax
4004e4:F20f 10 45 f0 movsd-0x10(%rbp),%xmm0
4004e9:48 89 c7 mov%rax,%rdi
4004ec:b8 01 00 mov$0x1,%eax
4004f1:e8 c2 fe ff ff callq 4003b8
返回0;
4004f6:b8 00 mov$0x0,%eax
}
它使用cvtsi2sdq-0x8(%rbp)、%xmm0和movsd%xmm0、-0x10(%rbp)从长整型转换为双精度


我想知道Intel 64 ISA中通常使用的其他方法是什么。

由于SIMD已得到很好的实现,您可能找不到其他方法。当然,您将使用压缩变量(cvtpi2pd)进行多个同时转换,但这可能不是您想要的


您唯一真正的选择是
fildl
/
fstpl
对,它将在x87浮点堆栈中加载long int,然后将其读回堆栈。

您对生成的指令特别感兴趣吗?如果是这样,你将如何运用这些知识?@wallyk我对这些说明感兴趣。我只是从C生成指令,看看什么类型的指令可以用于类型转换。我想知道英特尔64 ISA中通用而高效的类型转换方法。