blob: 3a59dd0a64e1f77f9f5e021eb2a323133850ce49 [file] [log] [blame]
// Copyright lowRISC contributors.
// Licensed under the Apache License, Version 2.0, see LICENSE for details.
// SPDX-License-Identifier: Apache-2.0
class csrng_item extends uvm_sequence_item;
// TODO: create
`uvm_object_utils_begin(csrng_item)
`uvm_object_utils_end
`uvm_object_new
acmd_e acmd;
bit [3:0] clen, flags;
bit [18:0] glen;
bit [31:0] cmd_data_q[$];
virtual function string convert2string();
string str = "";
str = {str, "\n"};
str = {str, $sformatf("\n\t |*********** csrng_item ************| \t") };
str = {str, $sformatf("\n\t |* acmd : %4s *| \t", acmd.name()) };
str = {str, $sformatf("\n\t |* clen : 0x%0h *| \t", clen) };
str = {str, $sformatf("\n\t |* flags : 0x%0h *| \t", flags) };
str = {str, $sformatf("\n\t |* glen : 0x%5h *| \t", glen) };
if (cmd_data_q.size()) begin
for (int i = 0; i < cmd_data_q.size(); i++) begin
str = {str, $sformatf("\n\t |* cmd_data_q[%2d] : 0x%0h *| \t", i, cmd_data_q[i]) };
end
end
str = {str, $sformatf("\n\t |***********************************| \t") };
str = {str, "\n"};
return str;
endfunction
endclass