123 for (i = 0; i < actual_transfer; i++)
129 esm->
rx_buf[my_thread_id][i]);
149 u32 n_written, max_dequeue, max_enqueue, max_transfer;
161 ASSERT (rx_fifo->master_thread_index == thread_index);
162 ASSERT (tx_fifo->master_thread_index == thread_index);
187 max_transfer =
clib_min (max_dequeue, max_enqueue);
218 esm->
rx_buf[thread_index],
226 esm->
rx_buf[thread_index],
231 ASSERT (actual_transfer == max_transfer);
242 esm->
rx_buf[thread_index],
250 esm->
rx_buf[thread_index],
255 if (n_written != max_transfer)
256 clib_warning (
"short trout! written %u read %u", n_written, max_transfer);
296 u32 segment_size = 512 << 20;
313 a->options = options;
326 a->namespace_id = appns_id;
339 a_cert->app_index = a->app_index;
345 a_key->app_index = a->app_index;
402 for (i = 0; i < num_threads; i++)
425 u8 server_uri_set = 0, *appns_id = 0;
426 u64 tmp, appns_flags = 0, appns_secret = 0;
427 char *default_uri =
"tcp://0.0.0.0/1234";
444 else if (
unformat (input,
"no-echo"))
452 else if (
unformat (input,
"private-segment-count %d",
455 else if (
unformat (input,
"private-segment-size %U",
458 if (tmp >= 0x100000000ULL)
460 (0,
"private segment size %lld (%llu) too large", tmp, tmp);
463 else if (
unformat (input,
"appns %_%v%_", &appns_id))
465 else if (
unformat (input,
"all-scope"))
466 appns_flags |= (APP_OPTIONS_FLAGS_USE_GLOBAL_SCOPE
467 | APP_OPTIONS_FLAGS_USE_LOCAL_SCOPE);
468 else if (
unformat (input,
"local-scope"))
469 appns_flags |= APP_OPTIONS_FLAGS_USE_LOCAL_SCOPE;
470 else if (
unformat (input,
"global-scope"))
471 appns_flags |= APP_OPTIONS_FLAGS_USE_GLOBAL_SCOPE;
472 else if (
unformat (input,
"secret %lu", &appns_secret))
503 clib_warning (
"No uri provided! Using default: %s", default_uri);
523 .path =
"test echo server",
524 .short_help =
"test echo server proto <proto> [no echo][fifo-size <mbytes>]" 525 "[rcv-buf-size <bytes>][prealloc-fifos <count>]" 526 "[private-segment-count <count>][private-segment-size <bytes[m|g]>]" 527 "[uri <tcp://ip/port>]",
static int echo_server_listen()
#define vec_validate(V, I)
Make sure vector is long enough for given index (no header, unspecified alignment) ...
static int app_recv_stream_raw(svm_fifo_t *f, u8 *buf, u32 len, u8 clear_evt, u8 peek)
int echo_server_session_accept_callback(session_t *s)
u32 vl_api_memclnt_create_internal(char *name, svm_queue_t *q)
u8 * format_session(u8 *s, va_list *args)
Format stream session as per the following format.
session_main_t session_main
u32 session_index
Index in thread pool where session was allocated.
u8 no_echo
Don't echo traffic.
static svm_msg_q_t * session_main_get_vpp_event_queue(u32 thread_index)
#define clib_memcpy_fast(a, b, c)
void echo_server_session_disconnect_callback(session_t *s)
svm_fifo_t * rx_fifo
Pointers to rx/tx buffers.
session_worker_t * wrk
Worker contexts.
u32 private_segment_size
Size of private segments.
static int echo_server_detach(void)
clib_memset(h->entries, 0, sizeof(h->entries[0])*entries)
static u32 svm_fifo_max_enqueue(svm_fifo_t *f)
struct _vnet_application_add_tls_cert_args_t vnet_app_add_tls_cert_args_t
u32 tls_engine
TLS engine: mbedtls/openssl.
clib_error_t * vnet_app_add_tls_cert(vnet_app_add_tls_cert_args_t *a)
struct _vnet_bind_args_t vnet_listen_args_t
session_t * sessions
Worker session pool.
static session_handle_t session_handle(session_t *s)
u32 my_client_index
API client handle.
struct _svm_fifo svm_fifo_t
int echo_server_session_connected_callback(u32 app_index, u32 api_context, session_t *s, u8 is_fail)
u32 prealloc_fifos
Preallocate fifos.
#define VLIB_INIT_FUNCTION(x)
struct _vnet_disconnect_args_t vnet_disconnect_args_t
svm_queue_t * vl_input_queue
Sever's event queue.
static u32 svm_fifo_max_dequeue(svm_fifo_t *f)
static const u32 test_srv_key_rsa_len
#define clib_error_return(e, args...)
struct vl_shmem_hdr_ * shmem_hdr
Binary API shared-memory segment header pointer.
int session_send_io_evt_to_thread(svm_fifo_t *f, session_evt_type_t evt_type)
static int echo_server_attach(u8 *appns_id, u64 appns_flags, u64 appns_secret)
echo_server_main_t echo_server_main
static int app_recv_dgram_raw(svm_fifo_t *f, u8 *buf, u32 len, app_session_transport_t *at, u8 clear_evt, u8 peek)
struct _vnet_app_attach_args_t vnet_app_attach_args_t
clib_error_t * vnet_app_add_tls_key(vnet_app_add_tls_key_args_t *a)
void echo_server_session_reset_callback(session_t *s)
static const char test_srv_crt_rsa[]
clib_error_t * vnet_session_enable_disable(vlib_main_t *vm, u8 is_en)
static int app_send_dgram_raw(svm_fifo_t *f, app_session_transport_t *at, svm_msg_q_t *vpp_evt_q, u8 *data, u32 len, u8 evt_type, u8 do_evt, u8 noblock)
static clib_error_t * echo_server_create_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
u32 app_index
Server app index.
API main structure, used by both vpp and binary API clients.
int vnet_application_attach(vnet_app_attach_args_t *a)
Attach application to vpp.
void test_bytes(echo_server_main_t *esm, int actual_transfer)
static u8 svm_fifo_set_event(svm_fifo_t *f)
Sets fifo event flag.
static_always_inline uword vlib_get_thread_index(void)
clib_error_t * echo_server_main_init(vlib_main_t *vm)
static int create_api_loopback(vlib_main_t *vm)
#define vec_free(V)
Free vector's memory (no header).
#define clib_warning(format, args...)
struct _stream_session_cb_vft session_cb_vft_t
u32 node_index
process node index for event scheduling
svm_queue_t * vl_input_queue
static const char test_srv_key_rsa[]
#define VLIB_CLI_COMMAND(x,...)
int echo_server_builtin_server_rx_callback_no_echo(session_t *s)
int echo_server_redirect_connect_callback(u32 client_index, void *mp)
int vnet_application_detach(vnet_app_detach_args_t *a)
Detach application from vpp.
struct _vnet_application_add_tls_key_args_t vnet_app_add_tls_key_args_t
int echo_server_rx_callback(session_t *s)
struct _vnet_app_detach_args_t vnet_app_detach_args_t
u8 thread_index
Index of the thread that allocated the session.
int svm_fifo_dequeue_drop(svm_fifo_t *f, u32 max_bytes)
int echo_server_add_segment_callback(u32 client_index, u64 segment_handle)
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
volatile u8 session_state
State in session layer state machine.
u8 ** rx_buf
Per-thread RX buffer.
int vnet_bind_uri(vnet_listen_args_t *a)
static int app_send_stream_raw(svm_fifo_t *f, svm_msg_q_t *vpp_evt_q, u8 *data, u32 len, u8 evt_type, u8 do_evt, u8 noblock)
char * server_uri
Server URI.
int vnet_disconnect_session(vnet_disconnect_args_t *a)
u32 private_segment_count
Number of private segments.
struct _svm_queue svm_queue_t
u8 is_dgram
set if transport is dgram
static vlib_thread_main_t * vlib_get_thread_main()
u32 rcv_buffer_size
Rcv buffer size.
static int echo_server_create(vlib_main_t *vm, u8 *appns_id, u64 appns_flags, u64 appns_secret)
int svm_fifo_peek(svm_fifo_t *f, u32 relative_offset, u32 max_bytes, u8 *copy_here)
struct session_dgram_header_ session_dgram_hdr_t
static session_cb_vft_t echo_server_session_cb_vft
static const u32 test_srv_crt_rsa_len
static uword pool_elts(void *v)
Number of active elements in a pool.