Skip to content
Snippets Groups Projects
Select Git revision
  • a03cafb9a2f76ce1a23f642ad15794b776b49b73
  • master default
  • ci-bump-test
  • abp-queue
  • new-delete-leaks
  • fused-continuation-and-completion-stealing
  • emper-fix-invalid-conv
  • remote-put-get-free-context-cycle
  • linux-version-construct-on-first-use
  • libstdc++-asserts
  • msan
  • libc++
  • completer-strategies
  • cactus_stack_devel_one_commit
  • client-load-change
  • cppcheck
  • flow
  • cast-if-future
  • async_network2
  • thread_safe_log_config
  • burak
  • attic/clang-release-tls-optimization-debug-and-fix
  • attic/continuation-stealing-dev
23 results

EchoServer.cpp

Blame
  • Forked from Lehrstuhl für Informatik 4 (Systemsoftware) / manycore / emper
    Source project has a limited visibility.
    EchoServer.cpp 2.35 KiB
    // SPDX-License-Identifier: LGPL-3.0-or-later
    // Copyright © 2020-2021 Florian Fischer
    #include <sys/socket.h>
    #include <sys/types.h>
    
    #include <atomic>
    #include <cerrno>
    #include <chrono>
    #include <cstdlib>
    #include <cstring>
    #include <iostream>
    #include <string>
    
    #include "Common.hpp"
    #include "Debug.hpp"
    #include "Runtime.hpp"
    #include "emper-config.h"
    #include "io.hpp"
    
    #ifdef EMPER_HAS_COMPARE_H
    #include <compare>
    #endif
    
    const std::string HOST = "::";
    const std::string PORT = "12345";
    
    unsigned int computations_us = 0;
    
    std::atomic<bool> quit = false;
    
    auto main(int argc, char* argv[]) -> int {
    	std::string host = HOST;
    	std::string port = PORT;
    
    	if (argc > 3) {
    		std::cerr << "Usage: " << argv[0] << " [port] [computation_us]" << std::endl;
    		exit(EXIT_FAILURE);
    	}
    
    	if (argc > 1) {
    		port = std::string(argv[1]);
    	}
    
    	if (argc > 2) {
    		computations_us = std::stoi(argv[2]);
    	}
    
    	std::cout << "Echoserver listening on " << host << ":" << port << std::endl;
    
    	Runtime runtime;
    	auto* listener = emper::io::tcp_listener(host, port, [](int socket) {
    		// NOLINTNEXTLINE(modernize-avoid-c-arrays)
    		char buf[1024];
    		while (!quit.load(std::memory_order_consume)) {
    			ssize_t bytes_recv = emper::io::recvAndWait(socket, buf, sizeof(buf), 0);
    			if (unlikely(bytes_recv <= 0)) {
    				// socket was shutdown
    				if (bytes_recv < 0) {
    					LOGE("server read failed:" << strerror(errno));
    				}
    				break;
    			}
    
    			if (unlikely(bytes_recv == 5 && strncmp("quit\n", buf, bytes_recv) == 0)) {
    				quit = true;
    				std::cout << "Echoserver received 'quit' command from client" << std::endl;
    				Runtime::getRuntime()->initiateTermination();
    				break;
    			}