:orphan: .. index:: pair: group; TAPI for miscellaneous remote calls .. _doxid-group__te__lib__rpc__misc: TAPI for miscellaneous remote calls =================================== .. toctree:: :hidden: struct_tapi_pat_receiver.rst struct_tapi_pat_sender.rst struct_tapi_rand_gen.rst struct_te_saved_mtu.rst Overview ~~~~~~~~ .. ref-code-block:: cpp :class: doxyrest-overview-code-block // typedefs typedef struct :ref:`tapi_rand_gen` :ref:`tapi_rand_gen`; typedef struct :ref:`tapi_pat_sender` :ref:`tapi_pat_sender`; typedef struct :ref:`tapi_pat_receiver` :ref:`tapi_pat_receiver`; typedef struct :ref:`te_saved_mtu` :ref:`te_saved_mtu`; // structs struct :ref:`tapi_pat_receiver`; struct :ref:`tapi_pat_sender`; struct :ref:`tapi_rand_gen`; struct :ref:`te_saved_mtu`; // global functions static void :ref:`tapi_rand_gen_set`(:ref:`tapi_rand_gen`* arg, int min, int max, tarpc_bool once); void :ref:`tapi_pat_sender_init`(:ref:`tapi_pat_sender`* p); void :ref:`tapi_pat_receiver_init`(:ref:`tapi_pat_receiver`* p); bool :ref:`rpc_find_func`(:ref:`rcf_rpc_server`* rpcs, const char* func_name); int :ref:`rpc_vlan_get_parent`(:ref:`rcf_rpc_server`* rpcs, const char* vlan_ifname, char* parent_ifname); int :ref:`rpc_bond_get_slaves`(:ref:`rcf_rpc_server`* rpcs, const char* bond_ifname, tqh_strings* slaves, int* slaves_num); :ref:`tarpc_ssize_t` :ref:`rpc_get_sizeof`(:ref:`rcf_rpc_server`* rpcs, const char* type_name); bool :ref:`rpc_protocol_info_cmp`(:ref:`rcf_rpc_server`* rpcs, const uint8_t* buf1, const uint8_t* buf2, tarpc_bool is_wide1, tarpc_bool is_wide2); rpc_ptr :ref:`rpc_get_addrof`(:ref:`rcf_rpc_server`* rpcs, const char* name); uint64_t :ref:`rpc_get_var`(:ref:`rcf_rpc_server`* rpcs, const char* name, :ref:`tarpc_size_t` size); void :ref:`rpc_set_var`(:ref:`rcf_rpc_server`* rpcs, const char* name, :ref:`tarpc_size_t` size, uint64_t val); int :ref:`rpc_simple_sender`(:ref:`rcf_rpc_server`* handle, int s, int size_min, int size_max, int size_rnd_once, int delay_min, int delay_max, int delay_rnd_once, int time2run, uint64_t* sent, int ignore_err); int :ref:`rpc_simple_receiver`(:ref:`rcf_rpc_server`* handle, int s, uint32_t time2run, uint64_t* received); int :ref:`rpc_pattern_sender`(:ref:`rcf_rpc_server`* rpcs, int s, :ref:`tapi_pat_sender`* args); int :ref:`rpc_pattern_receiver`(:ref:`rcf_rpc_server`* rpcs, int s, :ref:`tapi_pat_receiver`* args); int :ref:`rpc_wait_readable`(:ref:`rcf_rpc_server`* rpcs, int s, uint32_t timeout); int :ref:`rpc_recv_verify`(:ref:`rcf_rpc_server`* handle, int s, const char* gen_data_fname, uint64_t start); int :ref:`rpc_iomux_flooder`(:ref:`rcf_rpc_server`* handle, int* sndrs, int sndnum, int* rcvrs, int rcvnum, int bulkszs, int time2run, int time2wait, int iomux, uint64_t* tx_stat, uint64_t* rx_stat); int :ref:`rpc_send_flooder_iomux`(:ref:`rcf_rpc_server`* rpcs, int sock, :ref:`iomux_func` iomux, tarpc_send_function send_func, bool msg_dontwait, int packet_size, int duration, uint64_t* packets, uint32_t* errors); int :ref:`rpc_iomux_echoer`(:ref:`rcf_rpc_server`* handle, int* sockets, int socknum, int time2run, int iomux, uint64_t* tx_stat, uint64_t* rx_stat); int :ref:`rpc_iomux_splice`(:ref:`rcf_rpc_server`* rpcs, int iomux, int fd_in, int fd_out, size_t len, int flags, int time2run); ssize_t :ref:`rpc_socket_to_file`(:ref:`rcf_rpc_server`* handle, int sock, const char* path_name, long timeout); int64_t :ref:`rpc_copy_fd2fd`(:ref:`rcf_rpc_server`* rpcs, int out_fd, int in_fd, int timeout, uint64_t count); int :ref:`rpc_ftp_open`(:ref:`rcf_rpc_server`* handle, char* uri, bool rdonly, bool passive, int offset, int* sock); int :ref:`rpc_ftp_close`(:ref:`rcf_rpc_server`* handle, int sock); int :ref:`rpc_overfill_buffers_data`(:ref:`rcf_rpc_server`* rpcs, int sock, uint64_t* sent, :ref:`iomux_func` iomux, uint8_t** sent_data); static int :target:`rpc_overfill_buffers_gen`(:ref:`rcf_rpc_server`* rpcs, int sock, uint64_t* sent, :ref:`iomux_func` iomux); static int :target:`rpc_overfill_buffers`(:ref:`rcf_rpc_server`* rpcs, int sock, uint64_t* sent); int :ref:`rpc_drain_fd`(:ref:`rcf_rpc_server`* rpcs, int fd, size_t size, int time2wait, uint64_t* read); int :ref:`rpc_drain_fd_duration`(:ref:`rcf_rpc_server`* rpcs, int fd, size_t size, int time2wait, unsigned int duration, uint64_t* read); int :ref:`rpc_drain_fd_simple`(:ref:`rcf_rpc_server`* rpcs, int fd, uint64_t* read); int :ref:`rpc_overfill_fd`(:ref:`rcf_rpc_server`* rpcs, int write_end, uint64_t* sent); int :ref:`rpc_read_fd2te_dbuf_append`(:ref:`rcf_rpc_server`* rpcs, int fd, int time2wait, size_t amount, :ref:`te_dbuf`* dbuf); int :ref:`rpc_read_fd2te_dbuf`(:ref:`rcf_rpc_server`* rpcs, int fd, int time2wait, size_t amount, :ref:`te_dbuf`* dbuf); int :ref:`rpc_read_fd`(:ref:`rcf_rpc_server`* rpcs, int fd, int time2wait, size_t amount, void** buf, size_t* read); int :ref:`rpc_read_fd2te_string_append`(:ref:`rcf_rpc_server`* rpcs, int fd, int time2wait, size_t amount, :ref:`te_string`* testr); int :ref:`rpc_read_fd2te_string`(:ref:`rcf_rpc_server`* rpcs, int fd, int time2wait, size_t amount, :ref:`te_string`* testr); void :ref:`rpc_vm_trasher`(:ref:`rcf_rpc_server`* rpcs, bool start); void :ref:`rpc_set_buf_gen`(:ref:`rcf_rpc_server`* rpcs, const uint8_t* src_buf, size_t len, rpc_ptr dst_buf, size_t dst_off); static void :target:`rpc_set_buf`(:ref:`rcf_rpc_server`* rpcs, const uint8_t* src_buf, size_t len, rpc_ptr dst_buf); static void :target:`rpc_set_buf_off`(:ref:`rcf_rpc_server`* rpcs, const uint8_t* src_buf, size_t len, :ref:`rpc_ptr_off`* dst_buf); void :ref:`rpc_set_buf_pattern_gen`(:ref:`rcf_rpc_server`* rpcs, int pattern, size_t len, rpc_ptr dst_buf, size_t dst_off); static void :target:`rpc_set_buf_pattern`(:ref:`rcf_rpc_server`* rpcs, int pattern, size_t len, rpc_ptr dst_buf); static void :target:`rpc_set_buf_pattern_off`(:ref:`rcf_rpc_server`* rpcs, int pattern, size_t len, :ref:`rpc_ptr_off`* dst_buf); void :ref:`rpc_get_buf_gen`(:ref:`rcf_rpc_server`* rpcs, rpc_ptr src_buf, size_t src_off, size_t len, uint8_t* dst_buf); static void :target:`rpc_get_buf`(:ref:`rcf_rpc_server`* rpcs, rpc_ptr src_buf, size_t len, uint8_t* dst_buf); static void :target:`rpc_get_buf_off`(:ref:`rcf_rpc_server`* rpcs, :ref:`rpc_ptr_off`* src_buf, size_t len, uint8_t* dst_buf); void :ref:`rpc_create_child_process_socket`(const char* method, :ref:`rcf_rpc_server`* pco_father, int father_s, :ref:`rpc_socket_domain` domain, :ref:`rpc_socket_type` sock_type, :ref:`rcf_rpc_server`** pco_child, int* child_s); :ref:`te_errno` :ref:`tapi_sigaction_simple`(:ref:`rcf_rpc_server`* rpcs, :ref:`rpc_signum` signum, const char* handler, struct :ref:`rpc_struct_sigaction`* oldact); int :ref:`rpc_mcast_join`(:ref:`rcf_rpc_server`* rpcs, int s, const struct sockaddr* mcast_addr, int if_index, tarpc_joining_method how); int :ref:`rpc_mcast_leave`(:ref:`rcf_rpc_server`* rpcs, int s, const struct sockaddr* mcast_addr, int if_index, tarpc_joining_method how); int :ref:`rpc_mcast_source_join`(:ref:`rcf_rpc_server`* rpcs, int s, const struct sockaddr* mcast_addr, const struct sockaddr* source_addr, int if_index, tarpc_joining_method how); int :ref:`rpc_mcast_source_leave`(:ref:`rcf_rpc_server`* rpcs, int s, const struct sockaddr* mcast_addr, const struct sockaddr* source_addr, int if_index, tarpc_joining_method how); int :target:`rpc_common_mcast_join`(:ref:`rcf_rpc_server`* rpcs, int s, const struct sockaddr* mcast_addr, const struct sockaddr* source_addr, int if_index, tarpc_joining_method how); int :target:`rpc_common_mcast_leave`(:ref:`rcf_rpc_server`* rpcs, int s, const struct sockaddr* mcast_addr, const struct sockaddr* source_addr, int if_index, tarpc_joining_method how); int :ref:`rpc_memcmp`(:ref:`rcf_rpc_server`* rpcs, :ref:`rpc_ptr_off`* s1, :ref:`rpc_ptr_off`* s2, size_t n); int :ref:`rpc_iomux_create_state`(:ref:`rcf_rpc_server`* rpcs, :ref:`iomux_func` iomux, :ref:`tarpc_iomux_state`* iomux_st); int :ref:`rpc_multiple_iomux_wait`(:ref:`rcf_rpc_server`* rpcs, int fd, :ref:`iomux_func` iomux, :ref:`tarpc_iomux_state` iomux_st, int events, int count, int duration, int exp_rc, int* number, int* last_rc, int* zero_rc); int :ref:`rpc_iomux_close_state`(:ref:`rcf_rpc_server`* rpcs, :ref:`iomux_func` iomux, :ref:`tarpc_iomux_state` iomux_st); int :ref:`rpc_multiple_iomux`(:ref:`rcf_rpc_server`* rpcs, int fd, :ref:`iomux_func` iomux, int events, int count, int duration, int exp_rc, int* number, int* last_rc, int* zero_rc); int :ref:`rpc_raw2integer`(:ref:`rcf_rpc_server`* rpcs, uint8_t* data, size_t len); int :ref:`rpc_integer2raw`(:ref:`rcf_rpc_server`* rpcs, uint64_t number, uint8_t* data, size_t len); int :ref:`rpc_vfork_pipe_exec`(:ref:`rcf_rpc_server`* rpcs, bool use_exec); static bool :ref:`tapi_interface_is_mine`(const char* ta, const char* interface); :ref:`te_errno` :ref:`tapi_set_if_mtu_smart`(const char* ta, const struct if_nameindex* interface, int mtu, int* old_mtu); typedef :ref:`LIST_HEAD`(te_saved_mtus, :ref:`te_saved_mtu`); void :ref:`tapi_saved_mtus_free`(te_saved_mtus* mtus); :ref:`te_errno` :ref:`tapi_saved_mtus2str`(te_saved_mtus* mtus, char** str); :ref:`te_errno` :ref:`tapi_str2saved_mtus`(const char* str, te_saved_mtus* mtus); :ref:`te_errno` :ref:`tapi_store_saved_mtus`(const char* ta, const char* name, te_saved_mtus* mtus); bool :ref:`tapi_stored_mtus_exist`(const char* ta, const char* name); :ref:`te_errno` :ref:`tapi_retrieve_saved_mtus`(const char* ta, const char* name, te_saved_mtus* mtus); :ref:`te_errno` :ref:`tapi_set_if_mtu_smart2`(const char* ta, const char* if_name, int mtu, te_saved_mtus* backup); :ref:`te_errno` :ref:`tapi_set_if_mtu_smart2_rollback`(te_saved_mtus* backup); bool :ref:`tapi_interface_is_vlan`(:ref:`rcf_rpc_server`* rpcs, const struct if_nameindex* interface); :ref:`te_errno` :ref:`tapi_interface_vlan_count`(const char* ta, const char* if_name, size_t* num); void :ref:`rpc_release_rpc_ptr`(:ref:`rcf_rpc_server`* rpcs, rpc_ptr ptr, char* ns_string); int :ref:`rpc_remove_dir_with_files`(:ref:`rcf_rpc_server`* rpcs, const char* path); :ref:`te_errno` :ref:`rpc_te_file_check_executable`(:ref:`rcf_rpc_server`* rpcs, const char* path); // macros #define :ref:`RPC_PATTERN_GEN` #define :ref:`RPC_PATTERN_GEN_LCG` #define :ref:`TAPI_READ_BUF_SIZE` #define :ref:`TARPC_PAT_GEN_ARG_FMT` #define :ref:`TARPC_PAT_GEN_ARG_VAL`(_gen_arg) .. _details-group__te__lib__rpc__misc: Detailed Documentation ~~~~~~~~~~~~~~~~~~~~~~ Typedefs -------- .. index:: pair: typedef; tapi_rand_gen .. _doxid-group__te__lib__rpc__misc_1ga770a9de5195aa32f2c1965364431c5ad: .. ref-code-block:: cpp :class: doxyrest-title-code-block typedef struct :ref:`tapi_rand_gen` tapi_rand_gen Structure describing random value generation. .. index:: pair: typedef; tapi_pat_sender .. _doxid-group__te__lib__rpc__misc_1gac81a7a3109fc8a15da535ae3c3fba800: .. ref-code-block:: cpp :class: doxyrest-title-code-block typedef struct :ref:`tapi_pat_sender` tapi_pat_sender Pattern sender settings .. index:: pair: typedef; tapi_pat_receiver .. _doxid-group__te__lib__rpc__misc_1ga1fc6c9eb07360ee1737bb4d8003ca85d: .. ref-code-block:: cpp :class: doxyrest-title-code-block typedef struct :ref:`tapi_pat_receiver` tapi_pat_receiver Pattern receiver settings .. index:: pair: typedef; te_saved_mtu .. _doxid-group__te__lib__rpc__misc_1gad3e0b7165131d963a18e2414415a44c3: .. ref-code-block:: cpp :class: doxyrest-title-code-block typedef struct :ref:`te_saved_mtu` te_saved_mtu Structure for storing MTU values. Global Functions ---------------- .. index:: pair: function; tapi_rand_gen_set .. _doxid-group__te__lib__rpc__misc_1ga49d9c4c15b1e4abdf285d887cbcdab67: .. ref-code-block:: cpp :class: doxyrest-title-code-block static void tapi_rand_gen_set(:ref:`tapi_rand_gen`* arg, int min, int max, tarpc_bool once) Set fields of :ref:`tapi_rand_gen ` structure. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - arg - Pointer to :ref:`tapi_rand_gen ` structure. * - min - Minimum value. * - max - Maximum value. * - once - Value for once field (see description in :ref:`tapi_rand_gen ` declaration). .. index:: pair: function; tapi_pat_sender_init .. _doxid-group__te__lib__rpc__misc_1ga68e28693fb7c004947fea6e94ab8fc76: .. ref-code-block:: cpp :class: doxyrest-title-code-block void tapi_pat_sender_init(:ref:`tapi_pat_sender`* p) Initialize fields of :ref:`tapi_pat_sender ` structure. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - p - Pointer to :ref:`tapi_pat_sender ` structure. .. index:: pair: function; tapi_pat_receiver_init .. _doxid-group__te__lib__rpc__misc_1ga1066745ebc735ac8d0766316e665b957: .. ref-code-block:: cpp :class: doxyrest-title-code-block void tapi_pat_receiver_init(:ref:`tapi_pat_receiver`* p) Initialize fields of :ref:`tapi_pat_receiver ` structure. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - p - Pointer to :ref:`tapi_pat_receiver ` structure. .. index:: pair: function; rpc_find_func .. _doxid-group__te__lib__rpc__misc_1ga6a06deb3f2c05d01f0dee2a473366acc: .. ref-code-block:: cpp :class: doxyrest-title-code-block bool rpc_find_func(:ref:`rcf_rpc_server`* rpcs, const char* func_name) Try to search a given symbol in the current library used by a given PCO with help of :ref:`tarpc_find_func() `. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server * - func_name - Symbol to be searched .. rubric:: Returns: Value returned by :ref:`tarpc_find_func() ` .. index:: pair: function; rpc_vlan_get_parent .. _doxid-group__te__lib__rpc__misc_1ga5e41a7f973271cb60c1fbf5d461caff8: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_vlan_get_parent(:ref:`rcf_rpc_server`* rpcs, const char* vlan_ifname, char* parent_ifname) Return parent network interface name of vlan interface. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle * - vlan_ifname - VLAN interface name * - parent_ifname - Pointer to the parent network interface name with at least ``IF_NAMESIZE`` bytes size. .. rubric:: Returns: 0 on success or -1 in the case of failure .. index:: pair: function; rpc_bond_get_slaves .. _doxid-group__te__lib__rpc__misc_1gaa978b68e58eb1fc87947b563bc981707: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_bond_get_slaves(:ref:`rcf_rpc_server`* rpcs, const char* bond_ifname, tqh_strings* slaves, int* slaves_num) Return slaves network interfaces names of a bond interface. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle * - bond_ifname - Bond interface name * - slaves - Where to save list of slaves names * - slaves_num - Where to save number of interfaces in ``slaves`` (may be NULL) .. rubric:: Returns: 0 on success or -1 in case of failure .. index:: pair: function; rpc_get_sizeof .. _doxid-group__te__lib__rpc__misc_1ga57f2d8e46f7276ae0dfae71a3703a1fc: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`tarpc_ssize_t` rpc_get_sizeof(:ref:`rcf_rpc_server`* rpcs, const char* type_name) Get host value of sizeof(type_name). .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server * - type_name - Name of the type .. rubric:: Returns: Size of the type or -1 if such a type does not exist. .. index:: pair: function; rpc_protocol_info_cmp .. _doxid-group__te__lib__rpc__misc_1gaa3115021591acd8d5c5632656317a68c: .. ref-code-block:: cpp :class: doxyrest-title-code-block bool rpc_protocol_info_cmp(:ref:`rcf_rpc_server`* rpcs, const uint8_t* buf1, const uint8_t* buf2, tarpc_bool is_wide1, tarpc_bool is_wide2) Compare protocol information (WSAPROTOCOL_INFO) .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server * - buf1 - buffer containing protocol info to compare * - buf2 - buffer containing protocol info to compare * - is_wide1 - boolean defining if fields of first protocol info are wide-character * - is_wide2 - boolean defining if fields of second protocol info are wide-character .. rubric:: Returns: ``true`` if information in ``buf1`` is equal to information in buf2 .. index:: pair: function; rpc_get_addrof .. _doxid-group__te__lib__rpc__misc_1gaa427a8f547dfb8923af3a76b3b20738d: .. ref-code-block:: cpp :class: doxyrest-title-code-block rpc_ptr rpc_get_addrof(:ref:`rcf_rpc_server`* rpcs, const char* name) Get address of the variable known on RPC server. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server * - name - variable name .. rubric:: Returns: RPC address pointer or NULL is variable is not found .. index:: pair: function; rpc_get_var .. _doxid-group__te__lib__rpc__misc_1gae0dc08f12f075d32d5e7c1d3fa7458dd: .. ref-code-block:: cpp :class: doxyrest-title-code-block uint64_t rpc_get_var(:ref:`rcf_rpc_server`* rpcs, const char* name, :ref:`tarpc_size_t` size) Get value of the integer variable. Routine jumps to failure is the variable is not found or incorrect parameters are provided .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server * - name - variable name * - size - variable size (1, 2, 4, 8) .. rubric:: Returns: variable value .. index:: pair: function; rpc_set_var .. _doxid-group__te__lib__rpc__misc_1ga18ee4081d79910d80e238116cdcb455e: .. ref-code-block:: cpp :class: doxyrest-title-code-block void rpc_set_var(:ref:`rcf_rpc_server`* rpcs, const char* name, :ref:`tarpc_size_t` size, uint64_t val) Change value of the integer variable. Routine jumps to failure is the variable is not found or incorrect parameters are provided .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server * - name - variable name * - size - variable size (1, 2, 4, 8) * - val - variable value .. index:: pair: function; rpc_simple_sender .. _doxid-group__te__lib__rpc__misc_1gafb609473a88c924ec5ecda6f8c0c43a4: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_simple_sender(:ref:`rcf_rpc_server`* handle, int s, int size_min, int size_max, int size_rnd_once, int delay_min, int delay_max, int delay_rnd_once, int time2run, uint64_t* sent, int ignore_err) Simple sender. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handle - RPC server * - s - a socket to be user for sending * - size_min - minimum size of the message in bytes * - size_max - maximum size of the message in bytes * - size_rnd_once - if true, random size should be calculated only once and used for all messages; if false, random size is calculated for each message * - delay_min - minimum delay between messages in microseconds * - delay_max - maximum delay between messages in microseconds * - delay_rnd_once - if true, random delay should be calculated only once and used for all messages; if false, random delay is calculated for each message * - time2run - how long run (in seconds) * - sent - location for number of sent bytes * - ignore_err - Ignore errors while run .. rubric:: Returns: Number of sent bytes or -1 in the case of failure if ignore_err set to ``false`` or number of sent bytes or 0 if ignore_err set to ``true`` .. index:: pair: function; rpc_simple_receiver .. _doxid-group__te__lib__rpc__misc_1ga665291853b0f660c88278415f5a593bd: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_simple_receiver(:ref:`rcf_rpc_server`* handle, int s, uint32_t time2run, uint64_t* received) Simple receiver. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handle - RPC server * - s - a socket to be user for receiving * - time2run - how long run (in seconds) * - received - location for number of received bytes .. rubric:: Returns: number of received bytes or -1 in the case of failure .. index:: pair: function; rpc_pattern_sender .. _doxid-group__te__lib__rpc__misc_1gaeab66cb84fd81d73e4402bdd5d94771e: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_pattern_sender(:ref:`rcf_rpc_server`* rpcs, int s, :ref:`tapi_pat_sender`* args) Patterned data sender. Data may be sent using IO multiplexing or not, according to ``iomux`` argument, with non-blocking **send()** or blocking, respectively. In case of blocking **send()** no timeout is used. If there is any problems (e.g. ``ERPCTIMEOUT`` error), you should set the ``SO_SNDTIMEO`` via **setsockopt()** like it is implemented in :ref:`rpc_pattern_receiver `. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server. * - s - A socket to be used for sending. * - args - Pointer to :ref:`tapi_pat_sender ` structure. * - 0 - on success * - -1 - in the case of failure .. rubric:: Returns: Status code. .. index:: pair: function; rpc_pattern_receiver .. _doxid-group__te__lib__rpc__misc_1ga4bf5aab8f889e6906ff248af42ce3483: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_pattern_receiver(:ref:`rcf_rpc_server`* rpcs, int s, :ref:`tapi_pat_receiver`* args) Patterned data receiver. Data may be received using IO multiplexing or not, according to ``iomux`` argument, with non-blocking **recv()** or blocking, respectively. In case of blocking **recv()** the function sets ``SO_RCVTIMEO`` option several times and restores it to original value at the end. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server. * - s - Socket descriptor. * - args - Pointer to :ref:`tapi_pat_receiver ` structure. * - >= - 0 number of received bytes * - -2 - data doesn't match the pattern * - -1 - in the case of another failure .. rubric:: Returns: Status code. .. index:: pair: function; rpc_wait_readable .. _doxid-group__te__lib__rpc__misc_1gaf4c6490e2d99ecb14078ce5a281e0927: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_wait_readable(:ref:`rcf_rpc_server`* rpcs, int s, uint32_t timeout) Wait for readable socket. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server * - s - a socket to be user for select * - timeout - Receive timeout (in milliseconds) .. rubric:: Returns: result of select() call .. index:: pair: function; rpc_recv_verify .. _doxid-group__te__lib__rpc__misc_1ga86342a8d2f1c59bf78474e57b665786a: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_recv_verify(:ref:`rcf_rpc_server`* handle, int s, const char* gen_data_fname, uint64_t start) Receive and verify all acceptable data on socket. Verification made by function, which name is passed. This function should generate block of data by start sequence number (which is passed) and length. Then received and generated buffers are compared. Socket method recv(..., MSG_DONTWAIT) used. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handle - RPC server * - s - a socket to be user for receiving * - gen_data_fname - name of function to generate data * - start - sequence number of first byte will be received. .. rubric:: Returns: number of received bytes, -1 if system error, -2 if data not match. .. index:: pair: function; rpc_iomux_flooder .. _doxid-group__te__lib__rpc__misc_1ga514b43703eca0d20e863a3a1cd1469f4: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_iomux_flooder(:ref:`rcf_rpc_server`* handle, int* sndrs, int sndnum, int* rcvrs, int rcvnum, int bulkszs, int time2run, int time2wait, int iomux, uint64_t* tx_stat, uint64_t* rx_stat) Routine which receives data from specified set of sockets and sends data to specified set of sockets with maximum speed using I/O multiplexing. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handle - RPC server * - rcvrs - set of receiver sockets * - rcvnum - number of receiver sockets * - sndrs - set of sender sockets * - sndnum - number of sender sockets * - bulkszs - sizes of data bulks to send for each sender (in bytes, 1024 bytes maximum) * - time2run - how long send data (in seconds) * - time2wait - how long wait data (in seconds) * - iomux - type of I/O Multiplexing function (**select()**, **pselect()**, **poll()**) * - tx_stat - Tx statistics for set of sender socket to be updated (IN/OUT) * - rx_stat - Rx statistics for set of receiver socket to be updated (IN/OUT) .. rubric:: Returns: number of sent bytes or -1 in the case of failure .. index:: pair: function; rpc_send_flooder_iomux .. _doxid-group__te__lib__rpc__misc_1gae53cd14c388da8e110338a860c8e03b7: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_send_flooder_iomux(:ref:`rcf_rpc_server`* rpcs, int sock, :ref:`iomux_func` iomux, tarpc_send_function send_func, bool msg_dontwait, int packet_size, int duration, uint64_t* packets, uint32_t* errors) Send packets during a period of time, call an iomux to check OUT event if send operation is failed. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle. * - sock - Socket. * - iomux - Multiplexer function. * - send_func - Transmitting function. * - msg_dontwait - Use flag **MSG_DONTWAIT**. * - packet_size - Payload size to be sent by a single call, bytes. * - duration - How long transmit datagrams, milliseconds. * - packets - Sent packets (datagrams) number. * - errors - ``EAGAIN`` errors counter. .. rubric:: Returns: ``0`` on success or ``-1`` in the case of failure. .. index:: pair: function; rpc_iomux_echoer .. _doxid-group__te__lib__rpc__misc_1ga0ad6266d8b67c6e56d383dac4b1c186e: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_iomux_echoer(:ref:`rcf_rpc_server`* handle, int* sockets, int socknum, int time2run, int iomux, uint64_t* tx_stat, uint64_t* rx_stat) Routine which receives data from specified set of sockets using I/O multiplexing and sends them back to the socket. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handle - RPC server * - sockets - Set of sockets to be processed * - socknum - number of sockets to be processed * - time2run - how long send data (in seconds) * - iomux - type of I/O Multiplexing function (**select()**, **pselect()**, **poll()**) * - tx_stat - Tx statistics for set of sender socket to be updated (IN/OUT) * - rx_stat - Rx statistics for set of receiver socket to be updated (IN/OUT) .. rubric:: Returns: 0 on success or -1 in the case of failure .. index:: pair: function; rpc_iomux_splice .. _doxid-group__te__lib__rpc__misc_1ga69212a3614fbb37074371038de240adf: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_iomux_splice(:ref:`rcf_rpc_server`* rpcs, int iomux, int fd_in, int fd_out, size_t len, int flags, int time2run) Routine which calls I/O multiplexing function and then calls splice. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server * - iomux - type of I/O Multiplexing function (**select()**, **pselect()**, **poll()**) * - fd_in - file descriptor opened for writing * - fd_out - file descriptor opened for reading * - len - 'len' parameter for **splice()** call * - flags - flags for **splice()** call * - time2run - Duration of the call .. rubric:: Returns: number of sent bytes or -1 in the case of failure .. index:: pair: function; rpc_socket_to_file .. _doxid-group__te__lib__rpc__misc_1gae9d823e40c9999aa4ef3534e392862c9: .. ref-code-block:: cpp :class: doxyrest-title-code-block ssize_t rpc_socket_to_file(:ref:`rcf_rpc_server`* handle, int sock, const char* path_name, long timeout) Routine which receives data from opened socket descriptor and write its to the file. Processing is finished when timeout expired. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handle - RPC server * - sock - socket descriptor for data receiving * - path_name - path name where write received data * - timeout - timeout to finish processing .. rubric:: Returns: Number of processed bytes or -1 in the case of failure .. index:: pair: function; rpc_copy_fd2fd .. _doxid-group__te__lib__rpc__misc_1gac2d5d2e9051ade82f503515ad55825e7: .. ref-code-block:: cpp :class: doxyrest-title-code-block int64_t rpc_copy_fd2fd(:ref:`rcf_rpc_server`* rpcs, int out_fd, int in_fd, int timeout, uint64_t count) Copy data between one file descriptor and another. If ``in_fd`` is a file which supports mmap(2)-like operations then it is recommended to use ``rpc_sendfile`` cause it is more efficient. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle. * - out_fd - File descriptor opened for writing. Can be a socket. * - in_fd - File descriptor opened for reading. Can be a socket. * - timeout - Number of milliseconds that function should block waiting for **in_fd** to become ready to read the next portion of data while all requested data will not be read. * - count - Number of bytes to copy between the file descriptors. If ``0`` then all available data should be copied, i.e. while ``EOF`` will not be gotten. .. rubric:: Returns: If the transfer was successful, the number of copied bytes is returned. On error, ``-1`` is returned, and errno is set appropriately. .. index:: pair: function; rpc_ftp_open .. _doxid-group__te__lib__rpc__misc_1ga84744648f01ab634c5229c49d1671a35: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_ftp_open(:ref:`rcf_rpc_server`* handle, char* uri, bool rdonly, bool passive, int offset, int* sock) Open FTP connection for reading/writing the file. Control connection should be closed via ftp_close. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handle - RPC server * - uri - FTP uri: `ftp://user:password@server/directory/file `__ * - rdonly - if ``true``, get file * - passive - if ``true``, passive mode * - offset - file offset * - sock - pointer to a socket descriptor .. rubric:: Returns: File descriptor, which may be used for reading/writing data .. index:: pair: function; rpc_ftp_close .. _doxid-group__te__lib__rpc__misc_1gafe8a3ed207bd7f9f4da3da68b106feef: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_ftp_close(:ref:`rcf_rpc_server`* handle, int sock) Close FTP control connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handle - RPC server * - sock - control socket descriptor .. rubric:: Returns: 0 on success or -1 on failure .. index:: pair: function; rpc_overfill_buffers_data .. _doxid-group__te__lib__rpc__misc_1ga4b94a74efe57091e55a91e0b40768b3c: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_overfill_buffers_data(:ref:`rcf_rpc_server`* rpcs, int sock, uint64_t* sent, :ref:`iomux_func` iomux, uint8_t** sent_data) Overfill the buffers on receive and send sides of TCP connection. On Windows, this call excepts socket to be in blocking mode. To use it on non-blocking sockets refer to rpc_overfill_buffers_ex. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server * - sock - socket for sending * - sent - total bytes written to sending socket while both sending and receiving side buffers are overfilled. * - iomux - IOMUX function to use when checking for socket writeability. * - sent_data - If not ``NULL``, pointer to sent data will be retrieved here (it should be freed by the caller). .. rubric:: Returns: -1 in the case of failure or 0 on success .. index:: pair: function; rpc_drain_fd .. _doxid-group__te__lib__rpc__misc_1gaedf671b844a2ea716b8721eacd2bc14c: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_drain_fd(:ref:`rcf_rpc_server`* rpcs, int fd, size_t size, int time2wait, uint64_t* read) Drain all data on a fd. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle. * - fd - File descriptor or socket. * - size - Read buffer size, bytes. * - time2wait - How long wait for data after read failure, milliseconds. If a negative value is set, then blocking ``recv()`` will be used to read data. * - read - Pointer for read data amount or ``NULL``. .. rubric:: Returns: The last return code of ``recv()`` function: ``-1`` in the case of failure or ``0`` on success. In a common case ``-1`` with ``RPC_EAGAIN`` should be considered as the correct behavior if the connection was not closed from the peer side. .. index:: pair: function; rpc_drain_fd_duration .. _doxid-group__te__lib__rpc__misc_1gab6039944d70acf3b5ee60755c69bc319: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_drain_fd_duration(:ref:`rcf_rpc_server`* rpcs, int fd, size_t size, int time2wait, unsigned int duration, uint64_t* read) The same as :ref:`rpc_drain_fd() ` but allows to specify general time limit for this call. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle. * - fd - File descriptor or socket. * - size - Read buffer size, bytes. * - time2wait - How long to wait for data after read failure, milliseconds. If a negative value is set and ``duration`` is zero, then blocking ``recv()`` will be used to read data. Otherwise, if value is negative or zero, new data will be waited for until ``duration`` timeout expires with an iomux function. * - duration - If not zero, specifies time limit for this call, in seconds. * - read - Pointer for read data amount or ``NULL``. .. rubric:: Returns: The last return code of **recv()** function: ``-1`` in the case of failure or ``0`` on success. In a common case ``-1`` with ``RPC_EAGAIN`` should be considered as the correct behavior if the connection was not closed from the peer side. .. index:: pair: function; rpc_drain_fd_simple .. _doxid-group__te__lib__rpc__misc_1gaa8247f3518e9fa8ab4413fbfd79b23fd: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_drain_fd_simple(:ref:`rcf_rpc_server`* rpcs, int fd, uint64_t* read) Simplified call of ``:ref:`rpc_drain_fd() ```. It executes the call with default **size** and **time2wait** parameters what is useful in a common case. Also it checks return code and errno. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle. * - fd - File descriptor or socket. * - read - Pointer for read data amount or ``NULL``. .. rubric:: Returns: The last return code of ``recv()`` function. Actually it can be ``-1`` with ``RPC_EAGAIN`` or ``0``, otherwise the functions reports a verdict and jumps to cleanup. Zero return code indicates that the connection was closed from the peer side. .. index:: pair: function; rpc_overfill_fd .. _doxid-group__te__lib__rpc__misc_1ga5b44b44de5c02e85babebaa13f6d47e5: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_overfill_fd(:ref:`rcf_rpc_server`* rpcs, int write_end, uint64_t* sent) Overfill the buffers of the pipe. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server * - write_end - Write end of the pipe * - sent - total bytes written to the pipe .. rubric:: Returns: -1 in the case of failure or 0 on success .. index:: pair: function; rpc_read_fd2te_dbuf_append .. _doxid-group__te__lib__rpc__misc_1gab551e42aa6bf5679152cc9cd6dd3d492: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_read_fd2te_dbuf_append(:ref:`rcf_rpc_server`* rpcs, int fd, int time2wait, size_t amount, :ref:`te_dbuf`* dbuf) Read all data on an fd and append it to ``dbuf``. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle. * - fd - File descriptor or socket. * - time2wait - Time to wait for data, milliseconds. Negative value means an infinite timeout and it is a user responsibility to care about RPC timeout in this case. * - amount - Number of bytes to read, if ``0`` then only ``time2wait`` limits it. * - dbuf - Buffer to append read data to. .. rubric:: Returns: ``-1`` in the case of failure or ``0`` on success (timeout is expired, ``amount`` bytes is read, EOF is got). .. index:: pair: function; rpc_read_fd2te_dbuf .. _doxid-group__te__lib__rpc__misc_1ga4b07ddd35e7654bb3589235008361d88: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_read_fd2te_dbuf(:ref:`rcf_rpc_server`* rpcs, int fd, int time2wait, size_t amount, :ref:`te_dbuf`* dbuf) Read all data from fd to ``dbuf``. The function resets ``dbuf``. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle. * - fd - File descriptor or socket. * - time2wait - Time to wait for data, milliseconds. Negative value means an infinite timeout and it is a user responsibility to care about RPC timeout in this case. * - amount - Number of bytes to read, if ``0`` then only ``time2wait`` limits it. * - dbuf - Buffer to put read data to. .. rubric:: Returns: ``-1`` in the case of failure or ``0`` on success (timeout is expired, ``amount`` bytes is read, EOF is got). .. index:: pair: function; rpc_read_fd .. _doxid-group__te__lib__rpc__misc_1ga716ae01a0156503d12381e45d5b2449f: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_read_fd(:ref:`rcf_rpc_server`* rpcs, int fd, int time2wait, size_t amount, void** buf, size_t* read) Read all data on an fd. ``buf`` should be freed with free(3) when it is no longer needed, independently on result. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle. * - fd - File descriptor or socket. * - time2wait - Time to wait for data, milliseconds. Negative value means an infinite timeout and it is a user responsibility to care about RPC timeout in this case. * - amount - Number of bytes to read, if ``0`` then only ``time2wait`` limits it. * - buf - Pointer to buffer (it is allocated by the function). * - read - Number of read bytes. .. rubric:: Returns: ``-1`` in the case of failure or ``0`` on success (timeout is expired, ``amount`` bytes is read, EOF is got). .. index:: pair: function; rpc_read_fd2te_string_append .. _doxid-group__te__lib__rpc__misc_1ga72348def4fd89f4c97f6d08ed8454435: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_read_fd2te_string_append(:ref:`rcf_rpc_server`* rpcs, int fd, int time2wait, size_t amount, :ref:`te_string`* testr) Read all string data on an fd and append it to ``testr``. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle. * - fd - File descriptor or socket. * - time2wait - Time to wait for data, milliseconds. Negative value means an infinite timeout and it is a user responsibility to care about RPC timeout in this case. * - amount - Number of bytes to read, if ``0`` then only ``time2wait`` limits it. * - testr - Buffer to append read data to. .. rubric:: Returns: ``-1`` in the case of failure or ``0`` on success (timeout is expired, ``amount`` bytes is read, EOF is got). .. index:: pair: function; rpc_read_fd2te_string .. _doxid-group__te__lib__rpc__misc_1ga0521c20bda74969d8b23c68c86bd1b01: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_read_fd2te_string(:ref:`rcf_rpc_server`* rpcs, int fd, int time2wait, size_t amount, :ref:`te_string`* testr) Read all string data from fd to ``testr``. The function resets ``testr``. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle. * - fd - File descriptor or socket. * - time2wait - Time to wait for data, milliseconds. Negative value means an infinite timeout and it is a user responsibility to care about RPC timeout in this case. * - amount - Number of bytes to read, if ``0`` then only ``time2wait`` limits it. * - testr - Buffer to put read data to. .. rubric:: Returns: ``-1`` in the case of failure or ``0`` on success (timeout is expired, ``amount`` bytes is read, EOF is got). .. index:: pair: function; rpc_vm_trasher .. _doxid-group__te__lib__rpc__misc_1ga954092377d57c660380eaed6bbbc5b7e: .. ref-code-block:: cpp :class: doxyrest-title-code-block void rpc_vm_trasher(:ref:`rcf_rpc_server`* rpcs, bool start) VM trasher to keep memory pressure on the host where the specified RPC server runs. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server * - start - ``true`` if want to start the VM trasher, ``false`` if want to stop the VM trasher. .. index:: pair: function; rpc_set_buf_gen .. _doxid-group__te__lib__rpc__misc_1ga28d84b810bbda6588ffba7004d102604: .. ref-code-block:: cpp :class: doxyrest-title-code-block void rpc_set_buf_gen(:ref:`rcf_rpc_server`* rpcs, const uint8_t* src_buf, size_t len, rpc_ptr dst_buf, size_t dst_off) Copy the **src_buf** buffer in **dst_buf** located in TA address space .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle * - src_buf - pointer to the source buffer * - len - length of data to be copied * - dst_buf - pointer to the destination buffer * - dst_off - displacement in the destination buffer .. index:: pair: function; rpc_set_buf_pattern_gen .. _doxid-group__te__lib__rpc__misc_1ga39c306567556b6668e5276d4644810b1: .. ref-code-block:: cpp :class: doxyrest-title-code-block void rpc_set_buf_pattern_gen(:ref:`rcf_rpc_server`* rpcs, int pattern, size_t len, rpc_ptr dst_buf, size_t dst_off) Fill **dst_buf** located in TA address space by specified pattern .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle * - pattern - pattern to be used for buffer filling (TAPI_RPC_BUF_RAND if the buffer should be filled by random data) * - len - length of data to be copied * - dst_buf - pointer to the destination buffer * - dst_off - displacement in the destination buffer .. index:: pair: function; rpc_get_buf_gen .. _doxid-group__te__lib__rpc__misc_1ga99e6520323b8faeb25e68329dae3e50a: .. ref-code-block:: cpp :class: doxyrest-title-code-block void rpc_get_buf_gen(:ref:`rcf_rpc_server`* rpcs, rpc_ptr src_buf, size_t src_off, size_t len, uint8_t* dst_buf) Copy the **src_buf** buffer located in TA address space to the **dst_buf** buffer. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle * - src_buf - source buffer * - src_off - displacement in the source buffer * - len - length of data to be copied * - dst_buf - destination buffer .. index:: pair: function; rpc_create_child_process_socket .. _doxid-group__te__lib__rpc__misc_1gaf0f85a666f753ae8621d5eabb6fd7c8e: .. ref-code-block:: cpp :class: doxyrest-title-code-block void rpc_create_child_process_socket(const char* method, :ref:`rcf_rpc_server`* pco_father, int father_s, :ref:`rpc_socket_domain` domain, :ref:`rpc_socket_type` sock_type, :ref:`rcf_rpc_server`** pco_child, int* child_s) Create a child process (with a duplicated socket in case of winsock2). .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - method - "inherit", "DuplicateSocket" or "DuplicateHandle" * - pco_father - RPC server handle * - father_s - socket on **pco_father** * - domain - domain, used in test * - sock_type - type of socket, used in test * - pco_child - new process * - child_s - duplicated socket on **pco_child** .. index:: pair: function; tapi_sigaction_simple .. _doxid-group__te__lib__rpc__misc_1gab4278dff63582190360f63cfc0d02e0f: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_sigaction_simple(:ref:`rcf_rpc_server`* rpcs, :ref:`rpc_signum` signum, const char* handler, struct :ref:`rpc_struct_sigaction`* oldact) Wrapper for :ref:`rpc_sigaction() ` function to install 'sa_sigaction' with blocking of all signals and ``SA_RESTART`` flag. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle * - signum - Signal number * - handler - Signal handler 'sa_sigaction' * - oldact - Pointer to previously associated with the signal action or NULL .. rubric:: Returns: Status code. .. index:: pair: function; rpc_mcast_join .. _doxid-group__te__lib__rpc__misc_1ga0c249542a59eccb8c92044f237ed83a0: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_mcast_join(:ref:`rcf_rpc_server`* rpcs, int s, const struct sockaddr* mcast_addr, int if_index, tarpc_joining_method how) Join a multicasting group on specified interface. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle * - s - socket descriptor * - mcast_addr - multicast address (IPv4 or IPv6). * - if_index - interface index * - how - joining method: * ``TARPC_MCAST_ADD_DROP`` sockopt IP_ADD/DROP_MEMBERSHIP * ``TARPC_MCAST_JOIN_LEAVE`` sockopt MCAST_JOIN/LEAVE_GROUP * ``TARPC_MCAST_WSA`` WSAJoinLeaf(), no leave .. rubric:: Returns: 0 on success, -1 on failure .. index:: pair: function; rpc_mcast_leave .. _doxid-group__te__lib__rpc__misc_1ga4878c9fd336854d36f8cb65b0814ebcc: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_mcast_leave(:ref:`rcf_rpc_server`* rpcs, int s, const struct sockaddr* mcast_addr, int if_index, tarpc_joining_method how) Leave a multicasting group. Parameters are same as above. .. index:: pair: function; rpc_mcast_source_join .. _doxid-group__te__lib__rpc__misc_1ga9631e6db8bf7d2d69484727315bd4dcb: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_mcast_source_join(:ref:`rcf_rpc_server`* rpcs, int s, const struct sockaddr* mcast_addr, const struct sockaddr* source_addr, int if_index, tarpc_joining_method how) Join a multicasting group with source on specified interface. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle * - s - socket descriptor * - mcast_addr - multicast address * - source_addr - source address * - if_index - interface index * - how - joining method: * ``TARPC_MCAST_SOURCE_ADD_DROP`` sockopt IP_ADD/DROP_SOURCE_MEMBERSHIP * ``TARPC_MCAST_SOURCE_JOIN_LEAVE`` sockopt MCAST_JOIN/LEAVE_SOURCE_GROUP .. rubric:: Returns: 0 on success, -1 on failure .. index:: pair: function; rpc_mcast_source_leave .. _doxid-group__te__lib__rpc__misc_1gad69c04f7edaeaaaed0daf1c165e28ae2: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_mcast_source_leave(:ref:`rcf_rpc_server`* rpcs, int s, const struct sockaddr* mcast_addr, const struct sockaddr* source_addr, int if_index, tarpc_joining_method how) Leave a multicasting group with source. Parameters are same as above. .. index:: pair: function; rpc_memcmp .. _doxid-group__te__lib__rpc__misc_1ga96ad46e3041df53b2482d422bf4e1714: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_memcmp(:ref:`rcf_rpc_server`* rpcs, :ref:`rpc_ptr_off`* s1, :ref:`rpc_ptr_off`* s2, size_t n) Compare memory areas See memcmp(3) .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle * - s1 - RPC pointer to the first memory area * - s2 - RPC pointer to the second memory area * - n - Size of memory areas to be compared .. rubric:: Returns: An integer less than, equal to, or greater than zero if the first n bytes of s1 is found, respectively, to be less than, to match, or be greater than the first n bytes of s2. .. index:: pair: function; rpc_iomux_create_state .. _doxid-group__te__lib__rpc__misc_1ga706dff211743d9b71e8142ff342757f5: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_iomux_create_state(:ref:`rcf_rpc_server`* rpcs, :ref:`iomux_func` iomux, :ref:`tarpc_iomux_state`* iomux_st) Initialize :ref:`iomux_state ` with zero value Caller must free memory allocated for iomux_st using rpc_iomux_close() .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle * - iomux - Multiplexer function type * - iomux_st - The multiplexer context pointer .. rubric:: Returns: ``0`` on success or ``-1`` in the case of failure. .. index:: pair: function; rpc_multiple_iomux_wait .. _doxid-group__te__lib__rpc__misc_1ga68a630a57e868494e084a4a2f4867be8: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_multiple_iomux_wait(:ref:`rcf_rpc_server`* rpcs, int fd, :ref:`iomux_func` iomux, :ref:`tarpc_iomux_state` iomux_st, int events, int count, int duration, int exp_rc, int* number, int* last_rc, int* zero_rc) Call I/O multiplexing wait function multiple times .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle * - fd - File descriptor * - iomux - Iomux to be called * - iomux_st - The multiplexer context pointer * - events - **poll()** events to be checked for * - count - How many times to call a function or ``-1`` for unlimited * - duration - Call iomux during a specified time in milliseconds or ``-1`` * - exp_rc - Expected return value * - number - If not ``NULL``, will be set to the number of iomux calls before timeout occurred or an error was returned. * - last_rc - If not ``NULL``, will be set to the last return value of an iomux function. * - zero_rc - If not ``NULL``, number of zero code returned by iomux .. rubric:: Returns: ``0`` on success or ``-1`` in the case of failure. .. index:: pair: function; rpc_iomux_close_state .. _doxid-group__te__lib__rpc__misc_1ga37d0deb53d54a66b9237a022b441494b: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_iomux_close_state(:ref:`rcf_rpc_server`* rpcs, :ref:`iomux_func` iomux, :ref:`tarpc_iomux_state` iomux_st) Close iomux state when necessary .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle * - iomux - Multiplexer function type * - iomux_st - The multiplexer context pointer .. rubric:: Returns: ``0`` on success or ``-1`` in the case of failure. .. index:: pair: function; rpc_multiple_iomux .. _doxid-group__te__lib__rpc__misc_1ga137098af8bc596836e508e9eb292648d: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_multiple_iomux(:ref:`rcf_rpc_server`* rpcs, int fd, :ref:`iomux_func` iomux, int events, int count, int duration, int exp_rc, int* number, int* last_rc, int* zero_rc) Call I/O multiplexing function multiple times. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle * - fd - File descriptor * - iomux - Iomux to be called * - events - **poll()** events to be checked for * - count - How many times to call a function or ``-1`` for unlimited * - duration - Call iomux during a specified time in milliseconds or ``-1`` * - exp_rc - Expected return value * - number - If not ``NULL``, will be set to the number of iomux calls before timeout occurred or an error was returned. * - last_rc - If not ``NULL``, will be set to the last return value of an iomux function. * - zero_rc - If not ``NULL``, number of zero code returned by iomux .. index:: pair: function; rpc_raw2integer .. _doxid-group__te__lib__rpc__misc_1gae3d7b1828b2444c6479e8d0dd4304a56: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_raw2integer(:ref:`rcf_rpc_server`* rpcs, uint8_t* data, size_t len) Convert raw data to integer (this is useful when raw data was obtained from a test machine with different endianness). .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server * - data - Data to be converted * - len - Length of data to be converted .. rubric:: Returns: ``0`` on success or ``-1`` .. index:: pair: function; rpc_integer2raw .. _doxid-group__te__lib__rpc__misc_1gafc96b08a76ca00093612da88d0f0e751: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_integer2raw(:ref:`rcf_rpc_server`* rpcs, uint64_t number, uint8_t* data, size_t len) Convert integer value to raw representation (this is useful when raw data is to be processed by a test machine with different endianness). .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server * - number - Number to be converted * - data - Buffer where to place converted value * - len - Integer type size .. rubric:: Returns: ``0`` on success or ``-1`` .. index:: pair: function; rpc_vfork_pipe_exec .. _doxid-group__te__lib__rpc__misc_1ga45f69ea78e71a3ca18dacce6b4c6e97f: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_vfork_pipe_exec(:ref:`rcf_rpc_server`* rpcs, bool use_exec) Specioal function for sockapi-ts/basic/vfork_check_hang test. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server * - use_exec - Use **execve()** or **_exit()** function .. rubric:: Returns: ``0`` on success or ``-1`` .. index:: pair: function; tapi_interface_is_mine .. _doxid-group__te__lib__rpc__misc_1gac1c1f7b05250845b75cd6e62322f3df3: .. ref-code-block:: cpp :class: doxyrest-title-code-block static bool tapi_interface_is_mine(const char* ta, const char* interface) Determine if the interface is grabbed by the testing. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test agent name * - interface - Interface name .. rubric:: Returns: ``true`` if the interface is grabbed. .. index:: pair: function; tapi_set_if_mtu_smart .. _doxid-group__te__lib__rpc__misc_1ga7d11d94b74165f226bcc4038cde07a07: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_set_if_mtu_smart(const char* ta, const struct if_nameindex* interface, int mtu, int* old_mtu) Set new MTU value for a given interface (increasing MTU for the interfaces it is based on if necessary). This function does not save previous values of MTU for affected "ancestor" interfaces; you should rely on Configurator to restore them. Still it makes sense to restore MTU for the interface passed to this function, as otherwise Configurator may be not able to restore MTU values for its "descendant" interfaces, which may change as a side effect if we descrease MTU. Function :ref:`tapi_set_if_mtu_smart2() ` can be used to change MTU saving old values for all related interfaces, then the changes can be rolled back using function :ref:`tapi_set_if_mtu_smart2_rollback() `. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test agent name * - interface - Network interface * - mtu - MTU value * - old_mtu - If not ``NULL``, previous value of MTU for the interface will be saved. .. rubric:: Returns: Status code. .. index:: pair: function; LIST_HEAD .. _doxid-group__te__lib__rpc__misc_1ga7741c151600013fbd8545df35db75f9f: .. ref-code-block:: cpp :class: doxyrest-title-code-block typedef LIST_HEAD(te_saved_mtus, :ref:`te_saved_mtu`) Type of list of MTU values. .. index:: pair: function; tapi_saved_mtus_free .. _doxid-group__te__lib__rpc__misc_1gaec390cebcf1a23bf8de45629b5d38f11: .. ref-code-block:: cpp :class: doxyrest-title-code-block void tapi_saved_mtus_free(te_saved_mtus* mtus) Free memory allocated for items of a list of MTU values. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - mtus - Pointer to the list. .. index:: pair: function; tapi_saved_mtus2str .. _doxid-group__te__lib__rpc__misc_1ga26f36a9adc598a6b515b21f91d63e822: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_saved_mtus2str(te_saved_mtus* mtus, char** str) Convert list of saved MTU values to string. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - mtus - List of saved MTU values. * - str - Where to save pointer to the string (memory is allocated by this function). .. rubric:: Returns: Status code. .. index:: pair: function; tapi_str2saved_mtus .. _doxid-group__te__lib__rpc__misc_1ga1659b4136aea361707ca334d0f72c7af: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_str2saved_mtus(const char* str, te_saved_mtus* mtus) Convert string to list of saved MTU values. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - str - String to convert. * - mtus - Pointer to list head. .. rubric:: Returns: Status code. .. index:: pair: function; tapi_store_saved_mtus .. _doxid-group__te__lib__rpc__misc_1ga275f52578a16ac7b62664deaa592502a: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_store_saved_mtus(const char* ta, const char* name, te_saved_mtus* mtus) Save MTU values to a temporary local file. List of MTU values will be empty after calling this function. Register "saved_mtus" node under "/local" in Configuration tree to use this function. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name. * - name - Unique name. * - mtus - List of MTU values. .. rubric:: Returns: Status code. .. index:: pair: function; tapi_stored_mtus_exist .. _doxid-group__te__lib__rpc__misc_1ga402b66dad08ca24ffed497d94fcc6ada: .. ref-code-block:: cpp :class: doxyrest-title-code-block bool tapi_stored_mtus_exist(const char* ta, const char* name) Check whether MTU values are already stored under a given name. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name. * - name - Name used to identify MTU values list. .. rubric:: Returns: ``true`` if MTU values are stored under the ``name``, ``false`` otherwise. .. index:: pair: function; tapi_retrieve_saved_mtus .. _doxid-group__te__lib__rpc__misc_1gaa41e019f4bd4213bc5612ab33de2a473: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_retrieve_saved_mtus(const char* ta, const char* name, te_saved_mtus* mtus) Retrieve saved MTU values from a temporary local file. This function may be called only once for a given name, as the file fill be removed as a result. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name. * - name - Unique name previously passed to tapi_store_save_mtus(). * - mtus - MTU values. .. rubric:: Returns: Status code. .. index:: pair: function; tapi_set_if_mtu_smart2 .. _doxid-group__te__lib__rpc__misc_1ga8e59bb5b1eb3186d9e6ac7817cd0b239: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_set_if_mtu_smart2(const char* ta, const char* if_name, int mtu, te_saved_mtus* backup) Set new MTU value for a given interface (increasing MTU for the interfaces it is based on if necessary), previously saving MTU of all related interfaces. The same backup argument may be passed to several calls of this function; in that case all changes made by them can be reverted with a single call of :ref:`tapi_set_if_mtu_smart2_rollback() `. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test agent name * - if_name - Network interface name * - mtu - MTU value * - backup - If not ``NULL``, original values of MTU for all affected interfaces will be saved here. .. rubric:: Returns: Status code. .. index:: pair: function; tapi_set_if_mtu_smart2_rollback .. _doxid-group__te__lib__rpc__misc_1ga8ab4e58bbef868426f26ed2238990ba8: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_set_if_mtu_smart2_rollback(te_saved_mtus* backup) Revert changes made by :ref:`tapi_set_if_mtu_smart2() `. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - backup - Where the original MTU values are saved. .. rubric:: Returns: Status code. .. index:: pair: function; tapi_interface_is_vlan .. _doxid-group__te__lib__rpc__misc_1ga16186af8bb1853b91ac56c4313ec65ee: .. ref-code-block:: cpp :class: doxyrest-title-code-block bool tapi_interface_is_vlan(:ref:`rcf_rpc_server`* rpcs, const struct if_nameindex* interface) Check if the interface is VLAN interface. There could be some interfaces like ipvlan, macvlan, bond and etc. over vlan, and this function theoretically should work for such combinations, but it was tested only for macvlan over vlan. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handler * - interface - Interface name .. rubric:: Returns: ``true`` if the interface is grabbed. .. index:: pair: function; tapi_interface_vlan_count .. _doxid-group__te__lib__rpc__misc_1ga74478f7475bfa376a6b53963e939b60a: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_interface_vlan_count(const char* ta, const char* if_name, size_t* num) Compute number of VLAN interfaces on which the interface is based (including the interface itself). This should be the number of VLAN tags in Ethernet frames going via this interface. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test agent name * - if_name - Interface name * - num - Number of VLAN "ancestor" interfaces, including this interface itself if it is VLAN .. rubric:: Returns: Status code. .. index:: pair: function; rpc_release_rpc_ptr .. _doxid-group__te__lib__rpc__misc_1gad8357c8bbc63dfd9a4b9d37ecc6df0d1: .. ref-code-block:: cpp :class: doxyrest-title-code-block void rpc_release_rpc_ptr(:ref:`rcf_rpc_server`* rpcs, rpc_ptr ptr, char* ns_string) Release the RPC pointer with specified namespace without any system call .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle * - ptr - RPC pointer * - ns_string - Namespace as string for ``ptr`` .. index:: pair: function; rpc_remove_dir_with_files .. _doxid-group__te__lib__rpc__misc_1ga55f8846fa61246b74bc5339cac91de38: .. ref-code-block:: cpp :class: doxyrest-title-code-block int rpc_remove_dir_with_files(:ref:`rcf_rpc_server`* rpcs, const char* path) Remove a directory with all files. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server * - path - Path of the directory to be removed .. rubric:: Returns: -1 in the case of failure or 0 on success .. index:: pair: function; rpc_te_file_check_executable .. _doxid-group__te__lib__rpc__misc_1ga443c830aa5eb1aaefac6ed458b85674f: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` rpc_te_file_check_executable(:ref:`rcf_rpc_server`* rpcs, const char* path) Check that the file is executable. If ``path`` doesn't start with ``/`` or ````./ or ````../ then ``path`` is searched in directories from the remote ``PATH``. Otherwise, only the path itself is checked. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - rpcs - RPC server handle * - path - path to the file .. rubric:: Returns: Status code. .. rubric:: See also: :ref:`te_file_check_executable() ` Macros ------ .. index:: pair: define; RPC_PATTERN_GEN .. _doxid-group__te__lib__rpc__misc_1ga23673623ddf7632c21c29b61dd97d97e: .. ref-code-block:: cpp :class: doxyrest-title-code-block #define RPC_PATTERN_GEN Fill buffer with a sequence of concatenated numbers 1, 2, 3, ... using get_nth_elm() function. .. index:: pair: define; RPC_PATTERN_GEN_LCG .. _doxid-group__te__lib__rpc__misc_1ga9e2bdf3a1527673887ba84130d0cd848: .. ref-code-block:: cpp :class: doxyrest-title-code-block #define RPC_PATTERN_GEN_LCG Fills the buffer with a linear congruential sequence and updates **arg** parameter for the next call. Each element is calculated using the formula: X[n] = a \* X[n-1] + c, where *a* and *c* are taken from **arg** parameter: * *a* is **arg->coef2**, * *c* is **arg->coef3** See `https://en.wikipedia.org/wiki/Linear_congruential_generator `__ for details. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - buf - Buffer * - size - Buffer size in bytes * - arg - Pointer to :ref:`tarpc_pat_gen_arg ` structure, where * coef1 is *x0* - starting number in a sequence, * coef2 is *a* - multiplying constant, * coef3 is *c* - additive constant .. rubric:: Returns: 0 on success .. index:: pair: define; TAPI_READ_BUF_SIZE .. _doxid-group__te__lib__rpc__misc_1ga2ff2e09a5346b5666b0b2109b268ccfb: .. ref-code-block:: cpp :class: doxyrest-title-code-block #define TAPI_READ_BUF_SIZE Default read buffer size. .. index:: pair: define; TARPC_PAT_GEN_ARG_FMT .. _doxid-group__te__lib__rpc__misc_1ga50760b781f00a30c216e7ea3641b3b26: .. ref-code-block:: cpp :class: doxyrest-title-code-block #define TARPC_PAT_GEN_ARG_FMT Macro for logging the :ref:`tarpc_pat_gen_arg ` structure members. Using with :ref:`TARPC_PAT_GEN_ARG_VAL `. Example: .. ref-code-block:: cpp tarpc_pat_gen_arg pattern_gen_args = {1,2,3,4}; RING("pattern generator coeffs are "TARPC_PAT_GEN_ARG_FMT, TARPC_PAT_GEN_ARG_VAL(pattern_gen_args)); .. index:: pair: define; TARPC_PAT_GEN_ARG_VAL .. _doxid-group__te__lib__rpc__misc_1gaf036cb137640f3b3e2995989fce0359e: .. ref-code-block:: cpp :class: doxyrest-title-code-block #define TARPC_PAT_GEN_ARG_VAL(_gen_arg) Macro for logging the :ref:`tarpc_pat_gen_arg ` structure members. Using with :ref:`TARPC_PAT_GEN_ARG_FMT `. Example: .. ref-code-block:: cpp tarpc_pat_gen_arg pattern_gen_args = {1,2,3,4}; RING("pattern generator coeffs are "TARPC_PAT_GEN_ARG_FMT, TARPC_PAT_GEN_ARG_VAL(pattern_gen_args));