summaryrefslogtreecommitdiffstats
path: root/src/rpc-server/trex_rpc_async_server.h
blob: daefa17483e53ee65c93c41578803f3d2ead1a4f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/*
 Itay Marom
 Cisco Systems, Inc.
*/

/*
Copyright (c) 2015-2015 Cisco Systems, Inc.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/

#ifndef __TREX_RPC_ASYNC_SERVER_H__
#define __TREX_RPC_ASYNC_SERVER_H__

#include <trex_rpc_server_api.h>
#include <trex_stateless_port.h>

/**
 * async RPC server
 * 
 * @author imarom (11-Aug-15)
 */
class TrexRpcServerAsync : public TrexRpcServerInterface  {
public:

    TrexRpcServerAsync(const TrexRpcServerConfig &cfg);

protected:
    void _prepare();
    void _rpc_thread_cb();
    void _stop_rpc_thread();

private:

    void handle_server_error(const std::string &specific_err);

    static const int    RPC_MAX_MSG_SIZE = (20 * 1024);
    void               *m_context;
    void               *m_socket;
    uint8_t             m_msg_buffer[RPC_MAX_MSG_SIZE];
};


#endif /* __TREX_RPC_ASYNC_SERVER_H__ */