SystemC端口转换

时间:2017-01-30 08:17:41

标签: c++ ports systemc

我正在尝试将一种类型的SystemC端口转换为另一种类型:

从:

sc_port<sc_fifo_out_if<Type> > 

为:

sc_export<tlm::tlm_analysis_if<Type> > 

我使用这个类与一个线程在类型之间进行转换。

class port_converter : public sc_core::sc_module{
public:
    sc_port<sc_fifo_in_if<Type> > in_converter;
    sc_port<tlm::tlm_analysis_if<Type> > out_converter;

    // c'tor
    SC_HAS_PROCESS(port_converter);
    port_converter(sc_module_name nm) :
        sc_module(nm), in_converter("in"), out_converter("out") {
        SC_THREAD(main_action);
    }

    // main action 
    void main_action() {
        while (1){
            out_converter->write(in_converter->read());
        }
    }
};

The solution diagram

是否有更简单的方法在这些类型的端口之间进行转换?

1 个答案:

答案 0 :(得分:0)

接口sc_fifo_out_iftlm_analysis_if不完全兼容。所以这可能是你能得到的最好的。如果有人试图使用不兼容的方法,模拟将停止并出现错误。

更新:我不确定tlm_analysis_if是否保证无阻塞操作。

template <typename T>
struct my_converter : sc_fifo_out_if<T>, sc_core::sc_module {

    sc_export<sc_fifo_out_if<T>>          in{"in"};
    sc_port<tlm::tlm_analysis_if<T>>      out{"out"};

    my_converter(sc_core::sc_module_name){
        in.bind(*this);
    }

    bool nb_write(const T &t) override {
        out->write(t);
    }

    const sc_event &data_read_event() const override {
        SC_REPORT_ERROR("my_converter", "data_read_event not supported!!");
        return m_data_read_event;
    }

    void write(const T &t) override {
        nb_write(t);
    }

    int num_free() const override {
        SC_REPORT_ERROR("my_converter", "num_free not supported!!");
        return 1;
    }

private:
    sc_event m_data_read_event; // this even will never happen;
};