core/builtins: Add llvm_intrinsics prefix
This commit is contained in:
parent
eecba0b71d
commit
7195476edb
@ -4,7 +4,7 @@ use crate::{
|
|||||||
classes::{ArrayLikeValue, NDArrayValue, RangeValue, TypedArrayLikeAccessor},
|
classes::{ArrayLikeValue, NDArrayValue, RangeValue, TypedArrayLikeAccessor},
|
||||||
expr::destructure_range,
|
expr::destructure_range,
|
||||||
irrt::*,
|
irrt::*,
|
||||||
llvm_intrinsics::*,
|
llvm_intrinsics,
|
||||||
numpy::*,
|
numpy::*,
|
||||||
stmt::exn_constructor,
|
stmt::exn_constructor,
|
||||||
},
|
},
|
||||||
@ -1054,7 +1054,7 @@ pub fn get_builtins(unifier: &mut Unifier, primitives: &PrimitiveStore) -> Built
|
|||||||
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
||||||
.into_float_value();
|
.into_float_value();
|
||||||
|
|
||||||
let val = call_float_round(ctx, arg, None);
|
let val = llvm_intrinsics::call_float_round(ctx, arg, None);
|
||||||
let val_toint = ctx.builder
|
let val_toint = ctx.builder
|
||||||
.build_float_to_signed_int(val, llvm_i32, "round")
|
.build_float_to_signed_int(val, llvm_i32, "round")
|
||||||
.unwrap();
|
.unwrap();
|
||||||
@ -1074,7 +1074,7 @@ pub fn get_builtins(unifier: &mut Unifier, primitives: &PrimitiveStore) -> Built
|
|||||||
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
||||||
.into_float_value();
|
.into_float_value();
|
||||||
|
|
||||||
let val = call_float_round(ctx, arg, None);
|
let val = llvm_intrinsics::call_float_round(ctx, arg, None);
|
||||||
let val_toint = ctx.builder
|
let val_toint = ctx.builder
|
||||||
.build_float_to_signed_int(val, llvm_i64, "round")
|
.build_float_to_signed_int(val, llvm_i64, "round")
|
||||||
.unwrap();
|
.unwrap();
|
||||||
@ -1092,7 +1092,7 @@ pub fn get_builtins(unifier: &mut Unifier, primitives: &PrimitiveStore) -> Built
|
|||||||
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
||||||
.into_float_value();
|
.into_float_value();
|
||||||
|
|
||||||
let val = call_float_roundeven(ctx, arg, None);
|
let val = llvm_intrinsics::call_float_roundeven(ctx, arg, None);
|
||||||
|
|
||||||
Ok(Some(val.into()))
|
Ok(Some(val.into()))
|
||||||
}),
|
}),
|
||||||
@ -1301,7 +1301,7 @@ pub fn get_builtins(unifier: &mut Unifier, primitives: &PrimitiveStore) -> Built
|
|||||||
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
||||||
.into_float_value();
|
.into_float_value();
|
||||||
|
|
||||||
let val = call_float_floor(ctx, arg, None);
|
let val = llvm_intrinsics::call_float_floor(ctx, arg, None);
|
||||||
let val_toint = ctx.builder
|
let val_toint = ctx.builder
|
||||||
.build_float_to_signed_int(val, llvm_i32, "floor")
|
.build_float_to_signed_int(val, llvm_i32, "floor")
|
||||||
.unwrap();
|
.unwrap();
|
||||||
@ -1321,7 +1321,7 @@ pub fn get_builtins(unifier: &mut Unifier, primitives: &PrimitiveStore) -> Built
|
|||||||
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
||||||
.into_float_value();
|
.into_float_value();
|
||||||
|
|
||||||
let val = call_float_floor(ctx, arg, None);
|
let val = llvm_intrinsics::call_float_floor(ctx, arg, None);
|
||||||
let val_toint = ctx.builder
|
let val_toint = ctx.builder
|
||||||
.build_float_to_signed_int(val, llvm_i64, "floor")
|
.build_float_to_signed_int(val, llvm_i64, "floor")
|
||||||
.unwrap();
|
.unwrap();
|
||||||
@ -1339,7 +1339,7 @@ pub fn get_builtins(unifier: &mut Unifier, primitives: &PrimitiveStore) -> Built
|
|||||||
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
||||||
.into_float_value();
|
.into_float_value();
|
||||||
|
|
||||||
let val = call_float_floor(ctx, arg, None);
|
let val = llvm_intrinsics::call_float_floor(ctx, arg, None);
|
||||||
Ok(Some(val.into()))
|
Ok(Some(val.into()))
|
||||||
}),
|
}),
|
||||||
),
|
),
|
||||||
@ -1356,7 +1356,7 @@ pub fn get_builtins(unifier: &mut Unifier, primitives: &PrimitiveStore) -> Built
|
|||||||
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
||||||
.into_float_value();
|
.into_float_value();
|
||||||
|
|
||||||
let val = call_float_ceil(ctx, arg, None);
|
let val = llvm_intrinsics::call_float_ceil(ctx, arg, None);
|
||||||
let val_toint = ctx.builder
|
let val_toint = ctx.builder
|
||||||
.build_float_to_signed_int(val, llvm_i32, "ceil")
|
.build_float_to_signed_int(val, llvm_i32, "ceil")
|
||||||
.unwrap();
|
.unwrap();
|
||||||
@ -1376,7 +1376,7 @@ pub fn get_builtins(unifier: &mut Unifier, primitives: &PrimitiveStore) -> Built
|
|||||||
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
||||||
.into_float_value();
|
.into_float_value();
|
||||||
|
|
||||||
let val = call_float_ceil(ctx, arg, None);
|
let val = llvm_intrinsics::call_float_ceil(ctx, arg, None);
|
||||||
let val_toint = ctx.builder
|
let val_toint = ctx.builder
|
||||||
.build_float_to_signed_int(val, llvm_i64, "ceil")
|
.build_float_to_signed_int(val, llvm_i64, "ceil")
|
||||||
.unwrap();
|
.unwrap();
|
||||||
@ -1394,7 +1394,7 @@ pub fn get_builtins(unifier: &mut Unifier, primitives: &PrimitiveStore) -> Built
|
|||||||
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
.to_basic_value_enum(ctx, generator, ctx.primitives.float)?
|
||||||
.into_float_value();
|
.into_float_value();
|
||||||
|
|
||||||
let val = call_float_ceil(ctx, arg, None);
|
let val = llvm_intrinsics::call_float_ceil(ctx, arg, None);
|
||||||
Ok(Some(val.into()))
|
Ok(Some(val.into()))
|
||||||
}),
|
}),
|
||||||
),
|
),
|
||||||
@ -1543,21 +1543,21 @@ pub fn get_builtins(unifier: &mut Unifier, primitives: &PrimitiveStore) -> Built
|
|||||||
unreachable!()
|
unreachable!()
|
||||||
}
|
}
|
||||||
let val: BasicValueEnum = if [boolean, uint32, uint64].iter().any(|t| is_type(n_ty, *t)) {
|
let val: BasicValueEnum = if [boolean, uint32, uint64].iter().any(|t| is_type(n_ty, *t)) {
|
||||||
call_int_umin(
|
llvm_intrinsics::call_int_umin(
|
||||||
ctx,
|
ctx,
|
||||||
m_val.into_int_value(),
|
m_val.into_int_value(),
|
||||||
n_val.into_int_value(),
|
n_val.into_int_value(),
|
||||||
Some("min"),
|
Some("min"),
|
||||||
).into()
|
).into()
|
||||||
} else if [int32, int64].iter().any(|t| is_type(n_ty, *t)) {
|
} else if [int32, int64].iter().any(|t| is_type(n_ty, *t)) {
|
||||||
call_int_smin(
|
llvm_intrinsics::call_int_smin(
|
||||||
ctx,
|
ctx,
|
||||||
m_val.into_int_value(),
|
m_val.into_int_value(),
|
||||||
n_val.into_int_value(),
|
n_val.into_int_value(),
|
||||||
Some("min"),
|
Some("min"),
|
||||||
).into()
|
).into()
|
||||||
} else if is_type(m_ty, n_ty) && is_type(n_ty, float) {
|
} else if is_type(m_ty, n_ty) && is_type(n_ty, float) {
|
||||||
call_float_minnum(
|
llvm_intrinsics::call_float_minnum(
|
||||||
ctx,
|
ctx,
|
||||||
m_val.into_float_value(),
|
m_val.into_float_value(),
|
||||||
n_val.into_float_value(),
|
n_val.into_float_value(),
|
||||||
@ -1603,21 +1603,21 @@ pub fn get_builtins(unifier: &mut Unifier, primitives: &PrimitiveStore) -> Built
|
|||||||
unreachable!()
|
unreachable!()
|
||||||
}
|
}
|
||||||
let val: BasicValueEnum = if [boolean, uint32, uint64].iter().any(|t| is_type(n_ty, *t)) {
|
let val: BasicValueEnum = if [boolean, uint32, uint64].iter().any(|t| is_type(n_ty, *t)) {
|
||||||
call_int_umax(
|
llvm_intrinsics::call_int_umax(
|
||||||
ctx,
|
ctx,
|
||||||
m_val.into_int_value(),
|
m_val.into_int_value(),
|
||||||
n_val.into_int_value(),
|
n_val.into_int_value(),
|
||||||
Some("max"),
|
Some("max"),
|
||||||
).into()
|
).into()
|
||||||
} else if [int32, int64].iter().any(|t| is_type(n_ty, *t)) {
|
} else if [int32, int64].iter().any(|t| is_type(n_ty, *t)) {
|
||||||
call_int_smax(
|
llvm_intrinsics::call_int_smax(
|
||||||
ctx,
|
ctx,
|
||||||
m_val.into_int_value(),
|
m_val.into_int_value(),
|
||||||
n_val.into_int_value(),
|
n_val.into_int_value(),
|
||||||
Some("max"),
|
Some("max"),
|
||||||
).into()
|
).into()
|
||||||
} else if is_type(m_ty, n_ty) && is_type(n_ty, float) {
|
} else if is_type(m_ty, n_ty) && is_type(n_ty, float) {
|
||||||
call_float_maxnum(
|
llvm_intrinsics::call_float_maxnum(
|
||||||
ctx,
|
ctx,
|
||||||
m_val.into_float_value(),
|
m_val.into_float_value(),
|
||||||
n_val.into_float_value(),
|
n_val.into_float_value(),
|
||||||
@ -1658,14 +1658,14 @@ pub fn get_builtins(unifier: &mut Unifier, primitives: &PrimitiveStore) -> Built
|
|||||||
let val: BasicValueEnum = if [boolean, uint32, uint64].iter().any(|t| is_type(n_ty, *t)) {
|
let val: BasicValueEnum = if [boolean, uint32, uint64].iter().any(|t| is_type(n_ty, *t)) {
|
||||||
n_val
|
n_val
|
||||||
} else if [int32, int64].iter().any(|t| is_type(n_ty, *t)) {
|
} else if [int32, int64].iter().any(|t| is_type(n_ty, *t)) {
|
||||||
call_int_abs(
|
llvm_intrinsics::call_int_abs(
|
||||||
ctx,
|
ctx,
|
||||||
n_val.into_int_value(),
|
n_val.into_int_value(),
|
||||||
llvm_i1.const_zero(),
|
llvm_i1.const_zero(),
|
||||||
Some("abs"),
|
Some("abs"),
|
||||||
).into()
|
).into()
|
||||||
} else if is_type(n_ty, float) {
|
} else if is_type(n_ty, float) {
|
||||||
call_float_fabs(
|
llvm_intrinsics::call_float_fabs(
|
||||||
ctx,
|
ctx,
|
||||||
n_val.into_float_value(),
|
n_val.into_float_value(),
|
||||||
Some("abs"),
|
Some("abs"),
|
||||||
|
Loading…
Reference in New Issue
Block a user