added sc_comm_singleton to coordinate interaction with clients (e.g. web
browser)
This commit is contained in:
@ -16,76 +16,19 @@
|
||||
|
||||
#include "sysc/SiFive/uart.h"
|
||||
|
||||
#include "sysc/sc_comm_singleton.h"
|
||||
#include "scc/report.h"
|
||||
#include "scc/utilities.h"
|
||||
#include "sysc/SiFive/gen/uart_regs.h"
|
||||
#include "sysc/sc_singleton.h"
|
||||
|
||||
#include "seasocks/PrintfLogger.h"
|
||||
#include "seasocks/Server.h"
|
||||
#include "seasocks/StringUtil.h"
|
||||
#include "seasocks/WebSocket.h"
|
||||
#include "seasocks/util/Json.h"
|
||||
using namespace std;
|
||||
|
||||
|
||||
namespace sysc {
|
||||
namespace {
|
||||
|
||||
using namespace seasocks;
|
||||
|
||||
class MyHandler: public WebSocket::Handler {
|
||||
public:
|
||||
explicit MyHandler(Server* server) : _server(server), _currentValue(0) {
|
||||
setValue(1);
|
||||
}
|
||||
|
||||
virtual void onConnect(WebSocket* connection) {
|
||||
_connections.insert(connection);
|
||||
connection->send(_currentSetValue.c_str());
|
||||
cout << "Connected: " << connection->getRequestUri()
|
||||
<< " : " << formatAddress(connection->getRemoteAddress())
|
||||
<< endl;
|
||||
cout << "Credentials: " << *(connection->credentials()) << endl;
|
||||
}
|
||||
|
||||
virtual void onData(WebSocket* connection, const char* data) {
|
||||
if (0 == strcmp("die", data)) {
|
||||
_server->terminate();
|
||||
return;
|
||||
}
|
||||
if (0 == strcmp("close", data)) {
|
||||
cout << "Closing.." << endl;
|
||||
connection->close();
|
||||
cout << "Closed." << endl;
|
||||
return;
|
||||
}
|
||||
|
||||
int value = atoi(data) + 1;
|
||||
if (value > _currentValue) {
|
||||
setValue(value);
|
||||
for (auto c : _connections) {
|
||||
c->send(_currentSetValue.c_str());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
virtual void onDisconnect(WebSocket* connection) {
|
||||
_connections.erase(connection);
|
||||
cout << "Disconnected: " << connection->getRequestUri()
|
||||
<< " : " << formatAddress(connection->getRemoteAddress())
|
||||
<< endl;
|
||||
}
|
||||
|
||||
private:
|
||||
set<WebSocket*> _connections;
|
||||
Server* _server;
|
||||
int _currentValue;
|
||||
string _currentSetValue;
|
||||
|
||||
void setValue(int value) {
|
||||
_currentValue = value;
|
||||
_currentSetValue = makeExecString("set", _currentValue);
|
||||
}
|
||||
};
|
||||
|
||||
}
|
||||
uart::uart(sc_core::sc_module_name nm)
|
||||
@ -107,15 +50,16 @@ uart::uart(sc_core::sc_module_name nm)
|
||||
}
|
||||
return true;
|
||||
});
|
||||
auto& server = sc_singleton::inst().get_server();
|
||||
auto handler = std::make_shared<MyHandler>(&server);
|
||||
server.addWebSocketHandler((std::string{"/ws/"}+name()).c_str(), handler);
|
||||
|
||||
LOG(TRACE)<<"Adding WS handler for "<<(std::string{"/ws/"}+name());
|
||||
handler=std::make_shared<WsHandler>();
|
||||
sc_comm_singleton::inst().registerWebSocketHandler((std::string{"/ws/"}+name()).c_str(), handler);
|
||||
}
|
||||
|
||||
uart::~uart() {}
|
||||
|
||||
void uart::clock_cb() { this->clk = clk_i.read(); }
|
||||
void uart::clock_cb() {
|
||||
this->clk = clk_i.read();
|
||||
}
|
||||
|
||||
void uart::reset_cb() {
|
||||
if (rst_i.read())
|
||||
@ -127,7 +71,14 @@ void uart::reset_cb() {
|
||||
void uart::transmit_data() {
|
||||
if(regs->r_txdata.data != '\r') queue.push_back(regs->r_txdata.data);
|
||||
if (queue.size() >> 0 && (regs->r_txdata.data == '\n' || regs->r_txdata.data == 0)) {
|
||||
LOG(INFO) << this->name() << " transmit: '" << std::string(queue.begin(), queue.end()) << "'";
|
||||
std::string msg(queue.begin(), queue.end()-1);
|
||||
LOG(INFO) << this->name() << " transmit: '" << msg << "'";
|
||||
sc_core::sc_time now = sc_core::sc_time_stamp();
|
||||
sc_comm_singleton::inst().execute([this, msg, now](){
|
||||
std::stringstream os;
|
||||
os << "{\"time\":\"" << now << "\",\"message\":\""<<msg<<"\"}";
|
||||
this->handler->send(os.str());
|
||||
});
|
||||
queue.clear();
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user