All Downloads are FREE. Search and download functionalities are using the official Maven repository.

spinal.lib.bus.regif.Factory.RegSCR.scala Maven / Gradle / Ivy

package spinal.lib.bus.regif

import spinal.core._
/*
  * SCR(Set/Clear/Read) 3 Register Group,  always used for clock_eanble/soft_reset signal config
  * 1. SET: set register, write 1 set
  * 2. CLR: clear register, write 1 clear
  * 3. READ: read address
  * ```verilog demo
  * always@(posedge clk or negedge rstn)
  *   if(!rstn) begin
  *      xxx_cgen_x <= 1'b0 ;
  *   end else if(bus_addr == `xxx_SET && bus_wdata[x]) begin //W1S
  *      xxx_cgen_x <= 1'b1 ;
  *   end else if(bus_addr == `xxx_CLR && bus_wdata[x]) begin //W1C
  *      xxx_cgen_x <= 1'b0 ;
  *   end
  *
  *  always @(*) begin
  *    case(addr) begin
  *      `xxx_SET:  bus_rdata = {28'b0, xxx_cgen_3....xxx_cgen_0};
  *      `xxx_CLR:  bus_rdata = {28'b0, xxx_cgen_3....xxx_cgen_0};
  *      `xxx_READ: bus_rdata = {28'b0, xxx_cgen_3....xxx_cgen_0};
  *      ....
  *    endcase
  * ```
  */
class RegSCR(val name: String, offset: BigInt, doc: String, bi: BusIf, sec: Secure, grp: GrpTag) extends RegSliceGrp(offset, maxSize = 2, doc, sec, grp)(bi){
  val SET  = this.newRegAt(0, "SCR set register")(SymbolName(s"${name}_SET"))
  val CLR  = this.newReg("SCR clear register")(SymbolName(s"${name}_CLR"))
  val READ = this.newReg("SCR read register")(SymbolName(s"${name}_READ"))

  def fieldAt[T <: BaseType](pos: Int, hardType: HardType[T], resetValue:BigInt , doc: String)(implicit symbol: SymbolName): T = {
    val reg = SET.fieldAt(pos, hardType,    AccessType.W1S, resetValue = resetValue, doc = s"${doc}, write 1 set")(symbol)
         CLR.parasiteFieldAt(pos, reg, AccessType.W1C, resetValue = resetValue, doc = s"${doc}, write 1 clear")
         READ.parasiteFieldAt(pos, reg, AccessType.RO,  resetValue = resetValue, doc = s"${doc}, read addr")
    reg
  }

  def field[T <: BaseType](hardType: HardType[T], resetValue: Int, doc: String)(implicit symbol: SymbolName) = {
    val reg = SET.field(hardType, AccessType.W1S, resetValue = resetValue, doc = s"${doc}, write 1 set")(symbol)
         CLR.parasiteField(reg, AccessType.W1C, resetValue = resetValue, doc = s"${doc}, write 1 clear")
         READ.parasiteField(reg, AccessType.RO, resetValue = resetValue, doc = s"${doc}, read addr")
    reg
  }
}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy