iverilog/vvp/logic.h

236 lines
6.2 KiB
C
Raw Normal View History

#ifndef IVL_logic_H
#define IVL_logic_H
2001-11-06 04:07:21 +01:00
/*
* Copyright (c) 2000-2025 Stephen Williams (steve@icarus.com)
2001-11-06 04:07:21 +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
2012-08-29 03:41:23 +02:00
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
2001-11-06 04:07:21 +01:00
*/
# include "vvp_net.h"
# include "schedule.h"
# include <cstddef>
2001-11-06 04:07:21 +01:00
/*
* vvp_fun_boolean_ is just a common hook for holding operands.
*/
class vvp_fun_boolean_ : public vvp_net_fun_t, protected vvp_gen_event_s {
public:
explicit vvp_fun_boolean_(unsigned wid);
~vvp_fun_boolean_();
void recv_vec4(vvp_net_ptr_t p, const vvp_vector4_t&bit,
vvp_context_t) override;
void recv_vec4_pv(vvp_net_ptr_t p, const vvp_vector4_t&bit,
unsigned base, unsigned vwid, vvp_context_t) override;
void recv_real(vvp_net_ptr_t p, double real,
vvp_context_t) override;
2005-01-29 18:52:06 +01:00
protected:
vvp_vector4_t input_[4];
vvp_net_t*net_;
2005-01-29 18:52:06 +01:00
};
class vvp_fun_and : public vvp_fun_boolean_ {
public:
explicit vvp_fun_and(unsigned wid, bool invert);
2005-01-29 18:52:06 +01:00
~vvp_fun_and();
private:
void run_run() override;
bool invert_;
};
2020-07-09 10:44:44 +02:00
class vvp_fun_equiv : public vvp_fun_boolean_ {
public:
explicit vvp_fun_equiv();
~vvp_fun_equiv();
private:
void run_run() override;
2020-07-09 10:44:44 +02:00
};
class vvp_fun_impl : public vvp_fun_boolean_ {
public:
explicit vvp_fun_impl();
~vvp_fun_impl();
private:
void run_run() override;
2020-07-09 10:44:44 +02:00
};
/*
* vvp_fun_buf_not_ is just a common hook for holding operands.
*/
class vvp_fun_buf_not_ : public vvp_net_fun_t, protected vvp_gen_event_s {
public:
explicit vvp_fun_buf_not_(unsigned wid);
~vvp_fun_buf_not_();
void recv_vec4(vvp_net_ptr_t p, const vvp_vector4_t&bit,
vvp_context_t) override;
void recv_vec4_pv(vvp_net_ptr_t p, const vvp_vector4_t&bit,
unsigned base, unsigned vwid, vvp_context_t) override;
void recv_real(vvp_net_ptr_t p, double real,
vvp_context_t ctx) override;
protected:
vvp_vector4_t input_;
vvp_net_t*net_;
};
/*
* The buffer functor is a very primitive functor that takes the input
* from port-0 (and only port-0) and retransmits it as a vvp_vector4_t.
2004-12-31 06:56:36 +01:00
* The retransmitted vector has all Z values changed to X, just like
* the buf(Q,D) gate in Verilog.
*/
class vvp_fun_buf: public vvp_fun_buf_not_ {
public:
explicit vvp_fun_buf(unsigned wid);
virtual ~vvp_fun_buf();
private:
void run_run() override;
2001-11-06 04:07:21 +01:00
};
2004-12-31 06:56:36 +01:00
/*
* The vvp_fun_bufz is like the vvp_fun_buf, but it does not change
* Z values to X -- it passes Z values unchanged.
*/
class vvp_fun_bufz: public vvp_net_fun_t {
public:
explicit vvp_fun_bufz();
2004-12-31 06:56:36 +01:00
virtual ~vvp_fun_bufz();
void recv_vec4(vvp_net_ptr_t p, const vvp_vector4_t&bit,
vvp_context_t) override;
void recv_vec4_pv(vvp_net_ptr_t p, const vvp_vector4_t&bit,
unsigned base, unsigned vwid, vvp_context_t) override;
//void recv_vec8(vvp_net_ptr_t port, const vvp_vector8_t&bit);
void recv_real(vvp_net_ptr_t p, double bit,
vvp_context_t) override;
2004-12-31 06:56:36 +01:00
private:
};
/*
* The vp_fun_buft is like the vvp_fun_bufz, but is completely
* transparent to strengths.
*/
class vvp_fun_buft: public vvp_fun_bufz {
public:
void recv_vec8(vvp_net_ptr_t port, const vvp_vector8_t&bit) override;
private:
};
enum sel_type {SEL_PORT0, SEL_PORT1, SEL_BOTH};
2005-02-12 23:50:52 +01:00
/*
* The muxz functor is an A-B mux device, with the data inputs on
* ports 0 and 1. port 2 is the select input.
2005-02-13 00:05:25 +01:00
*
* The select input must be 1 bit wide. If it is 0, then the port-0
* vector is passed out. If select is 1, then port-1 is passed
* out. Otherwise, a vector is passed out that reflects x?: behavior
* in Verilog. The width of the blended output is the width of the largest
2005-02-13 00:05:25 +01:00
* input (port-0 or port-1) to enter the device. The narrow vector is
* padded with X values.
2005-02-12 23:50:52 +01:00
*/
class vvp_fun_muxz : public vvp_net_fun_t, private vvp_gen_event_s {
2005-02-12 23:50:52 +01:00
public:
2005-06-17 05:46:52 +02:00
explicit vvp_fun_muxz(unsigned width);
2005-02-12 23:50:52 +01:00
virtual ~vvp_fun_muxz();
void recv_vec4(vvp_net_ptr_t p, const vvp_vector4_t&bit,
vvp_context_t) override;
void recv_vec4_pv(vvp_net_ptr_t p, const vvp_vector4_t&bit,
unsigned base, unsigned vwid, vvp_context_t) override;
2005-02-12 23:50:52 +01:00
private:
void run_run() override;
2005-02-12 23:50:52 +01:00
private:
vvp_vector4_t a_;
vvp_vector4_t b_;
vvp_net_t*net_;
sel_type select_;
bool has_run_;
2005-02-12 23:50:52 +01:00
};
class vvp_fun_muxr : public vvp_net_fun_t, private vvp_gen_event_s {
2005-09-01 06:08:47 +02:00
public:
explicit vvp_fun_muxr();
virtual ~vvp_fun_muxr();
void recv_vec4(vvp_net_ptr_t p, const vvp_vector4_t&bit,
vvp_context_t) override;
void recv_real(vvp_net_ptr_t p, double bit,
vvp_context_t) override;
2005-09-01 06:08:47 +02:00
private:
void run_run() override;
2005-09-01 06:08:47 +02:00
private:
double a_;
double b_;
vvp_net_t*net_;
sel_type select_;
2005-09-01 06:08:47 +02:00
};
class vvp_fun_not: public vvp_fun_buf_not_ {
2005-09-19 23:45:09 +02:00
public:
explicit vvp_fun_not(unsigned wid);
2005-09-19 23:45:09 +02:00
virtual ~vvp_fun_not();
private:
void run_run() override;
2005-09-19 23:45:09 +02:00
};
class vvp_fun_or : public vvp_fun_boolean_ {
public:
explicit vvp_fun_or(unsigned wid, bool invert);
2005-09-19 23:45:09 +02:00
~vvp_fun_or();
private:
void run_run() override;
bool invert_;
2005-09-19 23:45:09 +02:00
};
class vvp_fun_xor : public vvp_fun_boolean_ {
public:
explicit vvp_fun_xor(unsigned wid, bool invert);
2005-09-19 23:45:09 +02:00
~vvp_fun_xor();
private:
void run_run() override;
bool invert_;
2005-09-19 23:45:09 +02:00
};
#endif /* IVL_logic_H */