2012-04-13 01:08:20 +00:00
|
|
|
// -*- mode: C++; c-file-style: "cc-mode" -*-
|
2006-08-26 11:35:28 +00:00
|
|
|
//*************************************************************************
|
|
|
|
//
|
2019-01-04 00:17:22 +00:00
|
|
|
// Copyright 2003-2019 by Wilson Snyder. This program is free software; you can
|
2006-08-26 11:35:28 +00:00
|
|
|
// redistribute it and/or modify it under the terms of either the GNU
|
2009-05-04 21:07:57 +00:00
|
|
|
// Lesser General Public License Version 3 or the Perl Artistic License.
|
|
|
|
// Version 2.0.
|
2006-08-26 11:35:28 +00:00
|
|
|
//
|
|
|
|
// Verilator is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
2008-06-10 01:25:10 +00:00
|
|
|
//
|
2006-08-26 11:35:28 +00:00
|
|
|
//*************************************************************************
|
|
|
|
///
|
|
|
|
/// \file
|
|
|
|
/// \brief Verilator: Common include for OS portability (verilated & verilator)
|
|
|
|
///
|
2019-05-08 03:00:52 +00:00
|
|
|
/// This header is used by both the Verilator source code (run on the
|
|
|
|
/// build and host system), and the Verilated output (run on the target
|
|
|
|
/// system). Code needed by only the host system goes into
|
|
|
|
/// config_build.h.in, code needed by Verilated code only goes into
|
|
|
|
/// verilated.h, and code needed by both goes here (verilatedos.h).
|
2006-08-26 11:35:28 +00:00
|
|
|
///
|
2008-04-25 12:14:27 +00:00
|
|
|
/// Code available from: http://www.veripool.org/verilator
|
2006-08-26 11:35:28 +00:00
|
|
|
///
|
|
|
|
//*************************************************************************
|
2019-10-05 00:17:11 +00:00
|
|
|
|
2006-08-26 11:35:28 +00:00
|
|
|
|
|
|
|
#ifndef _VERILATEDOS_H_
|
2018-11-29 00:59:10 +00:00
|
|
|
#define _VERILATEDOS_H_ 1 ///< Header Guard
|
2006-08-26 11:35:28 +00:00
|
|
|
|
|
|
|
//=========================================================================
|
|
|
|
// Compiler pragma abstraction
|
|
|
|
|
|
|
|
#ifdef __GNUC__
|
|
|
|
# define VL_ATTR_ALIGNED(alignment) __attribute__ ((aligned (alignment)))
|
2010-02-04 00:19:18 +00:00
|
|
|
# define VL_ATTR_ALWINLINE __attribute__ ((always_inline))
|
2019-05-15 02:03:50 +00:00
|
|
|
# define VL_ATTR_COLD __attribute__ ((cold))
|
|
|
|
# define VL_ATTR_HOT __attribute__ ((hot))
|
2006-08-26 11:35:28 +00:00
|
|
|
# define VL_ATTR_NORETURN __attribute__ ((noreturn))
|
2019-04-02 22:24:36 +00:00
|
|
|
# define VL_ATTR_PRINTF(fmtArgNum) __attribute__ ((format (printf, (fmtArgNum), (fmtArgNum)+1)))
|
2017-10-27 01:51:51 +00:00
|
|
|
# define VL_ATTR_PURE __attribute__ ((pure))
|
2006-08-26 11:35:28 +00:00
|
|
|
# define VL_ATTR_UNUSED __attribute__ ((unused))
|
2009-12-05 15:38:49 +00:00
|
|
|
# define VL_FUNC __func__
|
2017-10-27 01:51:51 +00:00
|
|
|
# if defined(__clang__) && defined(VL_THREADED)
|
|
|
|
# define VL_ACQUIRE(...) __attribute__ ((acquire_capability(__VA_ARGS__)))
|
|
|
|
# define VL_ACQUIRE_SHARED(...) __attribute__ ((acquire_shared_capability(__VA_ARGS__)))
|
|
|
|
# define VL_RELEASE(...) __attribute__ ((release_capability(__VA_ARGS__)))
|
|
|
|
# define VL_RELEASE_SHARED(...) __attribute__ ((release_shared_capability(__VA_ARGS__)))
|
|
|
|
# define VL_TRY_ACQUIRE(...) __attribute__ ((try_acquire_capability(__VA_ARGS__)))
|
|
|
|
# define VL_TRY_ACQUIRE_SHARED(...) __attribute__ ((try_acquire_shared_capability(__VA_ARGS__)))
|
|
|
|
# define VL_CAPABILITY(x) __attribute__ ((capability(x)))
|
|
|
|
# define VL_REQUIRES(x) __attribute__ ((requires_capability(x)))
|
|
|
|
# define VL_GUARDED_BY(x) __attribute__ ((guarded_by(x)))
|
|
|
|
# define VL_EXCLUDES(x) __attribute__ ((locks_excluded(x)))
|
|
|
|
# define VL_SCOPED_CAPABILITY __attribute__ ((scoped_lockable))
|
|
|
|
# endif
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_LIKELY(x) __builtin_expect(!!(x), 1)
|
|
|
|
# define VL_UNLIKELY(x) __builtin_expect(!!(x), 0)
|
2017-09-13 23:27:59 +00:00
|
|
|
# define VL_UNREACHABLE __builtin_unreachable();
|
2007-02-07 14:26:53 +00:00
|
|
|
# define VL_PREFETCH_RD(p) __builtin_prefetch((p),0)
|
|
|
|
# define VL_PREFETCH_RW(p) __builtin_prefetch((p),1)
|
2010-02-04 00:19:18 +00:00
|
|
|
#elif defined(_MSC_VER)
|
|
|
|
# define VL_FUNC __FUNCTION__
|
2017-10-27 01:51:51 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// Defaults for unsupported compiler features
|
|
|
|
#ifndef VL_ATTR_ALIGNED
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_ATTR_ALIGNED(alignment) ///< Align structure to specified byte alignment
|
2017-10-27 01:51:51 +00:00
|
|
|
#endif
|
|
|
|
#ifndef VL_ATTR_ALWINLINE
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_ATTR_ALWINLINE ///< Inline, even when not optimizing
|
2017-10-27 01:51:51 +00:00
|
|
|
#endif
|
2019-05-15 02:03:50 +00:00
|
|
|
#ifndef VL_ATTR_COLD
|
|
|
|
# define VL_ATTR_COLD ///< Function is rarely executed
|
|
|
|
#endif
|
|
|
|
#ifndef VL_ATTR_HOT
|
|
|
|
# define VL_ATTR_HOT ///< Function is highly executed
|
|
|
|
#endif
|
2017-10-27 01:51:51 +00:00
|
|
|
#ifndef VL_ATTR_NORETURN
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_ATTR_NORETURN ///< Function does not ever return
|
2017-10-27 01:51:51 +00:00
|
|
|
#endif
|
|
|
|
#ifndef VL_ATTR_PRINTF
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_ATTR_PRINTF(fmtArgNum) ///< Function with printf format checking
|
2017-10-27 01:51:51 +00:00
|
|
|
#endif
|
|
|
|
#ifndef VL_ATTR_PURE
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_ATTR_PURE ///< Function is pure (and thus also VL_MT_SAFE)
|
2017-10-27 01:51:51 +00:00
|
|
|
#endif
|
|
|
|
#ifndef VL_ATTR_UNUSED
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_ATTR_UNUSED ///< Function that may be never used
|
2017-10-27 01:51:51 +00:00
|
|
|
#endif
|
|
|
|
#ifndef VL_FUNC
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_FUNC "__func__" ///< Name of current function for error macros
|
2017-10-27 01:51:51 +00:00
|
|
|
#endif
|
|
|
|
#ifndef VL_CAPABILITY
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_ACQUIRE(...) ///< Function requires a capability/lock (-fthread-safety)
|
|
|
|
# define VL_ACQUIRE_SHARED(...) ///< Function aquires a shared capability/lock (-fthread-safety)
|
|
|
|
# define VL_RELEASE(...) ///< Function releases a capability/lock (-fthread-safety)
|
|
|
|
# define VL_RELEASE_SHARED(...) ///< Function releases a shared capability/lock (-fthread-safety)
|
|
|
|
# define VL_TRY_ACQUIRE(...) ///< Function returns bool if aquired a capability (-fthread-safety)
|
|
|
|
# define VL_TRY_ACQUIRE_SHARED(...) ///< Function returns bool if aquired a shared capability (-fthread-safety)
|
|
|
|
# define VL_REQUIRES(x) ///< Function requires a capability inbound (-fthread-safety)
|
|
|
|
# define VL_EXCLUDES(x) ///< Function requires not having a capability inbound (-fthread-safety)
|
|
|
|
# define VL_CAPABILITY(x) ///< Name of capability/lock (-fthread-safety)
|
|
|
|
# define VL_GUARDED_BY(x) ///< Name of mutex protecting this variable (-fthread-safety)
|
|
|
|
# define VL_SCOPED_CAPABILITY ///< Scoped threaded capability/lock (-fthread-safety)
|
2017-10-27 01:51:51 +00:00
|
|
|
#endif
|
|
|
|
#ifndef VL_LIKELY
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_LIKELY(x) (!!(x)) ///< Boolean expression more often true than false
|
|
|
|
# define VL_UNLIKELY(x) (!!(x)) ///< Boolean expression more often false than true
|
2017-10-27 01:51:51 +00:00
|
|
|
#endif
|
2019-07-01 02:37:03 +00:00
|
|
|
#define VL_UNCOVERABLE(x) VL_UNLIKELY(x) ///< Boolean expression never hit by users (no coverage)
|
2017-10-27 01:51:51 +00:00
|
|
|
#ifndef VL_UNREACHABLE
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_UNREACHABLE ///< Point that may never be reached
|
2017-10-27 01:51:51 +00:00
|
|
|
#endif
|
|
|
|
#ifndef VL_PREFETCH_RD
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_PREFETCH_RD(p) ///< Prefetch data with read intent
|
2017-10-27 01:51:51 +00:00
|
|
|
#endif
|
|
|
|
#ifndef VL_PREFETCH_RW
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_PREFETCH_RW(p) ///< Prefetch data with read/write intent
|
2006-08-26 11:35:28 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef VL_THREADED
|
2019-10-07 23:23:06 +00:00
|
|
|
# if defined(_MSC_VER) && _MSC_VER >= 1900
|
|
|
|
# define VL_THREAD_LOCAL thread_local
|
|
|
|
# elif defined(__GNUC__)
|
2017-10-08 01:29:57 +00:00
|
|
|
# if (__cplusplus < 201103L) && !defined(VL_THREADED_NO_C11_WARNING)
|
2017-10-27 01:51:51 +00:00
|
|
|
# error "VL_THREADED/--threads support requires C++-11 or newer only; use newer compiler"
|
2017-10-08 01:29:57 +00:00
|
|
|
# endif
|
2006-08-26 11:35:28 +00:00
|
|
|
# else
|
|
|
|
# error "Unsupported compiler for VL_THREADED: No thread-local declarator"
|
|
|
|
# endif
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_THREAD_LOCAL thread_local ///< Use new C++ static local thread
|
2006-08-26 11:35:28 +00:00
|
|
|
#else
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_THREAD_LOCAL ///< Use new C++ static local thread
|
2006-08-26 11:35:28 +00:00
|
|
|
#endif
|
2019-05-08 03:00:52 +00:00
|
|
|
#define VL_THREAD ///< Deprecated
|
|
|
|
#define VL_STATIC_OR_THREAD static ///< Deprecated
|
2006-08-26 11:35:28 +00:00
|
|
|
|
2017-10-27 00:05:42 +00:00
|
|
|
#define VL_PURE ///< Comment tag that Function is pure (and thus also VL_MT_SAFE)
|
|
|
|
#define VL_MT_SAFE ///< Comment tag that function is threadsafe when VL_THREADED
|
|
|
|
#define VL_MT_SAFE_POSTINIT ///< Comment tag that function is threadsafe when VL_THREADED, only during normal operation (post-init)
|
|
|
|
#define VL_MT_UNSAFE ///< Comment tag that function is not threadsafe when VL_THREADED
|
|
|
|
#define VL_MT_UNSAFE_ONE ///< Comment tag that function is not threadsafe when VL_THREADED, protected to make sure single-caller
|
|
|
|
|
2006-08-26 11:35:28 +00:00
|
|
|
#ifdef _MSC_VER
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_ULL(c) (c##ui64) ///< Add appropriate suffix to 64-bit constant
|
2006-08-26 11:35:28 +00:00
|
|
|
#else
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_ULL(c) (c##ULL) ///< Add appropriate suffix to 64-bit constant
|
2006-08-26 11:35:28 +00:00
|
|
|
#endif
|
|
|
|
|
2007-10-31 19:22:26 +00:00
|
|
|
// This is not necessarily the same as #UL, depending on what the IData typedef is.
|
2019-05-08 03:00:52 +00:00
|
|
|
#define VL_UL(c) (static_cast<IData>(c##UL)) ///< Add appropriate suffix to 32-bit constant
|
2007-10-31 19:22:26 +00:00
|
|
|
|
2017-07-07 00:25:59 +00:00
|
|
|
#if defined(VL_CPPCHECK) || defined(__clang_analyzer__)
|
2015-10-04 17:16:35 +00:00
|
|
|
# define VL_DANGLING(v)
|
|
|
|
#else
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_DANGLING(v) do { (v) = NULL; } while(0) ///< After e.g. delete, set variable to NULL to indicate must not use later
|
2015-10-04 17:16:35 +00:00
|
|
|
#endif
|
|
|
|
|
2014-03-15 18:50:03 +00:00
|
|
|
//=========================================================================
|
|
|
|
// C++-2011
|
|
|
|
|
|
|
|
#if __cplusplus >= 201103L || defined(__GXX_EXPERIMENTAL_CXX0X__)
|
2017-10-26 00:00:38 +00:00
|
|
|
# define VL_EQ_DELETE = delete
|
2017-10-18 22:22:58 +00:00
|
|
|
# define vl_unique_ptr std::unique_ptr
|
2018-06-16 00:57:07 +00:00
|
|
|
// By default we use std:: types in C++11.
|
|
|
|
// Define VL_USE_UNORDERED_TYPES to test these pre-C++11 classes
|
|
|
|
# ifdef VL_USE_UNORDERED_TYPES
|
|
|
|
# define VL_INCLUDE_UNORDERED_MAP "verilated_unordered_set_map.h"
|
|
|
|
# define VL_INCLUDE_UNORDERED_SET "verilated_unordered_set_map.h"
|
|
|
|
# else
|
|
|
|
# define vl_unordered_map std::unordered_map
|
|
|
|
# define vl_unordered_set std::unordered_set
|
|
|
|
# define VL_INCLUDE_UNORDERED_MAP <unordered_map>
|
|
|
|
# define VL_INCLUDE_UNORDERED_SET <unordered_set>
|
|
|
|
# endif
|
2014-03-15 18:50:03 +00:00
|
|
|
#else
|
2017-10-26 00:00:38 +00:00
|
|
|
# define VL_EQ_DELETE
|
2017-10-18 22:22:58 +00:00
|
|
|
# define vl_unique_ptr std::auto_ptr
|
2018-06-12 02:05:15 +00:00
|
|
|
# define VL_INCLUDE_UNORDERED_MAP "verilated_unordered_set_map.h"
|
|
|
|
# define VL_INCLUDE_UNORDERED_SET "verilated_unordered_set_map.h"
|
2014-03-15 18:50:03 +00:00
|
|
|
#endif
|
|
|
|
|
2014-11-27 15:52:38 +00:00
|
|
|
//=========================================================================
|
|
|
|
// Optimization
|
|
|
|
|
|
|
|
#ifndef VL_INLINE_OPT
|
2019-05-08 03:00:52 +00:00
|
|
|
# define VL_INLINE_OPT ///< "inline" if compiling all objects in single compiler run
|
2014-11-27 15:52:38 +00:00
|
|
|
#endif
|
|
|
|
|
2010-01-24 11:20:10 +00:00
|
|
|
//=========================================================================
|
|
|
|
// Warning disabled
|
|
|
|
|
|
|
|
#ifndef VL_WARNINGS
|
|
|
|
# ifdef _MSC_VER
|
2018-11-29 00:59:10 +00:00
|
|
|
# pragma warning(disable:4099) // C4099: type name first seen using 'class' now seen using 'struct' (V3AstNode)
|
|
|
|
# pragma warning(disable:4100) // C4100: unreferenced formal parameter (L4)
|
|
|
|
# pragma warning(disable:4127) // C4127: conditional expression is constant (L4)
|
|
|
|
# pragma warning(disable:4146) // C4146: unary minus operator applied to unsigned type, result still unsigned
|
|
|
|
# pragma warning(disable:4189) // C4189: local variable is initialized but not referenced (L4)
|
|
|
|
# pragma warning(disable:4244) // C4244: conversion from 'uint64_t' to 'uint_32_t', possible loss of data
|
|
|
|
# pragma warning(disable:4245) // C4245: conversion from 'int' to 'unsigned', signed/unsigned mismatch
|
|
|
|
# pragma warning(disable:4996) // C4996: sscanf/fopen/etc may be unsafe
|
2010-01-24 11:20:10 +00:00
|
|
|
# endif
|
|
|
|
#endif
|
|
|
|
|
2006-08-26 11:35:28 +00:00
|
|
|
//=========================================================================
|
|
|
|
// Basic integer types
|
|
|
|
|
2019-06-12 01:38:17 +00:00
|
|
|
#ifdef __MINGW32__
|
|
|
|
# define __USE_MINGW_ANSI_STDIO 1 // Force old MinGW (GCC 5 and older) to use C99 formats
|
|
|
|
# define __STDC_FORMAT_MACROS 1 // Otherwise MinGW doesn't get PRId64 for fstapi.c
|
|
|
|
#endif
|
|
|
|
|
2018-10-14 17:43:24 +00:00
|
|
|
#if defined(__CYGWIN__)
|
2010-01-16 16:53:08 +00:00
|
|
|
|
2006-08-26 11:35:28 +00:00
|
|
|
# include <stdint.h>
|
2018-08-31 10:52:12 +00:00
|
|
|
# include <sys/types.h> // __WORDSIZE
|
2018-10-14 17:43:24 +00:00
|
|
|
# include <unistd.h> // ssize_t
|
2019-05-08 03:00:52 +00:00
|
|
|
typedef unsigned char uint8_t; ///< 8-bit unsigned type (backward compatibility)
|
|
|
|
typedef unsigned short int uint16_t; ///< 16-bit unsigned type (backward compatibility)
|
|
|
|
typedef unsigned char vluint8_t; ///< 8-bit unsigned type
|
|
|
|
typedef unsigned short int vluint16_t; ///< 16-bit unsigned type
|
2018-11-29 00:59:10 +00:00
|
|
|
# if defined(__uint32_t_defined) || defined(___int32_t_defined) // Newer Cygwin uint32_t in stdint.h as an unsigned int
|
|
|
|
typedef int32_t vlsint32_t; ///< 32-bit signed type
|
|
|
|
typedef uint32_t vluint32_t; ///< 32-bit unsigned type
|
|
|
|
# else // Older Cygwin has long==uint32_t
|
2019-05-08 03:00:52 +00:00
|
|
|
typedef unsigned long uint32_t; ///< 32-bit unsigned type (backward compatibility)
|
|
|
|
typedef long vlsint32_t; ///< 32-bit signed type
|
|
|
|
typedef unsigned long vluint32_t; ///< 32-bit unsigned type
|
2010-01-16 16:53:08 +00:00
|
|
|
# endif
|
2010-04-10 01:51:15 +00:00
|
|
|
# if defined(__WORDSIZE) && (__WORDSIZE == 64)
|
2019-05-08 03:00:52 +00:00
|
|
|
typedef long vlsint64_t; ///< 64-bit signed type
|
|
|
|
typedef unsigned long vluint64_t; ///< 64-bit unsigned type
|
2010-04-10 01:51:15 +00:00
|
|
|
# else
|
2019-05-08 03:00:52 +00:00
|
|
|
typedef long long vlsint64_t; ///< 64-bit signed type
|
|
|
|
typedef unsigned long long vluint64_t; ///< 64-bit unsigned type
|
2010-04-10 01:51:15 +00:00
|
|
|
# endif
|
2010-01-16 16:53:08 +00:00
|
|
|
|
2008-11-05 15:52:23 +00:00
|
|
|
#elif defined(_WIN32) && defined(_MSC_VER)
|
2010-01-16 16:53:08 +00:00
|
|
|
|
2019-05-08 03:00:52 +00:00
|
|
|
typedef unsigned __int8 uint8_t; ///< 8-bit unsigned type (backward compatibility)
|
|
|
|
typedef unsigned __int16 uint16_t; ///< 16-bit unsigned type (backward compatibility)
|
|
|
|
typedef unsigned __int32 uint32_t; ///< 32-bit unsigned type (backward compatibility)
|
|
|
|
typedef unsigned __int8 vluint8_t; ///< 8-bit unsigned type
|
|
|
|
typedef unsigned __int16 vluint16_t; ///< 16-bit unsigned type
|
|
|
|
typedef signed __int32 vlsint32_t; ///< 32-bit signed type
|
|
|
|
typedef unsigned __int32 vluint32_t; ///< 32-bit unsigned type
|
|
|
|
typedef signed __int64 vlsint64_t; ///< 64-bit signed type
|
|
|
|
typedef unsigned __int64 vluint64_t; ///< 64-bit unsigned type
|
2010-01-16 16:53:08 +00:00
|
|
|
|
2010-04-10 10:46:24 +00:00
|
|
|
# ifndef _SSIZE_T_DEFINED
|
|
|
|
# ifdef _WIN64
|
|
|
|
typedef signed __int64 ssize_t; ///< signed size_t; returned from read()
|
|
|
|
# else
|
|
|
|
typedef signed __int32 ssize_t; ///< signed size_t; returned from read()
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
|
2018-11-29 00:59:10 +00:00
|
|
|
#else // Linux or compliant Unix flavors, -m64
|
2010-01-16 16:53:08 +00:00
|
|
|
|
2018-11-29 00:59:10 +00:00
|
|
|
# include <inttypes.h> // Solaris
|
2018-10-14 17:43:24 +00:00
|
|
|
# include <stdint.h> // Linux and most flavors
|
2018-08-31 10:52:12 +00:00
|
|
|
# include <sys/types.h> // __WORDSIZE
|
2018-10-14 17:43:24 +00:00
|
|
|
# include <unistd.h> // ssize_t
|
2019-05-08 03:00:52 +00:00
|
|
|
typedef uint8_t vluint8_t; ///< 32-bit unsigned type
|
|
|
|
typedef uint16_t vluint16_t; ///< 32-bit unsigned type
|
|
|
|
typedef int vlsint32_t; ///< 32-bit signed type
|
|
|
|
typedef uint32_t vluint32_t; ///< 32-bit signed type
|
2010-04-10 01:51:15 +00:00
|
|
|
# if defined(__WORDSIZE) && (__WORDSIZE == 64)
|
2019-05-08 03:00:52 +00:00
|
|
|
typedef long vlsint64_t; ///< 64-bit signed type
|
|
|
|
typedef unsigned long vluint64_t; ///< 64-bit unsigned type
|
2010-04-10 01:51:15 +00:00
|
|
|
# else
|
2019-05-08 03:00:52 +00:00
|
|
|
typedef long long vlsint64_t; ///< 64-bit signed type
|
|
|
|
typedef unsigned long long vluint64_t; ///< 64-bit unsigned type
|
2010-04-10 01:51:15 +00:00
|
|
|
# endif
|
2006-08-26 11:35:28 +00:00
|
|
|
#endif
|
|
|
|
|
2010-02-01 14:28:53 +00:00
|
|
|
//=========================================================================
|
|
|
|
// Printing printf/scanf formats
|
|
|
|
// Alas cinttypes isn't that standard yet
|
|
|
|
|
2019-04-02 22:24:36 +00:00
|
|
|
// Use Microsoft-specific format specifiers for Microsoft Visual C++ only
|
|
|
|
#ifdef _MSC_VER
|
2010-02-01 14:28:53 +00:00
|
|
|
# define VL_PRI64 "I64"
|
2019-04-02 22:24:36 +00:00
|
|
|
#else // use standard C99 format specifiers
|
2010-04-10 01:51:15 +00:00
|
|
|
# if defined(__WORDSIZE) && (__WORDSIZE == 64)
|
|
|
|
# define VL_PRI64 "l"
|
|
|
|
# else
|
|
|
|
# define VL_PRI64 "ll"
|
|
|
|
# endif
|
2010-02-01 14:28:53 +00:00
|
|
|
#endif
|
|
|
|
|
2015-06-16 11:13:45 +00:00
|
|
|
#if defined(_WIN32) && defined(_MSC_VER)
|
2015-06-22 01:01:02 +00:00
|
|
|
# if (_MSC_VER < 1900)
|
|
|
|
# define VL_SNPRINTF _snprintf
|
|
|
|
# else
|
|
|
|
# define VL_SNPRINTF snprintf
|
|
|
|
# endif
|
|
|
|
# define VL_VSNPRINTF vsnprintf
|
2015-06-04 23:37:03 +00:00
|
|
|
#else
|
2015-06-16 11:13:45 +00:00
|
|
|
# define VL_SNPRINTF snprintf
|
2015-06-04 23:37:03 +00:00
|
|
|
# define VL_VSNPRINTF vsnprintf
|
|
|
|
#endif
|
|
|
|
|
2013-11-29 13:28:48 +00:00
|
|
|
//=========================================================================
|
|
|
|
// File system functions
|
|
|
|
|
|
|
|
#ifdef _WIN32
|
|
|
|
# define VL_DEV_NULL "nul"
|
2018-11-29 00:59:10 +00:00
|
|
|
#else // Linux or compliant Unix flavors
|
2013-11-29 13:28:48 +00:00
|
|
|
# define VL_DEV_NULL "/dev/null"
|
|
|
|
#endif
|
|
|
|
|
2006-08-26 11:35:28 +00:00
|
|
|
//=========================================================================
|
|
|
|
// Integer size macros
|
|
|
|
|
2019-05-08 03:00:52 +00:00
|
|
|
#define VL_BYTESIZE 8 ///< Bits in a byte
|
|
|
|
#define VL_SHORTSIZE 16 ///< Bits in a short
|
|
|
|
#define VL_WORDSIZE 32 ///< Bits in a word
|
|
|
|
#define VL_QUADSIZE 64 ///< Bits in a quadword
|
|
|
|
#define VL_WORDSIZE_LOG2 5 ///< log2(VL_WORDSIZE)
|
2006-08-26 11:35:28 +00:00
|
|
|
|
2008-06-28 00:04:20 +00:00
|
|
|
/// Bytes this number of bits needs (1 bit=1 byte)
|
|
|
|
#define VL_BYTES_I(nbits) (((nbits)+(VL_BYTESIZE-1))/VL_BYTESIZE)
|
2006-08-26 11:35:28 +00:00
|
|
|
/// Words this number of bits needs (1 bit=1 word)
|
|
|
|
#define VL_WORDS_I(nbits) (((nbits)+(VL_WORDSIZE-1))/VL_WORDSIZE)
|
|
|
|
|
2017-11-01 22:51:41 +00:00
|
|
|
//=========================================================================
|
|
|
|
// Class definition helpers
|
|
|
|
|
|
|
|
// Used to declare a class as uncopyable; put after a private:
|
|
|
|
#define VL_UNCOPYABLE(Type) \
|
|
|
|
Type(const Type& other) VL_EQ_DELETE; \
|
|
|
|
Type& operator= (const Type&) VL_EQ_DELETE
|
|
|
|
|
2006-08-26 11:35:28 +00:00
|
|
|
//=========================================================================
|
|
|
|
// Verilated function size macros
|
|
|
|
|
2019-05-08 03:00:52 +00:00
|
|
|
#define VL_MULS_MAX_WORDS 16 ///< Max size in words of MULS operation
|
|
|
|
#define VL_TO_STRING_MAX_WORDS 64 ///< Max size in words of String conversion operation
|
2006-08-26 11:35:28 +00:00
|
|
|
|
|
|
|
//=========================================================================
|
|
|
|
// Base macros
|
|
|
|
|
2019-05-08 03:00:52 +00:00
|
|
|
#define VL_SIZEBITS_I (VL_WORDSIZE-1) ///< Bit mask for bits in a word
|
|
|
|
#define VL_SIZEBITS_Q (VL_QUADSIZE-1) ///< Bit mask for bits in a quad
|
2006-08-26 11:35:28 +00:00
|
|
|
|
|
|
|
/// Mask for words with 1's where relevant bits are (0=all bits)
|
|
|
|
#define VL_MASK_I(nbits) (((nbits) & VL_SIZEBITS_I) \
|
2019-05-08 03:00:52 +00:00
|
|
|
? ((1U << ((nbits) & VL_SIZEBITS_I) )-1) : ~0)
|
2006-08-26 11:35:28 +00:00
|
|
|
/// Mask for quads with 1's where relevant bits are (0=all bits)
|
|
|
|
#define VL_MASK_Q(nbits) (((nbits) & VL_SIZEBITS_Q) \
|
2019-05-08 03:00:52 +00:00
|
|
|
? ((VL_ULL(1) << ((nbits) & VL_SIZEBITS_Q) )-VL_ULL(1)) : VL_ULL(~0))
|
2018-11-29 00:59:10 +00:00
|
|
|
#define VL_BITWORD_I(bit) ((bit)/VL_WORDSIZE) ///< Word number for a wide quantity
|
|
|
|
#define VL_BITBIT_I(bit) ((bit)&VL_SIZEBITS_I) ///< Bit number for a bit in a long
|
|
|
|
#define VL_BITBIT_Q(bit) ((bit)&VL_SIZEBITS_Q) ///< Bit number for a bit in a quad
|
2006-08-26 11:35:28 +00:00
|
|
|
|
2011-09-21 13:08:05 +00:00
|
|
|
//=========================================================================
|
|
|
|
// Floating point
|
|
|
|
// #defines, to avoid requiring math.h on all compile runs
|
|
|
|
|
|
|
|
#ifdef _MSC_VER
|
|
|
|
# define VL_TRUNC(n) (((n)<0) ? ceil((n)) : floor((n)))
|
|
|
|
# define VL_ROUND(n) (((n)<0) ? ceil((n)-0.5) : floor((n)+0.5))
|
|
|
|
#else
|
|
|
|
# define VL_TRUNC(n) trunc(n)
|
|
|
|
# define VL_ROUND(n) round(n)
|
|
|
|
#endif
|
|
|
|
|
2018-05-09 01:43:32 +00:00
|
|
|
//=========================================================================
|
|
|
|
// Performance counters
|
|
|
|
|
|
|
|
/// The vluint64_t argument is loaded with a high-performance counter for profiling
|
|
|
|
/// or 0x0 if not implemeted on this platform
|
2018-07-22 15:53:35 +00:00
|
|
|
#if defined(__i386__) || defined(__x86_64__)
|
|
|
|
# define VL_RDTSC(val) { \
|
2018-05-25 02:17:44 +00:00
|
|
|
vluint32_t hi, lo; \
|
|
|
|
asm volatile("rdtsc" : "=a" (lo), "=d" (hi)); \
|
|
|
|
(val) = ((vluint64_t)lo) | (((vluint64_t)hi)<<32); \
|
|
|
|
}
|
2018-07-22 15:53:35 +00:00
|
|
|
#elif defined(__aarch64__)
|
|
|
|
# define VL_RDTSC(val) asm volatile("mrs %[rt],PMCCNTR_EL0" : [rt] "=r" (val));
|
|
|
|
#else
|
2018-05-09 01:43:32 +00:00
|
|
|
// We just silently ignore unknown OSes, as only leads to missing statistics
|
2018-07-22 15:53:35 +00:00
|
|
|
# define VL_RDTSC(val) (val) = 0;
|
2018-05-09 01:43:32 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
//=========================================================================
|
|
|
|
// Threading related OS-specific functions
|
|
|
|
|
|
|
|
#if VL_THREADED
|
2019-10-07 23:23:06 +00:00
|
|
|
# ifdef _WIN32
|
|
|
|
# define WIN32_LEAN_AND_MEAN
|
|
|
|
# define NOMINMAX
|
|
|
|
# include "Windows.h"
|
|
|
|
# define VL_CPU_RELAX() YieldProcessor()
|
|
|
|
# elif defined(__i386__) || defined(__x86_64__)
|
2018-05-09 01:43:32 +00:00
|
|
|
/// For more efficient busy waiting on SMT CPUs, let the processor know
|
|
|
|
/// we're just waiting so it can let another thread run
|
|
|
|
# define VL_CPU_RELAX() asm volatile("rep; nop" ::: "memory")
|
|
|
|
# elif defined(__ia64__)
|
|
|
|
# define VL_CPU_RELAX() asm volatile("hint @pause" ::: "memory")
|
|
|
|
# elif defined(__aarch64__)
|
|
|
|
# define VL_CPU_RELAX() asm volatile("yield" ::: "memory")
|
|
|
|
# elif defined(__powerpc64__)
|
|
|
|
# define VL_CPU_RELAX() asm volatile("or 1, 1, 1; or 2, 2, 2;" ::: "memory")
|
2018-06-12 02:05:15 +00:00
|
|
|
# else
|
2018-05-09 01:43:32 +00:00
|
|
|
# error "Missing VL_CPU_RELAX() definition. Or, don't use VL_THREADED"
|
|
|
|
# endif
|
|
|
|
#endif
|
|
|
|
|
2006-08-26 11:35:28 +00:00
|
|
|
//=========================================================================
|
|
|
|
|
2019-07-30 01:07:37 +00:00
|
|
|
#endif // Guard
|