#ifndef IVL_priv_H #define IVL_priv_H /* * Copyright (c) 2004-2014 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ # include # include /* * This is the output file where the generated result should be * written. */ extern FILE*out; /* * Keep a running count of errors that the stub detects. This will be * the error count returned to the ivl_target environment. */ extern int stub_errors; /* * This function finds the vector width of a signal. It relies on the * assumption that all the signal inputs to the nexus have the same * width. The ivl_target API should assert that condition. */ extern unsigned width_of_nexus(ivl_nexus_t nex); extern ivl_variable_type_t type_of_nexus(ivl_nexus_t nex); extern ivl_discipline_t discipline_of_nexus(ivl_nexus_t nex); extern unsigned width_of_type(ivl_type_t net); /* * Test that a given expression is a valid delay expression, and * print an error message if not. */ extern void test_expr_is_delay(ivl_expr_t expr); extern void show_class(ivl_type_t net); extern void show_enumerate(ivl_enumtype_t net); extern void show_constant(ivl_net_const_t net); /* * Show the details of the expression. */ extern void show_expression(ivl_expr_t net, unsigned ind); /* * Show the statement. */ extern void show_statement(ivl_statement_t net, unsigned ind); /* * Show the type of the signal, in one line. */ extern void show_type_of_signal(ivl_signal_t); extern void show_switch(ivl_switch_t net); /* */ extern const char*data_type_string(ivl_variable_type_t vtype); extern void show_net_type(ivl_type_t net_type); #endif /* IVL_priv_H */