Beispiel #1
0
void ndmda_fh_flush(struct ndm_session* sess)
{
  struct ndm_data_agent* da = sess->data_acb;
  struct ndmfhheap* fhh = &da->fhh;
  int rc;
  int fhtype;
  void* table;
  unsigned n_entry;

  rc = ndmfhh_get_table(fhh, &fhtype, &table, &n_entry);
  if (rc == NDMFHH_RET_OK && n_entry > 0) {
    struct ndmp_xa_buf xa;
    struct ndmfhh_generic_table* request;

    request = (void*)&xa.request.body;
    NDMOS_MACRO_ZEROFILL(&xa);

    xa.request.protocol_version = fhtype >> 16;
    xa.request.header.message = fhtype & 0xFFFF;

    request->table_len = n_entry;
    request->table_val = table;

    ndma_send_to_control(sess, &xa, sess->plumb.data);
  }

  ndmfhh_reset(fhh);
}
Beispiel #2
0
int
ndma_notify_data_read (struct ndm_session *sess,
  unsigned long long offset, unsigned long long length)
{
	struct ndmconn *	conn = sess->plumb.control;

	NDMC_WITH_NO_REPLY(ndmp9_notify_data_read, NDMP9VER)
		request->offset = offset;
		request->length = length;
		ndma_send_to_control (sess, xa, sess->plumb.data);
	NDMC_ENDWITH

	return 0;
}
Beispiel #3
0
int
ndma_notify_mover_halted (struct ndm_session *sess)
{
	struct ndmconn *	conn = sess->plumb.control;
	struct ndm_tape_agent *	ta = sess->tape_acb;

	assert (ta->mover_state.state == NDMP9_MOVER_STATE_HALTED);
	assert (ta->mover_state.halt_reason != NDMP9_MOVER_HALT_NA);

	NDMC_WITH_NO_REPLY(ndmp9_notify_mover_halted, NDMP9VER)
		request->reason = ta->mover_state.halt_reason;
		ndma_send_to_control (sess, xa, sess->plumb.tape);
	NDMC_ENDWITH

	return 0;
}
Beispiel #4
0
int
ndma_notify_data_halted (struct ndm_session *sess)
{
	struct ndmconn *	conn = sess->plumb.control;
	struct ndm_data_agent *	da = sess->data_acb;

	assert (da->data_state.state == NDMP9_DATA_STATE_HALTED);
	assert (da->data_state.halt_reason != NDMP9_DATA_HALT_NA);

	NDMC_WITH_NO_REPLY(ndmp9_notify_data_halted, NDMP9VER)
		request->reason = da->data_state.halt_reason;
		ndma_send_to_control (sess, xa, sess->plumb.data);
	NDMC_ENDWITH

	return 0;
}
Beispiel #5
0
int
ndma_notify_mover_paused (struct ndm_session *sess)
{
	struct ndmconn *	conn = sess->plumb.control;
	struct ndm_tape_agent *	ta = sess->tape_acb;

	assert (ta->mover_state.state == NDMP9_MOVER_STATE_PAUSED);
	assert (ta->mover_state.pause_reason != NDMP9_MOVER_PAUSE_NA);

	NDMC_WITH_NO_REPLY(ndmp9_notify_mover_paused, NDMP9VER)
		request->reason = ta->mover_state.pause_reason;
		request->seek_position = ta->mover_want_pos;
		ndma_send_to_control (sess, xa, sess->plumb.tape);
	NDMC_ENDWITH

	return 0;
}
Beispiel #6
0
void
ndma_send_logmsg (struct ndm_session *sess, ndmp9_log_type ltype,
  struct ndmconn *from_conn,
  char *fmt, ...)
{
	struct ndmconn *	conn = from_conn;
	char			buf[4096];
	va_list			ap;

	va_start (ap, fmt);
	vsnprintf (buf, sizeof(buf), fmt, ap);
	va_end (ap);

	if (!from_conn) return;

	switch (from_conn->protocol_version) {
#ifndef NDMOS_OPTION_NO_NDMP2
	case NDMP2VER:
		switch (ltype) {
		default:
		case NDMP9_LOG_NORMAL:
		case NDMP9_LOG_ERROR:
		case NDMP9_LOG_WARNING:
		    NDMC_WITH_NO_REPLY(ndmp2_log_log, NDMP2VER)
			request->entry = buf;
			ndma_send_to_control (sess, xa, from_conn);
		    NDMC_ENDWITH
		    break;

		case NDMP9_LOG_DEBUG:
		    NDMC_WITH_NO_REPLY(ndmp2_log_debug, NDMP2VER)
			request->level = NDMP2_DBG_USER_INFO;
			request->message = buf;
			ndma_send_to_control (sess, xa, from_conn);
		    NDMC_ENDWITH
		    break;
		}
	    break;
#endif /* !NDMOS_OPTION_NO_NDMP2 */
#ifndef NDMOS_OPTION_NO_NDMP3
	case NDMP3VER:
	    NDMC_WITH_NO_REPLY(ndmp3_log_message, NDMP3VER)
		switch (ltype) {
		default:
		case NDMP9_LOG_NORMAL:
			request->log_type = NDMP3_LOG_NORMAL;
			break;

		case NDMP9_LOG_DEBUG:
			request->log_type = NDMP3_LOG_DEBUG;
			break;

		case NDMP9_LOG_ERROR:
			request->log_type = NDMP3_LOG_ERROR;
			break;

		case NDMP9_LOG_WARNING:
			request->log_type = NDMP3_LOG_WARNING;
			break;
		}
		request->message_id = time(0);
		request->entry = buf;
		ndma_send_to_control (sess, xa, from_conn);
	    NDMC_ENDWITH
	    break;
#endif /* !NDMOS_OPTION_NO_NDMP3 */
#ifndef NDMOS_OPTION_NO_NDMP4
	case NDMP4VER:
	    NDMC_WITH_POST(ndmp4_log_message, NDMP4VER)
		switch (ltype) {
		default:
		case NDMP9_LOG_NORMAL:
			request->log_type = NDMP4_LOG_NORMAL;
			break;

		case NDMP9_LOG_DEBUG:
			request->log_type = NDMP4_LOG_DEBUG;
			break;

		case NDMP9_LOG_ERROR:
			request->log_type = NDMP4_LOG_ERROR;
			break;

		case NDMP9_LOG_WARNING:
			request->log_type = NDMP4_LOG_WARNING;
			break;
		}
		request->message_id = time(0);
		request->entry = buf;
		ndma_send_to_control (sess, xa, from_conn);
	    NDMC_ENDWITH
	    break;
#endif /* !NDMOS_OPTION_NO_NDMP4 */

	default:
		/* BOGUS */
		break;
	}
}