TLM fifo的代码示例

时间:2012-10-02 17:11:37

标签: systemc

我是TLM的新手。 有人可以给我一个用TLM fifo连接两个进程的示例代码吗?

谢谢

2 个答案:

答案 0 :(得分:3)

我搜索了doulos,但我只看到了插座的例子。 有人帮助了我,我在这里留下了一个tlm fifo的代码示例

#include "systemc"
#include "tlm.h"


// PRODUCER 1

SC_MODULE(producer)
{
sc_core::sc_port< tlm::tlm_fifo_put_if<int> > out;  //FIFO OUT

SC_CTOR(producer)
    : out("out")
{
    SC_THREAD(run);  //função
}

void run()
{
    int i = 42;
    std::cout << name() << ": " << i << std::endl;
    out->put(i);
}
}; // producer

// CONSUMER

SC_MODULE(consumer)
{
    sc_core::sc_port< tlm::tlm_fifo_get_if<int> > in;

    SC_CTOR(consumer)
    : in("in")
    {
        SC_THREAD(run);  //função
    }

    void run()
    {
       int i = in->get();
       std::cout << name() << ": " << i << std::endl;
    }
}; // consumer


 // MAIN
 int sc_main(int, char*[] )
 {
     tlm::tlm_fifo<int> fifo("fifo");

     producer prod("producer");
     prod.out(fifo);
     consumer cons("consumer");
     cons.in(fifo);

     sc_core::sc_start();
     char myLine[100];
     cin.getline(myLine, 100);
     return 0;
}

谢谢

答案 1 :(得分:1)

doulos website中有一些很好的例子。