iverilog/vvp/vpi_priv.h

286 lines
8.8 KiB
C
Raw Normal View History

#ifndef __vpi_priv_H
#define __vpi_priv_H
/*
* Copyright (c) 2001 Stephen Williams (steve@icarus.com)
*
* This source code is free software; you can redistribute it
* and/or modify it in source code form under the terms of the GNU
* General Public License as published by the Free Software
* Foundation; either version 2 of the License, or (at your option)
* any later version.
*
* This program 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.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
*/
#if !defined(WINNT)
#ident "$Id: vpi_priv.h,v 1.24 2001/10/31 04:27:47 steve Exp $"
#endif
# include "vpi_user.h"
2001-03-20 07:16:23 +01:00
# include "pointers.h"
# include "memory.h"
/*
* This header file contains the internal definitions that the vvp
* program uses to implement the public interface in the vpi_user.h
* header file elsewhere.
*/
/*
* This structure is the very base of a vpiHandle. Every handle
* structure starts with this structure, so that the library can
* internally pass the derived types as pointers to one of these.
*/
struct __vpiHandle {
const struct __vpirt *vpi_type;
};
/*
* Objects with this structure are used to represent a type of
* vpiHandle. A specific object becomes of this type by holding a
* pointer to an instance of this structure.
*/
struct __vpirt {
int type_code;
/* These methods extract information from the handle. */
int (*vpi_get_)(int, vpiHandle);
char* (*vpi_get_str_)(int, vpiHandle);
void (*vpi_get_value_)(vpiHandle, p_vpi_value);
vpiHandle (*vpi_put_value_)(vpiHandle, p_vpi_value, p_vpi_time, int);
/* These methods follow references. */
vpiHandle (*handle_)(int, vpiHandle);
vpiHandle (*iterate_)(int, vpiHandle);
vpiHandle (*index_)(vpiHandle, int);
};
/*
* The vpiHandle for an iterator has this structure. The definition of
* the methods lives in vpi_iter.c
*/
struct __vpiIterator {
struct __vpiHandle base;
vpiHandle *args;
unsigned nargs;
unsigned next;
};
extern vpiHandle vpip_make_iterator(unsigned nargs, vpiHandle*args);
2001-03-18 01:37:55 +01:00
/*
* Scopes are created by .scope statements in the source.
*/
struct __vpiScope {
struct __vpiHandle base;
struct __vpiScope *scope;
2001-03-18 01:37:55 +01:00
/* The scope has a name. */
char*name;
/* Keep an array of internal scope items. */
struct __vpiHandle**intern;
unsigned nintern;
2001-04-18 06:21:23 +02:00
/* Keep a list of threads in the scope. */
vthread_t threads;
2001-03-18 01:37:55 +01:00
};
2001-04-18 06:21:23 +02:00
extern struct __vpiScope* vpip_peek_current_scope(void);
2001-03-18 01:37:55 +01:00
extern void vpip_attach_to_current_scope(vpiHandle obj);
2001-03-20 07:16:23 +01:00
/*
* Signals include the variable types (reg, integer, time) and are
* distinguished by the vpiType code. They also have a parent scope,
* a declared name and declaration indices.
*/
struct __vpiSignal {
struct __vpiHandle base;
2001-04-18 06:21:23 +02:00
struct __vpiScope* scope;
2001-03-20 07:16:23 +01:00
/* The name of this reg/net object */
char*name;
/* The indices that define the width and access offset. */
int msb, lsb;
2001-04-04 19:43:19 +02:00
/* Flags */
unsigned signed_flag : 1;
2001-03-20 07:16:23 +01:00
/* The represented value is here. */
vvp_fvector_t bits;
/* This is the callback event functor */
struct callback_functor_s *callback;
2001-03-20 07:16:23 +01:00
};
extern vpiHandle vpip_make_reg(char*name, int msb, int lsb, bool signed_flag,
vvp_fvector_t vec);
extern vpiHandle vpip_make_net(char*name, int msb, int lsb, bool signed_flag,
vvp_fvector_t vec);
2001-06-22 00:54:12 +02:00
/*
* Memory is an array of bits that is accessible in N-bit chunks, with
* N being the width of a word. The memory word handle just points
* back to the memory and uses an index to identify its position in
* the memory.
*/
extern vpiHandle vpip_make_memory(vvp_memory_t mem);
/*
* When a loaded VPI module announces a system task/function, one
* __vpiUserSystf object is created to hold the definition of that
2001-05-20 02:46:12 +02:00
* task/function. The distinction between task and function is stored
* in the vpi_systf_data structure data that was supplied by the
* external module.
*
* When the compiler encounters a %vpi_call statement, it creates a
* __vpiSysTaskCall to represent that particular call. The call refers
* to the definition handle so that when the %vpi_call instruction is
* encountered at run-time, the definition can be located and used.
2001-05-20 02:46:12 +02:00
*
* The vpiSysTaskCall handles both functions and tasks, as the two are
* extremely similar. The different VPI type is reflected in a
* different vpi_type pointer in the base structure. The only
* additional part is the vbit/vwid that is used by the put of the
* system function call to place the values in the vthread bit space.
*/
struct __vpiUserSystf {
struct __vpiHandle base;
s_vpi_systf_data info;
};
struct __vpiSysTaskCall {
struct __vpiHandle base;
2001-04-18 06:21:23 +02:00
struct __vpiScope* scope;
struct __vpiUserSystf*defn;
unsigned nargs;
vpiHandle*args;
2001-05-20 02:46:12 +02:00
/* These represent where in the vthread to put the return value. */
unsigned short vbit, vwid;
};
extern struct __vpiSysTaskCall*vpip_cur_task;
/*
* These are implemented in vpi_const.cc. These are vpiHandles for
* constants.
*/
struct __vpiStringConst {
struct __vpiHandle base;
const char*value;
};
vpiHandle vpip_make_string_const(char*text);
struct __vpiBinaryConst {
struct __vpiHandle base;
unsigned nbits;
unsigned char*bits;
};
vpiHandle vpip_make_binary_const(unsigned wid, char*bits);
/*
* This one looks like a constant, but really is a vector in the current
* thread.
*/
vpiHandle vpip_make_vthr_vector(unsigned base, unsigned wid);
/*
* This function is called before any compilation to load VPI
* modules. This gives the modules a chance to announce their
* contained functions before compilation commences. It is called only
* once per module.
*/
extern void vpip_load_module(const char*name);
# define VPIP_MODULE_PATH_MAX 64
extern const char* vpip_module_path[64];
extern unsigned vpip_module_path_cnt;
/*
* The vpip_build_vpi_call function creates a __vpiSysTaskCall object
* and returns the handle. The compiler uses this function when it
* encounters a %vpi_call statement.
*
* The %vpi_call instruction has as its only parameter the handle that
* is returned by the vpip_build_vpi_call. This includes all the
* information needed by vpip_execute_vpi_call to actually execute the
* call. However, the vpiSysTaskCall that is the returned handle,
* holds a parameter argument list that is passed in here.
*
2001-05-20 02:46:12 +02:00
* The vbit and vwid fields are used if this turns out to be a system
* function. In that case, the vbit and vwid are used to address the
* vector is thread bit space where the result is supposed to go.
*
* Note that the argv array is saved in the handle, and should should
* not be released by the caller.
*/
extern vpiHandle vpip_build_vpi_call(const char*name,
2001-05-20 02:46:12 +02:00
unsigned vbit, unsigned vwid,
unsigned argc,
vpiHandle*argv);
extern vthread_t vpip_current_vthread;
extern void vpip_execute_vpi_call(vthread_t thr, vpiHandle obj);
2001-03-18 01:37:55 +01:00
/*
* These are functions used by the compiler to prepare for compilation
* and to finish compilation in preparation for execution.
*/
vpiHandle vpip_sim_time(void);
extern int vpip_get_time_precision(void);
extern void vpip_set_time_precision(int pres);
/*
* $Log: vpi_priv.h,v $
* Revision 1.24 2001/10/31 04:27:47 steve
* Rewrite the functor type to have fewer functor modes,
* and use objects to manage the different types.
* (Stephan Boettcher)
*
* Revision 1.23 2001/10/15 01:49:50 steve
* Support getting scope of scope, and scope of signals.
*
* Revision 1.22 2001/08/08 01:05:06 steve
* Initial implementation of vvp_fvectors.
* (Stephan Boettcher)
*
* Revision 1.21 2001/07/30 02:44:05 steve
* Cleanup defines and types for mingw compile.
*
* Revision 1.20 2001/07/26 03:13:51 steve
* Make the -M flag add module search paths.
*
* Revision 1.19 2001/07/11 02:27:21 steve
* Add support for REadOnlySync and monitors.
*
* Revision 1.18 2001/06/30 23:03:17 steve
* support fast programming by only writing the bits
* that are listed in the input file.
*
2001-06-22 00:54:12 +02:00
* Revision 1.17 2001/06/21 22:54:12 steve
* Support cbValueChange callbacks.
*
2001-05-20 02:46:12 +02:00
* Revision 1.16 2001/05/20 00:46:12 steve
* Add support for system function calls.
*
* Revision 1.15 2001/05/10 00:26:53 steve
* VVP support for memories in expressions,
* including general support for thread bit
* vectors as system task parameters.
* (Stephan Boettcher)
*
* Revision 1.14 2001/05/08 23:59:33 steve
* Add ivl and vvp.tgt support for memories in
* expressions and l-values. (Stephan Boettcher)
*/
#endif