Mercurial > pygar
annotate modules/bluespec/Pygar/lab4/ProcessorSystemRRR.cpp @ 39:5a30f173bbac pygar svn.40
[svn r40] no longer cpu terminating dependent
author | punk |
---|---|
date | Tue, 04 May 2010 19:32:25 -0400 |
parents | 74716e9a81cc |
children |
rev | line source |
---|---|
rlm@8 | 1 #include <cstdio> |
rlm@8 | 2 #include <cstdlib> |
rlm@8 | 3 #include <iostream> |
rlm@8 | 4 #include <iomanip> |
rlm@8 | 5 #include <stdio.h> |
rlm@8 | 6 #include <sys/stat.h> |
rlm@8 | 7 |
rlm@8 | 8 #include "asim/rrr/service_ids.h" |
rlm@8 | 9 |
rlm@8 | 10 #include "asim/provides/connected_application.h" |
rlm@8 | 11 |
rlm@8 | 12 |
rlm@8 | 13 |
rlm@8 | 14 using namespace std; |
rlm@8 | 15 |
rlm@8 | 16 // ===== service instantiation ===== |
rlm@8 | 17 PROCESSORSYSTEMRRR_SERVER_CLASS PROCESSORSYSTEMRRR_SERVER_CLASS::instance; |
rlm@8 | 18 |
rlm@8 | 19 // constructor |
rlm@8 | 20 PROCESSORSYSTEMRRR_SERVER_CLASS::PROCESSORSYSTEMRRR_SERVER_CLASS() : |
rlm@8 | 21 serverStub(new PROCESSORSYSTEMRRR_SERVER_STUB_CLASS(this)) |
rlm@8 | 22 { |
rlm@8 | 23 // instantiate stub |
rlm@8 | 24 memory = NULL; |
rlm@8 | 25 fflush(stdout); |
rlm@8 | 26 } |
rlm@8 | 27 |
rlm@8 | 28 // destructor |
rlm@8 | 29 PROCESSORSYSTEMRRR_SERVER_CLASS::~PROCESSORSYSTEMRRR_SERVER_CLASS() |
rlm@8 | 30 { |
rlm@8 | 31 Cleanup(); |
rlm@8 | 32 } |
rlm@8 | 33 |
rlm@8 | 34 // init |
rlm@8 | 35 void |
rlm@8 | 36 PROCESSORSYSTEMRRR_SERVER_CLASS::Init(PLATFORMS_MODULE p) |
rlm@8 | 37 { |
rlm@8 | 38 parent = p; |
rlm@8 | 39 } |
rlm@8 | 40 |
rlm@8 | 41 // uninit |
rlm@8 | 42 void |
rlm@8 | 43 PROCESSORSYSTEMRRR_SERVER_CLASS::Uninit() |
rlm@8 | 44 { |
rlm@8 | 45 Cleanup(); |
rlm@8 | 46 } |
rlm@8 | 47 |
rlm@8 | 48 // cleanup |
rlm@8 | 49 void |
rlm@8 | 50 PROCESSORSYSTEMRRR_SERVER_CLASS::Cleanup() |
rlm@8 | 51 { |
rlm@8 | 52 delete serverStub; |
rlm@8 | 53 } |
rlm@8 | 54 |
rlm@8 | 55 |
rlm@8 | 56 // |
rlm@8 | 57 // RRR service methods |
rlm@8 | 58 // |
rlm@8 | 59 |
rlm@8 | 60 UINT32 |
rlm@8 | 61 PROCESSORSYSTEMRRR_SERVER_CLASS::MemoryRequestLoad (UINT32 address) |
rlm@8 | 62 { |
rlm@8 | 63 UINT32 returnVal; |
rlm@8 | 64 |
rlm@8 | 65 if(memory == NULL) { |
rlm@8 | 66 memory = new FUNCP_SIMULATED_MEMORY_CLASS(); |
rlm@8 | 67 } |
rlm@8 | 68 |
rlm@8 | 69 |
rlm@8 | 70 |
rlm@8 | 71 memory->Read(0,(UINT64) address, sizeof(UINT32), &returnVal); |
rlm@8 | 72 return returnVal; |
rlm@8 | 73 } |
rlm@8 | 74 |
rlm@8 | 75 void |
rlm@8 | 76 PROCESSORSYSTEMRRR_SERVER_CLASS::MemoryRequestStore (UINT32 address, UINT32 data) |
rlm@8 | 77 { |
rlm@8 | 78 if(memory == NULL) { |
rlm@8 | 79 memory = new FUNCP_SIMULATED_MEMORY_CLASS(); |
rlm@8 | 80 } |
rlm@8 | 81 |
rlm@8 | 82 memory->Write(0,(UINT64) address, sizeof(UINT32), &data); |
rlm@8 | 83 } |