Added seasocks via conan
This commit is contained in:
parent
b0dcb3b60e
commit
b94d637177
|
@ -1,4 +1,4 @@
|
||||||
cmake_minimum_required(VERSION 2.8.12)
|
cmake_minimum_required(VERSION 3.3)
|
||||||
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_CURRENT_SOURCE_DIR}/cmake ${CMAKE_CURRENT_SOURCE_DIR}/sc-components/cmake)
|
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_CURRENT_SOURCE_DIR}/cmake ${CMAKE_CURRENT_SOURCE_DIR}/sc-components/cmake)
|
||||||
|
|
||||||
include(cmake/GitFunctions.cmake)
|
include(cmake/GitFunctions.cmake)
|
||||||
|
@ -16,19 +16,26 @@ set(GIT_SUBMODULE_BRANCH_dbt-core ${GIT_BRANCH})
|
||||||
|
|
||||||
include(GNUInstallDirs)
|
include(GNUInstallDirs)
|
||||||
include(Submodules)
|
include(Submodules)
|
||||||
|
include(Conan)
|
||||||
|
|
||||||
#enable_testing()
|
#enable_testing()
|
||||||
|
|
||||||
|
set(CMAKE_CXX_STANDARD 14)
|
||||||
|
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||||
|
set(CMAKE_CXX_EXTENSIONS OFF)
|
||||||
|
|
||||||
if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU" OR "${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
|
if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU" OR "${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
|
||||||
set(warnings "-Wall -Wextra -Werror")
|
set(warnings "-Wall -Wextra -Werror")
|
||||||
set(CMAKE_CXX_FLAG_RELEASE "-O3 -DNDEBUG")
|
set(CMAKE_CXX_FLAG_RELEASE "-O3 -DNDEBUG -D_GLIBCXX_USE_CXX11_ABI=0")
|
||||||
set(CMAKE_C_FLAG_RELEASE "-O3 -DNDEBUG")
|
set(CMAKE_C_FLAG_RELEASE "-O3 -DNDEBUG")
|
||||||
set(CMAKE_CXX_FLAG_DEBUG "-Og")
|
set(CMAKE_CXX_FLAG_DEBUG "-Og -D_GLIBCXX_USE_CXX11_ABI=0")
|
||||||
set(CMAKE_C_FLAG_DEBUG "-Og")
|
set(CMAKE_C_FLAG_DEBUG "-Og")
|
||||||
elseif ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC")
|
elseif ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC")
|
||||||
set(warnings "/W4 /WX /EHsc")
|
set(warnings "/W4 /WX /EHsc")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
setup_conan()
|
||||||
|
|
||||||
find_package(Threads)
|
find_package(Threads)
|
||||||
find_package(Tcmalloc)
|
find_package(Tcmalloc)
|
||||||
|
|
||||||
|
@ -40,3 +47,5 @@ add_subdirectory(dbt-core)
|
||||||
add_subdirectory(sc-components)
|
add_subdirectory(sc-components)
|
||||||
add_subdirectory(riscv)
|
add_subdirectory(riscv)
|
||||||
add_subdirectory(riscv.sc)
|
add_subdirectory(riscv.sc)
|
||||||
|
|
||||||
|
message(STATUS "Build Type: ${CMAKE_BUILD_TYPE}")
|
24
README.md
24
README.md
|
@ -25,20 +25,32 @@ DBT-RISE-RiscV uses libGIS (https://github.com/vsergeev/libGIS) as well as ELFIO
|
||||||
|
|
||||||
**Quick start**
|
**Quick start**
|
||||||
|
|
||||||
* you need to have a decent compiler, make and cmake installed
|
* you need to have a decent compiler, make, python, and cmake installed
|
||||||
* install LLVM 4.0 according to http://apt.llvm.org/
|
* install LLVM 4.0 according to http://apt.llvm.org/ (if it is not already provided by your distribution)
|
||||||
* download and install SystemC from http://accellera.org/downloads/standards/systemc
|
* install conan.io (see also http://docs.conan.io/en/latest/installation.html)
|
||||||
|
```
|
||||||
|
pip install conan
|
||||||
|
```
|
||||||
|
* download and install SystemC from http://accellera.org/downloads/standards/systemc (this is going to be replaced with a conan.io integration)
|
||||||
* optionally download and install SystemC Verification Library (SCV) from Accelera into the same location
|
* optionally download and install SystemC Verification Library (SCV) from Accelera into the same location
|
||||||
|
* setup conan to use the minres repo
|
||||||
|
```
|
||||||
|
conan add remote minres https://dl.bintray.com/minres/conan-repo
|
||||||
|
```
|
||||||
* checkout source from git
|
* checkout source from git
|
||||||
* start an out-of-source build like so (e.g. when using LLVM 3.9 and bash)
|
* start an out-of-source build like so (e.g. when using bash)
|
||||||
```
|
```
|
||||||
cd DBT-RISE-RiscV
|
cd DBT-RISE-RiscV
|
||||||
mkdir build
|
mkdir build
|
||||||
cd build
|
cd build
|
||||||
cmake ..
|
cmake ..
|
||||||
make
|
cmake --build .
|
||||||
```
|
```
|
||||||
* if the SystemC installation is not found by cmake you can optionally specify the location by either setting the following environment variables pointing to the installation
|
* if the SystemC installation is not found by cmake you can optionally specify the location by either setting the following environment variables pointing to the installation
|
||||||
- SYSTEMC_HOME
|
- SYSTEMC_HOME
|
||||||
- SYSTEMC_PREFIX
|
- SYSTEMC_PREFIX
|
||||||
|
* if you encounter issues when linking wrt. c++11 symbols you might have run into GCC ABI incompatibility introduced from GCC 5.0 onwards. You can fix this by adding '-s compiler.libcxx=libstdc++11' to the conan call or changing compiler.libcxx to
|
||||||
|
```
|
||||||
|
compiler.libcxx=libstdc++11
|
||||||
|
```
|
||||||
|
in $HOME/.conan/profiles/default
|
|
@ -0,0 +1,42 @@
|
||||||
|
macro(setup_conan)
|
||||||
|
find_program(conan conan)
|
||||||
|
if(NOT EXISTS ${conan})
|
||||||
|
message(FATAL_ERROR "Conan is required. Please see README.md")
|
||||||
|
return()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(${CMAKE_HOST_SYSTEM_NAME} STREQUAL Darwin)
|
||||||
|
set(os Macos)
|
||||||
|
else()
|
||||||
|
set(os ${CMAKE_HOST_SYSTEM_NAME})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(${CMAKE_CXX_COMPILER_ID} STREQUAL GNU)
|
||||||
|
set(compiler gcc)
|
||||||
|
elseif(${CMAKE_CXX_COMPILER_ID} STREQUAL AppleClang)
|
||||||
|
set(compiler apple-clang)
|
||||||
|
else()
|
||||||
|
message(FATAL_ERROR "Unknown compiler: ${CMAKE_CXX_COMPILER_ID}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
string(SUBSTRING ${CMAKE_CXX_COMPILER_VERSION} 0 3 compiler_version)
|
||||||
|
|
||||||
|
set(conanfile ${CMAKE_SOURCE_DIR}/conanfile.txt)
|
||||||
|
set(conanfile_cmake ${CMAKE_BINARY_DIR}/conanbuildinfo.cmake)
|
||||||
|
|
||||||
|
if(${CMAKE_BUILD_TYPE} STREQUAL RelWithDebInfo)
|
||||||
|
execute_process(COMMAND ${conan} install --build=missing
|
||||||
|
-s build_type=Release
|
||||||
|
${CMAKE_SOURCE_DIR} RESULT_VARIABLE return_code)
|
||||||
|
else()
|
||||||
|
execute_process(COMMAND ${conan} install --build=missing
|
||||||
|
-s build_type=${CMAKE_BUILD_TYPE}
|
||||||
|
${CMAKE_SOURCE_DIR} RESULT_VARIABLE return_code)
|
||||||
|
endif()
|
||||||
|
if(NOT ${return_code} EQUAL 0)
|
||||||
|
message(FATAL_ERROR "conan install command failed.")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
include(${conanfile_cmake})
|
||||||
|
conan_basic_setup(TARGETS)
|
||||||
|
endmacro()
|
|
@ -0,0 +1,10 @@
|
||||||
|
[requires]
|
||||||
|
Poco/1.7.8p3@pocoproject/stable
|
||||||
|
Seasocks/1.3.2@seasocks/stable
|
||||||
|
|
||||||
|
[generators]
|
||||||
|
cmake
|
||||||
|
|
||||||
|
[options]
|
||||||
|
Poco:shared=True
|
||||||
|
Seasocks:shared=False
|
|
@ -0,0 +1,49 @@
|
||||||
|
/*
|
||||||
|
* sc_singleton.h
|
||||||
|
*
|
||||||
|
* Created on: 09.10.2017
|
||||||
|
* Author: eyck
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef RISCV_SC_INCL_SYSC_SC_SINGLETON_H_
|
||||||
|
#define RISCV_SC_INCL_SYSC_SC_SINGLETON_H_
|
||||||
|
|
||||||
|
#include <sysc/kernel/sc_module.h>
|
||||||
|
#include <memory>
|
||||||
|
#include <thread>
|
||||||
|
|
||||||
|
namespace seasocks {
|
||||||
|
class Server;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace sysc {
|
||||||
|
|
||||||
|
class sc_singleton: public sc_core::sc_module {
|
||||||
|
public:
|
||||||
|
sc_singleton() = delete;
|
||||||
|
|
||||||
|
sc_singleton(const sc_singleton&) = delete;
|
||||||
|
|
||||||
|
sc_singleton& operator=(sc_singleton& o) = delete;
|
||||||
|
|
||||||
|
virtual ~sc_singleton();
|
||||||
|
|
||||||
|
static sc_singleton& inst(){
|
||||||
|
static sc_singleton i("__sc_singleton");
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
|
||||||
|
seasocks::Server& get_server();
|
||||||
|
protected:
|
||||||
|
void start_of_simulation();
|
||||||
|
|
||||||
|
private:
|
||||||
|
sc_singleton(sc_core::sc_module_name nm);
|
||||||
|
std::unique_ptr<seasocks::Server> m_serv;
|
||||||
|
std::thread t;
|
||||||
|
void thread_func();
|
||||||
|
};
|
||||||
|
|
||||||
|
} /* namespace sysc */
|
||||||
|
|
||||||
|
#endif /* RISCV_SC_INCL_SYSC_SC_SINGLETON_H_ */
|
|
@ -36,6 +36,7 @@ target_link_libraries(${APPLICATION_NAME} ${LIBRARY_NAME})
|
||||||
target_link_libraries(${APPLICATION_NAME} risc-v)
|
target_link_libraries(${APPLICATION_NAME} risc-v)
|
||||||
target_link_libraries(${APPLICATION_NAME} dbt-core)
|
target_link_libraries(${APPLICATION_NAME} dbt-core)
|
||||||
target_link_libraries(${APPLICATION_NAME} sc-components)
|
target_link_libraries(${APPLICATION_NAME} sc-components)
|
||||||
|
target_link_libraries(${APPLICATION_NAME} CONAN_PKG::Seasocks)
|
||||||
target_link_libraries(${APPLICATION_NAME} external)
|
target_link_libraries(${APPLICATION_NAME} external)
|
||||||
target_link_libraries(${APPLICATION_NAME} ${llvm_libs})
|
target_link_libraries(${APPLICATION_NAME} ${llvm_libs})
|
||||||
target_link_libraries(${APPLICATION_NAME} ${SystemC_LIBRARIES} )
|
target_link_libraries(${APPLICATION_NAME} ${SystemC_LIBRARIES} )
|
||||||
|
|
|
@ -0,0 +1,57 @@
|
||||||
|
/*
|
||||||
|
* sc_singleton.cpp
|
||||||
|
*
|
||||||
|
* Created on: 09.10.2017
|
||||||
|
* Author: eyck
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "sysc/sc_singleton.h"
|
||||||
|
|
||||||
|
#include "seasocks/PrintfLogger.h"
|
||||||
|
#include "seasocks/Server.h"
|
||||||
|
#include "seasocks/StringUtil.h"
|
||||||
|
#include "seasocks/util/Json.h"
|
||||||
|
#include "seasocks/ResponseWriter.h"
|
||||||
|
#include "seasocks/util/RootPageHandler.h"
|
||||||
|
#include "seasocks/util/CrackedUriPageHandler.h"
|
||||||
|
#include "seasocks/util/StaticResponseHandler.h"
|
||||||
|
|
||||||
|
namespace sysc {
|
||||||
|
|
||||||
|
using namespace seasocks;
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
const std::string MSG_TXT { "Hello World"};
|
||||||
|
}
|
||||||
|
|
||||||
|
void sc_singleton::start_of_simulation() {
|
||||||
|
//Launch a thread
|
||||||
|
t=std::thread(&sc_singleton::thread_func, this);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
sc_singleton::sc_singleton(sc_core::sc_module_name nm)
|
||||||
|
: sc_core::sc_module(nm)
|
||||||
|
, m_serv(new seasocks::Server(std::make_shared<PrintfLogger>(Logger::Level::DEBUG))){
|
||||||
|
auto rootHandler = make_shared<seasocks::RootPageHandler>();
|
||||||
|
rootHandler->add(std::shared_ptr<CrackedUriPageHandler>(new StaticResponseHandler("/", Response::textResponse(MSG_TXT))));
|
||||||
|
m_serv->addPageHandler(rootHandler);
|
||||||
|
}
|
||||||
|
|
||||||
|
sc_singleton::~sc_singleton() {
|
||||||
|
//Join the thread with the main thread
|
||||||
|
t.join();
|
||||||
|
}
|
||||||
|
|
||||||
|
void sc_singleton::thread_func() {
|
||||||
|
get_server().serve(".", 9090);
|
||||||
|
}
|
||||||
|
|
||||||
|
seasocks::Server& sc_singleton::get_server() {
|
||||||
|
return *m_serv.get();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
} /* namespace sysc */
|
||||||
|
|
|
@ -19,9 +19,75 @@
|
||||||
#include "scc/report.h"
|
#include "scc/report.h"
|
||||||
#include "scc/utilities.h"
|
#include "scc/utilities.h"
|
||||||
#include "sysc/SiFive/gen/uart_regs.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"
|
||||||
|
|
||||||
namespace sysc {
|
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)
|
uart::uart(sc_core::sc_module_name nm)
|
||||||
: sc_core::sc_module(nm)
|
: sc_core::sc_module(nm)
|
||||||
, tlm_target<>(clk)
|
, tlm_target<>(clk)
|
||||||
|
@ -41,6 +107,10 @@ uart::uart(sc_core::sc_module_name nm)
|
||||||
}
|
}
|
||||||
return true;
|
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);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
uart::~uart() {}
|
uart::~uart() {}
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit ba65d9f172246d6735a40fd6259ec13467e43419
|
Subproject commit d5abb72bf3e9030e4a7800195cb6ea5e1bb218cc
|
Loading…
Reference in New Issue