20#ifndef __EXPLICIT_AT_TARGET_H__ 
   21#define __EXPLICIT_AT_TARGET_H__ 
   24#include "tlm_utils/simple_target_socket.h" 
   60      assert(address < 400);
 
   68        std::cout << 
name() << 
": Received write request: A = 0x" 
   69                  << std::hex << (
unsigned int)address << 
", D = 0x" << 
data 
   73        *
reinterpret_cast<unsigned int*
>(&
mMem[address]) = 
data;
 
   84        std::cout << 
name() << 
": Received read request: A = 0x" 
   85                  << std::hex << (
unsigned int)address
 
   89        data = *
reinterpret_cast<unsigned int*
>(&
mMem[address]);
 
 
  125      assert(address < 400);
 
  127        *
reinterpret_cast<unsigned int*
>(&
mMem[address]);
 
 
  144    if (r.get_address() >= 400) 
return 0;
 
  146    unsigned int tmp = (int)r.get_address();
 
  147    unsigned int num_bytes;
 
  148    if (tmp + r.get_data_length() >= 400) {
 
  149      num_bytes = 400 - tmp;
 
  152      num_bytes = r.get_data_length();
 
  154    if (!r.is_read() && !r.is_write()) {
 
  158      for (
unsigned int i = 0; i < num_bytes; ++i) {
 
  159        r.get_data_ptr()[i] = 
mMem[i + tmp];
 
  163      for (
unsigned int i = 0; i < num_bytes; ++i) {
 
  164        mMem[i + tmp] = r.get_data_ptr()[i];
 
 
 
target_socket_type socket
tlm_utils::simple_target_socket< ExplicitATTarget > target_socket_type
transaction_type * mCurrentTransaction
tlm::tlm_phase phase_type
tlm::tlm_sync_enum sync_enum_type
unsigned int transport_dbg(transaction_type &r)
ExplicitATTarget(sc_core::sc_module_name name)
SC_HAS_PROCESS(ExplicitATTarget)
sync_enum_type myNBTransport(transaction_type &trans, phase_type &phase, sc_core::sc_time &t)
sc_core::sc_event mResponseEvent
tlm::tlm_generic_payload transaction_type
sc_module(const sc_module_name &)
const char * name() const
unsigned char * get_data_ptr() const
void set_response_status(const tlm_response_status response_status)
sc_dt::uint64 get_address() const
tlm_command get_command() const
const sc_time SC_ZERO_TIME
const sc_time & sc_time_stamp()