OpenCores
URL https://opencores.org/ocsvn/ulpi_wrapper/ulpi_wrapper/trunk

Subversion Repositories ulpi_wrapper

[/] [ulpi_wrapper/] [trunk/] [testbench/] [sc_vpi_clock.h] - Rev 5

Go to most recent revision | Compare with Previous | Blame | View Log

#ifndef __SC_VPI_CLOCK_H__
#define __SC_VPI_CLOCK_H__
 
#include <systemc.h>
#include <vpi_user.h>
 
 
static int sc_vpi_clock_after_delay(p_cb_data cb_data);
 
class sc_vpi_clock
{
public:
 
    sc_signal <bool> m_clk;
    int              m_low_ns;
    int              m_high_ns;
    uint64_t         m_last_time;
 
    sc_module_name   m_name;
 
    vpiHandle        m_vpi_handle;
 
    sc_vpi_clock(sc_module_name name) : m_clk(name), m_name(name)
    {
        m_low_ns  = 5;
        m_high_ns = 5;
        m_last_time = 0;
 
        m_vpi_handle = vpi_handle_by_name((const char*)name, NULL);
        sc_assert(m_vpi_handle != NULL);
    }
 
    void start(void) { after_delay(); }
 
    int after_delay(void)
    {
        bool clk_next = !m_clk.read(); 
        s_vpi_time  vpi_time_s;
        s_cb_data   cb_data_s;
 
        vpi_time_s.type = vpiSimTime;
        vpi_time_s.high = 0;
        vpi_time_s.low  = 0;
 
        s_vpi_value  value_s;
        value_s.format = vpiIntVal;
        value_s.value.integer = clk_next;
        vpi_put_value(m_vpi_handle, &value_s, &vpi_time_s, vpiInertialDelay);     
 
        // Setup wait time
        vpi_time_s.high = 0;
        vpi_time_s.low  = clk_next ? m_high_ns : m_low_ns;
        vpi_time_s.type = vpiSimTime;
 
        m_clk.write(clk_next);   
 
        // Get current time
        uint64_t time_value = 0;
        s_vpi_time time_now;
        time_now.type = vpiSimTime;
        vpi_get_time (0, &time_now);
 
        time_value = time_now.high;
        time_value <<= 32;
        time_value |= time_now.low;
 
        // Update systemC TB
        if(sc_pending_activity())
            sc_start((int)(time_value-m_last_time),SC_NS);
 
        // Attach value change callbacks for outputs
        cb_data_s.user_data = (PLI_BYTE8*)this;
        cb_data_s.reason    = cbAfterDelay;
        cb_data_s.cb_rtn    = sc_vpi_clock_after_delay;
        cb_data_s.time      = &vpi_time_s;
        cb_data_s.value     = NULL;
        vpi_register_cb(&cb_data_s);        
    }
};
 
static int sc_vpi_clock_after_delay(p_cb_data cb_data)
{
    sc_vpi_clock *p = (sc_vpi_clock*)cb_data->user_data;
    return p->after_delay();
}
 
 
#endif
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.