Skip to content

Commit

Permalink
Merge pull request #18 from efabless/sequence_response
Browse files Browse the repository at this point in the history
send response to the bus sequence from driver
  • Loading branch information
M0stafaRady authored Apr 17, 2024
2 parents 1a869fe + 1304812 commit 7a60229
Show file tree
Hide file tree
Showing 5 changed files with 23 additions and 13 deletions.
2 changes: 2 additions & 0 deletions bus_env/bus_agent/bus_ahb_driver.py
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,8 @@ async def data_phase(self, tr):
await self.drive_delay()
while self.vif.HREADYOUT == 0:
await self.drive_delay()
tr.data = self.vif.HRDATA.value.integer
self.seq_item_port.put_response(tr)

def end_of_trans(self):
self.vif.HSEL.value = 0b00
Expand Down
13 changes: 8 additions & 5 deletions bus_env/bus_agent/bus_apb_driver.py
Original file line number Diff line number Diff line change
Expand Up @@ -41,32 +41,35 @@ async def run_phase(self, phase):
# uvm_do_callbacks(apb_master,apb_master_cbs,trans_received(self,tr))

if tr.kind == bus_item.READ:
data = []
await self.read(tr.addr, data)
tr.data = data[0]
tr.data = await self.read(tr.addr)
elif tr.kind == bus_item.WRITE:
await self.write(tr.addr, tr.data)

await self.trans_executed(tr)
# uvm_do_callbacks(apb_master,apb_master_cbs,trans_executed(self,tr))
self.seq_item_port.item_done()
self.seq_item_port.put_response(tr)

async def trans_received(self, tr):
await Timer(1, "NS")

async def trans_executed(self, tr):
await Timer(1, "NS")

async def read(self, addr, data):
async def read(self, addr):
uvm_info(self.tag, "Doing APB read to addr " + hex(addr), UVM_HIGH)
self.vif.PADDR.value = addr
self.vif.PWRITE.value = 0
self.vif.PSEL.value = 1
await self.drive_delay()
self.vif.PENABLE.value = 1
await self.drive_delay()
data.append(self.vif.PRDATA)
try:
data = self.vif.PRDATA.value.integer
except TypeError or ValueError:
data = self.vif.PRDATA.value
self.end_of_trans()
return data

async def write(self, addr, data):
uvm_info(self.tag, "Doing APB write to addr " + hex(addr), UVM_HIGH)
Expand Down
7 changes: 6 additions & 1 deletion bus_env/bus_agent/bus_wb_driver.py
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,9 @@ async def run_phase(self, phase):
await self.drive_delay()
self.seq_item_port.item_done()
continue
await self.send_trans(tr)
tr.data = await self.send_trans(tr)
self.seq_item_port.item_done()
self.seq_item_port.put_response(tr)

async def send_trans(self, tr):
if tr.kind == bus_item.READ:
Expand All @@ -49,6 +50,10 @@ async def send_trans(self, tr):
while self.vif.ack_o.value == 0:
await self.drive_delay()
self.end_of_trans()
if tr.kind == bus_item.READ:
return self.vif.dat_o.value.integer
else:
return tr.data

def end_of_trans(self):
self.vif.sel_i.value = 0b0000
Expand Down
4 changes: 4 additions & 0 deletions bus_env/bus_seq_lib/bus_seq_base.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,10 @@ def __init__(self, name="bus_seq_base"):
self.req = bus_item()
self.rsp = bus_item()
self.tag = name
# disable checking for overflow if the response queue is full
# if respose checking is needed the sequence should take care of it
self.set_response_queue_error_report_disabled(1)
self.response_queue_error_report_disabled = 1

async def body(self):
# get register names/address conversion dict
Expand Down
10 changes: 3 additions & 7 deletions bus_env/bus_seq_lib/write_read_regs.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
from uvm.seq import UVMSequence
from uvm.macros.uvm_object_defines import uvm_object_utils
from uvm.macros.uvm_message_defines import uvm_info, uvm_fatal
from uvm.macros.uvm_sequence_defines import uvm_do_with, uvm_do
Expand All @@ -7,15 +6,12 @@
from uvm.base.uvm_config_db import UVMConfigDb
from cocotb_coverage.coverage import coverage_db
import os
from EF_UVM.bus_env.bus_seq_lib.bus_seq_base import bus_seq_base


class write_read_regs(UVMSequence):

class write_read_regs(bus_seq_base):
def __init__(self, name="write_read_regs"):
UVMSequence.__init__(self, name)
self.set_automatic_phase_objection(1)
self.req = bus_item()
self.rsp = bus_item()
super().__init__(name)
self.tag = name

async def body(self):
Expand Down

0 comments on commit 7a60229

Please sign in to comment.