cairo_lang_sierra/extensions/modules/int/
unsigned128.rsuse super::unsigned::{
Uint64Type, UintBitwiseLibfunc, UintDivmodLibfunc, UintOperationLibfunc, UintSquareRootLibfunc,
UintTraits,
};
use super::{IntConstLibfunc, IntEqualLibfunc, IntToFelt252Libfunc, IntTraits, IntType};
use crate::define_libfunc_hierarchy;
use crate::extensions::bitwise::BitwiseType;
use crate::extensions::felt252::Felt252Type;
use crate::extensions::is_zero::{IsZeroLibfunc, IsZeroTraits};
use crate::extensions::lib_func::{
BranchSignature, DeferredOutputKind, LibfuncSignature, OutputVarInfo, ParamSignature,
SierraApChange, SignatureSpecializationContext,
};
use crate::extensions::range_check::RangeCheckType;
use crate::extensions::{
NamedType, NoGenericArgsGenericLibfunc, NoGenericArgsGenericType, OutputVarReferenceInfo,
SpecializationError,
};
use crate::ids::GenericTypeId;
pub type Uint128Type = IntType<Uint128Traits>;
#[derive(Default)]
pub struct U128MulGuaranteeType;
impl NoGenericArgsGenericType for U128MulGuaranteeType {
const ID: GenericTypeId = GenericTypeId::new_inline("U128MulGuarantee");
const STORABLE: bool = true;
const DUPLICATABLE: bool = false;
const DROPPABLE: bool = false;
const ZERO_SIZED: bool = false;
}
define_libfunc_hierarchy! {
pub enum Uint128Libfunc {
Operation(UintOperationLibfunc<Uint128Traits>),
Divmod(UintDivmodLibfunc<Uint128Traits>),
GuaranteeMul(U128GuaranteeMulLibfunc),
MulGuaranteeVerify(U128MulGuaranteeVerifyLibfunc),
Equal(IntEqualLibfunc<Uint128Traits>),
SquareRoot(UintSquareRootLibfunc<Uint128Traits>),
Const(IntConstLibfunc<Uint128Traits>),
FromFelt252(Uint128sFromFelt252Libfunc),
ToFelt252(IntToFelt252Libfunc<Uint128Traits>),
IsZero(IsZeroLibfunc<Uint128Traits>),
Bitwise(UintBitwiseLibfunc<Uint128Traits>),
ByteReverse(U128ByteReverseLibfunc),
}, Uint128Concrete
}
#[derive(Default)]
pub struct Uint128Traits;
impl IntTraits for Uint128Traits {
type IntType = u128;
const GENERIC_TYPE_ID: GenericTypeId = GenericTypeId::new_inline("u128");
const IS_SMALL: bool = false;
const CONST: &'static str = "u128_const";
const EQUAL: &'static str = "u128_eq";
const TO_FELT252: &'static str = "u128_to_felt252";
const TRY_FROM_FELT252: &'static str = "u128_try_from_felt252";
}
impl UintTraits for Uint128Traits {
const OVERFLOWING_ADD: &'static str = "u128_overflowing_add";
const OVERFLOWING_SUB: &'static str = "u128_overflowing_sub";
const SQUARE_ROOT: &'static str = "u128_sqrt";
const SQUARE_ROOT_TYPE_ID: GenericTypeId = <Uint64Type as NamedType>::ID;
const DIVMOD: &'static str = "u128_safe_divmod";
const BITWISE: &'static str = "bitwise";
}
impl IsZeroTraits for Uint128Traits {
const IS_ZERO: &'static str = "u128_is_zero";
const GENERIC_TYPE_ID: GenericTypeId = <Uint128Type as NamedType>::ID;
}
#[derive(Default)]
pub struct U128GuaranteeMulLibfunc {}
impl NoGenericArgsGenericLibfunc for U128GuaranteeMulLibfunc {
const STR_ID: &'static str = "u128_guarantee_mul";
fn specialize_signature(
&self,
context: &dyn SignatureSpecializationContext,
) -> Result<LibfuncSignature, SpecializationError> {
let u128_type = context.get_concrete_type(Uint128Type::id(), &[])?;
Ok(LibfuncSignature::new_non_branch_ex(
vec![ParamSignature::new(u128_type.clone()), ParamSignature::new(u128_type.clone())],
vec![
OutputVarInfo {
ty: u128_type.clone(),
ref_info: OutputVarReferenceInfo::NewTempVar { idx: 0 },
},
OutputVarInfo {
ty: u128_type,
ref_info: OutputVarReferenceInfo::NewTempVar { idx: 1 },
},
OutputVarInfo {
ty: context.get_concrete_type(U128MulGuaranteeType::id(), &[])?,
ref_info: OutputVarReferenceInfo::SimpleDerefs,
},
],
SierraApChange::Known { new_vars_only: true },
))
}
}
#[derive(Default)]
pub struct U128MulGuaranteeVerifyLibfunc {}
impl NoGenericArgsGenericLibfunc for U128MulGuaranteeVerifyLibfunc {
const STR_ID: &'static str = "u128_mul_guarantee_verify";
fn specialize_signature(
&self,
context: &dyn SignatureSpecializationContext,
) -> Result<LibfuncSignature, SpecializationError> {
let range_check_type = context.get_concrete_type(RangeCheckType::id(), &[])?;
Ok(LibfuncSignature::new_non_branch_ex(
vec![
ParamSignature::new(range_check_type.clone()).with_allow_add_const(),
ParamSignature::new(context.get_concrete_type(U128MulGuaranteeType::id(), &[])?),
],
vec![OutputVarInfo::new_builtin(range_check_type, 0)],
SierraApChange::Known { new_vars_only: false },
))
}
}
#[derive(Default)]
pub struct Uint128sFromFelt252Libfunc {}
impl NoGenericArgsGenericLibfunc for Uint128sFromFelt252Libfunc {
const STR_ID: &'static str = "u128s_from_felt252";
fn specialize_signature(
&self,
context: &dyn SignatureSpecializationContext,
) -> Result<LibfuncSignature, SpecializationError> {
let range_check_type = context.get_concrete_type(RangeCheckType::id(), &[])?;
let rc_output_info = OutputVarInfo::new_builtin(range_check_type.clone(), 0);
Ok(LibfuncSignature {
param_signatures: vec![
ParamSignature::new(range_check_type).with_allow_add_const(),
ParamSignature::new(context.get_concrete_type(Felt252Type::id(), &[])?),
],
branch_signatures: vec![
BranchSignature {
vars: vec![
rc_output_info.clone(),
OutputVarInfo {
ty: context.get_concrete_type(Uint128Type::id(), &[])?,
ref_info: OutputVarReferenceInfo::SameAsParam { param_idx: 1 },
},
],
ap_change: SierraApChange::Known { new_vars_only: false },
},
BranchSignature {
vars: vec![
rc_output_info,
OutputVarInfo {
ty: context.get_concrete_type(Uint128Type::id(), &[])?,
ref_info: OutputVarReferenceInfo::NewTempVar { idx: 0 },
},
OutputVarInfo {
ty: context.get_concrete_type(Uint128Type::id(), &[])?,
ref_info: OutputVarReferenceInfo::NewTempVar { idx: 1 },
},
],
ap_change: SierraApChange::Known { new_vars_only: false },
},
],
fallthrough: Some(0),
})
}
}
#[derive(Default)]
pub struct U128ByteReverseLibfunc {}
impl NoGenericArgsGenericLibfunc for U128ByteReverseLibfunc {
const STR_ID: &'static str = "u128_byte_reverse";
fn specialize_signature(
&self,
context: &dyn SignatureSpecializationContext,
) -> Result<LibfuncSignature, SpecializationError> {
let bitwise_ty = context.get_concrete_type(BitwiseType::id(), &[])?;
let u128_ty = context.get_concrete_type(Uint128Type::id(), &[])?;
Ok(LibfuncSignature::new_non_branch_ex(
vec![
ParamSignature::new(bitwise_ty.clone()).with_allow_add_const(),
ParamSignature::new(u128_ty.clone()),
],
vec![
OutputVarInfo::new_builtin(bitwise_ty, 0),
OutputVarInfo {
ty: u128_ty,
ref_info: OutputVarReferenceInfo::Deferred(DeferredOutputKind::Generic),
},
],
SierraApChange::Known { new_vars_only: false },
))
}
}