mirror of
https://github.com/odin-lang/Odin.git
synced 2025-12-28 17:04:34 +00:00
amd64 support half in the abi too
This commit is contained in:
@@ -527,6 +527,8 @@ namespace lbAbiAmd64SysV {
|
||||
enum RegClass {
|
||||
RegClass_NoClass,
|
||||
RegClass_Int,
|
||||
RegClass_SSEHs,
|
||||
RegClass_SSEHv,
|
||||
RegClass_SSEFs,
|
||||
RegClass_SSEFv,
|
||||
RegClass_SSEDs,
|
||||
@@ -545,6 +547,8 @@ namespace lbAbiAmd64SysV {
|
||||
|
||||
gb_internal bool is_sse(RegClass reg_class) {
|
||||
switch (reg_class) {
|
||||
case RegClass_SSEHs:
|
||||
case RegClass_SSEHv:
|
||||
case RegClass_SSEFs:
|
||||
case RegClass_SSEFv:
|
||||
case RegClass_SSEDs:
|
||||
@@ -693,6 +697,8 @@ namespace lbAbiAmd64SysV {
|
||||
case RegClass_Int:
|
||||
needed_int += 1;
|
||||
break;
|
||||
case RegClass_SSEHs:
|
||||
case RegClass_SSEHv:
|
||||
case RegClass_SSEFs:
|
||||
case RegClass_SSEFv:
|
||||
case RegClass_SSEDs:
|
||||
@@ -804,6 +810,8 @@ namespace lbAbiAmd64SysV {
|
||||
to_write = RegClass_Memory;
|
||||
} else if (newv == RegClass_SSEUp) {
|
||||
switch (oldv) {
|
||||
case RegClass_SSEHv:
|
||||
case RegClass_SSEHs:
|
||||
case RegClass_SSEFv:
|
||||
case RegClass_SSEFs:
|
||||
case RegClass_SSEDv:
|
||||
@@ -918,6 +926,7 @@ namespace lbAbiAmd64SysV {
|
||||
sz -= rs;
|
||||
break;
|
||||
}
|
||||
case RegClass_SSEHv:
|
||||
case RegClass_SSEFv:
|
||||
case RegClass_SSEDv:
|
||||
case RegClass_SSEInt8:
|
||||
@@ -928,6 +937,10 @@ namespace lbAbiAmd64SysV {
|
||||
unsigned elems_per_word = 0;
|
||||
LLVMTypeRef elem_type = nullptr;
|
||||
switch (reg_class) {
|
||||
case RegClass_SSEHv:
|
||||
elems_per_word = 4;
|
||||
elem_type = LLVMHalfTypeInContext(c);
|
||||
break;
|
||||
case RegClass_SSEFv:
|
||||
elems_per_word = 2;
|
||||
elem_type = LLVMFloatTypeInContext(c);
|
||||
@@ -962,6 +975,10 @@ namespace lbAbiAmd64SysV {
|
||||
continue;
|
||||
}
|
||||
break;
|
||||
case RegClass_SSEHs:
|
||||
array_add(&types, LLVMHalfTypeInContext(c));
|
||||
sz -= 2;
|
||||
break;
|
||||
case RegClass_SSEFs:
|
||||
array_add(&types, LLVMFloatTypeInContext(c));
|
||||
sz -= 4;
|
||||
@@ -1008,9 +1025,11 @@ namespace lbAbiAmd64SysV {
|
||||
break;
|
||||
}
|
||||
case LLVMPointerTypeKind:
|
||||
case LLVMHalfTypeKind:
|
||||
unify(cls, ix + off/8, RegClass_Int);
|
||||
break;
|
||||
case LLVMHalfTypeKind:
|
||||
unify(cls, ix + off/8, (off%8 == 2) ? RegClass_SSEHv : RegClass_SSEHs);
|
||||
break;
|
||||
case LLVMFloatTypeKind:
|
||||
unify(cls, ix + off/8, (off%8 == 4) ? RegClass_SSEFv : RegClass_SSEFs);
|
||||
break;
|
||||
@@ -1070,7 +1089,7 @@ namespace lbAbiAmd64SysV {
|
||||
break;
|
||||
};
|
||||
case LLVMHalfTypeKind:
|
||||
reg = RegClass_SSEInt16;
|
||||
reg = RegClass_SSEHv;
|
||||
break;
|
||||
case LLVMFloatTypeKind:
|
||||
reg = RegClass_SSEFv;
|
||||
|
||||
Reference in New Issue
Block a user