/*
* Copyright (c) 1998,1999,2000
* Traakan, Inc., Los Altos, CA
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice unmodified, this list of conditions, and the following
* disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
/*
* Project: NDMJOB
* Ident: $Id: $
*
* Description:
*
*/
#include "smc_priv.h"
static char *strend(char *s);
char *
smc_elem_type_code_to_str(int code)
{
switch (code) {
case SMC_ELEM_TYPE_ALL: return "ALL";
case SMC_ELEM_TYPE_MTE: return "ARM";
case SMC_ELEM_TYPE_SE: return "SLOT";
case SMC_ELEM_TYPE_IEE: return "IEE";
case SMC_ELEM_TYPE_DTE: return "TAPE";
default: return "???";
}
}
int
smc_pp_element_address_assignments (struct smc_element_address_assignment *eaa,
int lineno, char *buf)
{
sprintf (buf, "slots %d@%d drive %d@%d arm %d@%d i/e %d@%d",
eaa->se_count, eaa->se_addr,
eaa->dte_count, eaa->dte_addr,
eaa->mte_count, eaa->mte_addr,
eaa->iee_count, eaa->iee_addr);
return 1;
}
int
smc_pp_element_descriptor (struct smc_element_descriptor *edp,
int lineno, char *ret_buf)
{
int nline = 0;
char buf[100];
*ret_buf = 0;
*buf = 0;
sprintf (buf, "@%-3d %-4s",
edp->element_address,
smc_elem_type_code_to_str(edp->element_type_code));
if (edp->Full)
strcat (buf, " Full ");
else
strcat (buf, " Empty");
if (edp->element_type_code == SMC_ELEM_TYPE_MTE) {
if (edp->Access) {
/* unusual for MTE */
/* actually not defined */
strcat (buf, " ?access=granted?");
}
} else {
if (!edp->Access) {
/* unusual for all non-MTE elements */
strcat (buf, " ?access=denied?");
}
}
if (edp->PVolTag && edp->Full) {
sprintf (strend(buf), " PVolTag(%s,#%d)",
edp->primary_vol_tag.volume_id,
edp->primary_vol_tag.volume_seq);
}
if (edp->Except) {
sprintf (strend(buf), " Except(asc=%02x,ascq=%02x)",
edp->asc, edp->ascq);
}
if (*buf && nline++ == lineno) strcpy (ret_buf, buf);
*buf = 0;
#define INDENT_SPACES " " /* 10 spaces */
if (edp->AVolTag) {
sprintf (buf, INDENT_SPACES "AVolTag(%s,#%d)",
edp->alternate_vol_tag.volume_id,
edp->alternate_vol_tag.volume_seq);
}
if (*buf && nline++ == lineno) strcpy (ret_buf, buf);
*buf = 0;
if (edp->SValid) {
sprintf (buf, INDENT_SPACES "SValid(src=%d,%sinvert)",
edp->src_se_addr,
edp->Invert ? "" : "!");
}
if (*buf && nline++ == lineno) strcpy (ret_buf, buf);
*buf = 0;
if (edp->element_type_code == SMC_ELEM_TYPE_DTE) {
strcpy (buf, INDENT_SPACES);
if (edp->ID_valid) {
sprintf (strend(buf), "ID sid=%d", edp->scsi_sid);
} else {
strcat (buf, "no-sid-data");
}
if (edp->LU_valid) {
sprintf (strend(buf), " lun=%d", edp->scsi_lun);
} else {
strcat (buf, " no-lun-data");
}
if (edp->ID_valid && edp->Not_bus) {
strcat (buf, " not-same-bus");
}
}
if (*buf && nline++ == lineno) strcpy (ret_buf, buf);
*buf = 0;
if (edp->element_type_code == SMC_ELEM_TYPE_IEE) {
strcpy (buf, INDENT_SPACES);
if (edp->InEnab)
strcat (buf, " can-import");
else
strcat (buf, " can-not-import");
if (edp->ExEnab)
strcat (buf, " can-export");
else
strcat (buf, " can-not-export");
if (edp->ImpExp)
strcat (buf, " by-oper");
else
strcat (buf, " by-mte");
}
if (*buf && nline++ == lineno) strcpy (ret_buf, buf);
*buf = 0;
return nline;
}
static char *
strend (char *s)
{
while (*s) s++;
return s;
}