int ndmca_data_connect (struct ndm_session *sess) { struct ndmconn * conn = sess->plumb.data; struct ndm_control_agent *ca = &sess->control_acb; int rc; ndmp9_addr addr; if (ca->job.tape_tcp) { char *host; char *port; struct sockaddr_in sin; host = ca->job.tape_tcp; port = strchr(ca->job.tape_tcp, ':'); *port++ = '\0'; rc = ndmhost_lookup(host, &sin); addr.addr_type = NDMP9_ADDR_TCP; addr.ndmp9_addr_u.tcp_addr.ip_addr = ntohl(sin.sin_addr.s_addr); addr.ndmp9_addr_u.tcp_addr.port = atoi(port); } else { addr = ca->mover_addr; } NDMC_WITH(ndmp9_data_connect, NDMP9VER) request->addr = addr; rc = NDMC_CALL(conn); NDMC_ENDWITH return rc; }
int ndmca_data_get_env (struct ndm_session *sess) { struct ndmconn * conn = sess->plumb.data; struct ndm_control_agent *ca = &sess->control_acb; int rc; unsigned int i; ndmp9_pval * d_pv; ndmp9_pval * s_pv; NDMC_WITH_VOID_REQUEST(ndmp9_data_get_env, NDMP9VER) rc = NDMC_CALL(conn); if (rc) return rc; for (i = 0; i < reply->env.env_len; i++) { s_pv = &reply->env.env_val[i]; d_pv = &ca->job.result_env_tab.env[i]; d_pv->name = NDMOS_API_STRDUP (s_pv->name); d_pv->value = NDMOS_API_STRDUP (s_pv->value); } ca->job.result_env_tab.n_env = i; NDMC_FREE_REPLY(); NDMC_ENDWITH return rc; }
int ndmca_data_listen (struct ndm_session *sess) { struct ndmconn * conn = sess->plumb.data; struct ndm_control_agent *ca = &sess->control_acb; int rc; NDMC_WITH(ndmp9_data_listen, NDMP9VER) if (sess->plumb.tape == sess->plumb.data) { request->addr_type = NDMP9_ADDR_LOCAL; } else { request->addr_type = NDMP9_ADDR_TCP; } rc = NDMC_CALL(conn); if (rc) return rc; if (request->addr_type != reply->data_connection_addr.addr_type) { ndmalogf (sess, 0, 0, "DATA_LISTEN addr_type mismatch"); return -1; } ca->data_addr = reply->data_connection_addr; NDMC_ENDWITH return 0; }
int ndmca_mover_close (struct ndm_session *sess) { struct ndmconn * conn = sess->plumb.tape; int rc; NDMC_WITH_VOID_REQUEST(ndmp9_mover_close, NDMP9VER) rc = NDMC_CALL(conn); NDMC_ENDWITH return rc; }
int ndmca_data_stop (struct ndm_session *sess) { struct ndmconn * conn = sess->plumb.data; int rc; NDMC_WITH_VOID_REQUEST(ndmp9_data_stop, NDMP9VER) rc = NDMC_CALL(conn); NDMC_ENDWITH return rc; }
int ndmca_mover_set_record_size (struct ndm_session *sess) { struct ndmconn * conn = sess->plumb.tape; struct ndm_control_agent *ca = &sess->control_acb; int rc; NDMC_WITH(ndmp9_mover_set_record_size, NDMP9VER) request->record_size = ca->job.record_size; rc = NDMC_CALL(conn); NDMC_ENDWITH return rc; }
int ndmca_data_connect (struct ndm_session *sess) { struct ndmconn * conn = sess->plumb.data; struct ndm_control_agent *ca = &sess->control_acb; int rc; NDMC_WITH(ndmp9_data_connect, NDMP9VER) request->addr = ca->mover_addr; rc = NDMC_CALL(conn); NDMC_ENDWITH return rc; }
int ndmca_mover_read (struct ndm_session *sess, unsigned long long offset, unsigned long long length) { struct ndmconn * conn = sess->plumb.tape; int rc; NDMC_WITH(ndmp9_mover_read, NDMP9VER) request->offset = offset; request->length = length; rc = NDMC_CALL(conn); NDMC_ENDWITH return rc; }
int ndmca_tape_open (struct ndm_session *sess) { struct ndmconn * conn = sess->plumb.tape; struct ndm_control_agent *ca = &sess->control_acb; int rc; NDMC_WITH (ndmp9_tape_open, NDMP9VER) request->device = ca->job.tape_device; request->mode = ca->tape_mode; rc = NDMC_CALL(conn); ca->tape_state.error = reply->error; NDMC_ENDWITH return rc; }
int ndmca_tape_write (struct ndm_session *sess, char *buf, unsigned count) { struct ndmconn * conn = sess->plumb.tape; int rc; NDMC_WITH(ndmp9_tape_write, NDMP9VER) request->data_out.data_out_len = count; request->data_out.data_out_val = buf; rc = NDMC_CALL(conn); if (rc == 0) { if (reply->count != count) rc = -1; } NDMC_ENDWITH return rc; }
int ndmca_mover_get_state (struct ndm_session *sess) { struct ndmconn * conn = sess->plumb.tape; struct ndm_control_agent *ca = &sess->control_acb; struct ndmp9_mover_get_state_reply *state = &ca->mover_state; int rc; NDMC_WITH_VOID_REQUEST(ndmp9_mover_get_state, NDMP9VER) rc = NDMC_CALL(conn); if (rc) { NDMOS_MACRO_ZEROFILL (state); ca->mover_state.state = -1; } else { *state = *reply; } NDMC_ENDWITH return rc; }
int ndmca_tape_read_partial (struct ndm_session *sess, char *buf, unsigned count, int *read_count) { struct ndmconn * conn = sess->plumb.tape; int rc; NDMC_WITH(ndmp9_tape_read, NDMP9VER) request->count = count; rc = NDMC_CALL(conn); if (rc == 0) { *read_count = reply->data_in.data_in_len; bcopy (reply->data_in.data_in_val, buf, *read_count); } else { rc = reply->error; } NDMC_FREE_REPLY(); NDMC_ENDWITH return rc; }
int ndmca_data_start_recover_filehist (struct ndm_session *sess) { struct ndmconn * conn = sess->plumb.data; struct ndm_control_agent *ca = &sess->control_acb; unsigned n_env = ca->job.env_tab.n_env; ndmp9_pval * env = ca->job.env_tab.env; unsigned n_nlist = ca->job.nlist_tab.n_nlist; ndmp9_name * nlist = ca->job.nlist_tab.nlist; ndmp9_addr addr; int rc; if (conn->protocol_version > 2) { if (ca->swap_connect) { if ( (rc = ndmca_mover_connect (sess)) != 0) { return rc; } } else { if ( (rc = ndmca_data_connect (sess)) != 0) { return rc; } } addr.addr_type = NDMP9_ADDR_AS_CONNECTED; } else { addr = ca->mover_addr; } NDMC_WITH(ndmp9_data_start_recover_filehist, NDMP9VER) request->addr = addr; request->bu_type = ca->job.bu_type; request->env.env_len = n_env; request->env.env_val = env; request->nlist.nlist_len = n_nlist; request->nlist.nlist_val = nlist; rc = NDMC_CALL(conn); NDMC_ENDWITH return rc; }
int ndmca_tape_mtio (struct ndm_session *sess, ndmp9_tape_mtio_op op, u_long count, u_long *resid) { struct ndmconn * conn = sess->plumb.tape; int rc; NDMC_WITH(ndmp9_tape_mtio, NDMP9VER) request->tape_op = op; request->count = count; rc = NDMC_CALL(conn); if (!rc) { if (resid) { *resid = reply->resid_count; } else if (reply->resid_count != 0) { return -1; } } NDMC_ENDWITH return rc; }
int ndmca_test_query_conn_types(struct ndm_session* sess, struct ndmconn* ref_conn) { struct ndmconn* conn = ref_conn; struct ndm_control_agent* ca = sess->control_acb; int rc; unsigned int i; switch (conn->protocol_version) { default: return -1234; #ifndef NDMOS_OPTION_NO_NDMP2 case NDMP2VER: NDMC_WITH_VOID_REQUEST(ndmp2_config_get_mover_type, NDMP2VER) rc = NDMC_CALL(conn); if (rc) { ndmalogf(sess, "Test", 1, "GET_MOVER_TYPE failed"); return rc; } for (i = 0; i < reply->methods.methods_len; i++) { switch (reply->methods.methods_val[i]) { case NDMP2_ADDR_LOCAL: ca->has_local_addr = 1; break; case NDMP2_ADDR_TCP: ca->has_tcp_addr = 1; break; default: break; } } NDMC_FREE_REPLY(); NDMC_ENDWITH break; #endif /* !NDMOS_OPTION_NO_NDMP2 */ #ifndef NDMOS_OPTION_NO_NDMP3 case NDMP3VER: NDMC_WITH_VOID_REQUEST(ndmp3_config_get_connection_type, NDMP3VER) rc = NDMC_CALL(conn); if (rc) { ndmalogf(sess, "Test", 1, "GET_CONNECTION_TYPE failed"); return rc; } for (i = 0; i < reply->addr_types.addr_types_len; i++) { switch (reply->addr_types.addr_types_val[i]) { case NDMP3_ADDR_LOCAL: ca->has_local_addr = 1; break; case NDMP3_ADDR_TCP: ca->has_tcp_addr = 1; break; default: break; } } NDMC_FREE_REPLY(); NDMC_ENDWITH break; #endif /* !NDMOS_OPTION_NO_NDMP3 */ #ifndef NDMOS_OPTION_NO_NDMP4 case NDMP4VER: NDMC_WITH_VOID_REQUEST(ndmp4_config_get_connection_type, NDMP4VER) rc = NDMC_CALL(conn); if (rc) { ndmalogf(sess, "Test", 1, "GET_CONNECTION_TYPE failed"); return rc; } for (i = 0; i < reply->addr_types.addr_types_len; i++) { switch (reply->addr_types.addr_types_val[i]) { case NDMP4_ADDR_LOCAL: ca->has_local_addr = 1; break; case NDMP4_ADDR_TCP: ca->has_tcp_addr = 1; break; default: break; } } NDMC_FREE_REPLY(); NDMC_ENDWITH break; #endif /* !NDMOS_OPTION_NO_NDMP4 */ } return 0; }