mirror of
https://github.com/verilator/verilator.git
synced 2025-01-01 04:07:34 +00:00
Support 1800-2023 DPI headers, svGetTime/svgGetTimeUnit/svGetTimePrecision methods.
This commit is contained in:
parent
91dd3c5fac
commit
fa7234ff68
3
Changes
3
Changes
@ -14,11 +14,10 @@ Verilator 5.023 devel
|
|||||||
**Major:**
|
**Major:**
|
||||||
|
|
||||||
* Support 1800-2023 keywords.
|
* Support 1800-2023 keywords.
|
||||||
|
* Support 1800-2023 DPI headers, svGetTime/svgGetTimeUnit/svGetTimePrecision methods.
|
||||||
|
|
||||||
**Minor:**
|
**Minor:**
|
||||||
|
|
||||||
* Add warning on 'TOP'-named modules (#4935). [Yanglin Xun]
|
|
||||||
* Fix invalid cast on string structure creation (#4921). [esynr3z]
|
* Fix invalid cast on string structure creation (#4921). [esynr3z]
|
||||||
|
|
||||||
|
|
||||||
|
@ -770,6 +770,36 @@ int svGetCallerInfo(const char** fileNamepp, int* lineNumberp) {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//======================================================================
|
||||||
|
// Time
|
||||||
|
|
||||||
|
int svGetTime(const svScope scope, svTimeVal* time) {
|
||||||
|
if (VL_UNLIKELY(!time)) return -1;
|
||||||
|
const QData qtime = VL_TIME_Q();
|
||||||
|
VlWide<2> itime;
|
||||||
|
VL_SET_WQ(itime, qtime);
|
||||||
|
time->low = itime[0];
|
||||||
|
time->high = itime[1];
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int svGetTimeUnit(const svScope scope, int32_t* time_unit) {
|
||||||
|
if (VL_UNLIKELY(!time_unit)) return -1;
|
||||||
|
const VerilatedScope* const vscopep = reinterpret_cast<const VerilatedScope*>(scope);
|
||||||
|
if (!vscopep) { // Null asks for global, not unlikely
|
||||||
|
*time_unit = Verilated::threadContextp()->timeunit();
|
||||||
|
} else {
|
||||||
|
*time_unit = vscopep->timeunit();
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int svGetTimePrecision(const svScope scope, int32_t* time_precision) {
|
||||||
|
if (VL_UNLIKELY(!time_precision)) return -1;
|
||||||
|
*time_precision = Verilated::threadContextp()->timeprecision();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
//======================================================================
|
//======================================================================
|
||||||
// Disables
|
// Disables
|
||||||
|
|
||||||
|
@ -150,10 +150,21 @@ extern "C" {
|
|||||||
#define vpiIntegerNet 681
|
#define vpiIntegerNet 681
|
||||||
#define vpiLogicNet vpiNet
|
#define vpiLogicNet vpiNet
|
||||||
#define vpiTimeNet 682
|
#define vpiTimeNet 682
|
||||||
|
#define vpiUnionNet 525
|
||||||
|
#define vpiShortRealNet 526
|
||||||
|
#define vpiRealNet 527
|
||||||
|
#define vpiByteNet 528
|
||||||
|
#define vpiShortIntNet 529
|
||||||
|
#define vpiIntNet 530
|
||||||
|
#define vpiLongIntNet 531
|
||||||
|
#define vpiBitNet 532
|
||||||
|
#define vpiInterconnectNet 533
|
||||||
|
#define vpiInterconnectArray 534
|
||||||
#define vpiStructNet 683
|
#define vpiStructNet 683
|
||||||
#define vpiBreak 684
|
#define vpiBreak 684
|
||||||
#define vpiContinue 685
|
#define vpiContinue 685
|
||||||
#define vpiPackedArrayNet 693
|
#define vpiPackedArrayNet 693
|
||||||
|
#define vpiNettypeDecl 523
|
||||||
#define vpiConstraintExpr 747
|
#define vpiConstraintExpr 747
|
||||||
#define vpiElseConst 748
|
#define vpiElseConst 748
|
||||||
#define vpiImplication 749
|
#define vpiImplication 749
|
||||||
@ -174,6 +185,8 @@ extern "C" {
|
|||||||
#define vpiBaseTypespec 703
|
#define vpiBaseTypespec 703
|
||||||
#define vpiElemTypespec 704
|
#define vpiElemTypespec 704
|
||||||
|
|
||||||
|
#define vpiNetTypedefAlias 705
|
||||||
|
|
||||||
#define vpiInputSkew 706
|
#define vpiInputSkew 706
|
||||||
#define vpiOutputSkew 707
|
#define vpiOutputSkew 707
|
||||||
#define vpiGlobalClocking 708
|
#define vpiGlobalClocking 708
|
||||||
@ -206,7 +219,8 @@ extern "C" {
|
|||||||
#define vpiMessages 735
|
#define vpiMessages 735
|
||||||
#define vpiLoopVars 737
|
#define vpiLoopVars 737
|
||||||
|
|
||||||
#define vpiConcurrentAssertions 740
|
#define vpiConcurrentAssertion 740
|
||||||
|
#define vpiConcurrentAssertions vpiConcurrentAssertion
|
||||||
#define vpiMatchItem 741
|
#define vpiMatchItem 741
|
||||||
#define vpiMember 742
|
#define vpiMember 742
|
||||||
#define vpiElement 743
|
#define vpiElement 743
|
||||||
@ -221,6 +235,7 @@ extern "C" {
|
|||||||
/**************************************************************************/
|
/**************************************************************************/
|
||||||
/************************ generic object properties ***********************/
|
/************************ generic object properties ***********************/
|
||||||
/**************************************************************************/
|
/**************************************************************************/
|
||||||
|
|
||||||
#define vpiTop 600
|
#define vpiTop 600
|
||||||
|
|
||||||
#define vpiUnit 602
|
#define vpiUnit 602
|
||||||
@ -255,7 +270,6 @@ extern "C" {
|
|||||||
#define vpiModportPort 2
|
#define vpiModportPort 2
|
||||||
/* vpiPort is also a port type. It is defined in vpi_user.h */
|
/* vpiPort is also a port type. It is defined in vpi_user.h */
|
||||||
|
|
||||||
|
|
||||||
#define vpiConstantVariable 612
|
#define vpiConstantVariable 612
|
||||||
#define vpiStructUnionMember 615
|
#define vpiStructUnionMember 615
|
||||||
|
|
||||||
@ -407,6 +421,7 @@ extern "C" {
|
|||||||
/***************************** structure *****************************/
|
/***************************** structure *****************************/
|
||||||
|
|
||||||
/**************************** CALLBACK REASONS ****************************/
|
/**************************** CALLBACK REASONS ****************************/
|
||||||
|
#define vpiMethodFuncCall 648
|
||||||
#define cbStartOfThread 600 /* callback on thread creation */
|
#define cbStartOfThread 600 /* callback on thread creation */
|
||||||
#define cbEndOfThread 601 /* callback on thread termination */
|
#define cbEndOfThread 601 /* callback on thread termination */
|
||||||
#define cbEnterThread 602 /* callback on reentering thread */
|
#define cbEnterThread 602 /* callback on reentering thread */
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
* This file contains the constant definitions, structure definitions,
|
* This file contains the constant definitions, structure definitions,
|
||||||
* and routine declarations used by SystemVerilog DPI.
|
* and routine declarations used by SystemVerilog DPI.
|
||||||
*
|
*
|
||||||
* This file is from the SystemVerilog IEEE 1800-2017 Annex I.
|
* This file is from the SystemVerilog IEEE 1800-2023 Annex I.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef INCLUDED_SVDPI
|
#ifndef INCLUDED_SVDPI
|
||||||
@ -111,6 +111,26 @@ typedef uint32_t svBitVecVal;
|
|||||||
((N) == 32 ? (VALUE) : \
|
((N) == 32 ? (VALUE) : \
|
||||||
(((VALUE) & (1 << (N))) ? ((VALUE) | ~SV_MASK(N)) : ((VALUE) & SV_MASK(N))))
|
(((VALUE) & (1 << (N))) ? ((VALUE) | ~SV_MASK(N)) : ((VALUE) & SV_MASK(N))))
|
||||||
|
|
||||||
|
#ifndef VPI_TIME
|
||||||
|
#define VPI_TIME
|
||||||
|
typedef struct t_vpi_time {
|
||||||
|
int32_t type;
|
||||||
|
uint32_t high, low;
|
||||||
|
double real;
|
||||||
|
} s_vpi_time, *p_vpi_time;
|
||||||
|
|
||||||
|
#define vpiScaledRealTime 1
|
||||||
|
#define vpiSimTime 2
|
||||||
|
#define vpiSuppressTime 3
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* time value */
|
||||||
|
typedef s_vpi_time svTimeVal;
|
||||||
|
|
||||||
|
/* time value types */
|
||||||
|
#define sv_scaled_real_time vpiScaledRealTime
|
||||||
|
#define sv_sim_time vpiSimTime
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Implementation-dependent representation.
|
* Implementation-dependent representation.
|
||||||
*/
|
*/
|
||||||
@ -277,7 +297,7 @@ XXTERN svScope svGetScope( void );
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Set context for subsequent export function execution.
|
* Set context for subsequent export function execution.
|
||||||
* This function must be called before calling an export function, unless
|
* This function shall be called before calling an export function, unless
|
||||||
* the export function is called while executing an import function. In that
|
* the export function is called while executing an import function. In that
|
||||||
* case the export function shall inherit the scope of the surrounding import
|
* case the export function shall inherit the scope of the surrounding import
|
||||||
* function. This is known as the "default scope".
|
* function. This is known as the "default scope".
|
||||||
@ -297,7 +317,7 @@ XXTERN svScope svGetScopeFromName(const char* scopeName);
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Store an arbitrary user data pointer for later retrieval by svGetUserData()
|
* Store an arbitrary user data pointer for later retrieval by svGetUserData()
|
||||||
* The userKey is generated by the user. It must be guaranteed by the user to
|
* The userKey is generated by the user. It needs to be guaranteed by the user to
|
||||||
* be unique from all other userKey's for all unique data storage requirements
|
* be unique from all other userKey's for all unique data storage requirements
|
||||||
* It is recommended that the address of static functions or variables in the
|
* It is recommended that the address of static functions or variables in the
|
||||||
* user's C code be used as the userKey.
|
* user's C code be used as the userKey.
|
||||||
@ -329,24 +349,49 @@ XXTERN void* svGetUserData(const svScope scope, void* userKey);
|
|||||||
* modified. Whether this information is available or not is implementation-
|
* modified. Whether this information is available or not is implementation-
|
||||||
* specific. Note that the string provided (if any) is owned by the SV
|
* specific. Note that the string provided (if any) is owned by the SV
|
||||||
* implementation and is valid only until the next call to any SV function.
|
* implementation and is valid only until the next call to any SV function.
|
||||||
* Applications must not modify this string or free it
|
* Applications shall not modify this string or free it.
|
||||||
*/
|
*/
|
||||||
XXTERN int svGetCallerInfo(const char** fileName, int *lineNumber);
|
XXTERN int svGetCallerInfo(const char** fileName, int *lineNumber);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Returns 1 if the current execution thread is in the disabled state.
|
* Returns 1 if the current execution thread is in the disabled state.
|
||||||
* Disable protocol must be adhered to if in the disabled state.
|
* Disable protocol shall be adhered to if in the disabled state.
|
||||||
*/
|
*/
|
||||||
XXTERN int svIsDisabledState( void );
|
XXTERN int svIsDisabledState( void );
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Imported functions call this API function during disable processing to
|
* Imported functions call this API function during disable processing to
|
||||||
* acknowledge that they are correctly participating in the DPI disable protocol.
|
* acknowledge that they are correctly participating in the DPI disable protocol.
|
||||||
* This function must be called before returning from an imported function that is
|
* This function shall be called before returning from an imported function that is
|
||||||
* in the disabled state.
|
* in the disabled state.
|
||||||
*/
|
*/
|
||||||
XXTERN void svAckDisabledState( void );
|
XXTERN void svAckDisabledState( void );
|
||||||
|
|
||||||
|
/* Mantis 5713/D9
|
||||||
|
* Retrieve the current simulation time, scaled to the time unit of the scope.
|
||||||
|
* If scope is NULL, then time is scaled to the simulation time unit.
|
||||||
|
* It is an error to call svGetTime() with an invalid svScope.
|
||||||
|
* This function returns -1 for all error cases, 0 upon success.
|
||||||
|
*/
|
||||||
|
XXTERN int svGetTime(const svScope scope, svTimeVal* time);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Retrieve the time unit for scope.
|
||||||
|
* If scope is NULL, then simulation time unit is retrieved.
|
||||||
|
* It is an error to call svGetTimeUnit() with an invalid svScope.
|
||||||
|
* This function returns -1 for all error cases, 0 upon success.
|
||||||
|
*/
|
||||||
|
XXTERN int svGetTimeUnit(const svScope scope, int32_t* time_unit);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Retrieve the time precision for scope.
|
||||||
|
* If scope is NULL, then simulation time unit is retrieved.
|
||||||
|
* It is an error to call svGetTimePrecision() with an invalid svScope.
|
||||||
|
* This function returns -1 for all error cases, 0 upon success.
|
||||||
|
*/
|
||||||
|
XXTERN int svGetTimePrecision(const svScope scope, int32_t* time_precision);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
**********************************************************
|
**********************************************************
|
||||||
* DEPRECATED PORTION OF FILE STARTS FROM HERE.
|
* DEPRECATED PORTION OF FILE STARTS FROM HERE.
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
* vpi_user.h
|
* vpi_user.h
|
||||||
*
|
*
|
||||||
* IEEE Std 1800-2017 Programming Language Interface (PLI)
|
* IEEE Std 1800-2023 Programming Language Interface (PLI)
|
||||||
*
|
*
|
||||||
* This file contains the constant definitions, structure definitions, and
|
* This file contains the constant definitions, structure definitions, and
|
||||||
* routine declarations used by the SystemVerilog Verification Procedural
|
* routine declarations used by the SystemVerilog Verification Procedural
|
||||||
@ -344,6 +344,9 @@ typedef PLI_UINT32 *vpiHandle;
|
|||||||
#define vpiSupply0 11 /* supply-0 net */
|
#define vpiSupply0 11 /* supply-0 net */
|
||||||
#define vpiNone 12 /* no default net type (1364-2001) */
|
#define vpiNone 12 /* no default net type (1364-2001) */
|
||||||
#define vpiUwire 13 /* unresolved wire net (1364-2005) */
|
#define vpiUwire 13 /* unresolved wire net (1364-2005) */
|
||||||
|
#define vpiNettypeNet 14 /* user-defined nettype net */
|
||||||
|
#define vpiNettypeNetSelect 15 /* user-defined nettype net subelement */
|
||||||
|
#define vpiInterconnect 16 /* interconnect net */
|
||||||
|
|
||||||
#define vpiExplicitScalared 23 /* explicitly scalared (Boolean) */
|
#define vpiExplicitScalared 23 /* explicitly scalared (Boolean) */
|
||||||
#define vpiExplicitVectored 24 /* explicitly vectored (Boolean) */
|
#define vpiExplicitVectored 24 /* explicitly vectored (Boolean) */
|
||||||
@ -573,6 +576,9 @@ typedef PLI_UINT32 *vpiHandle;
|
|||||||
|
|
||||||
/******************************* time structure *******************************/
|
/******************************* time structure *******************************/
|
||||||
|
|
||||||
|
#ifndef VPI_TIME /* added in 1800-2023 */
|
||||||
|
#define VPI_TIME
|
||||||
|
|
||||||
typedef struct t_vpi_time
|
typedef struct t_vpi_time
|
||||||
{
|
{
|
||||||
PLI_INT32 type; /* [vpiScaledRealTime, vpiSimTime,
|
PLI_INT32 type; /* [vpiScaledRealTime, vpiSimTime,
|
||||||
@ -587,6 +593,8 @@ typedef struct t_vpi_time
|
|||||||
#define vpiSimTime 2
|
#define vpiSimTime 2
|
||||||
#define vpiSuppressTime 3
|
#define vpiSuppressTime 3
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************** delay structures ******************************/
|
/****************************** delay structures ******************************/
|
||||||
|
|
||||||
typedef struct t_vpi_delay
|
typedef struct t_vpi_delay
|
||||||
@ -741,9 +749,8 @@ typedef struct t_vpi_arrayvalue
|
|||||||
typedef struct t_vpi_systf_data
|
typedef struct t_vpi_systf_data
|
||||||
{
|
{
|
||||||
PLI_INT32 type; /* vpiSysTask, vpiSysFunc */
|
PLI_INT32 type; /* vpiSysTask, vpiSysFunc */
|
||||||
PLI_INT32 sysfunctype; /* vpiSysTask, vpi[Int,Real,Time,Sized,
|
PLI_INT32 sysfunctype; /* vpi[Int,Real,Time,Sized,SizedSigned]Func */
|
||||||
SizedSigned]Func */
|
PLI_BYTE8 *tfname; /* first character has to be '$' */
|
||||||
PLI_BYTE8 *tfname; /* first character must be '$' */
|
|
||||||
PLI_INT32 (*calltf)(PLI_BYTE8 *);
|
PLI_INT32 (*calltf)(PLI_BYTE8 *);
|
||||||
PLI_INT32 (*compiletf)(PLI_BYTE8 *);
|
PLI_INT32 (*compiletf)(PLI_BYTE8 *);
|
||||||
PLI_INT32 (*sizetf)(PLI_BYTE8 *); /* for sized function callbacks only */
|
PLI_INT32 (*sizetf)(PLI_BYTE8 *); /* for sized function callbacks only */
|
||||||
|
@ -10,8 +10,12 @@ Time scale of t is 100s / 10ms
|
|||||||
acc%0t=1234567890123456789000000000000.000000ns acc%0d=12345678901234567890
|
acc%0t=1234567890123456789000000000000.000000ns acc%0d=12345678901234567890
|
||||||
[1000000000000000.000000ns] stime%0t=1000000000000000.000000ns stime%0d=10000 stime%0f=10000.000000
|
[1000000000000000.000000ns] stime%0t=1000000000000000.000000ns stime%0d=10000 stime%0f=10000.000000
|
||||||
[1000000000000000.000000ns] rtime%0t=1000000000000000.000000ns rtime%0d=10000 rtime%0f=10000.000000
|
[1000000000000000.000000ns] rtime%0t=1000000000000000.000000ns rtime%0d=10000 rtime%0f=10000.000000
|
||||||
|
global svGetTime = 0 0,100000000
|
||||||
|
global svGetTimeUnit = 0 -2 svGetTmePrecision = 0 -2
|
||||||
global vpiSimTime = 0,100000000 vpiScaledRealTime = 1e+08
|
global vpiSimTime = 0,100000000 vpiScaledRealTime = 1e+08
|
||||||
global vpiTimeUnit = -2 vpiTimePrecision = -2
|
global vpiTimeUnit = -2 vpiTimePrecision = -2
|
||||||
|
top.t svGetTime = 0 0,100000000
|
||||||
|
top.t svGetTimeUnit = 0 2 svGetTmePrecision = 0 -2
|
||||||
top.t vpiSimTime = 0,100000000 vpiScaledRealTime = 10000
|
top.t vpiSimTime = 0,100000000 vpiScaledRealTime = 10000
|
||||||
top.t vpiTimeUnit = 2 vpiTimePrecision = -2
|
top.t vpiTimeUnit = 2 vpiTimePrecision = -2
|
||||||
*-* All Finished *-*
|
*-* All Finished *-*
|
||||||
|
@ -10,8 +10,12 @@ Time scale of t is 10ms / 10ns
|
|||||||
acc%0t=123456789012345678900000000.000000ns acc%0d=12345678901234567890
|
acc%0t=123456789012345678900000000.000000ns acc%0d=12345678901234567890
|
||||||
[600000000.000000ns] stime%0t=600000000.000000ns stime%0d=60 stime%0f=60.000000
|
[600000000.000000ns] stime%0t=600000000.000000ns stime%0d=60 stime%0f=60.000000
|
||||||
[600000000.000000ns] rtime%0t=600000000.000000ns rtime%0d=60 rtime%0f=60.000000
|
[600000000.000000ns] rtime%0t=600000000.000000ns rtime%0d=60 rtime%0f=60.000000
|
||||||
|
global svGetTime = 0 0,60000000
|
||||||
|
global svGetTimeUnit = 0 -2 svGetTmePrecision = 0 -8
|
||||||
global vpiSimTime = 0,60000000 vpiScaledRealTime = 6e+07
|
global vpiSimTime = 0,60000000 vpiScaledRealTime = 6e+07
|
||||||
global vpiTimeUnit = -2 vpiTimePrecision = -8
|
global vpiTimeUnit = -2 vpiTimePrecision = -8
|
||||||
|
top.t svGetTime = 0 0,60000000
|
||||||
|
top.t svGetTimeUnit = 0 -2 svGetTmePrecision = 0 -8
|
||||||
top.t vpiSimTime = 0,60000000 vpiScaledRealTime = 60
|
top.t vpiSimTime = 0,60000000 vpiScaledRealTime = 60
|
||||||
top.t vpiTimeUnit = -2 vpiTimePrecision = -8
|
top.t vpiTimeUnit = -2 vpiTimePrecision = -8
|
||||||
*-* All Finished *-*
|
*-* All Finished *-*
|
||||||
|
@ -10,8 +10,12 @@ Time scale of t is 1fs / 1fs
|
|||||||
acc%0t=12345678901234.567890ns acc%0d=12345678901234567890
|
acc%0t=12345678901234.567890ns acc%0d=12345678901234567890
|
||||||
[0.000060ns] stime%0t=0.000060ns stime%0d=60 stime%0f=60.000000
|
[0.000060ns] stime%0t=0.000060ns stime%0d=60 stime%0f=60.000000
|
||||||
[0.000060ns] rtime%0t=0.000060ns rtime%0d=60 rtime%0f=60.000000
|
[0.000060ns] rtime%0t=0.000060ns rtime%0d=60 rtime%0f=60.000000
|
||||||
|
global svGetTime = 0 0,60
|
||||||
|
global svGetTimeUnit = 0 -15 svGetTmePrecision = 0 -15
|
||||||
global vpiSimTime = 0,60 vpiScaledRealTime = 60
|
global vpiSimTime = 0,60 vpiScaledRealTime = 60
|
||||||
global vpiTimeUnit = -15 vpiTimePrecision = -15
|
global vpiTimeUnit = -15 vpiTimePrecision = -15
|
||||||
|
top.t svGetTime = 0 0,60
|
||||||
|
top.t svGetTimeUnit = 0 -15 svGetTmePrecision = 0 -15
|
||||||
top.t vpiSimTime = 0,60 vpiScaledRealTime = 60
|
top.t vpiSimTime = 0,60 vpiScaledRealTime = 60
|
||||||
top.t vpiTimeUnit = -15 vpiTimePrecision = -15
|
top.t vpiTimeUnit = -15 vpiTimePrecision = -15
|
||||||
*-* All Finished *-*
|
*-* All Finished *-*
|
||||||
|
@ -10,8 +10,12 @@ Time scale of t is 1ms / 10ns
|
|||||||
acc%0t=12345678901234567890000000.000000ns acc%0d=12345678901234567890
|
acc%0t=12345678901234567890000000.000000ns acc%0d=12345678901234567890
|
||||||
[60000000.000000ns] stime%0t=60000000.000000ns stime%0d=60 stime%0f=60.000000
|
[60000000.000000ns] stime%0t=60000000.000000ns stime%0d=60 stime%0f=60.000000
|
||||||
[60000000.000000ns] rtime%0t=60000000.000000ns rtime%0d=60 rtime%0f=60.000000
|
[60000000.000000ns] rtime%0t=60000000.000000ns rtime%0d=60 rtime%0f=60.000000
|
||||||
|
global svGetTime = 0 0,6000000
|
||||||
|
global svGetTimeUnit = 0 -3 svGetTmePrecision = 0 -8
|
||||||
global vpiSimTime = 0,6000000 vpiScaledRealTime = 6e+06
|
global vpiSimTime = 0,6000000 vpiScaledRealTime = 6e+06
|
||||||
global vpiTimeUnit = -3 vpiTimePrecision = -8
|
global vpiTimeUnit = -3 vpiTimePrecision = -8
|
||||||
|
top.t svGetTime = 0 0,6000000
|
||||||
|
top.t svGetTimeUnit = 0 -3 svGetTmePrecision = 0 -8
|
||||||
top.t vpiSimTime = 0,6000000 vpiScaledRealTime = 60
|
top.t vpiSimTime = 0,6000000 vpiScaledRealTime = 60
|
||||||
top.t vpiTimeUnit = -3 vpiTimePrecision = -8
|
top.t vpiTimeUnit = -3 vpiTimePrecision = -8
|
||||||
*-* All Finished *-*
|
*-* All Finished *-*
|
||||||
|
@ -10,8 +10,12 @@ Time scale of t is 1ns / 1ns
|
|||||||
acc%0t=12345678901234567890.000000ns acc%0d=12345678901234567890
|
acc%0t=12345678901234567890.000000ns acc%0d=12345678901234567890
|
||||||
[60.000000ns] stime%0t=60.000000ns stime%0d=60 stime%0f=60.000000
|
[60.000000ns] stime%0t=60.000000ns stime%0d=60 stime%0f=60.000000
|
||||||
[60.000000ns] rtime%0t=60.000000ns rtime%0d=60 rtime%0f=60.000000
|
[60.000000ns] rtime%0t=60.000000ns rtime%0d=60 rtime%0f=60.000000
|
||||||
|
global svGetTime = 0 0,60
|
||||||
|
global svGetTimeUnit = 0 -9 svGetTmePrecision = 0 -9
|
||||||
global vpiSimTime = 0,60 vpiScaledRealTime = 60
|
global vpiSimTime = 0,60 vpiScaledRealTime = 60
|
||||||
global vpiTimeUnit = -9 vpiTimePrecision = -9
|
global vpiTimeUnit = -9 vpiTimePrecision = -9
|
||||||
|
top.t svGetTime = 0 0,60
|
||||||
|
top.t svGetTimeUnit = 0 -9 svGetTmePrecision = 0 -9
|
||||||
top.t vpiSimTime = 0,60 vpiScaledRealTime = 60
|
top.t vpiSimTime = 0,60 vpiScaledRealTime = 60
|
||||||
top.t vpiTimeUnit = -9 vpiTimePrecision = -9
|
top.t vpiTimeUnit = -9 vpiTimePrecision = -9
|
||||||
*-* All Finished *-*
|
*-* All Finished *-*
|
||||||
|
@ -10,8 +10,12 @@ Time scale of t is 1ps / 1fs
|
|||||||
acc%0t=12345678901234567.890000ns acc%0d=12345678901234567890
|
acc%0t=12345678901234567.890000ns acc%0d=12345678901234567890
|
||||||
[0.060000ns] stime%0t=0.060000ns stime%0d=60 stime%0f=60.000000
|
[0.060000ns] stime%0t=0.060000ns stime%0d=60 stime%0f=60.000000
|
||||||
[0.060000ns] rtime%0t=0.060000ns rtime%0d=60 rtime%0f=60.000000
|
[0.060000ns] rtime%0t=0.060000ns rtime%0d=60 rtime%0f=60.000000
|
||||||
|
global svGetTime = 0 0,60000
|
||||||
|
global svGetTimeUnit = 0 -12 svGetTmePrecision = 0 -15
|
||||||
global vpiSimTime = 0,60000 vpiScaledRealTime = 60000
|
global vpiSimTime = 0,60000 vpiScaledRealTime = 60000
|
||||||
global vpiTimeUnit = -12 vpiTimePrecision = -15
|
global vpiTimeUnit = -12 vpiTimePrecision = -15
|
||||||
|
top.t svGetTime = 0 0,60000
|
||||||
|
top.t svGetTimeUnit = 0 -12 svGetTmePrecision = 0 -15
|
||||||
top.t vpiSimTime = 0,60000 vpiScaledRealTime = 60
|
top.t vpiSimTime = 0,60000 vpiScaledRealTime = 60
|
||||||
top.t vpiTimeUnit = -12 vpiTimePrecision = -15
|
top.t vpiTimeUnit = -12 vpiTimePrecision = -15
|
||||||
*-* All Finished *-*
|
*-* All Finished *-*
|
||||||
|
@ -10,8 +10,12 @@ Time scale of t is 1s / 10ns
|
|||||||
acc%0t=12345678901234567890000000000.000000ns acc%0d=12345678901234567890
|
acc%0t=12345678901234567890000000000.000000ns acc%0d=12345678901234567890
|
||||||
[60000000000.000000ns] stime%0t=60000000000.000000ns stime%0d=60 stime%0f=60.000000
|
[60000000000.000000ns] stime%0t=60000000000.000000ns stime%0d=60 stime%0f=60.000000
|
||||||
[60000000000.000000ns] rtime%0t=60000000000.000000ns rtime%0d=60 rtime%0f=60.000000
|
[60000000000.000000ns] rtime%0t=60000000000.000000ns rtime%0d=60 rtime%0f=60.000000
|
||||||
|
global svGetTime = 0 1,1705032704
|
||||||
|
global svGetTimeUnit = 0 0 svGetTmePrecision = 0 -8
|
||||||
global vpiSimTime = 1,1705032704 vpiScaledRealTime = 6e+09
|
global vpiSimTime = 1,1705032704 vpiScaledRealTime = 6e+09
|
||||||
global vpiTimeUnit = 0 vpiTimePrecision = -8
|
global vpiTimeUnit = 0 vpiTimePrecision = -8
|
||||||
|
top.t svGetTime = 0 1,1705032704
|
||||||
|
top.t svGetTimeUnit = 0 0 svGetTmePrecision = 0 -8
|
||||||
top.t vpiSimTime = 1,1705032704 vpiScaledRealTime = 60
|
top.t vpiSimTime = 1,1705032704 vpiScaledRealTime = 60
|
||||||
top.t vpiTimeUnit = 0 vpiTimePrecision = -8
|
top.t vpiTimeUnit = 0 vpiTimePrecision = -8
|
||||||
*-* All Finished *-*
|
*-* All Finished *-*
|
||||||
|
@ -10,8 +10,12 @@ Time scale of t is 1us / 1ns
|
|||||||
acc%0t=12345678901234567890000.000000ns acc%0d=12345678901234567890
|
acc%0t=12345678901234567890000.000000ns acc%0d=12345678901234567890
|
||||||
[60000.000000ns] stime%0t=60000.000000ns stime%0d=60 stime%0f=60.000000
|
[60000.000000ns] stime%0t=60000.000000ns stime%0d=60 stime%0f=60.000000
|
||||||
[60000.000000ns] rtime%0t=60000.000000ns rtime%0d=60 rtime%0f=60.000000
|
[60000.000000ns] rtime%0t=60000.000000ns rtime%0d=60 rtime%0f=60.000000
|
||||||
|
global svGetTime = 0 0,60000
|
||||||
|
global svGetTimeUnit = 0 -6 svGetTmePrecision = 0 -9
|
||||||
global vpiSimTime = 0,60000 vpiScaledRealTime = 60000
|
global vpiSimTime = 0,60000 vpiScaledRealTime = 60000
|
||||||
global vpiTimeUnit = -6 vpiTimePrecision = -9
|
global vpiTimeUnit = -6 vpiTimePrecision = -9
|
||||||
|
top.t svGetTime = 0 0,60000
|
||||||
|
top.t svGetTimeUnit = 0 -6 svGetTmePrecision = 0 -9
|
||||||
top.t vpiSimTime = 0,60000 vpiScaledRealTime = 60
|
top.t vpiSimTime = 0,60000 vpiScaledRealTime = 60
|
||||||
top.t vpiTimeUnit = -6 vpiTimePrecision = -9
|
top.t vpiTimeUnit = -6 vpiTimePrecision = -9
|
||||||
*-* All Finished *-*
|
*-* All Finished *-*
|
||||||
|
@ -13,10 +13,14 @@
|
|||||||
#include "vpi_user.h"
|
#include "vpi_user.h"
|
||||||
|
|
||||||
#include <cstdio>
|
#include <cstdio>
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
// These require the above. Comment prevents clang-format moving them
|
// These require the above. Comment prevents clang-format moving them
|
||||||
|
#include "TestCheck.h"
|
||||||
#include "TestVpi.h"
|
#include "TestVpi.h"
|
||||||
|
|
||||||
|
int errors = 0;
|
||||||
|
|
||||||
//======================================================================
|
//======================================================================
|
||||||
|
|
||||||
#define NEED_EXTERNS
|
#define NEED_EXTERNS
|
||||||
@ -29,7 +33,45 @@ extern void dpii_check();
|
|||||||
|
|
||||||
//======================================================================
|
//======================================================================
|
||||||
|
|
||||||
void show(vpiHandle obj) {
|
void dpi_bad() {
|
||||||
|
{
|
||||||
|
int res = svGetTime(0, nullptr);
|
||||||
|
TEST_CHECK_EQ(res, -1);
|
||||||
|
}
|
||||||
|
{
|
||||||
|
int res = svGetTimeUnit(0, nullptr);
|
||||||
|
TEST_CHECK_EQ(res, -1);
|
||||||
|
}
|
||||||
|
{
|
||||||
|
int res = svGetTimePrecision(0, nullptr);
|
||||||
|
TEST_CHECK_EQ(res, -1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void dpi_show(svScope obj) {
|
||||||
|
const char* namep;
|
||||||
|
if (obj) {
|
||||||
|
namep = svGetNameFromScope(obj);
|
||||||
|
} else {
|
||||||
|
namep = "global";
|
||||||
|
}
|
||||||
|
|
||||||
|
svTimeVal t; // aka s_vpi_time
|
||||||
|
t.type = vpiSimTime;
|
||||||
|
int gres = svGetTime(obj, &t);
|
||||||
|
vpi_printf(const_cast<char*>("%s svGetTime = %d %d,%d\n"), namep, gres, (int)t.high,
|
||||||
|
(int)t.low);
|
||||||
|
|
||||||
|
// These will both print the precision, because the 0 asks for global scope
|
||||||
|
int32_t u = 99;
|
||||||
|
int ures = svGetTimeUnit(obj, &u);
|
||||||
|
int32_t p = 99;
|
||||||
|
int pres = svGetTimePrecision(obj, &p);
|
||||||
|
vpi_printf(const_cast<char*>("%s svGetTimeUnit = %d %d"), namep, ures, u);
|
||||||
|
vpi_printf(const_cast<char*>(" svGetTmePrecision = %d %d\n"), pres, p);
|
||||||
|
}
|
||||||
|
|
||||||
|
void vpi_show(vpiHandle obj) {
|
||||||
const char* namep;
|
const char* namep;
|
||||||
if (obj) {
|
if (obj) {
|
||||||
namep = vpi_get_str(vpiName, obj);
|
namep = vpi_get_str(vpiName, obj);
|
||||||
@ -55,12 +97,21 @@ void show(vpiHandle obj) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void dpii_check() {
|
void dpii_check() {
|
||||||
show(0);
|
dpi_bad();
|
||||||
|
dpi_show(0);
|
||||||
|
vpi_show(0);
|
||||||
|
|
||||||
|
svScope smod = svGetScopeFromName("top.t");
|
||||||
|
if (!smod) {
|
||||||
|
vpi_printf(const_cast<char*>("-- Cannot svGetScopeFromName\n"));
|
||||||
|
} else {
|
||||||
|
dpi_show(smod);
|
||||||
|
}
|
||||||
|
|
||||||
TestVpiHandle mod = vpi_handle_by_name((PLI_BYTE8*)"top.t", NULL);
|
TestVpiHandle mod = vpi_handle_by_name((PLI_BYTE8*)"top.t", NULL);
|
||||||
if (!mod) {
|
if (!mod) {
|
||||||
vpi_printf(const_cast<char*>("-- Cannot vpi_find module\n"));
|
vpi_printf(const_cast<char*>("-- Cannot vpi_find module\n"));
|
||||||
} else {
|
} else {
|
||||||
show(mod);
|
vpi_show(mod);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user