summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorSuren A. Chilingaryan <csa@suren.me>2018-08-14 21:58:29 +0200
committerSuren A. Chilingaryan <csa@suren.me>2018-08-14 21:58:29 +0200
commit5cdb425d6843c100189611c2edb37b03efc1dc5a (patch)
tree82c5e7397b2950c41c00d09ed8020e9d98ced693 /src
parentad4fef28ad3fc8b73a3bf97c229e878e8c680e16 (diff)
downloadods-5cdb425d6843c100189611c2edb37b03efc1dc5a.tar.gz
ods-5cdb425d6843c100189611c2edb37b03efc1dc5a.tar.bz2
ods-5cdb425d6843c100189611c2edb37b03efc1dc5a.tar.xz
ods-5cdb425d6843c100189611c2edb37b03efc1dc5a.zip
Make it compatible with CentOS 7.5
Diffstat (limited to 'src')
-rw-r--r--src/CMakeLists.txt12
-rw-r--r--src/ConfigReader/ConfigReader.h4
-rw-r--r--src/DetectorModule/DetectorModule.cpp4
-rw-r--r--src/ReceiverThreads.vma/ReceiverThreads.cpp166
-rw-r--r--src/ReceiverThreads.vma/ReceiverThreads.h34
-rw-r--r--src/UDPClient/UDPClient.cpp1
-rw-r--r--src/UDPServer/UDPServer.cpp20
-rw-r--r--src/cmake/FindLibConfig.cmake22
-rw-r--r--src/main_client.cpp18
-rw-r--r--src/main_server.cpp23
10 files changed, 41 insertions, 263 deletions
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
index d4ee49d..92c4ca3 100644
--- a/src/CMakeLists.txt
+++ b/src/CMakeLists.txt
@@ -1,4 +1,4 @@
-cmake_minimum_required(VERSION 3.5)
+cmake_minimum_required(VERSION 2.8)
project(OnlineDetectorSimulator)
#define some speciel output paths for libraries and executables
@@ -11,13 +11,16 @@ set(CMAKE_CXX_STANDARD 11)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
set(Boost_USE_MULTITHREADED ON)
-SET(BOOST_MIN_VERSION "1.58.0")
-add_definitions(-DBOOST_LOG_DYN_LINK=1)
+SET(BOOST_MIN_VERSION "1.53.0")
+
+add_definitions(-std=c++11)
#find required packages
find_package(LibConfig REQUIRED)
-find_package(Boost ${BOOST_MIN_VERSION} REQUIRED COMPONENTS log filesystem)
+find_package(Boost ${BOOST_MIN_VERSION} REQUIRED COMPONENTS filesystem)
find_package(OpenMP)
+set(LIBVMA_INCLUDE_DIR "/mnt/ands/include")
+
#add openmp
if(OPENMP_FOUND)
@@ -29,6 +32,7 @@ endif()
include_directories(
${LIBCONFIGPP_INCLUDE_DIR}
${BOOST_INCLUDE_DIRS}
+ ${LIBVMA_INCLUDE_DIR}
)
set(LINK_LIBRARIES ${LINK_LIBRARIES}
diff --git a/src/ConfigReader/ConfigReader.h b/src/ConfigReader/ConfigReader.h
index 2819f41..f654a5a 100644
--- a/src/ConfigReader/ConfigReader.h
+++ b/src/ConfigReader/ConfigReader.h
@@ -11,8 +11,6 @@
#define CONFIGREADER_H
#pragma once
-#include <boost/log/trivial.hpp>
-
#include <libconfig.h++>
#include <string>
@@ -26,7 +24,6 @@ public:
template<typename T>
bool lookupValue(const std::string& identifier, T& value) {
bool ret = cfg.lookupValue(identifier.c_str(), value);
- BOOST_LOG_TRIVIAL(debug) << "Configuration value " << identifier << ": " << value;
return ret;
}
@@ -35,7 +32,6 @@ public:
libconfig::Setting& s = cfg.lookup(identifier.c_str());
if(s.getLength() > index){
value = s[index];
- BOOST_LOG_TRIVIAL(debug) << "Configuration value " << identifier << "[" << index << "]: " << value;
return true;
}
return false;
diff --git a/src/DetectorModule/DetectorModule.cpp b/src/DetectorModule/DetectorModule.cpp
index 6767eb9..ff517fe 100644
--- a/src/DetectorModule/DetectorModule.cpp
+++ b/src/DetectorModule/DetectorModule.cpp
@@ -10,8 +10,6 @@
#include "DetectorModule.h"
#include "../ConfigReader/ConfigReader.h"
-#include <boost/log/trivial.hpp>
-
#include <exception>
#include <fstream>
@@ -64,7 +62,6 @@ DetectorModule::DetectorModule(const int detectorID, const std::string& address,
}
auto DetectorModule::send(int packets = 1) -> void{
- BOOST_LOG_TRIVIAL(debug) << "Detectormodule " << detectorID_ << " :sending udp packet with index " << index_ << ".";
int numberOfParts = numberOfProjections_/numberOfProjectionsPerPacket_;
// sendBuffer_[0] = (sizeof(std::size_t)) & 0xff;
// sendBuffer_[1] = (sizeof(std::size_t) >> 8) & 0xff;
@@ -131,7 +128,6 @@ auto DetectorModule::readInput() -> void {
path_.append("/");
//open file
const std::string filePath = path_ + fileName_ + std::to_string(detectorID_+1) + fileEnding_;
- BOOST_LOG_TRIVIAL(debug) << "DetectorModule: Path = " << filePath;
std::ifstream input(filePath, std::ios::in | std::ios::binary);
if(input){
//allocate memory in vector
diff --git a/src/ReceiverThreads.vma/ReceiverThreads.cpp b/src/ReceiverThreads.vma/ReceiverThreads.cpp
deleted file mode 100644
index 650a840..0000000
--- a/src/ReceiverThreads.vma/ReceiverThreads.cpp
+++ /dev/null
@@ -1,166 +0,0 @@
-/*
- * Copyright 2016
- *
- * ReceiverThreads.cpp
- *
- * Created on: 21.07.2016
- * Author: Tobias Frust
- */
-
-#include "ReceiverThreads.h"
-#include "../UDPServer/UDPServer.h"
-
-#include <boost/log/trivial.hpp>
-
-ReceiverThreads::ReceiverThreads(const std::string& address, const int timeIntervall, const int numberOfDetectorModules)
- : timeIntervall_{timeIntervall}, numberOfDetectorModules_{numberOfDetectorModules}, address_{address}, loss_{0} {
-
- for(auto i = 0; i < numberOfDetectorModules; i++){
- receiverModules_.emplace_back(&ReceiverThreads::receiverThread, this, 4000+i);
- }
-
- for(auto i = 0; i < numberOfDetectorModules; i++){
- receiverModules_[i].join();
- }
-
-}
-
-auto ReceiverThreads::receiverThread(const int port) -> void {
- int max_packets = 100;
- int max_packet_size = 65535;
-
-
- struct vma_ap_t *vma = vma_get_api();
- if (!vma) throw "Can't get LibVMA API"
-
- struct vma_packet_desc_t vma_packet;
- struct vma_buff_t *vma_buf;
- int vma_buf_offset;
-
- int vma_ring_fd;
- vma->get_socket_rings_fds(fd?, &vma_ring_fd, 1);
- if (vma_ring_fd < 0) throw "Can't get ring fds";
-
- while (true) {
- // free vma packets
-
-
- struct vma_completion_t vma_comps[max_packets];
- int n_packets = vma->socketxtreme_poll(vma_ring_fd, vma_comps, max_packets, 0);
- if (!n_packets) continue;
-
- for (int i = 0; i < n_packets; i++) {
- switch (vma_comps[i].events) {
- case VMA_SOCKETXTREME_PACKET:
- break;
- case EPOLLERR:
- case EPOLLRDHUP:
- printf("Polling error event=0x%lx user_data=%ld\n", vma_comps[i].events, vma_comps[i].user_data);
- throw "Polling error";
- default:
- printf("Unsupported event=0x%lx user_data=%ld\n", vma_comps[i].events, vma_comps[i].user_data);
- throw "Polling error";
- }
-
- int packet_len = vma_comps[i].packet.total_len;
- int n_buffs = vma_comps[i].packet.num_bufs;
-
- vma_comps.packet.buff_lst
-
- vma_comps[i].packet.buff_lst->payload
-/*
-<------><------><------><------><------>conn = conns_in[vma_comps.user_data] vma_comps.packet.total_len;
-<------><------><------><------><------>conn->vma_packet.num_bufs = vma_comps.packet.num_bufs;
-<------><------><------><------><------>conn->vma_packet.total_len = vma_comps.packet.total_len;
-<------><------><------><------><------>conn->vma_packet.buff_lst = vma_comps.packet.buff_lst;
-<------><------><------><------><------>conn->vma_buf = conn->vma_packet.buff_lst;
-<------><------><------><------><------>conn->vma_buf_offset = 0;
-*/
-/*
- ret = _min((_config.msg_size - conn->msg_len), (conn->vma_buf->len - conn->vma_buf_offset));
- memcpy(((uint8_t *)msg_hdr) + conn->msg_len,
- ((uint8_t *)conn->vma_buf->payload) + conn->vma_buf_offset,
- ret);
-*/
- _vma_api->socketxtreme_free_vma_packets(&conn->vma_packet, 1);
- }
-
-
-auto ReceiverThreads::receiverThread(const int port) -> void {
- int max_packets = 100;
- int max_packet_size = 65535;
-
- UDPServer server = UDPServer(address_, port);
- std::vector<std::vector<char>> buffers;
-
- std::size_t rcv_index = 0;
- std::size_t rcv_packets = 0;
- std::size_t rcv_size = 0;
-
- std::size_t lastIndex{0};
- std::size_t loss = 0;
-
- struct mmsghdr msg[max_packets];
- struct iovec msgvec[max_packets];
-
- buffers.resize(max_packets);
-
- memset(msg, 0, sizeof(msg));
- memset(msgvec, 0, sizeof(msgvec));
- for (int i = 0; i < max_packets; i++) {
- buffers[i].resize(max_packet_size);
-
- msgvec[i].iov_base = buffers[i].data();
- msgvec[i].iov_len = buffers[i].size();
- msg[i].msg_hdr.msg_iov = &msgvec[i];
- msg[i].msg_hdr.msg_iovlen = 1;
- }
-
-
- BOOST_LOG_TRIVIAL(info) << "Address: " << address_ << " port: " << port << " timeout: " << timeIntervall_;
-
- double coef = 1000. * 1000. * 1000. / 1024. / 1024. / 1024.;
- auto ts_last = std::chrono::high_resolution_clock::now();
- while(true){
- int packets = server.mrecv(max_packets, msg, 1); //timeIntervall_);
-
- if (packets >= 0) {
- for (int i = 0; i < packets; i++) {
- int bytes = msg[i].msg_len;
- unsigned short *buf = reinterpret_cast<unsigned short*>(msgvec[i].iov_base);
-
- rcv_packets++;
- rcv_size += bytes;
-
-// BOOST_LOG_TRIVIAL(debug) << "Received " << bytes << " Bytes.";
- std::size_t index =*((std::size_t *)buf);
- int diff = index - lastIndex - 1;
- if(diff > 0){
- loss += diff;
- BOOST_LOG_TRIVIAL(debug) << "Packet loss or wrong order! new: " << index << " old: " << lastIndex;
- }
-
-/* if (port == 4000) {
- printf("%i:%i:%i:%i,", index, diff, loss, i);
- }*/
-
- lastIndex = index;
- }
- }
-
- auto ts = std::chrono::high_resolution_clock::now();
- std::chrono::nanoseconds d = ts - ts_last;
- if (d.count() >= 1000000000) {
- printf("Lost %.2lf%, Received: %i (%zu bytes, %.3lf GBit/s) in %.3lf ms\n", loss / (double)(lastIndex - rcv_index)*100.0, rcv_packets, rcv_size, 8. * rcv_size * coef / d.count() , 1. * d.count() / 1000000);
- rcv_packets = 0;
- rcv_size = 0;
- rcv_index = lastIndex;
- loss = 0;
- ts_last = ts;
- }
- }
-
- BOOST_LOG_TRIVIAL(info) << "Lost " << loss << " from " << lastIndex << " packets; (" << loss/(double)lastIndex*100.0 << "%)";
- loss_ += loss;
-}
-
diff --git a/src/ReceiverThreads.vma/ReceiverThreads.h b/src/ReceiverThreads.vma/ReceiverThreads.h
deleted file mode 100644
index 3cc986c..0000000
--- a/src/ReceiverThreads.vma/ReceiverThreads.h
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * Copyright 2016
- *
- * ReceiverThreads.h
- *
- * Created on: 21.07.2016
- * Author: Tobias Frust
- */
-
-#ifndef RECEIVERTHREADS_H_
-#define RECEIVERTHREADS_H_
-
-#include <vector>
-#include <thread>
-
-class ReceiverThreads {
-public:
- ReceiverThreads(const std::string& address, const int timeIntervall, const int numberOfDetectorModules);
-
- auto run() -> void;
-private:
- auto receiverThread(const int port) -> void;
-
- std::vector<std::thread> receiverModules_;
-
- std::size_t loss_;
-
- int timeIntervall_;
- int numberOfDetectorModules_;
-
- std::string address_;
-};
-
-#endif /* RECEIVERTHREADS_H_ */
diff --git a/src/UDPClient/UDPClient.cpp b/src/UDPClient/UDPClient.cpp
index b9d55d0..803b9f1 100644
--- a/src/UDPClient/UDPClient.cpp
+++ b/src/UDPClient/UDPClient.cpp
@@ -40,6 +40,7 @@
#include "UDPClient.h"
+#include <stdio.h>
#include <string.h>
#include <unistd.h>
diff --git a/src/UDPServer/UDPServer.cpp b/src/UDPServer/UDPServer.cpp
index 42166b4..d2d1988 100644
--- a/src/UDPServer/UDPServer.cpp
+++ b/src/UDPServer/UDPServer.cpp
@@ -46,6 +46,7 @@
#include <string.h>
#include <unistd.h>
+#include <errno.h>
#ifndef SOCK_CLOEXEC
#define SOCK_CLOEXEC 0
@@ -55,6 +56,7 @@ UDPServer::UDPServer(const std::string& addr, int port)
: f_port(port)
, f_addr(addr)
{
+ char errno_str[16];
char decimal_port[16];
snprintf(decimal_port, sizeof(decimal_port), "%d", f_port);
decimal_port[sizeof(decimal_port) / sizeof(decimal_port[0]) - 1] = '\0';
@@ -69,11 +71,27 @@ UDPServer::UDPServer(const std::string& addr, int port)
throw udp_client_server_runtime_error(("invalid address or port for UDP socket: \"" + addr + ":" + decimal_port + "\"").c_str());
}
f_socket = socket(f_addrinfo->ai_family, SOCK_DGRAM | SOCK_CLOEXEC, IPPROTO_UDP);
+ // First call fails with LibVMA for some reason?
+ if (f_socket == -1)
+ f_socket = socket(f_addrinfo->ai_family, SOCK_DGRAM | SOCK_CLOEXEC, IPPROTO_UDP);
if(f_socket == -1)
{
+ sprintf(errno_str, "%d", errno);
freeaddrinfo(f_addrinfo);
- throw udp_client_server_runtime_error(("could not create UDP socket for: \"" + addr + ":" + decimal_port + "\"").c_str());
+ throw udp_client_server_runtime_error(("could not create UDP socket for: \"" + addr + ":" + decimal_port + "\", errno: " + errno_str).c_str());
}
+
+/*
+ const char *strdev = "enp5s0d1";
+ r = setsockopt(f_socket, SOL_SOCKET, SO_BINDTODEVICE, (void *)strdev, strlen(strdev));
+ if(r != 0)
+ {
+ freeaddrinfo(f_addrinfo);
+ close(f_socket);
+ throw udp_client_server_runtime_error(("could not associate socket : \"" + addr + ":" + decimal_port + "\" with device \"" + strdev + "\"").c_str());
+ }
+*/
+
r = bind(f_socket, f_addrinfo->ai_addr, f_addrinfo->ai_addrlen);
if(r != 0)
{
diff --git a/src/cmake/FindLibConfig.cmake b/src/cmake/FindLibConfig.cmake
index 436d2a5..a888412 100644
--- a/src/cmake/FindLibConfig.cmake
+++ b/src/cmake/FindLibConfig.cmake
@@ -31,22 +31,22 @@ FIND_LIBRARY(LIBCONFIGPP_LIBRARY config++
/usr/lib
)
-FIND_LIBRARY(LIBCONFIG_STATIC_LIBRARY "libconfig${CMAKE_STATIC_LIBRARY_SUFFIX}"
- /usr/local/lib
- /usr/lib
-)
+#FIND_LIBRARY(LIBCONFIG_STATIC_LIBRARY "libconfig${CMAKE_STATIC_LIBRARY_SUFFIX}"
+# /usr/local/lib
+# /usr/lib
+#)
-FIND_LIBRARY(LIBCONFIGPP_STATIC_LIBRARY "libconfig++${CMAKE_STATIC_LIBRARY_SUFFIX}"
- /usr/local/lib
- /usr/lib
-)
+#FIND_LIBRARY(LIBCONFIGPP_STATIC_LIBRARY "libconfig++${CMAKE_STATIC_LIBRARY_SUFFIX}"
+# /usr/local/lib
+# /usr/lib
+#)
IF(LIBCONFIG_INCLUDE_DIR)
IF(LIBCONFIG_LIBRARY)
SET(LIBCONFIG_FOUND TRUE)
SET(LIBCONFIG_LIBRARIES ${LIBCONFIG_LIBRARY})
- SET(LIBCONFIG_STATIC_LIBRARY_PATH ${LIBCONFIG_STATIC_LIBRARY})
+# SET(LIBCONFIG_STATIC_LIBRARY_PATH ${LIBCONFIG_STATIC_LIBRARY})
ENDIF(LIBCONFIG_LIBRARY)
ENDIF(LIBCONFIG_INCLUDE_DIR)
@@ -54,7 +54,7 @@ IF(LIBCONFIGPP_INCLUDE_DIR)
IF(LIBCONFIGPP_LIBRARY)
SET(LIBCONFIGPP_FOUND TRUE)
SET(LIBCONFIGPP_LIBRARIES ${LIBCONFIGPP_LIBRARY})
- SET(LIBCONFIGPP_STATIC_LIBRARY_PATH ${LIBCONFIGPP_STATIC_LIBRARY})
+# SET(LIBCONFIGPP_STATIC_LIBRARY_PATH ${LIBCONFIGPP_STATIC_LIBRARY})
ENDIF(LIBCONFIGPP_LIBRARY)
ENDIF(LIBCONFIGPP_INCLUDE_DIR)
@@ -62,7 +62,7 @@ IF (LIBCONFIG_FOUND)
IF (NOT LibConfig_FIND_QUIETLY)
MESSAGE(STATUS "Found LibConfig++: ${LIBCONFIGPP_LIBRARIES}" )
MESSAGE(STATUS "Found LibConfig: ${LIBCONFIG_LIBRARIES}")
- MESSAGE(STATUS "static LibConfig path: ${LIBCONFIG_STATIC_LIBRARY_PATH}")
+# MESSAGE(STATUS "static LibConfig path: ${LIBCONFIG_STATIC_LIBRARY_PATH}")
ENDIF (NOT LibConfig_FIND_QUIETLY)
ELSE (LIBCONFIG_FOUND)
IF (LibConfig_FIND_REQUIRED)
diff --git a/src/main_client.cpp b/src/main_client.cpp
index fb0c1e3..28c472c 100644
--- a/src/main_client.cpp
+++ b/src/main_client.cpp
@@ -2,28 +2,14 @@
#include "DetectorModule/DetectorModule.h"
#include "Detector/Detector.h"
-#include <boost/log/core.hpp>
-#include <boost/log/trivial.hpp>
-#include <boost/log/expressions.hpp>
-
#include <iostream>
#include <string>
-void initLog() {
-/*
-#ifndef NDEBUG
- boost::log::core::get()->set_filter(boost::log::trivial::severity >= boost::log::trivial::debug);
-#else
- boost::log::core::get()->set_filter(boost::log::trivial::severity >= boost::log::trivial::info);
-#endif
-*/
- boost::log::core::get()->set_filter(boost::log::trivial::severity >= boost::log::trivial::info);
-}
int main (int argc, char *argv[]){
if(argc < 5){
- BOOST_LOG_TRIVIAL(error) << "Program usage: ./onlineDetectorSimulatorClient <address> <first_port> <num_ports> <packets_per_second>";
+ std::cerr << "Program usage: ./onlineDetectorSimulatorClient <address> <first_port> <num_ports> <packets_per_second>";
return 0;
}
@@ -36,8 +22,6 @@ int main (int argc, char *argv[]){
double timegap = 1./(double)imagesPerSec;
unsigned int intervall = timegap*1000*1000;
- initLog();
-
std::cout << "Sending UDP packages: " << std::endl;
auto configPath = std::string { "config.cfg" };
diff --git a/src/main_server.cpp b/src/main_server.cpp
index b2f9425..7c6cee4 100644
--- a/src/main_server.cpp
+++ b/src/main_server.cpp
@@ -1,25 +1,10 @@
#include "UDPServer/UDPServer.h"
#include "ReceiverThreads/ReceiverThreads.h"
-#include <boost/log/core.hpp>
-#include <boost/log/trivial.hpp>
-#include <boost/log/expressions.hpp>
-
#include <iostream>
#include <string>
#include <thread>
-void initLog() {
-/*
-#ifndef NDEBUG
- boost::log::core::get()->set_filter(boost::log::trivial::severity >= boost::log::trivial::debug);
-#else
- boost::log::core::get()->set_filter(boost::log::trivial::severity >= boost::log::trivial::info);
-#endif
-*/
- boost::log::core::get()->set_filter(boost::log::trivial::severity >= boost::log::trivial::info);
-}
-
void start(std::function<void(void)> func){
std::thread([func]() {
while (true)
@@ -31,10 +16,8 @@ void start(std::function<void(void)> func){
int main (int argc, char *argv[]){
- initLog();
-
if(argc < 4){
- BOOST_LOG_TRIVIAL(error) << "Program usage: ./onlineDetectorSimulatorServer <address> <first_port> <num_ports>";
+ std::cerr << "Program usage: ./onlineDetectorSimulatorServer <address> <first_port> <num_ports>";
return 0;
}
@@ -66,12 +49,8 @@ int main (int argc, char *argv[]){
// std::size_t index = *((std::size_t *)buf.data());
// if(index%1000 == 99) printf("%lu\n", index);
//
-// if(lastIndex != (index-1))
-// BOOST_LOG_TRIVIAL(warning) << "Packet loss or wrong order!";
-//
// lastIndex = index;
//
-// BOOST_LOG_TRIVIAL(debug) << "Server: Received " << bytes << " Bytes with Index " << index;
// }
return 0;