diff --git a/core/src/main/scala/chisel3/ChiselEnumImpl.scala b/core/src/main/scala/chisel3/ChiselEnumImpl.scala index 967a5e39ae4..95c3c63abe4 100644 --- a/core/src/main/scala/chisel3/ChiselEnumImpl.scala +++ b/core/src/main/scala/chisel3/ChiselEnumImpl.scala @@ -70,8 +70,8 @@ private[chisel3] abstract class EnumTypeImpl(private[chisel3] val factory: Chise _wire := this.asUInt _wire } - _padded.asTypeOf(that) - case None => super.asTypeOf(that) + _padded._asTypeOfImpl(that) + case None => super._asTypeOfImpl(that) } } @@ -222,15 +222,7 @@ private[chisel3] abstract class EnumTypeImpl(private[chisel3] val factory: Chise for ((name, value) <- allNamesPadded) { when(this === value) { for ((r, c) <- result.zip(name)) { - // todo: this doesn't work in scala3 - // r := c.toChar.U - // ^^^^^^^^^^ - // value U is not a member of Char. - // An extension method was tried, - // but could not be fully constructed: - // - // chisel3.fromLongToLiteral(c.toChar) - // r := c.toChar.U + r := asUInt(c) } } } diff --git a/core/src/main/scala/chisel3/DataImpl.scala b/core/src/main/scala/chisel3/DataImpl.scala index dc7201ca7fd..062aba1f1fc 100644 --- a/core/src/main/scala/chisel3/DataImpl.scala +++ b/core/src/main/scala/chisel3/DataImpl.scala @@ -861,7 +861,7 @@ private[chisel3] trait DataImpl extends HasId with NamedComponent { self: Data = /** Returns Some(width) if the width is known, else None. */ final def widthOption: Option[Int] = if (isWidthKnown) Some(getWidth) else None - protected def _asTypeOfImpl[T <: Data](that: T)(implicit sourceInfo: SourceInfo): T = { + private[chisel3] def _asTypeOfImpl[T <: Data](that: T)(implicit sourceInfo: SourceInfo): T = { that._fromUInt(this.asUInt).asInstanceOf[T].viewAsReadOnly { _ => "Return values of asTypeOf are now read-only" }