iverilog/vvp/compile.h

380 lines
13 KiB
C
Raw Normal View History

2001-03-11 01:29:38 +01:00
#ifndef __compile_H
#define __compile_H
/*
2005-02-03 05:55:13 +01:00
* Copyright (c) 2001-2005 Stephen Williams (steve@icarus.com)
2001-03-11 01:29:38 +01:00
*
* 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
*/
#ifdef HAVE_CVS_IDENT
2005-05-24 03:43:27 +02:00
#ident "$Id: compile.h,v 1.72 2005/05/24 01:43:27 steve Exp $"
2001-03-11 01:29:38 +01:00
#endif
# include <stdio.h>
2001-03-20 07:16:23 +01:00
# include "parse_misc.h"
# include "vpi_user.h"
# include "vvp_net.h"
2001-03-11 01:29:38 +01:00
/*
* The functions described here are the compile time support
* functions. Various bits of the compile process are taken care of
* here. What is called when is mostly controlled by the parser.
*
* Before compilation takes place, the compile_init function must be
* called once to set stuff up.
*/
extern void compile_init(void);
extern void compile_cleanup(void);
extern bool verbose_flag;
2001-11-06 04:07:21 +01:00
/*
* Connect a list of symbols to a contiguous set of ipoints.
* Constants C<?> are handled by setting the ival of the ipoint.
*/
extern void inputs_connect(vvp_net_t*fdx, unsigned argc, struct symb_s*argv);
extern void input_connect(vvp_net_t*fdx, unsigned port, char*label);
2001-11-06 04:07:21 +01:00
2005-04-01 08:02:45 +02:00
/*
* This function is an expansion of the inputs_connect function. It
* uses the inputs_connect function, but it creates vvp_wide_fun_t
* nodes to handle arbitrary width nodes, and connects those nodes to
* the vvp_wide_fun_core object passed in.
*/
extern void wide_inputs_connect(vvp_wide_fun_core*core,
unsigned argc, struct symb_s*argv);
2001-11-06 04:07:21 +01:00
/*
* Add a functor to the symbol table
*/
extern void define_functor_symbol(const char*label, vvp_net_t*ipt);
2001-11-06 04:07:21 +01:00
/*
* This is a count of errors encountered during compilation. If this
* is non-zero, then simulation is not recommended.
*/
extern unsigned compile_errors;
2001-03-23 03:40:22 +01:00
extern const char* module_path;
extern void compile_load_vpi_module(char*name);
extern void compile_vpi_time_precision(long pre);
2001-03-11 01:29:38 +01:00
/*
* This function is called by the parser to compile a functor
* statement. The strings passed in are allocated by the lexor, but
* this function will free them. (Or save them permanently.) This
* includes the argv array and the strings it references.
*
2003-02-10 00:33:26 +01:00
* The argc and argv are a list of char* that are the port parameters
2001-03-11 01:29:38 +01:00
* of the functor. The compile should match those port parameters up
* to existing functors to manage the linking.
*/
extern void compile_functor(char*label, char*type,
2005-04-03 07:45:51 +02:00
vvp_delay_t*delay, unsigned ostr0,
2001-12-14 03:04:49 +01:00
unsigned ostr1,
2001-03-20 07:16:23 +01:00
unsigned argc, struct symb_s*argv);
2001-03-11 01:29:38 +01:00
2001-05-09 04:53:25 +02:00
/*
* This is called by the parser to make a resolver. This is a special
* kind of functor; a strength aware functor. It has up to 4 inputs
* that are blended to make a resolved output. The type string selects
* a resolution algorithm.
2001-05-09 04:53:25 +02:00
*/
extern void compile_resolver(char*label, char*type,
unsigned argc, struct symb_s*argv);
extern void compile_concat(char*label, unsigned w0, unsigned w1,
unsigned w2, unsigned w3,
unsigned argc, struct symb_s*argv);
/*
* This is called by the parser to create a part select node.
* See the PART SELECT STATEMENT section in the README.txt
*/
extern void compile_part_select(char*label, char*src,
unsigned base, unsigned wid);
extern void compile_part_select_pv(char*label, char*src,
unsigned base, unsigned wid,
unsigned vec_wid);
2005-05-09 01:40:14 +02:00
extern void compile_part_select_var(char*label, char*src,
char*var, unsigned wid);
2001-06-05 05:05:41 +02:00
/*
* This is called by the parser to make the various arithmetic and
* comparison functors.
2001-06-05 05:05:41 +02:00
*/
2004-06-30 04:15:57 +02:00
extern void compile_arith_div(char*label, long width, bool signed_flag,
2001-10-16 04:47:37 +02:00
unsigned argc, struct symb_s*argv);
extern void compile_arith_mod(char*label, long width,
unsigned argc, struct symb_s*argv);
extern void compile_arith_mult(char*label, long width,
unsigned argc, struct symb_s*argv);
2001-06-05 05:05:41 +02:00
extern void compile_arith_sum(char*label, long width,
unsigned argc, struct symb_s*argv);
2001-06-07 05:09:03 +02:00
extern void compile_arith_sub(char*label, long width,
unsigned argc, struct symb_s*argv);
2005-01-22 02:06:20 +01:00
extern void compile_cmp_eeq(char*label, long width,
unsigned argc, struct symb_s*argv);
2005-03-09 06:52:03 +01:00
extern void compile_cmp_nee(char*label, long width,
unsigned argc, struct symb_s*argv);
2004-06-16 18:33:25 +02:00
extern void compile_cmp_eq(char*label, long width,
unsigned argc, struct symb_s*argv);
extern void compile_cmp_ne(char*label, long width,
unsigned argc, struct symb_s*argv);
2003-04-11 07:15:38 +02:00
extern void compile_cmp_ge(char*label, long width, bool signed_flag,
unsigned argc, struct symb_s*argv);
2003-04-11 07:15:38 +02:00
extern void compile_cmp_gt(char*label, long width, bool signed_flag,
unsigned argc, struct symb_s*argv);
2005-04-24 22:07:25 +02:00
extern void compile_dff(char*label,
struct symb_s arg_d,
struct symb_s arg_c,
struct symb_s arg_e,
struct symb_s arg_a);
2005-02-03 05:55:13 +01:00
extern void compile_reduce_and(char*label, struct symb_s arg);
extern void compile_reduce_or(char*label, struct symb_s arg);
extern void compile_reduce_xor(char*label, struct symb_s arg);
extern void compile_reduce_nand(char*label, struct symb_s arg);
extern void compile_reduce_nor(char*label, struct symb_s arg);
extern void compile_reduce_xnor(char*label, struct symb_s arg);
2005-05-24 03:43:27 +02:00
extern void compile_extend_signed(char*label, long width, struct symb_s arg);
extern void compile_repeat(char*label, long width, long repeat,
struct symb_s arg);
2001-07-06 06:46:44 +02:00
extern void compile_shiftl(char*label, long width,
unsigned argc, struct symb_s*argv);
2001-07-07 04:57:33 +02:00
extern void compile_shiftr(char*label, long width,
unsigned argc, struct symb_s*argv);
2001-06-05 05:05:41 +02:00
extern void compile_timescale(long units);
2001-05-09 04:53:25 +02:00
extern void compile_vpi_symbol(const char*label, vpiHandle obj);
extern void compile_vpi_lookup(vpiHandle *objref, char*label);
2003-03-11 00:37:07 +01:00
extern void compile_param_string(char*label, char*name,
char*str, char*value);
2002-03-18 01:19:34 +01:00
/*
* This function schedules a lookup of an indexed label. The ref
* points to the vvp_net_t that receives the result. The result may
2002-03-18 01:19:34 +01:00
* be assigned later, if the symbol is defined later in the source
* file, so the memory that ref points to must persist.
*
* The text for the label will be deleted by this function, or the
* cleanup that completes the binding.
2002-03-18 01:19:34 +01:00
*/
extern void functor_ref_lookup(vvp_net_t**ref, char*lab);
2002-03-18 01:19:34 +01:00
/*
* This function schedules a lookup of the labeled instruction. The
* code points to a code structure that points to the instruction
* field that receives the result, and the label is the name to
* lookup. The lookup will free the label text when it is done.
*/
extern void code_label_lookup(struct vvp_code_s *code, char *label);
/*
2001-04-25 06:35:05 +02:00
* The `compile_udp_def' function creates a UDP. The `table' is a
* NULL terminated array of char*, as assembled by `compile_udp_table'.
* `compile_udp_table' is called with `table'==NULL to create a new
2001-04-25 06:35:05 +02:00
* table, or with an existing table to append to.
*
* `compile_udp_functor' creates a mode-3 functor referring to the
* labeled UDP.
*/
extern void compile_udp_def(int sequ, char*label, char *name,
unsigned nin, unsigned init, char **table);
extern void compile_udp_functor(char*label, char*type,
2005-04-03 07:45:51 +02:00
vvp_delay_t*delay,
unsigned argc, struct symb_s*argv);
extern char **compile_udp_table(char **table, char *row);
/*
* Memory Instances, Ports, and Initialization
*/
extern void compile_memory(char *label, char *name, int lsb, int msb,
unsigned idxs, long *idx);
extern void compile_memory_port(char *label, char *memid,
unsigned argc, struct symb_s *argv);
extern void compile_memory_init(char *memid, unsigned idx, long val);
2002-03-18 01:19:34 +01:00
/*
* Compile the .ufunc statement.
*/
extern void compile_ufunc(char*label, char*code, unsigned wid,
unsigned argc, struct symb_s*argv,
unsigned portc, struct symb_s*portv,
struct symb_s retv);
/*
* The compile_event function takes the parts of the event statement
* and makes the various objects needed to simulate it. This includes
* the functor that receives the signals and the event_t that holds
* the threads.
*/
extern void compile_event(char*label, char*type,
unsigned argc, struct symb_s*argv);
extern void compile_named_event(char*label, char*type);
/*
* Word declarations include a label, a type symbol, and a vpi name.
*/
extern void compile_word(char*label, char*type, char*name);
2001-03-11 01:29:38 +01:00
/*
* A code statement is a label, an opcode and up to 3 operands. There
* are a few lexical types that the parser recognizes of the operands,
* given by the ltype_e enumeration. The compile_code function takes
* the label, mnemonic and parsed operands and writes a properly
* formed instruction into the code space. The label is set into the
* symbol table with the address of the instruction.
*/
#define OPERAND_MAX 3
2001-03-20 07:16:23 +01:00
enum ltype_e { L_NUMB, L_SYMB };
2001-03-11 01:29:38 +01:00
struct comp_operands_s {
unsigned argc;
struct {
enum ltype_e ltype;
union {
unsigned long numb;
2001-03-20 07:16:23 +01:00
struct symb_s symb;
2001-03-11 01:29:38 +01:00
};
} argv[OPERAND_MAX];
};
typedef struct comp_operands_s*comp_operands_t;
extern void compile_code(char*label, char*mnem, comp_operands_t opa);
2001-04-18 06:21:23 +02:00
extern void compile_disable(char*label, struct symb_s symb);
2001-05-20 02:46:12 +02:00
extern void compile_vpi_call(char*label, char*name,
unsigned argc, vpiHandle*argv);
2001-05-20 02:46:12 +02:00
/* Compile a function call. The vbit and vwid encode the return
type. If the vwid >0, the return type is a vector. If the vwid is
<0, the return type is -vpiRealConst or some other constant subtype
code that represents the function type. */
2001-05-20 02:46:12 +02:00
extern void compile_vpi_func_call(char*label, char*name,
unsigned vbit, int vwid,
2001-05-20 02:46:12 +02:00
unsigned argc, vpiHandle*argv);
2001-04-18 06:21:23 +02:00
extern void compile_fork(char*label, struct symb_s targ_s,
struct symb_s scope_s);
extern void compile_codelabel(char*label);
2001-03-11 01:29:38 +01:00
2001-03-18 01:37:55 +01:00
/*
* The parser uses these functions to compile .scope statements.
* The implementations of these live in the vpi_scope.cc file.
*/
extern void compile_scope_decl(char*typ, char*lab, char*nam,char*tnam,char*par);
2001-03-18 01:37:55 +01:00
extern void compile_scope_recall(char*sym);
2001-03-11 01:29:38 +01:00
/*
* The parser uses this function to declare a thread. The start_sym is
* the start instruction, and must already be defined.
*/
2003-09-04 22:26:30 +02:00
extern void compile_thread(char*start_sym, char*flag);
2001-03-11 01:29:38 +01:00
/*
2001-03-20 07:16:23 +01:00
* This function is called to create a var vector with the given name.
2001-03-11 01:29:38 +01:00
*/
extern void compile_variable(char*label, char*name,
int msb, int lsb, char signed_flag);
2001-03-11 01:29:38 +01:00
extern void compile_net(char*label, char*name,
int msb, int lsb, bool signed_flag,
2001-03-25 01:35:35 +01:00
unsigned argc, struct symb_s*argv);
2001-03-11 01:29:38 +01:00
/*
* $Log: compile.h,v $
2005-05-24 03:43:27 +02:00
* Revision 1.72 2005/05/24 01:43:27 steve
* Add a sign-extension node.
*
2005-05-09 01:40:14 +02:00
* Revision 1.71 2005/05/08 23:40:14 steve
* Add support for variable part select.
*
2005-04-28 06:59:53 +02:00
* Revision 1.70 2005/04/28 04:59:53 steve
* Remove dead functor code.
*
2005-04-24 22:07:25 +02:00
* Revision 1.69 2005/04/24 20:07:26 steve
* Add DFF nodes.
*
2005-04-03 07:45:51 +02:00
* Revision 1.68 2005/04/03 05:45:51 steve
* Rework the vvp_delay_t class.
*
2005-04-01 08:02:45 +02:00
* Revision 1.67 2005/04/01 06:02:45 steve
* Reimplement combinational UDPs.
*
* Revision 1.66 2005/03/18 02:56:04 steve
* Add support for LPM_UFUNC user defined functions.
*
2005-03-09 06:52:03 +01:00
* Revision 1.65 2005/03/09 05:52:04 steve
* Handle case inequality in netlists.
*
2005-03-09 05:52:40 +01:00
* Revision 1.64 2005/03/09 04:52:40 steve
* reimplement memory ports.
*
* Revision 1.63 2005/03/03 04:33:10 steve
* Rearrange how memories are supported as vvp_vector4 arrays.
*
* Revision 1.62 2005/02/07 22:42:42 steve
* Add .repeat functor and BIFIF functors.
*
2005-02-03 05:55:13 +01:00
* Revision 1.61 2005/02/03 04:55:13 steve
* Add support for reduction logic gates.
*
2005-01-22 02:06:20 +01:00
* Revision 1.60 2005/01/22 01:06:20 steve
* Implement the .cmp/eeq LPM node.
*
* Revision 1.59 2005/01/09 20:11:15 steve
* Add the .part/pv node and related functionality.
*
* Revision 1.58 2004/12/29 23:45:13 steve
* Add the part concatenation node (.concat).
*
* Add a vvp_event_anyedge class to handle the special
* case of .event statements of edge type. This also
* frees the posedge/negedge types to handle all 4 inputs.
*
* Implement table functor recv_vec4 method to receive
* and process vectors.
*
* Revision 1.57 2004/12/11 02:31:29 steve
* Rework of internals to carry vectors through nexus instead
* of single bits. Make the ivl, tgt-vvp and vvp initial changes
* down this path.
*
* Revision 1.56 2004/10/04 01:10:59 steve
* Clean up spurious trailing white space.
*
2004-06-30 04:15:57 +02:00
* Revision 1.55 2004/06/30 02:15:57 steve
* Add signed LPM divide.
2001-03-11 01:29:38 +01:00
*/
#endif