forked from libre-chip/fayalite
split int::IntCmp into expr::HdlPartialEq and expr::HdlPartialOrd
This commit is contained in:
parent
9ad4ec0f39
commit
78edfc97b2
|
@ -641,6 +641,18 @@ impl<T: PortType> GetTarget for MemPort<T> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub trait HdlPartialEq<Rhs> {
|
||||||
|
fn cmp_eq(self, rhs: Rhs) -> Expr<Bool>;
|
||||||
|
fn cmp_ne(self, rhs: Rhs) -> Expr<Bool>;
|
||||||
|
}
|
||||||
|
|
||||||
|
pub trait HdlPartialOrd<Rhs>: HdlPartialEq<Rhs> {
|
||||||
|
fn cmp_lt(self, rhs: Rhs) -> Expr<Bool>;
|
||||||
|
fn cmp_le(self, rhs: Rhs) -> Expr<Bool>;
|
||||||
|
fn cmp_gt(self, rhs: Rhs) -> Expr<Bool>;
|
||||||
|
fn cmp_ge(self, rhs: Rhs) -> Expr<Bool>;
|
||||||
|
}
|
||||||
|
|
||||||
pub trait ReduceBits {
|
pub trait ReduceBits {
|
||||||
type UIntOutput;
|
type UIntOutput;
|
||||||
type BoolOutput;
|
type BoolOutput;
|
||||||
|
|
|
@ -11,11 +11,12 @@ use crate::{
|
||||||
GetTarget, Target, TargetPathArrayElement, TargetPathBundleField,
|
GetTarget, Target, TargetPathArrayElement, TargetPathBundleField,
|
||||||
TargetPathDynArrayElement, TargetPathElement,
|
TargetPathDynArrayElement, TargetPathElement,
|
||||||
},
|
},
|
||||||
CastTo, Expr, ExprEnum, Flow, NotALiteralExpr, ReduceBits, ToExpr, ToLiteralBits,
|
CastTo, Expr, ExprEnum, Flow, HdlPartialEq, HdlPartialOrd, NotALiteralExpr, ReduceBits,
|
||||||
|
ToExpr, ToLiteralBits,
|
||||||
},
|
},
|
||||||
int::{
|
int::{
|
||||||
Bool, BoolOrIntType, DynSize, IntCmp, IntType, KnownSize, SInt, SIntType, SIntValue, Size,
|
Bool, BoolOrIntType, DynSize, IntType, KnownSize, SInt, SIntType, SIntValue, Size, UInt,
|
||||||
UInt, UIntType, UIntValue,
|
UIntType, UIntValue,
|
||||||
},
|
},
|
||||||
intern::{Intern, Interned},
|
intern::{Intern, Interned},
|
||||||
reset::{AsyncReset, Reset, SyncReset, ToAsyncReset, ToReset, ToSyncReset},
|
reset::{AsyncReset, Reset, SyncReset, ToAsyncReset, ToReset, ToSyncReset},
|
||||||
|
@ -1422,36 +1423,45 @@ forward_value_to_expr_binary_op_trait! {
|
||||||
Shr::shr
|
Shr::shr
|
||||||
}
|
}
|
||||||
|
|
||||||
pub trait IntCmpExpr<Rhs: Type>: Type {
|
pub trait ExprPartialEq<Rhs: Type>: Type {
|
||||||
fn cmp_eq(lhs: Expr<Self>, rhs: Expr<Rhs>) -> Expr<Bool>;
|
fn cmp_eq(lhs: Expr<Self>, rhs: Expr<Rhs>) -> Expr<Bool>;
|
||||||
fn cmp_ne(lhs: Expr<Self>, rhs: Expr<Rhs>) -> Expr<Bool>;
|
fn cmp_ne(lhs: Expr<Self>, rhs: Expr<Rhs>) -> Expr<Bool>;
|
||||||
|
}
|
||||||
|
|
||||||
|
pub trait ExprPartialOrd<Rhs: Type>: ExprPartialEq<Rhs> {
|
||||||
fn cmp_lt(lhs: Expr<Self>, rhs: Expr<Rhs>) -> Expr<Bool>;
|
fn cmp_lt(lhs: Expr<Self>, rhs: Expr<Rhs>) -> Expr<Bool>;
|
||||||
fn cmp_le(lhs: Expr<Self>, rhs: Expr<Rhs>) -> Expr<Bool>;
|
fn cmp_le(lhs: Expr<Self>, rhs: Expr<Rhs>) -> Expr<Bool>;
|
||||||
fn cmp_gt(lhs: Expr<Self>, rhs: Expr<Rhs>) -> Expr<Bool>;
|
fn cmp_gt(lhs: Expr<Self>, rhs: Expr<Rhs>) -> Expr<Bool>;
|
||||||
fn cmp_ge(lhs: Expr<Self>, rhs: Expr<Rhs>) -> Expr<Bool>;
|
fn cmp_ge(lhs: Expr<Self>, rhs: Expr<Rhs>) -> Expr<Bool>;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<Lhs: ToExpr, Rhs: ToExpr> IntCmp<Rhs> for Lhs
|
impl<Lhs: ToExpr, Rhs: ToExpr> HdlPartialEq<Rhs> for Lhs
|
||||||
where
|
where
|
||||||
Lhs::Type: IntCmpExpr<Rhs::Type>,
|
Lhs::Type: ExprPartialEq<Rhs::Type>,
|
||||||
{
|
{
|
||||||
fn cmp_eq(self, rhs: Rhs) -> Expr<Bool> {
|
fn cmp_eq(self, rhs: Rhs) -> Expr<Bool> {
|
||||||
IntCmpExpr::cmp_eq(self.to_expr(), rhs.to_expr())
|
ExprPartialEq::cmp_eq(self.to_expr(), rhs.to_expr())
|
||||||
}
|
}
|
||||||
fn cmp_ne(self, rhs: Rhs) -> Expr<Bool> {
|
fn cmp_ne(self, rhs: Rhs) -> Expr<Bool> {
|
||||||
IntCmpExpr::cmp_ne(self.to_expr(), rhs.to_expr())
|
ExprPartialEq::cmp_ne(self.to_expr(), rhs.to_expr())
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<Lhs: ToExpr, Rhs: ToExpr> HdlPartialOrd<Rhs> for Lhs
|
||||||
|
where
|
||||||
|
Lhs::Type: ExprPartialOrd<Rhs::Type>,
|
||||||
|
{
|
||||||
fn cmp_lt(self, rhs: Rhs) -> Expr<Bool> {
|
fn cmp_lt(self, rhs: Rhs) -> Expr<Bool> {
|
||||||
IntCmpExpr::cmp_lt(self.to_expr(), rhs.to_expr())
|
ExprPartialOrd::cmp_lt(self.to_expr(), rhs.to_expr())
|
||||||
}
|
}
|
||||||
fn cmp_le(self, rhs: Rhs) -> Expr<Bool> {
|
fn cmp_le(self, rhs: Rhs) -> Expr<Bool> {
|
||||||
IntCmpExpr::cmp_le(self.to_expr(), rhs.to_expr())
|
ExprPartialOrd::cmp_le(self.to_expr(), rhs.to_expr())
|
||||||
}
|
}
|
||||||
fn cmp_gt(self, rhs: Rhs) -> Expr<Bool> {
|
fn cmp_gt(self, rhs: Rhs) -> Expr<Bool> {
|
||||||
IntCmpExpr::cmp_gt(self.to_expr(), rhs.to_expr())
|
ExprPartialOrd::cmp_gt(self.to_expr(), rhs.to_expr())
|
||||||
}
|
}
|
||||||
fn cmp_ge(self, rhs: Rhs) -> Expr<Bool> {
|
fn cmp_ge(self, rhs: Rhs) -> Expr<Bool> {
|
||||||
IntCmpExpr::cmp_ge(self.to_expr(), rhs.to_expr())
|
ExprPartialOrd::cmp_ge(self.to_expr(), rhs.to_expr())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1461,6 +1471,7 @@ macro_rules! impl_compare_op {
|
||||||
#[dyn_type($DynTy:ident)]
|
#[dyn_type($DynTy:ident)]
|
||||||
#[to_dyn_type($lhs:ident => $dyn_lhs:expr, $rhs:ident => $dyn_rhs:expr)]
|
#[to_dyn_type($lhs:ident => $dyn_lhs:expr, $rhs:ident => $dyn_rhs:expr)]
|
||||||
#[type($Lhs:ty, $Rhs:ty)]
|
#[type($Lhs:ty, $Rhs:ty)]
|
||||||
|
#[trait($Trait:ident)]
|
||||||
$(
|
$(
|
||||||
struct $name:ident;
|
struct $name:ident;
|
||||||
fn $method:ident();
|
fn $method:ident();
|
||||||
|
@ -1512,7 +1523,7 @@ macro_rules! impl_compare_op {
|
||||||
}
|
}
|
||||||
})*
|
})*
|
||||||
|
|
||||||
impl$(<$LhsWidth: Size, $RhsWidth: Size>)? IntCmpExpr<$Rhs> for $Lhs {
|
impl$(<$LhsWidth: Size, $RhsWidth: Size>)? $Trait<$Rhs> for $Lhs {
|
||||||
$(fn $method($lhs: Expr<Self>, $rhs: Expr<$Rhs>) -> Expr<Bool> {
|
$(fn $method($lhs: Expr<Self>, $rhs: Expr<$Rhs>) -> Expr<Bool> {
|
||||||
$name::new($dyn_lhs, $dyn_rhs).to_expr()
|
$name::new($dyn_lhs, $dyn_rhs).to_expr()
|
||||||
})*
|
})*
|
||||||
|
@ -1524,8 +1535,16 @@ impl_compare_op! {
|
||||||
#[dyn_type(Bool)]
|
#[dyn_type(Bool)]
|
||||||
#[to_dyn_type(lhs => lhs, rhs => rhs)]
|
#[to_dyn_type(lhs => lhs, rhs => rhs)]
|
||||||
#[type(Bool, Bool)]
|
#[type(Bool, Bool)]
|
||||||
|
#[trait(ExprPartialEq)]
|
||||||
struct CmpEqB; fn cmp_eq(); PartialEq::eq();
|
struct CmpEqB; fn cmp_eq(); PartialEq::eq();
|
||||||
struct CmpNeB; fn cmp_ne(); PartialEq::ne();
|
struct CmpNeB; fn cmp_ne(); PartialEq::ne();
|
||||||
|
}
|
||||||
|
|
||||||
|
impl_compare_op! {
|
||||||
|
#[dyn_type(Bool)]
|
||||||
|
#[to_dyn_type(lhs => lhs, rhs => rhs)]
|
||||||
|
#[type(Bool, Bool)]
|
||||||
|
#[trait(ExprPartialOrd)]
|
||||||
struct CmpLtB; fn cmp_lt(); PartialOrd::lt();
|
struct CmpLtB; fn cmp_lt(); PartialOrd::lt();
|
||||||
struct CmpLeB; fn cmp_le(); PartialOrd::le();
|
struct CmpLeB; fn cmp_le(); PartialOrd::le();
|
||||||
struct CmpGtB; fn cmp_gt(); PartialOrd::gt();
|
struct CmpGtB; fn cmp_gt(); PartialOrd::gt();
|
||||||
|
@ -1537,8 +1556,17 @@ impl_compare_op! {
|
||||||
#[dyn_type(UInt)]
|
#[dyn_type(UInt)]
|
||||||
#[to_dyn_type(lhs => Expr::as_dyn_int(lhs), rhs => Expr::as_dyn_int(rhs))]
|
#[to_dyn_type(lhs => Expr::as_dyn_int(lhs), rhs => Expr::as_dyn_int(rhs))]
|
||||||
#[type(UIntType<LhsWidth>, UIntType<RhsWidth>)]
|
#[type(UIntType<LhsWidth>, UIntType<RhsWidth>)]
|
||||||
|
#[trait(ExprPartialEq)]
|
||||||
struct CmpEqU; fn cmp_eq(); PartialEq::eq();
|
struct CmpEqU; fn cmp_eq(); PartialEq::eq();
|
||||||
struct CmpNeU; fn cmp_ne(); PartialEq::ne();
|
struct CmpNeU; fn cmp_ne(); PartialEq::ne();
|
||||||
|
}
|
||||||
|
|
||||||
|
impl_compare_op! {
|
||||||
|
#[width(LhsWidth, RhsWidth)]
|
||||||
|
#[dyn_type(UInt)]
|
||||||
|
#[to_dyn_type(lhs => Expr::as_dyn_int(lhs), rhs => Expr::as_dyn_int(rhs))]
|
||||||
|
#[type(UIntType<LhsWidth>, UIntType<RhsWidth>)]
|
||||||
|
#[trait(ExprPartialOrd)]
|
||||||
struct CmpLtU; fn cmp_lt(); PartialOrd::lt();
|
struct CmpLtU; fn cmp_lt(); PartialOrd::lt();
|
||||||
struct CmpLeU; fn cmp_le(); PartialOrd::le();
|
struct CmpLeU; fn cmp_le(); PartialOrd::le();
|
||||||
struct CmpGtU; fn cmp_gt(); PartialOrd::gt();
|
struct CmpGtU; fn cmp_gt(); PartialOrd::gt();
|
||||||
|
@ -1550,8 +1578,17 @@ impl_compare_op! {
|
||||||
#[dyn_type(SInt)]
|
#[dyn_type(SInt)]
|
||||||
#[to_dyn_type(lhs => Expr::as_dyn_int(lhs), rhs => Expr::as_dyn_int(rhs))]
|
#[to_dyn_type(lhs => Expr::as_dyn_int(lhs), rhs => Expr::as_dyn_int(rhs))]
|
||||||
#[type(SIntType<LhsWidth>, SIntType<RhsWidth>)]
|
#[type(SIntType<LhsWidth>, SIntType<RhsWidth>)]
|
||||||
|
#[trait(ExprPartialEq)]
|
||||||
struct CmpEqS; fn cmp_eq(); PartialEq::eq();
|
struct CmpEqS; fn cmp_eq(); PartialEq::eq();
|
||||||
struct CmpNeS; fn cmp_ne(); PartialEq::ne();
|
struct CmpNeS; fn cmp_ne(); PartialEq::ne();
|
||||||
|
}
|
||||||
|
|
||||||
|
impl_compare_op! {
|
||||||
|
#[width(LhsWidth, RhsWidth)]
|
||||||
|
#[dyn_type(SInt)]
|
||||||
|
#[to_dyn_type(lhs => Expr::as_dyn_int(lhs), rhs => Expr::as_dyn_int(rhs))]
|
||||||
|
#[type(SIntType<LhsWidth>, SIntType<RhsWidth>)]
|
||||||
|
#[trait(ExprPartialOrd)]
|
||||||
struct CmpLtS; fn cmp_lt(); PartialOrd::lt();
|
struct CmpLtS; fn cmp_lt(); PartialOrd::lt();
|
||||||
struct CmpLeS; fn cmp_le(); PartialOrd::le();
|
struct CmpLeS; fn cmp_le(); PartialOrd::le();
|
||||||
struct CmpGtS; fn cmp_gt(); PartialOrd::gt();
|
struct CmpGtS; fn cmp_gt(); PartialOrd::gt();
|
||||||
|
|
|
@ -679,15 +679,6 @@ impl StaticType for Bool {
|
||||||
const MASK_TYPE_PROPERTIES: TypeProperties = Bool::TYPE_PROPERTIES;
|
const MASK_TYPE_PROPERTIES: TypeProperties = Bool::TYPE_PROPERTIES;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub trait IntCmp<Rhs> {
|
|
||||||
fn cmp_eq(self, rhs: Rhs) -> Expr<Bool>;
|
|
||||||
fn cmp_ne(self, rhs: Rhs) -> Expr<Bool>;
|
|
||||||
fn cmp_lt(self, rhs: Rhs) -> Expr<Bool>;
|
|
||||||
fn cmp_le(self, rhs: Rhs) -> Expr<Bool>;
|
|
||||||
fn cmp_gt(self, rhs: Rhs) -> Expr<Bool>;
|
|
||||||
fn cmp_ge(self, rhs: Rhs) -> Expr<Bool>;
|
|
||||||
}
|
|
||||||
|
|
||||||
impl ToLiteralBits for bool {
|
impl ToLiteralBits for bool {
|
||||||
fn to_literal_bits(&self) -> Result<Interned<BitSlice>, NotALiteralExpr> {
|
fn to_literal_bits(&self) -> Result<Interned<BitSlice>, NotALiteralExpr> {
|
||||||
Ok(interned_bit(*self))
|
Ok(interned_bit(*self))
|
||||||
|
|
|
@ -6,10 +6,10 @@ use crate::{
|
||||||
enum_::{Enum, EnumType, EnumVariant},
|
enum_::{Enum, EnumType, EnumVariant},
|
||||||
expr::{
|
expr::{
|
||||||
ops::{self, EnumLiteral},
|
ops::{self, EnumLiteral},
|
||||||
CastBitsTo, CastToBits, Expr, ExprEnum, ToExpr,
|
CastBitsTo, CastToBits, Expr, ExprEnum, HdlPartialEq, ToExpr,
|
||||||
},
|
},
|
||||||
hdl,
|
hdl,
|
||||||
int::{DynSize, IntCmp, Size, UInt, UIntType},
|
int::{DynSize, Size, UInt, UIntType},
|
||||||
intern::{Intern, Interned},
|
intern::{Intern, Interned},
|
||||||
memory::{DynPortType, Mem, MemPort},
|
memory::{DynPortType, Mem, MemPort},
|
||||||
module::{
|
module::{
|
||||||
|
|
|
@ -6,9 +6,12 @@ pub use crate::{
|
||||||
cli::Cli,
|
cli::Cli,
|
||||||
clock::{Clock, ClockDomain, ToClock},
|
clock::{Clock, ClockDomain, ToClock},
|
||||||
enum_::{HdlNone, HdlOption, HdlSome},
|
enum_::{HdlNone, HdlOption, HdlSome},
|
||||||
expr::{CastBitsTo, CastTo, CastToBits, Expr, MakeUninitExpr, ReduceBits, ToExpr},
|
expr::{
|
||||||
|
CastBitsTo, CastTo, CastToBits, Expr, HdlPartialEq, HdlPartialOrd, MakeUninitExpr,
|
||||||
|
ReduceBits, ToExpr,
|
||||||
|
},
|
||||||
hdl, hdl_module,
|
hdl, hdl_module,
|
||||||
int::{Bool, DynSize, IntCmp, KnownSize, SInt, SIntType, Size, UInt, UIntType},
|
int::{Bool, DynSize, KnownSize, SInt, SIntType, Size, UInt, UIntType},
|
||||||
memory::{Mem, MemBuilder, ReadUnderWrite},
|
memory::{Mem, MemBuilder, ReadUnderWrite},
|
||||||
module::{
|
module::{
|
||||||
annotate, connect, connect_any, incomplete_wire, instance, memory, memory_array,
|
annotate, connect, connect_any, incomplete_wire, instance, memory, memory_array,
|
||||||
|
|
Loading…
Reference in a new issue