| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 | #include <iostream>#include <deque>#include "mpcio.hpp"#include "preproc.hpp"static void usage(const char *progname){    std::cerr << "Usage: " << progname << " [-p] [-t num] player_num player_addrs args ...\n";    std::cerr << "-p: preprocessing mode\n";    std::cerr << "-t num: use num threads for the computational players\n";    std::cerr << "player_num = 0 or 1 for the computational players\n";    std::cerr << "player_num = 2 for the server player\n";    std::cerr << "player_addrs is omitted for player 0\n";    std::cerr << "player_addrs is p0's hostname for player 1\n";    std::cerr << "player_addrs is p0's hostname followed by p1's hostname for player 2\n";    exit(1);}static void comp_player_main(boost::asio::io_context &io_context,    unsigned player, bool preprocessing, int num_threads, const char *p0addr,    char **args){    tcp::socket serversock(io_context);    std::deque<tcp::socket> peersocks;    mpcio_setup_computational(player, io_context, p0addr, num_threads,        peersocks, serversock);    MPCIO mpcio(player, preprocessing, peersocks, std::move(serversock));    // Queue up the work to be done    boost::asio::post(io_context, [&]{        if (preprocessing) {            preprocessing_comp(mpcio, num_threads, args);        }    });    // Start another thread; one will perform the work and the other    // will execute the async_write handlers    boost::thread t([&]{io_context.run();});    io_context.run();    t.join();}static void server_player_main(boost::asio::io_context &io_context,    bool preprocessing, const char *p0addr, const char *p1addr, char **args){    tcp::socket p0sock(io_context), p1sock(io_context);    mpcio_setup_server(io_context, p0addr, p1addr, p0sock, p1sock);    MPCServerIO mpcserverio(preprocessing, std::move(p0sock),        std::move(p1sock));    // Queue up the work to be done    boost::asio::post(io_context, [&]{        if (preprocessing) {            preprocessing_server(mpcserverio, args);        }    });    // Start another thread; one will perform the work and the other    // will execute the async_write handlers    boost::thread t([&]{io_context.run();});    io_context.run();    t.join();}int main(int argc, char **argv){    char **args = argv+1; // Skip argv[0] (the program name)    bool preprocessing = false;    unsigned player = 0;    int num_threads = 1;    const char *p0addr = NULL;    const char *p1addr = NULL;    // Get the options    while (*args && *args[0] == '-') {        if (!strcmp("-p", *args)) {            preprocessing = true;            ++args;        } else if (!strcmp("-t", *args)) {            if (args[1]) {                num_threads = atoi(args[1]);                if (num_threads < 1) {                    usage(argv[0]);                }                args += 2;            } else {                usage(argv[0]);            }        }    }    if (*args == NULL) {        // No arguments?        usage(argv[0]);    } else {        player = atoi(*args);        ++args;    }    if (player > 2) {        usage(argv[0]);    }    if (player > 0) {        if (*args == NULL) {            usage(argv[0]);        } else {            p0addr = *args;            ++args;        }    }    if (player > 1) {        if (*args == NULL) {            usage(argv[0]);        } else {            p1addr = *args;            ++args;        }    }    /*    std::cout << "Preprocessing = " <<            (preprocessing ? "true" : "false") << "\n";    std::cout << "Thread count = " << num_threads << "\n";    std::cout << "Player = " << player << "\n";    if (p0addr) {        std::cout << "Player 0 addr = " << p0addr << "\n";    }    if (p1addr) {        std::cout << "Player 1 addr = " << p1addr << "\n";    }    std::cout << "Args =";    for (char **a = args; *a; ++a) {        std::cout << " " << *a;    }    std::cout << "\n";    */    // Make the network connections    boost::asio::io_context io_context;    if (player < 2) {        comp_player_main(io_context, player, preprocessing, num_threads, p0addr, args);    } else {        server_player_main(io_context, preprocessing, p0addr, p1addr, args);    }    return 0;}
 |