|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/180a6/180a67ce44f79a6885b1aa1e6502087811b76b36" alt="../images/main/bulllet_4dots_orange.gif" |
Extensions for User-Specified Types
|
|
|
In order to support user-specified composite types, the user needs to provide a partial template specialization of scv_extensions for the specific composite type in the test bench. |
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
Similar to the existing SystemC SC_MODULE macro, the SCV_EXTENSIONS and SCV_ENUM_EXTENSIONS macros create appropriate classes for the user-specified composite type and userspecified enumeration type. |
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
The related macros in the SystemC Verification Standard to facilitate this process are summarized in the following table: |
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
The scv_extensions Macros
|
Description
|
SCV_EXTENSIONS (type_name)
|
This macro is similar to SC_MODULE(). It defines the extension class for the composite type identified by type_name.
|
SCV_EXTENSIONS_CTOR (type_name)
|
This macro is similar to SC_CTOR(). It defines the constructor for the extension class of the composite type identified by type_name.
|
SCV_EXTENSIONS_ BASE_CLASS (base_type_name)
|
This macro declares base_type_name as the base class of the class to be extended. It must be instantiated within the block after SCV_EXTENSIONS_CTOR.
|
SCV_FIELD (field_name)
|
This macro declares a field identified by field_name. SCV_ENUM_EXTENSIONS(type_name) This macro is similar to SC_MODULE(). It defines the extension class for an enumeration identified by type_name.
|
SCV_ENUM_CTOR (type_name)
|
This macro is similar to SC_CTOR(). It defines the constructor for the extension class of the enumeration identified by type_name.
|
SCV_ENUM (enum_element_name)
|
This macro declares an enumeration element identified by enum_element_name.
|
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/a641b/a641bf107436728a5843fe8ccadf001de8455b7f" alt="../images/main/bullet_star_pink.gif" |
Example : scv_user_defined
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
1 #include <scv.h>
2
3 struct packet_t {
4 sc_uint<8> addr;
5 sc_uint<12> data;
6 };
7
8 SCV_EXTENSIONS(packet_t) {
9 public:
10 scv_extensions< sc_uint<8> > addr;
11 scv_extensions< sc_uint<12> > data;
12 SCV_EXTENSIONS_CTOR(packet_t) {
13 SCV_FIELD(addr);
14 SCV_FIELD(data);
15 }
16 };
17
18 int sc_main (int argc, char* argv[]) {
19 packet_t pkt;
20 pkt.addr = rand();
21 pkt.data = rand();
22 int bitwidth = scv_get_extensions(pkt.addr).get_bitwidth();
23 cout << "Width of addr is "<< bitwidth << endl;
24 bitwidth = scv_get_extensions(pkt.data).get_bitwidth();
25 cout << "Width of data is "<< bitwidth << endl;
26 scv_get_extensions(pkt).print();
27 return 0;
28 }
You could download file scv_user_defined.cpp here
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/a641b/a641bf107436728a5843fe8ccadf001de8455b7f" alt="../images/main/bullet_star_pink.gif" |
Simulation Output : scv_user_defined
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
Width of addr is 8
Width of data is 12
{
addr:103
data:966
}
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c2c27/c2c277fbe75b68ffa3f0eb99f3b30bb25fa28361" alt=""
|
|
Copyright © 1998-2025 |
Deepak Kumar Tala - All rights reserved |
Do you have any Comment? mail me at:deepak@asic-world.com
|
|