aboutsummaryrefslogtreecommitdiff
path: root/src/llvm_backend_expr.cpp
diff options
context:
space:
mode:
authorLaytan <laytanlaats@hotmail.com>2024-08-12 13:54:28 +0200
committerGitHub <noreply@github.com>2024-08-12 13:54:28 +0200
commitfd9a008e1ec75cd9340692635087e032caabb64c (patch)
tree315cf2788b77bc8f4b18c80c873b1bcea1adb070 /src/llvm_backend_expr.cpp
parent450fc3ec778750573d34c96b576ba5e64e94bde4 (diff)
parente3f375afd8e1c08c82818d7132296c277d871436 (diff)
Merge pull request #4058 from laytan/fix-cvararg-bitset
fix c_vararg bit_set
Diffstat (limited to 'src/llvm_backend_expr.cpp')
-rw-r--r--src/llvm_backend_expr.cpp11
1 files changed, 11 insertions, 0 deletions
diff --git a/src/llvm_backend_expr.cpp b/src/llvm_backend_expr.cpp
index f843dfa92..962082cae 100644
--- a/src/llvm_backend_expr.cpp
+++ b/src/llvm_backend_expr.cpp
@@ -2469,6 +2469,17 @@ gb_internal lbValue lb_emit_conv(lbProcedure *p, lbValue value, Type *t) {
return {};
}
+gb_internal lbValue lb_emit_c_vararg(lbProcedure *p, lbValue arg, Type *type) {
+ Type *core = core_type(type);
+ if (core->kind == Type_BitSet) {
+ core = core_type(bit_set_to_int(core));
+ arg = lb_emit_transmute(p, arg, core);
+ }
+
+ Type *promoted = c_vararg_promote_type(core);
+ return lb_emit_conv(p, arg, promoted);
+}
+
gb_internal lbValue lb_compare_records(lbProcedure *p, TokenKind op_kind, lbValue left, lbValue right, Type *type) {
GB_ASSERT((is_type_struct(type) || is_type_union(type)) && is_type_comparable(type));
lbValue left_ptr = lb_address_from_load_or_generate_local(p, left);