20 #ifndef __SYSTEMC_EXT_TLM_CORE_1_REQ_RSP_INTERFACES_CORE_IFS_HH__ 21 #define __SYSTEMC_EXT_TLM_CORE_1_REQ_RSP_INTERFACES_CORE_IFS_HH__ 29 template <
typename REQ,
typename RSP>
48 virtual void get(T &
t) { t =
get(); }
55 virtual void put(
const T &
t) = 0;
64 virtual bool nb_get(T &
t) = 0;
65 virtual bool nb_can_get(
tlm_tag<T> *t=
nullptr)
const = 0;
74 virtual bool nb_put(
const T &
t) = 0;
75 virtual bool nb_can_put(
tlm_tag<T> *t=
nullptr)
const = 0;
100 template <
typename T>
104 virtual bool nb_peek(T &
t)
const = 0;
105 virtual bool nb_can_peek(
tlm_tag<T> *t=
nullptr)
const = 0;
110 template <
typename T>
117 template <
typename T>
122 template <
typename T>
127 template <
typename T>
virtual void transport(const REQ &req, RSP &rsp)
virtual RSP transport(const REQ &)=0
virtual void peek(T &t) const