swapnilm Posted March 20, 2013 Report Share Posted March 20, 2013 Hello All, I want to connect driver directly to the monitor,(not going through any DUT). So how does it work? Which TLM can be used and how? Can someone plz help in this regard? The transaction packets are being sent from driver to monitor in byte form. So please guide me through. Thanks, Swapnil Quote Link to comment Share on other sites More sharing options...
whiteriver Posted March 21, 2013 Report Share Posted March 21, 2013 The driver must be connected to an interface. The monitor also must be connected to an interface. So you just have to connect them to the same interface. Quote Link to comment Share on other sites More sharing options...
swapnilm Posted March 21, 2013 Author Report Share Posted March 21, 2013 Hello whiteriver, In order for me to check the functionality of my verification environment, I want to check whatever packets I am sending through driver, I am receiving the same packets. Hence rather than sending the packets inside the DUT, which may increase the complexity of debugging, I want to directly connect driver to the monitor. I thought there should be a way, through some TLMs, to check this kind of functionality. And if at all, I am supposed to connect both driver and monitor to interface only, should the other end of interface not be connected to DUT? Or can I really connect the same interface to both monitor and driver, and not connecting that interface to the DUT? Can it work this way also? Plz give some idea. Regds, Swapnil Quote Link to comment Share on other sites More sharing options...
sega Posted March 21, 2013 Report Share Posted March 21, 2013 Hi swapnilm, you can do a check between sent packets and monitored packets as below. monitor and driver should connected to same interface and that both components should have a analysis export port ,so whenever your packet is ready to send for comparision you can directly pass those packets with write method of analysis port to the scoreboard ,where u have to declare as a import port and compare with the uvm compare task. as per your question you can directly try to connect driver and monitor with analysis export port in to driver and import port in to monitor.I think it should work with out any outside interface because both is extended from the uvm_component base class. Regards Quote Link to comment Share on other sites More sharing options...
swapnilm Posted March 21, 2013 Author Report Share Posted March 21, 2013 Hello Sega, I connected the analysis ports for both driver and monitor in scoreboard and comparing the sent and the received packets. Also connected the driver with the monitor through an interface and and empty DUT (which only prints the bytes are received in the DUT). But still the packets are mismatch. I am not getting any clue where its might be going wrong. I am getting following errors. Plz see if you can get any clue out of it. Errors:- # UVM_ERROR @ 50: reporter [PCKSZ] 16 bits needed to unpack integral, yet only 0 available. # UVM_ERROR @ 50: reporter [PCKSZ] 16 bits needed to unpack integral, yet only 0 available. UVM_FATAL @ 600: uvm_test_top.env_h.agent_h.sequencer1_h [uvm_test_top.env_h.agent_h.sequencer1_h] Item_done() called with no outstanding requests. Each call to item_done() must be paired with a previous call to get_next_item(). And dont know why but only 1 packet is being sent, although I am trying to send many packets through a sequence. But its not working. Please give some guidance, if you you are getting any clue of where it might be going wrong? Thanks and regds, Swapnil Quote Link to comment Share on other sites More sharing options...
sega Posted April 1, 2013 Report Share Posted April 1, 2013 Hi swapnilm, sorry for delayed reply. Can you once try the same thing with using UVM_NOPACK for each and every field in to packet class, which are present into object utilities. I am not much sure but it showing some packing and unpacking related issue so i think we can try without using internal packing and unpacking utils once. Regards sega Quote Link to comment Share on other sites More sharing options...
samrat patel Posted April 27, 2013 Report Share Posted April 27, 2013 Hello Swapnil You can connect driver to monitor directly using interface .through this interface you can communicate directly between driver and monitor without using dut. i will post my code here so you will get idea from it.It is working successfully. Quote Link to comment Share on other sites More sharing options...
swapnilm Posted April 27, 2013 Author Report Share Posted April 27, 2013 Hello Samrat, that will be great, thanks. Quote Link to comment Share on other sites More sharing options...
lrcrsr Posted May 7, 2013 Report Share Posted May 7, 2013 Both the driver and monitor must have virtual interface variables. You can initialize both these variables to point to the same instance of the interface. Whenever the driver drives a signal on the interface, this change will be visible in the monitor's virtual interface. At some point in the future when you want to connect the DUT, you will be able to instantiate the DUT in the same environment without any modifications to your driver or monitor. Loganath Quote Link to comment Share on other sites More sharing options...
jadec Posted May 7, 2013 Report Share Posted May 7, 2013 Take a look at Figure 1 in the UVM user guide. You should have 2 agents for your DUT. One for the input side (what you're calling your "driver") and one for the output side (which I think you're calling your "monitor"). Each of these agents contains a monitor. The input monitor should communicate to your scoreboard as will the output monitor. This allows you to check the functionality of the DUT (comparing what it saw on the inputs to what it generated on the outputs). If you want to check the functionality of the driver, you'll need to compare the input transactions in the driver against those observed by the input monitor (this is not generally automated). Quote Link to comment Share on other sites More sharing options...
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.