:orphan: .. index:: pair: group; iSCSI .. _doxid-group__tapi__tad__iscsi: iSCSI ===== .. toctree:: :hidden: enum_iscsi_bit_spec_t.rst enum_tapi_iscsi_change_key_val_type.rst enum_tapi_iscsi_parameter.rst enum_tapi_iscsi_parameter_type.rst Overview ~~~~~~~~ Copyright (C) 2004-2022 OKTET Labs Ltd. :ref:`More...` .. ref-code-block:: cpp :class: doxyrest-overview-code-block // typedefs typedef int :target:`iscsi_target_id`; typedef int :target:`iscsi_cid`; typedef struct iscsi_io_handle_t :target:`iscsi_io_handle_t`; typedef unsigned :target:`iscsi_io_taskid`; // enums enum { :target:`@72::ISCSI_OPCODE_UNDEF` = 0xff, }; enum :ref:`iscsi_bit_spec_t`; enum :ref:`tapi_iscsi_change_key_val_type`; enum :ref:`tapi_iscsi_parameter`; enum :ref:`tapi_iscsi_parameter_type`; // global functions :ref:`te_errno` :ref:`tapi_iscsi_tgt_csap_create`(const char* ta_name, :ref:`iscsi_digest_type` hdr_dig, :ref:`iscsi_digest_type` data_dig, :ref:`csap_handle_t`* csap); :ref:`te_errno` :ref:`tapi_iscsi_ini_csap_create`(const char* ta_name, int sid, :ref:`csap_handle_t` listen_csap, int timeout, :ref:`iscsi_digest_type` hdr_dig, :ref:`iscsi_digest_type` data_dig, :ref:`csap_handle_t`* csap); :ref:`te_errno` :ref:`tapi_iscsi_sock_csap_create`(const char* ta_name, int socket, :ref:`iscsi_digest_type` hdr_dig, :ref:`iscsi_digest_type` data_dig, :ref:`csap_handle_t`* csap); int :ref:`tapi_iscsi_recv_pkt`(const char* ta_name, int sid, :ref:`csap_handle_t` csap, int timeout, :ref:`csap_handle_t` forward_csap, :ref:`iscsi_target_params_t`* params, uint8_t* buffer, size_t* length); int :ref:`tapi_iscsi_start_poll_recv_pkt`(unsigned n_csaps, :ref:`rcf_trpoll_csap`* csaps, int timeout); int :ref:`tapi_iscsi_recv_polled_pkt`(:ref:`rcf_trpoll_csap`* the_csap, :ref:`iscsi_target_params_t`* params, uint8_t* buffer, size_t* length); int :ref:`tapi_iscsi_send_pkt`(const char* ta_name, int sid, :ref:`csap_handle_t` csap, :ref:`iscsi_target_params_t`* params, uint8_t* buffer, size_t length); int :ref:`tapi_iscsi_send_pkt_last`(const char* ta_name, int sid, :ref:`csap_handle_t` csap, uint8_t* buffer, size_t length); int :ref:`tapi_iscsi_forward_all`(const char* ta_name, int session, :ref:`csap_handle_t` csap_rcv, :ref:`csap_handle_t` csap_fwd, unsigned int timeout, unsigned int* forwarded); :ref:`te_errno` :ref:`tapi_iscsi_exchange_until_silent`(const char* ta, int session, :ref:`csap_handle_t` csap_a, :ref:`csap_handle_t` csap_b, unsigned int timeout); :ref:`te_errno` :ref:`tapi_iscsi_exchange_until_pattern`(const char* ta, int session, :ref:`csap_handle_t` csap_a, :ref:`csap_handle_t` csap_b, :ref:`asn_value`* pattern, uint8_t* buffer, size_t* length, unsigned int timeout); :ref:`te_errno` :target:`tapi_iscsi_exchange_until_stop`(const char* ta, int session, :ref:`csap_handle_t` csap_a, :ref:`csap_handle_t` csap_b, unsigned int timeout); :ref:`te_errno` :target:`tapi_iscsi_exchange_stop`(const char* ta, int session, :ref:`csap_handle_t` csap_a, :ref:`csap_handle_t` csap_b); :ref:`te_errno` :ref:`tapi_iscsi_prepare_pattern_unit`(iscsi_bit_spec_t i_bit, uint8_t opcode, iscsi_bit_spec_t f_bit, :ref:`asn_value`** pattern); int :ref:`tapi_iscsi_get_key_num`(:ref:`iscsi_segment_data` segment_data); char* :ref:`tapi_iscsi_get_key_name`(:ref:`iscsi_segment_data` segment_data, int key_index); int :ref:`tapi_iscsi_get_key_index_by_name`(:ref:`iscsi_segment_data` segment_data, char* name); :ref:`iscsi_key_values` :ref:`tapi_iscsi_get_key_values`(:ref:`iscsi_segment_data` segment_data, int key_index); int :ref:`tapi_iscsi_get_key_values_num`(:ref:`iscsi_key_values` values); int :ref:`tapi_iscsi_get_key_value`(:ref:`iscsi_key_values` values, int key_value_index, char** value); int :ref:`tapi_iscsi_add_new_key`(:ref:`iscsi_segment_data` segment_data, char* name, int key_index); :ref:`iscsi_key_values` :ref:`tapi_iscsi_key_values_create`(int num, ...); int :ref:`tapi_iscsi_set_key_values`(:ref:`iscsi_segment_data` segment_data, int key_index, :ref:`iscsi_key_values` values); void :ref:`tapi_iscsi_free_key_values`(:ref:`iscsi_key_values` values); int :ref:`tapi_iscsi_delete_key`(:ref:`iscsi_segment_data` segment_data, int key_index); :ref:`iscsi_segment_data` :ref:`tapi_iscsi_keys_create`(int num, ...); int :ref:`tapi_iscsi_find_key_and_value`(:ref:`iscsi_segment_data` segment_data, const char* key_name, int num, ...); int :ref:`tapi_iscsi_return_key_value`(:ref:`iscsi_segment_data` segment_data, const char* key_name, const char* buf, int buf_len); int :ref:`tapi_iscsi_change_key_values`(:ref:`iscsi_segment_data` segment_data, char* key_name, :ref:`tapi_iscsi_change_key_val_type` change, int num, ...); void :ref:`tapi_iscsi_keys_data_free`(:ref:`iscsi_segment_data`); int :target:`tapi_iscsi_target_set_parameter`(const char* ta, :ref:`tapi_iscsi_parameter` param, const char* value); int :target:`tapi_iscsi_target_customize`(const char* ta, int id, const char* key, const char* value); int :target:`tapi_iscsi_target_customize_intval`(const char* ta, int id, const char* key, int value); int :target:`tapi_iscsi_target_cause_logout`(const char* ta, int id, int timeout); int :target:`tapi_iscsi_target_cause_renegotiate`(const char* ta, int id, int timeout); int :target:`tapi_iscsi_target_will_drop`(const char* ta, int id, bool drop_all, int time2wait, int time2retain); int :target:`tapi_iscsi_target_set_failure_state`(const char* ta, int id, const char* status, const char* sense, const char* add_code); int :ref:`tapi_iscsi_initiator_advertize_set`(const char* ta, iscsi_target_id target_id, iscsi_cid cid, :ref:`tapi_iscsi_parameter` param, bool advertize); int :ref:`tapi_iscsi_initiator_set_parameter`(const char* ta, iscsi_target_id target_id, iscsi_cid cid, :ref:`tapi_iscsi_parameter` param, const char* value, bool advertize); iscsi_target_id :ref:`tapi_iscsi_initiator_add_target`(const char* ta, const struct sockaddr* target_addr); int :ref:`tapi_iscsi_initiator_del_target`(const char* ta, iscsi_target_id tgt_id); iscsi_cid :ref:`tapi_iscsi_initiator_conn_add`(const char* ta, iscsi_target_id tgt_id); iscsi_cid :ref:`tapi_iscsi_initiator_conn_establish`(const char* ta, iscsi_target_id tgt_id, iscsi_cid cid); int :ref:`tapi_iscsi_initiator_conn_del`(const char* ta, iscsi_target_id tgt_id, iscsi_cid cid); int :ref:`tapi_iscsi_initiator_conn_down`(const char* ta, iscsi_target_id tgt_id, iscsi_cid cid); :ref:`tapi_iscsi_parameter` :ref:`tapi_iscsi_get_param_map`(const char* param); int :ref:`tapi_iscsi_find_key_values`(:ref:`iscsi_segment_data` segment_data, const char* key_name, :ref:`iscsi_key_values`* key_array); int :ref:`tapi_iscsi_key_value_read`(:ref:`iscsi_key_values` val_array, int val_index, char* buf, size_t* buf_len); int :ref:`tapi_iscsi_key_value_write`(:ref:`iscsi_key_values` val_array, int val_index, const char* string); static int :ref:`tapi_iscsi_set_local_secret`(const char* ta, const char* secret); static int :target:`tapi_iscsi_set_local_name`(const char* ta, const char* name); static int :target:`tapi_iscsi_set_peer_secret`(const char* ta, const char* secret); static int :target:`tapi_iscsi_set_peer_name`(const char* ta, const char* name); static int :target:`tapi_iscsi_set_challenge_length`(const char* ta, int len); static int :target:`tapi_iscsi_set_encoding_format`(const char* ta, int fmt); static int :target:`tapi_iscsi_set_tgt_auth_req`(const char* ta, int tgt_auth); static int :target:`tapi_iscsi_set_security_negotiations_phase`(const char* ta, int use); :ref:`iscsi_digest_type` :target:`iscsi_digest_str2enum`(const char* digest_type); char* :target:`iscsi_digest_enum2str`(:ref:`iscsi_digest_type` digest_type); int :target:`tapi_iscsi_target_inform_new_test`(const char* ta); :ref:`te_errno` :ref:`tapi_iscsi_target_mount`(const char* ta); :ref:`te_errno` :ref:`tapi_iscsi_target_unmount`(const char* ta); :ref:`te_errno` :ref:`tapi_iscsi_target_file_write`(const char* ta, const char* fname, const void* data, size_t length, size_t multiply); :ref:`te_errno` :ref:`tapi_iscsi_target_file_read`(const char* ta, const char* fname, void* data, size_t length); :ref:`te_errno` :ref:`tapi_iscsi_target_raw_write`(const char* ta, off_t offset, const void* data, size_t length, size_t multiply); :ref:`te_errno` :ref:`tapi_iscsi_target_raw_read`(const char* ta, off_t offset, void* data, size_t length); :ref:`te_errno` :ref:`tapi_iscsi_io_prepare`(const char* ta, iscsi_target_id id, bool use_signal, bool use_fs, size_t bufsize, iscsi_io_handle_t** ioh); :ref:`te_errno` :ref:`tapi_iscsi_io_reset`(iscsi_io_handle_t* ioh); :ref:`te_errno` :ref:`tapi_iscsi_io_finish`(iscsi_io_handle_t* ioh); bool :ref:`tapi_iscsi_io_enable_signal`(iscsi_io_handle_t* ioh, bool enable); :ref:`te_errno` :ref:`tapi_iscsi_io_get_status`(iscsi_io_handle_t* ioh, iscsi_io_taskid taskid); bool :ref:`tapi_iscsi_io_is_complete`(iscsi_io_handle_t* ioh, iscsi_io_taskid taskid); bool :ref:`tapi_iscsi_initiator_is_device_ready`(const char* ta, iscsi_target_id id); :ref:`te_errno` :ref:`tapi_iscsi_initiator_mount`(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid); :ref:`te_errno` :ref:`tapi_iscsi_initiator_unmount`(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid); :ref:`te_errno` :ref:`tapi_iscsi_initiator_open`(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid, const char* fname, int mode); :ref:`te_errno` :ref:`tapi_iscsi_initiator_close`(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid); :ref:`te_errno` :ref:`tapi_iscsi_initiator_noop`(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid); :ref:`te_errno` :ref:`tapi_iscsi_initiator_fsync`(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid); :ref:`te_errno` :ref:`tapi_iscsi_initiator_seek`(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid, off_t pos); :ref:`te_errno` :ref:`tapi_iscsi_initiator_write`(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid, void* data, size_t length); :ref:`te_errno` :ref:`tapi_iscsi_initiator_read`(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid, void* data, size_t length); :ref:`te_errno` :ref:`tapi_iscsi_initiator_write_file`(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid, const char* fname); :ref:`te_errno` :ref:`tapi_iscsi_initiator_read_file`(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid, const char* fname); // macros #define :ref:`ISCSI_INITIATOR_SET_ADVERTIZE`(_ta_, _target_id_, _cid_, _param_name_, _value_) #define :ref:`ISCSI_INITIATOR_SET_NOT_ADVERTIZE`(_ta_, _target_id_, _cid_, _param_name_, _value_) #define :target:`ISCSI_IO_SIGNAL` #define :target:`ISCSI_TARGET_SET_PARAM`(ta_, param_id_, value_) #define :target:`ISCSI_TARGET_SET_PARAM_BY_NAME`(_ta_, _param_name_, _value_) #define :target:`PDU_CONTAINS_KEY`(segment_data_, key_name_) #define :target:`PDU_CONTAINS_KEY_VALUE_PAIR`(segment_data_, key_name_, key_value_) #define :target:`TAPI_ISCSI_KEY_INVALID` .. _details-group__tapi__tad__iscsi: Detailed Documentation ~~~~~~~~~~~~~~~~~~~~~~ Copyright (C) 2004-2022 OKTET Labs Ltd. All rights reserved. Global Functions ---------------- .. index:: pair: function; tapi_iscsi_tgt_csap_create .. _doxid-group__tapi__tad__iscsi_1ga6937aac814809c8421f862107aea1c2e: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_tgt_csap_create(const char* ta_name, :ref:`iscsi_digest_type` hdr_dig, :ref:`iscsi_digest_type` data_dig, :ref:`csap_handle_t`* csap) Create 'iscsi' target CSAP. Run iSCSI UNH Target Rx thread and create a socket pair to communicate with it. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta_name - Test Agent name * - hdr_dig - Header digests used by iSCSI protocol * - data_dig - Data digests used by iSCSI protocol * - csap - Location for handle of new CSAP .. rubric:: Returns: Status code of the operation. .. index:: pair: function; tapi_iscsi_ini_csap_create .. _doxid-group__tapi__tad__iscsi_1gab77db892e0f3d1b588928ef1922d871c: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_ini_csap_create(const char* ta_name, int sid, :ref:`csap_handle_t` listen_csap, int timeout, :ref:`iscsi_digest_type` hdr_dig, :ref:`iscsi_digest_type` data_dig, :ref:`csap_handle_t`* csap) Create 'iscsi' initiator CSAP. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta_name - Test Agent name * - sid - RCF SID to be used to wait connection on *listen_csap* * - listen_csap - TCP listening CSAP, on which TCP connection from the Initiator sould be received * - timeout - Timeout to wait connection * - hdr_dig - Header digests used by iSCSI protocol * - data_dig - Data digests used by iSCSI protocol * - csap - Location for handle of new CSAP .. rubric:: Returns: Status code of the operation. .. index:: pair: function; tapi_iscsi_sock_csap_create .. _doxid-group__tapi__tad__iscsi_1ga857ed7290fdb64e75905baede184087c: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_sock_csap_create(const char* ta_name, int socket, :ref:`iscsi_digest_type` hdr_dig, :ref:`iscsi_digest_type` data_dig, :ref:`csap_handle_t`* csap) Create 'iscsi' CSAP over connected TCP socket on TA. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta_name - Test Agent name * - socket - File descriptor of TCP socket on TA * - hdr_dig - Header digests used by iSCSI protocol * - data_dig - Data digests used by iSCSI protocol * - csap - Location for handle of new CSAP .. rubric:: Returns: Status code of the operation. .. index:: pair: function; tapi_iscsi_recv_pkt .. _doxid-group__tapi__tad__iscsi_1ga674012d63c359ba445bbc20a5a5206e2: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_recv_pkt(const char* ta_name, int sid, :ref:`csap_handle_t` csap, int timeout, :ref:`csap_handle_t` forward_csap, :ref:`iscsi_target_params_t`* params, uint8_t* buffer, size_t* length) Receive one message via iSCSI CSAP. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta_name - Test Agent name * - sid - RCF SID * - csap - Identifier of CSAP * - timeout - Timeout of operation in milliseconds * - forward_csap - Identifier of CSAP, to which received data should be forwarded, may be CSAP_INVALID_HANDLE * - params - Location for iSCSI current params (OUT) * - buffer - Location for received data (OUT) * - length - Length of buffer / received data (IN/OUT) .. rubric:: Returns: Zero on success or error code. .. index:: pair: function; tapi_iscsi_start_poll_recv_pkt .. _doxid-group__tapi__tad__iscsi_1gaefc06ceacf852ac71b3b50aaabf29ad1: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_start_poll_recv_pkt(unsigned n_csaps, :ref:`rcf_trpoll_csap`* csaps, int timeout) Prepare for receive a message on one of several CSAPS .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - n_csaps - Number of CSAPs to poll * - csaps - CSAP poll structures * - timeout - Timeout of a receive in milliseconds .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_recv_polled_pkt .. _doxid-group__tapi__tad__iscsi_1gaf36aaef24af6069039b45c7de9df9dfb: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_recv_polled_pkt(:ref:`rcf_trpoll_csap`* the_csap, :ref:`iscsi_target_params_t`* params, uint8_t* buffer, size_t* length) Wait for a message on one of several CSAPs .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - n_csaps - Number of CSAPs to poll * - csaps - CSAP poll structures * - timeout - Timeout of a receive in milliseconds * - params - Location for iSCSI current params (OUT) * - ready_index - An index in ``csaps`` of a CSAP on which a message has been get, or (-1) in case of a timeout on all CSAPs. * - buffer - Location for received data (OUT) * - length - Length of buffer / received data (IN/OUT) .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_send_pkt .. _doxid-group__tapi__tad__iscsi_1gacd653d91c57d5f0ae4e0c0c55c010169: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_send_pkt(const char* ta_name, int sid, :ref:`csap_handle_t` csap, :ref:`iscsi_target_params_t`* params, uint8_t* buffer, size_t length) Send one message via iSCSI CSAP. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta_name - test Agent name * - sid - RCF SID * - csap - identifier of CSAP * - params - iSCSI new params * - buffer - data to be sent * - length - length of buffer .. rubric:: Returns: Zero on success or error code. .. index:: pair: function; tapi_iscsi_send_pkt_last .. _doxid-group__tapi__tad__iscsi_1gad6d8105f16246775d02cbb196f68fab1: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_send_pkt_last(const char* ta_name, int sid, :ref:`csap_handle_t` csap, uint8_t* buffer, size_t length) Send LAST message via iSCSI CSAP, and try to ensure sending FIN in the last TCP push. Note: use only with network TCP connection, not AF_LOCAL. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta_name - test Agent name * - sid - RCF SID * - csap - identifier of CSAP * - buffer - data to be sent * - length - length of buffer .. rubric:: Returns: Zero on success or error code. .. index:: pair: function; tapi_iscsi_forward_all .. _doxid-group__tapi__tad__iscsi_1ga35752c523f643b212cfe22a0338fc39f: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_forward_all(const char* ta_name, int session, :ref:`csap_handle_t` csap_rcv, :ref:`csap_handle_t` csap_fwd, unsigned int timeout, unsigned int* forwarded) Receive all data which currently are waiting for receive in specified iSCSI CSAP and forward them into another CSAP, without passing via RCF to test. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - TA name * - sid - RCF session id * - csap_rcv - identifier of receive CSAP * - csap_fwd - identifier of CSAP which should obtain data * - timeout - timeout to wait data, in milliseconds * - forwarded - number of forwarded PDUs (OUT) .. rubric:: Returns: status code .. index:: pair: function; tapi_iscsi_exchange_until_silent .. _doxid-group__tapi__tad__iscsi_1ga2efd2320f933af6d79113a8c49726ba7: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_exchange_until_silent(const char* ta, int session, :ref:`csap_handle_t` csap_a, :ref:`csap_handle_t` csap_b, unsigned int timeout) Pass all iSCSI PDUs from one iSCSI CSAP to another and reverse, until in both directions silence will be established during specified timeout. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - TA name * - sid - RCF session id * - csap_a - identifier of one side CSAP * - csap_b - identifier of another side CSAP * - timeout - timeout to wait data, in milliseconds .. rubric:: Returns: status code .. index:: pair: function; tapi_iscsi_exchange_until_pattern .. _doxid-group__tapi__tad__iscsi_1ga0e33cfec35571f1e9422308b281c201f: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_exchange_until_pattern(const char* ta, int session, :ref:`csap_handle_t` csap_a, :ref:`csap_handle_t` csap_b, :ref:`asn_value`* pattern, uint8_t* buffer, size_t* length, unsigned int timeout) Pass all iSCSI PDUs from one iSCSI CSAP to another and reverse, until packet, matching to specified pattern, will be catched on csap_a. This packet will be passed to the test, if 'buffer' is not NULL. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - TA name. * - sid - RCF session id. * - csap_a - Identifier of one side CSAP. * - csap_b - Identifier of another side CSAP. * - pattern - ASN value with PatternUnit NDS. * - buffer - Location for received data (OUT). * - length - Length of buffer / received data (IN/OUT). * - timeout - Timeout to wait data, in milliseconds. .. rubric:: Returns: status code .. index:: pair: function; tapi_iscsi_prepare_pattern_unit .. _doxid-group__tapi__tad__iscsi_1ga015c53b9c3dd0d19bd88cfb97b766f61: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_prepare_pattern_unit(iscsi_bit_spec_t i_bit, uint8_t opcode, iscsi_bit_spec_t f_bit, :ref:`asn_value`** pattern) Prepare pattern_unit with iSCSI PDU. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - i_bit - Pattern for i-bit field. * - opcode - Pattern for opcode field, while opcode has only 6 bits, value 0xff used for mark unset. * - f_bit - Pattern for i-bit field. * - pattern - location for ASN value prepared (OUT). .. rubric:: Returns: status code .. index:: pair: function; tapi_iscsi_get_key_num .. _doxid-group__tapi__tad__iscsi_1ga93d67ce51aa59c23c75e9307980e2422: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_get_key_num(:ref:`iscsi_segment_data` segment_data) Get number of keys in iSCSI PDU Segment Data. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - segment_data - iSCSI PDU Segment Data in asn format .. rubric:: Returns: number of keys ot -1 if error occurred. .. index:: pair: function; tapi_iscsi_get_key_name .. _doxid-group__tapi__tad__iscsi_1ga23e615f13aa3fa5fd553f7de9377d669: .. ref-code-block:: cpp :class: doxyrest-title-code-block char* tapi_iscsi_get_key_name(:ref:`iscsi_segment_data` segment_data, int key_index) Get key name from iSCSI PDU Segment Data. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - segment_data - iSCSI PDU Segment Data in asn format * - key_index - key index in iSCSI PDU Segment Data .. rubric:: Returns: key name or NULL if error occurred. .. index:: pair: function; tapi_iscsi_get_key_index_by_name .. _doxid-group__tapi__tad__iscsi_1gaa9597d20129eab3dde60057395d104f6: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_get_key_index_by_name(:ref:`iscsi_segment_data` segment_data, char* name) Get key index in iSCSI PDU Segment Data by key name. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - segment_data - iSCSI PDU Segment Data in asn format * - name - key name .. rubric:: Returns: key index or TAPI_ISCSI_KEY_INVALID if error occurred. .. index:: pair: function; tapi_iscsi_get_key_values .. _doxid-group__tapi__tad__iscsi_1ga453b1804f082cfcaba8e64d2972d6aaa: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`iscsi_key_values` tapi_iscsi_get_key_values(:ref:`iscsi_segment_data` segment_data, int key_index) Get values of key from iSCSI PDU Segment Data. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - segment_data - iSCSI PDU Segment Data in asn format * - key_index - key index .. rubric:: Returns: key values in asn format or NULL if error occurred. .. index:: pair: function; tapi_iscsi_get_key_values_num .. _doxid-group__tapi__tad__iscsi_1ga130531e87af4864eead3c2e8d150adad: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_get_key_values_num(:ref:`iscsi_key_values` values) Get number of key values. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - values - key values in asn format .. rubric:: Returns: number of values or -1 if error occurred. .. index:: pair: function; tapi_iscsi_get_key_value .. _doxid-group__tapi__tad__iscsi_1gaf0fd72e779e280c1d65fbce4016f4eb0: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_get_key_value(:ref:`iscsi_key_values` values, int key_value_index, char** value) Get key value from list of values. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - values - key values list in asn format * - key_value_index - value index in the list * - value - location for value (OUT) .. rubric:: Returns: 0 or error code .. index:: pair: function; tapi_iscsi_add_new_key .. _doxid-group__tapi__tad__iscsi_1gaa9bd8a63a51388dbfbdcd572b66cdef2: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_add_new_key(:ref:`iscsi_segment_data` segment_data, char* name, int key_index) Add a new key into an iSCSI PDU Segment Data. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - segment_data - iSCSI PDU Segment Data in asn format * - name - key name * - key_index - index of key in iSCSI PDU Segment Data, if key_index is TAPI_ISCSI_KEY_INVALID then key is to be inserted to the end of key list .. rubric:: Returns: key index or -1 if error occurred. .. index:: pair: function; tapi_iscsi_key_values_create .. _doxid-group__tapi__tad__iscsi_1ga31686b6cadb3295d1ed6591d8b413c20: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`iscsi_key_values` tapi_iscsi_key_values_create(int num, ...) Create list of key values in asn format .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - num - number of values * - ... - list of pairs (type, value), where type is iscsi_key_value_type_xxx, and value is an appropriate type value .. rubric:: Returns: list of values or NULL if error occurred. .. index:: pair: function; tapi_iscsi_set_key_values .. _doxid-group__tapi__tad__iscsi_1gac4914f6d76efe39858bbb918ca38c6d5: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_set_key_values(:ref:`iscsi_segment_data` segment_data, int key_index, :ref:`iscsi_key_values` values) Assign a list of values to a key in iSCSI PDU Segment Data .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - segment_data - iSCSI PDU Segment Data in asn format * - key_index - key index * - values - list of key values in asn format .. rubric:: Returns: 0 or error code. .. index:: pair: function; tapi_iscsi_free_key_values .. _doxid-group__tapi__tad__iscsi_1gaa32e060887a2a13164f1c8c28a6b495a: .. ref-code-block:: cpp :class: doxyrest-title-code-block void tapi_iscsi_free_key_values(:ref:`iscsi_key_values` values) Free list of key values .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - values - list of key values. .. index:: pair: function; tapi_iscsi_delete_key .. _doxid-group__tapi__tad__iscsi_1ga98f3bf6a12f378d5f0d86c142cd5ea23: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_delete_key(:ref:`iscsi_segment_data` segment_data, int key_index) Delete a key from iSCSI PDU Segment Data in asn format .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - segment_data - iSCSI PDU Segment Data in asn format * - key_index - key index .. rubric:: Returns: 0 or error code. .. index:: pair: function; tapi_iscsi_keys_create .. _doxid-group__tapi__tad__iscsi_1gab0df8db675750047cc4a9595135165e7: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`iscsi_segment_data` tapi_iscsi_keys_create(int num, ...) Create an iSCSI PDU Segment Data in asn format. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - num - number of keys in iSCSI PDU Segment Data * - ... - list of keys names .. rubric:: Returns: iSCSI PDU Segment Data in asn format or NULL if error occurred .. index:: pair: function; tapi_iscsi_find_key_and_value .. _doxid-group__tapi__tad__iscsi_1gafbd51c050558fafd6cb73c16cdef580f: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_find_key_and_value(:ref:`iscsi_segment_data` segment_data, const char* key_name, int num, ...) Check that iSCSI PDU SEgment Data contains a key with a given name and its list of values contains list of values followed by num .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - segment_data - iSCSI PDU Segment Data in asn format * - key_name - Key name * - num - number of key values to be checked * - ... - List of key values, they should be contained in key values list .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_return_key_value .. _doxid-group__tapi__tad__iscsi_1gac519984e66e2d552c9e609d771cae39f: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_return_key_value(:ref:`iscsi_segment_data` segment_data, const char* key_name, const char* buf, int buf_len) Find the key and return its value .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - segment_data - iSCSI PDU Segment Data in asn format * - key_name - the name of key (according to RFC3720) * - buf - Location to return values of the key * - buf_len - The length of the buf .. rubric:: Returns: 0 or error code. .. index:: pair: function; tapi_iscsi_change_key_values .. _doxid-group__tapi__tad__iscsi_1ga667eb3e8b72c5b721e1b2d621b069e3c: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_change_key_values(:ref:`iscsi_segment_data` segment_data, char* key_name, :ref:`tapi_iscsi_change_key_val_type` change, int num, ...) Change key values list according action given (See comments to tapi_iscsi_change_key_val_type) .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - segment_data - iSCSI PDU Segment Data in asn format * - key_name - Key name * - change - Action to take on key values list * - num - Number of given key values * - ... - List of key values .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_keys_data_free .. _doxid-group__tapi__tad__iscsi_1ga09ce1355227cce9b8e81fd625eb82ded: .. ref-code-block:: cpp :class: doxyrest-title-code-block void tapi_iscsi_keys_data_free(:ref:`iscsi_segment_data`) Free an iSCSI PDU Segment Data. .. index:: pair: function; tapi_iscsi_initiator_advertize_set .. _doxid-group__tapi__tad__iscsi_1ga0c97df3517dd5ec721c8461c3328ad0d: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_initiator_advertize_set(const char* ta, iscsi_target_id target_id, iscsi_cid cid, :ref:`tapi_iscsi_parameter` param, bool advertize) Function configures parameter not to be advertized. By default the parameter is not advertized. When "SET" operation is called on it the Initiator is told to advertize the parameter. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Name of the TA on which the Initiator is configured * - target_id - ID of the Taraget * - param - Parameter to configure .. index:: pair: function; tapi_iscsi_initiator_set_parameter .. _doxid-group__tapi__tad__iscsi_1gaeb9464e887b5bfc1d69943bd61e41e69: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_initiator_set_parameter(const char* ta, iscsi_target_id target_id, iscsi_cid cid, :ref:`tapi_iscsi_parameter` param, const char* value, bool advertize) Function configures parameters of the Initiator. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Name of the TA on which the Initiator is configured * - target_id - ID of the target * - param - Parameter to configure * - value - New value added .. rubric:: Returns: return of the cfg_set_instance_fmt .. index:: pair: function; tapi_iscsi_initiator_add_target .. _doxid-group__tapi__tad__iscsi_1ga19eb27276f0e069b0bb60769828f3328: .. ref-code-block:: cpp :class: doxyrest-title-code-block iscsi_target_id tapi_iscsi_initiator_add_target(const char* ta, const struct sockaddr* target_addr) Function adds target to the Initiator targets list. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Name of the TA on which the Initiator is configured * - target_addr - Address of the target .. rubric:: Returns: id of the target or -errno .. index:: pair: function; tapi_iscsi_initiator_del_target .. _doxid-group__tapi__tad__iscsi_1ga4be17b13e392ffe601118224183ad57e: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_initiator_del_target(const char* ta, iscsi_target_id tgt_id) Function adds target to the Initiator targets list. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Name of the TA on which the Initiator is configured * - tgt_id - ID of the target to destroy .. rubric:: Returns: id of the target or -errno .. index:: pair: function; tapi_iscsi_initiator_conn_add .. _doxid-group__tapi__tad__iscsi_1ga01cd8ec47a1e73fc2bfab9737af5908b: .. ref-code-block:: cpp :class: doxyrest-title-code-block iscsi_cid tapi_iscsi_initiator_conn_add(const char* ta, iscsi_target_id tgt_id) Function adds the connection. It should be called before the connection can be configured. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Name of the TA on which the Initiator is placed * - tgt_id - Id of the Target to establish connection with .. rubric:: Returns: CID of the newly created connection .. index:: pair: function; tapi_iscsi_initiator_conn_establish .. _doxid-group__tapi__tad__iscsi_1ga49d1c9d21882b20b8aa51aa301a80fa5: .. ref-code-block:: cpp :class: doxyrest-title-code-block iscsi_cid tapi_iscsi_initiator_conn_establish(const char* ta, iscsi_target_id tgt_id, iscsi_cid cid) Function tries to establish the connection with the given cid between the target and the initiator. Before calling this function the :ref:`tapi_iscsi_initiator_conn_add() ` function should be called. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Name of the TA on which the Initiator is placed * - tgt_id - Id of the Target to establish connection with * - cid - ID of the connection to establish .. rubric:: Returns: CID of the newly created connection .. index:: pair: function; tapi_iscsi_initiator_conn_del .. _doxid-group__tapi__tad__iscsi_1ga6d478e55ba78770b216ec2cf14429ecf: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_initiator_conn_del(const char* ta, iscsi_target_id tgt_id, iscsi_cid cid) Function tries to delete connection from the Initiator. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Name of the TA on which the Initiator is placed * - tgt_id - Id of the Target the connection with which should be deleted * - cid - ID of the connection to delete .. rubric:: Returns: errno .. index:: pair: function; tapi_iscsi_initiator_conn_down .. _doxid-group__tapi__tad__iscsi_1gaa6553f10fcc775db486e3f7781aa197a: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_initiator_conn_down(const char* ta, iscsi_target_id tgt_id, iscsi_cid cid) Function stops the connection with the given cid between the initiator and the target. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Name of the TA on which the Initiator is placed * - tgt_id - Id of the Target the connection with which should be deleted * - cid - ID of the connection to delete .. rubric:: Returns: errno .. index:: pair: function; tapi_iscsi_get_param_map .. _doxid-group__tapi__tad__iscsi_1ga5360379021291922b4f6b8e46de48bb9: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`tapi_iscsi_parameter` tapi_iscsi_get_param_map(const char* param) Function converts string representation of iSCSI parameter to corresponding enum value of tapi_iscsi_parameter type. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - param - Name of the TA on which the Initiator is placed .. rubric:: Returns: iSCSI parameter index or -1, if fails .. index:: pair: function; tapi_iscsi_find_key_values .. _doxid-group__tapi__tad__iscsi_1ga2c512b256f6eece15db52873549e3150: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_find_key_values(:ref:`iscsi_segment_data` segment_data, const char* key_name, :ref:`iscsi_key_values`* key_array) Find specified key name in segment data and determine number of key values for its name. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - segment_data - iSCSI PDU Segment Data in asn format * - key_name - the name of key (according to RFC3720) * - key_array - location for pointer to found ASN value to key values array (OUT) .. rubric:: Returns: number of key values for passed key name, zero if none, or -1 if error encountered. .. index:: pair: function; tapi_iscsi_key_value_read .. _doxid-group__tapi__tad__iscsi_1ga4660a8d327250b3f8dc725d183552323: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_key_value_read(:ref:`iscsi_key_values` val_array, int val_index, char* buf, size_t* buf_len) Read key value by index of value in array. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - val_array - array with values for some key, ASN Value * - val_index - index of key value to be read * - buf - location for key value (OUT) * - buf_len - length of buffer/read data (IN/OUT) .. rubric:: Returns: status of operation .. index:: pair: function; tapi_iscsi_key_value_write .. _doxid-group__tapi__tad__iscsi_1ga34c8633cc8d6f18332586cb8ae2e1374: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_iscsi_key_value_write(:ref:`iscsi_key_values` val_array, int val_index, const char* string) Write key value by index of value in array. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - val_array - array with values for some key, ASN Value * - val_index - index of key value to be read * - string - new string key value, NULL for remove .. rubric:: Returns: status of operation .. index:: pair: function; tapi_iscsi_set_local_secret .. _doxid-group__tapi__tad__iscsi_1ga7eebbc51a3bcfbc0e57663459b46b828: .. ref-code-block:: cpp :class: doxyrest-title-code-block static int tapi_iscsi_set_local_secret(const char* ta, const char* secret) The following functions are DEPRECATED!!! They will be removed as soon as all the tests use the new API .. index:: pair: function; tapi_iscsi_target_mount .. _doxid-group__tapi__tad__iscsi_1gaabbaf272ee356dbf55abb3535f20a997: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_target_mount(const char* ta) Mount a target backing store. Note: this will work only if the target is using a file-based backing store. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_target_unmount .. _doxid-group__tapi__tad__iscsi_1gaf5c75e606b0cf65c8750cd1a8d2ffb26: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_target_unmount(const char* ta) Unmount a target backing store. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_target_file_write .. _doxid-group__tapi__tad__iscsi_1ga40cf33e8e4c4e55b654aae3fdd154312: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_target_file_write(const char* ta, const char* fname, const void* data, size_t length, size_t multiply) Write data to a target's backing store filesystem to a file with a given name. Note: This function should be called only after :ref:`tapi_iscsi_target_mount() `. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name * - fname - A filename to write * - data - Buffer to write * - length - Length of data to write * - multiply - Write the buffer that many times .. rubric:: Returns: Status code .. rubric:: See also: tapi_iscsi_initiator_raw_read .. index:: pair: function; tapi_iscsi_target_file_read .. _doxid-group__tapi__tad__iscsi_1ga5fd88c87e7ffe96b37ff1d2f807b5193: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_target_file_read(const char* ta, const char* fname, void* data, size_t length) Read data from a target's backing store filesystem from a file with a given name. Note: This function should be called only after :ref:`tapi_iscsi_target_mount() `. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name * - fname - A filename to read from * - data - Buffer to store data * - length - Length of buffer .. rubric:: Returns: Status code .. rubric:: See also: tapi_iscsi_initiator_raw_read .. index:: pair: function; tapi_iscsi_target_raw_write .. _doxid-group__tapi__tad__iscsi_1ga0071a967304696cc6ddbe82a4728cac0: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_target_raw_write(const char* ta, off_t offset, const void* data, size_t length, size_t multiply) Write raw data to a target's backing store. Note: This function is NOT to be used in conjunction with :ref:`tapi_iscsi_target_mount() `. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name * - offset - A position to write * - data - Buffer to write * - length - Length of data to write * - multiply - Write the buffer that many times .. rubric:: Returns: Status code .. rubric:: See also: tapi_iscsi_initiator_raw_read .. index:: pair: function; tapi_iscsi_target_raw_read .. _doxid-group__tapi__tad__iscsi_1ga436182ce43f9a658de889483c2d77e99: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_target_raw_read(const char* ta, off_t offset, void* data, size_t length) Reads data from a target's device at a given position Note: This function is NOT to be used in conjunction with :ref:`tapi_iscsi_target_mount() `. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name * - offset - A position to read from * - data - Buffer to store data * - length - Length of data .. rubric:: Returns: Status code .. rubric:: See also: tapi_iscsi_initiator_raw_write .. index:: pair: function; tapi_iscsi_io_prepare .. _doxid-group__tapi__tad__iscsi_1ga568df613eacbc2bc2bac78206cb6a806: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_io_prepare(const char* ta, iscsi_target_id id, bool use_signal, bool use_fs, size_t bufsize, iscsi_io_handle_t** ioh) Create a new asynchronous I/O handler .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name * - id - target id to connect * - use_signal - Should a signal be sent after an I/O operation is complete * - use_fs - ``true`` if using a filesystem on an ISCSI device * - bufsize - Buffer size for file copying operations, that is, :ref:`tapi_iscsi_initiator_read_file() ` and :ref:`tapi_iscsi_initiator_write_file() `. * - ioh - A pointer to resulting handler (OUT) .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_io_reset .. _doxid-group__tapi__tad__iscsi_1ga5b34dc1af57f6b2ba6be02ed93627d90: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_io_reset(iscsi_io_handle_t* ioh) Resets the I/O handler task queue .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ioh - I/O handler * - TE_EINPROGRESS - There are incomplete tasks pending .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_io_finish .. _doxid-group__tapi__tad__iscsi_1gaffe1acdcc1302ec82ac1bf36d5015150: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_io_finish(iscsi_io_handle_t* ioh) Destroy an asynchronous I/O handler .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ioh - I/O handler .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_io_enable_signal .. _doxid-group__tapi__tad__iscsi_1ga870e9d4d60f8f0032be5c8e1831e081f: .. ref-code-block:: cpp :class: doxyrest-title-code-block bool tapi_iscsi_io_enable_signal(iscsi_io_handle_t* ioh, bool enable) .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ioh - I/O handler * - enable - .. rubric:: Returns: Previous state .. index:: pair: function; tapi_iscsi_io_get_status .. _doxid-group__tapi__tad__iscsi_1gaf1ea44da1b46dde68a07e49c6445f7f7: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_io_get_status(iscsi_io_handle_t* ioh, iscsi_io_taskid taskid) Gets the status code of a task of a I/O handler .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ioh - I/O handle * - taskid - Task ID * - TE_EINPROGRESS - if the task has not completed .. rubric:: Returns: Status code of a given task .. index:: pair: function; tapi_iscsi_io_is_complete .. _doxid-group__tapi__tad__iscsi_1gac78953bb3fe7eae8a124a449b900749b: .. ref-code-block:: cpp :class: doxyrest-title-code-block bool tapi_iscsi_io_is_complete(iscsi_io_handle_t* ioh, iscsi_io_taskid taskid) Checks whether a task has completed .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ioh - I/O handle * - taskid - Task ID .. rubric:: Returns: ``true`` if the task has completed .. index:: pair: function; tapi_iscsi_initiator_is_device_ready .. _doxid-group__tapi__tad__iscsi_1ga25743dc4e22242fe396e6cfa056eab04: .. ref-code-block:: cpp :class: doxyrest-title-code-block bool tapi_iscsi_initiator_is_device_ready(const char* ta, iscsi_target_id id) Checks whether an iSCSI device is present and ready .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent * - id - Target id .. rubric:: Returns: ``true`` if the device is ready .. index:: pair: function; tapi_iscsi_initiator_mount .. _doxid-group__tapi__tad__iscsi_1ga995ae86eb0cf2f6f6fc25bc1383f434b: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_initiator_mount(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid) Request mounting an iSCSI device on the TA, if the I/O handler has been created with "use_fs" == ``true``. Otherwise a no-op. Note: you need to call :ref:`tapi_iscsi_target_mount() ` before this function to create a filesystem on a target backing store. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ioh - I/O handler * - taskid - A pointer to store a task ID or NULL (OUT) .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_initiator_unmount .. _doxid-group__tapi__tad__iscsi_1ga996c7b4ba4fb725d17b8d8ee2c87c993: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_initiator_unmount(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid) Request unmounting an iSCSI device on the TA. No-op if "use_fs" is not ``true`` for the I/O handler. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ioh - I/O handler * - taskid - A pointer to store a task ID or NULL (OUT) .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_initiator_open .. _doxid-group__tapi__tad__iscsi_1gab96971d3c8055b649f3369a0ca686947: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_initiator_open(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid, const char* fname, int mode) Opens a file on an iSCSI filesystem .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ioh - I/O handler * - taskid - A pointer to store a task ID or NULL (OUT) * - fname - Filename * - mode - Standard UNIX file open mode .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_initiator_close .. _doxid-group__tapi__tad__iscsi_1gaa6c2ee560e8a2571b196a8f7f9ff3da0: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_initiator_close(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid) Closes a file on an iSCSI filesystem previously opened by :ref:`tapi_iscsi_initiator_open() `. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ioh - I/O handler * - taskid - A pointer to store a task ID or NULL (OUT) .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_initiator_noop .. _doxid-group__tapi__tad__iscsi_1ga016af2e5d08391801238565f4d61bf28: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_initiator_noop(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid) Does nothing. Its sole purpose is to providc a task to wait for that never fails (useful when testing for a I/O failure). .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ioh - I/O handler * - taskid - A pointer to store a task ID or NULL (OUT) .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_initiator_fsync .. _doxid-group__tapi__tad__iscsi_1gae503e4b8544fd16669ca98c65a45cc08: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_initiator_fsync(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid) Syncs the written data of an iSCSI-mounted filesystem file or a SCSI block device. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ioh - I/O handler * - taskid - A pointer to store a task ID or NULL (OUT) .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_initiator_seek .. _doxid-group__tapi__tad__iscsi_1gaed544e5881c4af2cdd114fe80fc15877: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_initiator_seek(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid, off_t pos) Request a seek operation on an iSCSI device. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ioh - I/O handler * - taskid - A pointer to store a task ID or NULL (OUT) * - pos - Positiion to seek to .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_initiator_write .. _doxid-group__tapi__tad__iscsi_1gaf1afb257570410081ba1807556c41153: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_initiator_write(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid, void* data, size_t length) Request a write operation on an iSCSI device. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ioh - I/O handler * - taskid - A pointer to store a task ID or NULL (OUT) * - data - A pointer to a buffer with data * - length - Length of data to write .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_initiator_read .. _doxid-group__tapi__tad__iscsi_1gafbb553194e6df2e53656be8d84f22eed: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_initiator_read(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid, void* data, size_t length) Request a read operation on an iSCSI device. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ioh - I/O handler * - taskid - A pointer to store a task ID or NULL (OUT) * - data - A pointer to a buffer to store data * - length - Length of the buffer .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_initiator_write_file .. _doxid-group__tapi__tad__iscsi_1ga17ac8744bc65869d92481dc41f69a6f2: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_initiator_write_file(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid, const char* fname) Request a write operation on an iSCSI device using data from a file. The copying is done in chunks of size 'bufsize' passed to iscsi_io_prepare(). .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ioh - I/O handler * - data - A pointer to a zero-terminated string to write * - taskid - A pointer to store a task ID or NULL (OUT) * - fname - Name of a file with data .. rubric:: Returns: Status code .. index:: pair: function; tapi_iscsi_initiator_read_file .. _doxid-group__tapi__tad__iscsi_1gab029ac206c887a1c5e5ae316e4a00c9f: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_iscsi_initiator_read_file(iscsi_io_handle_t* ioh, iscsi_io_taskid* taskid, const char* fname) Request a read operation on an iSCSI device putting data to a file. The copying is done in chunks of size 'bufsize' passed to iscsi_io_prepare(). .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ioh - I/O handler * - data - A pointer to a zero-terminated string to verify * - fname - Name of a file to store data .. rubric:: Returns: Status code Macros ------ .. index:: pair: define; ISCSI_INITIATOR_SET_ADVERTIZE .. _doxid-group__tapi__tad__iscsi_1gad0af7131534031988fd45ea6ab9831d7: .. ref-code-block:: cpp :class: doxyrest-title-code-block #define ISCSI_INITIATOR_SET_ADVERTIZE(_ta_, _target_id_, _cid_, _param_name_, _value_) Macro configures the Initiator. The configured parameter will be advertized by the Initiator during the Login State. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - _ta\_ - Agent on which the Initiator is configured * - _target_id\_ - ID of the Target for which the parameter is configured * - _param_name\_ - Name of the parameter to configure * - _value\_ - New value of the parameter (in string form) .. index:: pair: define; ISCSI_INITIATOR_SET_NOT_ADVERTIZE .. _doxid-group__tapi__tad__iscsi_1ga1db36449a4ac980d52806066d86a7a8d: .. ref-code-block:: cpp :class: doxyrest-title-code-block #define ISCSI_INITIATOR_SET_NOT_ADVERTIZE(_ta_, _target_id_, _cid_, _param_name_, _value_) Macro configures the Initiator. The configured parameter will NOT be advertized by the Initiator during the Login State. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - _ta\_ - Agent on which the Initiator is configured * - _target_id\_ - ID of the Target for which the parameter is configured * - _param_name\_ - Name of the parameter to configure * - _value\_ - New value of the parameter (in string form)