parent
1443834186
commit
45c491cd69
@ -11,9 +11,9 @@ import util.AsyncResetRegVec
|
||||
case class GPIOConfig(address: BigInt, width: Int)
|
||||
|
||||
trait HasGPIOParameters {
|
||||
val params: Tuple2[Parameters, GPIOConfig]
|
||||
implicit val p = params._1
|
||||
val c = params._2
|
||||
implicit val p: Parameters
|
||||
val params: GPIOConfig
|
||||
val c = params
|
||||
}
|
||||
|
||||
// YAGNI: Make the PUE, DS, and
|
||||
@ -289,7 +289,7 @@ object GPIOInputPinCtrl {
|
||||
}
|
||||
|
||||
// Magic TL2 Incantation to create a TL2 Slave
|
||||
class TLGPIO(p: Parameters, c: GPIOConfig)
|
||||
class TLGPIO(c: GPIOConfig)(implicit p: Parameters)
|
||||
extends TLRegisterRouter(c.address, interrupts = c.width, beatBytes = p(PeripheryBusConfig).beatBytes)(
|
||||
new TLRegBundle(Tuple2(p, c), _) with GPIOBundle)(
|
||||
new TLRegModule(Tuple2(p, c), _, _) with GPIOModule)
|
||||
new TLRegBundle(c, _) with GPIOBundle)(
|
||||
new TLRegModule(c, _, _) with GPIOModule)
|
||||
|
@ -8,7 +8,7 @@ import uncore.tilelink2.TLFragmenter
|
||||
|
||||
trait PeripheryGPIO {
|
||||
this: TopNetwork { val gpioConfig: GPIOConfig } =>
|
||||
val gpio = LazyModule(new TLGPIO(p, gpioConfig))
|
||||
val gpio = LazyModule(new TLGPIO(gpioConfig))
|
||||
gpio.node := TLFragmenter(peripheryBusConfig.beatBytes, cacheBlockBytes)(peripheryBus.node)
|
||||
intBus.intnode := gpio.intnode
|
||||
}
|
||||
|
@ -21,9 +21,9 @@ case class MockAONConfig(
|
||||
}
|
||||
|
||||
trait HasMockAONParameters {
|
||||
val params: (MockAONConfig, Parameters)
|
||||
val c = params._1
|
||||
implicit val p = params._2
|
||||
implicit val p: Parameters
|
||||
val params: MockAONConfig
|
||||
val c = params
|
||||
}
|
||||
|
||||
class MockAONPMUIO extends Bundle {
|
||||
@ -99,7 +99,7 @@ trait MockAONModule extends Module with HasRegMap with HasMockAONParameters {
|
||||
|
||||
}
|
||||
|
||||
class MockAON(c: MockAONConfig)(implicit val p: Parameters)
|
||||
class MockAON(c: MockAONConfig)(implicit p: Parameters)
|
||||
extends TLRegisterRouter(c.address, interrupts = 2, size = c.size, beatBytes = p(PeripheryBusConfig).beatBytes, concurrency = 1)(
|
||||
new TLRegBundle((c, p), _) with MockAONBundle)(
|
||||
new TLRegModule((c, p), _, _) with MockAONModule)
|
||||
new TLRegBundle(c, _) with MockAONBundle)(
|
||||
new TLRegModule(c, _, _) with MockAONModule)
|
||||
|
@ -27,7 +27,7 @@ class MockAONWrapperBundle extends Bundle {
|
||||
val rsts = new MockAONMOffRstIO()
|
||||
}
|
||||
|
||||
class MockAONWrapper(c: MockAONConfig)(implicit val p: Parameters) extends LazyModule {
|
||||
class MockAONWrapper(c: MockAONConfig)(implicit p: Parameters) extends LazyModule {
|
||||
|
||||
val node = TLAsyncInputNode()
|
||||
val intnode = IntOutputNode()
|
||||
|
@ -56,9 +56,9 @@ case class PWMBundleConfig(
|
||||
}
|
||||
|
||||
trait HasPWMParameters {
|
||||
val params: (PWMConfig, Parameters)
|
||||
val c = params._1
|
||||
implicit val p = params._2
|
||||
implicit val p: Parameters
|
||||
val params: PWMConfig
|
||||
val c = params
|
||||
}
|
||||
|
||||
trait PWMBundle extends Bundle with HasPWMParameters {
|
||||
@ -76,7 +76,7 @@ trait PWMModule extends Module with HasRegMap with HasPWMParameters {
|
||||
regmap((GenericTimer.timerRegMap(pwm, 0, c.regBytes)):_*)
|
||||
}
|
||||
|
||||
class TLPWM(c: PWMConfig)(implicit val p: Parameters)
|
||||
class TLPWM(c: PWMConfig)(implicit p: Parameters)
|
||||
extends TLRegisterRouter(c.address, interrupts = c.ncmp, size = c.size, beatBytes = p(PeripheryBusConfig).beatBytes)(
|
||||
new TLRegBundle((c, p), _) with PWMBundle)(
|
||||
new TLRegModule((c, p), _, _) with PWMModule)
|
||||
new TLRegBundle(c, _) with PWMBundle)(
|
||||
new TLRegModule(c, _, _) with PWMModule)
|
||||
|
@ -118,7 +118,7 @@ class SPITopModule[B <: SPITopBundle](c: SPIConfigBase, bundle: => B, outer: TLS
|
||||
RegField.r(1, ip.rxwm)))
|
||||
}
|
||||
|
||||
abstract class TLSPIBase(c: SPIConfigBase)(implicit val p: Parameters) extends LazyModule {
|
||||
abstract class TLSPIBase(c: SPIConfigBase)(implicit p: Parameters) extends LazyModule {
|
||||
require(isPow2(c.rSize))
|
||||
val rnode = TLRegisterNode(address = AddressSet(c.rAddress, c.rSize-1), beatBytes = p(PeripheryBusConfig).beatBytes)
|
||||
val intnode = IntSourceNode(1)
|
||||
|
@ -46,9 +46,9 @@ class UARTPortIO extends Bundle {
|
||||
}
|
||||
|
||||
trait MixUARTParameters {
|
||||
val params: (UARTConfig, Parameters)
|
||||
val c = params._1
|
||||
implicit val p = params._2
|
||||
implicit val p: Parameters
|
||||
val params: UARTConfig
|
||||
val c = params
|
||||
}
|
||||
|
||||
trait UARTTopBundle extends Bundle with MixUARTParameters with HasUARTParameters {
|
||||
@ -269,7 +269,7 @@ class Majority(in: Set[Bool]) {
|
||||
}
|
||||
|
||||
// Magic TL2 Incantation to create a TL2 Slave
|
||||
class UART(c: UARTConfig)(implicit val p: Parameters)
|
||||
class UART(c: UARTConfig)(implicit p: Parameters)
|
||||
extends TLRegisterRouter(c.address, interrupts = 1, beatBytes = p(PeripheryBusConfig).beatBytes)(
|
||||
new TLRegBundle((c, p), _) with UARTTopBundle)(
|
||||
new TLRegModule((c, p), _, _) with UARTTopModule)
|
||||
new TLRegBundle(c, _) with UARTTopBundle)(
|
||||
new TLRegModule(c, _, _) with UARTTopModule)
|
||||
|
Loading…
x
Reference in New Issue
Block a user