AXI4Arbiter object scala code reading

object AXI4Arbiter

{

def applyT \<: Data(policy: TLArbiter.Policy)(sink: IrrevocableIOT, sources: IrrevocableIOT*): Unit = {

if (sources.isEmpty) {

sink.valid := false.B

} else {

returnWinner(policy)(sink, sources:_*)

}

}

def returnWinnerT \<: Data(policy: TLArbiter.Policy)(sink: IrrevocableIOT, sources: IrrevocableIOT*) = {

require (!sources.isEmpty)

// The arbiter is irrevocable; when !idle, repeat last request

val idle = RegInit(true.B)

// Who wants access to the sink?

val valids = sources.map(_.valid)

val anyValid = valids.reduce(_ || _)

// Arbitrate amongst the requests

val readys = VecInit(policy(valids.size, Cat(valids.reverse), idle).asBools)

// Which request wins arbitration?

val winner = VecInit((readys zip valids) map { case (r,v) => r&&v })

// Confirm the policy works properly

require (readys.size == valids.size)

// Never two winners

val prefixOR = winner.scanLeft(false.B)(||).init

assert((prefixOR zip winner) map { case (p,w) => !p || !w } reduce {_ && _})

// If there was any request, there is a winner

assert (!anyValid || winner.reduce(||))

// The one-hot source granted access in the previous cycle

val state = RegInit(VecInit.fill(sources.size)(false.B))

val muxState = Mux(idle, winner, state)

state := muxState

// Determine when we go idle

when (anyValid) { idle := false.B }

when (sink.fire) { idle := true.B }

if (sources.size > 1) {

val allowed = Mux(idle, readys, state)

(sources zip allowed) foreach { case (s, r) =>

s.ready := sink.ready && r

}

} else {

sources(0).ready := sink.ready

}

sink.valid := Mux(idle, anyValid, Mux1H(state, valids))

sink.bits :<= Mux1H(muxState, sources.map(_.bits))

muxState

}

}

相关推荐
李白的天不白3 天前
确认 Nginx 配置文件是否真的生效
scala
醉颜凉5 天前
Scala自定义Monad实战:从理论到应用的完整指南
大数据·算法·scala
那晚的她5 天前
Scala中Set集合
开发语言·后端·scala
IvanCodes5 天前
二、Scala流程控制:分支与循环
大数据·scala
Veggie265 天前
【Scala PyTorch深度学习】PyTorch On Scala系列课程 第十四章 29 PyTorch模型扩展自定义Module【AI Infra3】[PyTorch Scala硕士研一课程】
人工智能·深度学习·scala
Clf丶忆笙5 天前
搭建支持多语言开发的Quarkus环境:Java、Kotlin与Scala全栈指南
java·开发语言·云原生·kotlin·scala·quarkus
IvanCodes5 天前
四、Scala深入面向对象:类、对象与伴生关系
开发语言·后端·scala
嗯.~5 天前
scala的泛型应用场景
开发语言·后端·scala
醉颜凉5 天前
Scala Cats Effect纯函数式并发编程:从Fiber模型到生产级应用
大数据·网络·scala
2601_961194027 天前
考研学校专业课真题
spring boot·考研·eclipse·log4j·scala·symfony