aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2021-10-02 18:12:34 +0100
committergingerBill <bill@gingerbill.org>2021-10-02 18:12:34 +0100
commit036fa5cb24609655094b7292b16277aca0db975d (patch)
tree2c7a82d34aafe0353394f686cc23b6976570d4b7 /src
parent81fe50d623c1edb2df1334a2ef906bfc219bd18b (diff)
Correct ABI for windows with LLVM
Diffstat (limited to 'src')
-rw-r--r--src/llvm_abi.cpp6
-rw-r--r--src/llvm_backend_general.cpp2
2 files changed, 5 insertions, 3 deletions
diff --git a/src/llvm_abi.cpp b/src/llvm_abi.cpp
index 83de3dd84..8d3d5542f 100644
--- a/src/llvm_abi.cpp
+++ b/src/llvm_abi.cpp
@@ -239,7 +239,7 @@ i64 lb_alignof(LLVMTypeRef type) {
case LLVMIntegerTypeKind:
{
unsigned w = LLVMGetIntTypeWidth(type);
- return gb_clamp((w + 7)/8, 1, build_context.max_align);
+ return gb_clamp((w + 7)/8, 1, build_context.word_size);
}
case LLVMHalfTypeKind:
return 2;
@@ -342,7 +342,7 @@ namespace lbAbi386 {
LLVMTypeRef t = arg_types[i];
LLVMTypeKind kind = LLVMGetTypeKind(t);
i64 sz = lb_sizeof(t);
- if (kind == LLVMStructTypeKind) {
+ if (kind == LLVMStructTypeKind || kind == LLVMArrayTypeKind) {
if (sz == 0) {
args[i] = lb_arg_type_ignore(t);
} else {
@@ -392,7 +392,7 @@ namespace lbAbiAmd64Win64 {
for (unsigned i = 0; i < arg_count; i++) {
LLVMTypeRef t = arg_types[i];
LLVMTypeKind kind = LLVMGetTypeKind(t);
- if (kind == LLVMStructTypeKind) {
+ if (kind == LLVMStructTypeKind || kind == LLVMArrayTypeKind) {
i64 sz = lb_sizeof(t);
switch (sz) {
case 1:
diff --git a/src/llvm_backend_general.cpp b/src/llvm_backend_general.cpp
index f5ff583a9..094275429 100644
--- a/src/llvm_backend_general.cpp
+++ b/src/llvm_backend_general.cpp
@@ -1736,10 +1736,12 @@ LLVMTypeRef lb_type_internal(lbModule *m, Type *type) {
LLVMTypeRef struct_type = LLVMStructTypeInContext(ctx, fields.data, cast(unsigned)fields.count, type->Struct.is_packed);
map_set(&m->struct_field_remapping, hash_pointer(struct_type), field_remapping);
map_set(&m->struct_field_remapping, hash_pointer(type), field_remapping);
+ #if 0
GB_ASSERT_MSG(lb_sizeof(struct_type) == full_type_size,
"(%lld) %s vs (%lld) %s",
cast(long long)lb_sizeof(struct_type), LLVMPrintTypeToString(struct_type),
cast(long long)full_type_size, type_to_string(type));
+ #endif
return struct_type;
}
break;