275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock/*
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * CDDL HEADER START
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock *
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * The contents of this file are subject to the terms of the
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * Common Development and Distribution License (the "License").
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * You may not use this file except in compliance with the License.
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock *
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * or http://www.opensolaris.org/os/licensing.
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * See the License for the specific language governing permissions
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * and limitations under the License.
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock *
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * When distributing Covered Code, include this CDDL HEADER in each
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * If applicable, add the following below this CDDL HEADER, with the
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * fields enclosed by brackets "[]" replaced with your own identifying
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * information: Portions Copyright [yyyy] [name of copyright owner]
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock *
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * CDDL HEADER END
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock */
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock/*
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * Use is subject to license terms.
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock */
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock#pragma ident "%Z%%M% %I% %E% SMI"
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock#include <sys/types.h>
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock#include <stddef.h>
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock#include <stdio.h>
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock#include <string.h>
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock#include <libnvpair.h>
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock#include <scsi/libses.h>
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock#include "ses2_impl.h"
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_device(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_device_status_impl_t *dip = (ses2_device_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_DEV_PROP_SLOT_ADDR,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_slot_addr);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_REPORT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_report);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_RMV, dip->sdsi_rmv);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_READY_TO_INSERT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_ready_to_insert);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_ENC_BYP_B,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_enclosure_bypassed_b);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_ENC_BYP_A,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_enclosure_bypassed_a);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_DO_NOT_REMOVE,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_do_not_remove);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_APP_BYP_A,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_app_client_bypassed_a);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_DEV_BYP_B,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_device_bypassed_b);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_DEV_BYP_A,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_device_bypassed_a);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_BYP_B,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_bypassed_b);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_BYP_A,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_bypassed_a);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_OFF,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_device_off);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_FAULT_RQSTD,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_fault_reqstd);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_FAULT_SENSED,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_fault_sensed);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_APP_BYP_B,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_app_client_bypassed_b);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_psu(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_psu_status_impl_t *pip = (ses2_psu_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock pip->spsi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PSU_PROP_DC_OVER_CURRENT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock pip->spsi_dc_over_current);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PSU_PROP_DC_UNDER_VOLTAGE,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock pip->spsi_dc_under_voltage);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PSU_PROP_DC_OVER_VOLTAGE,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock pip->spsi_dc_over_voltage);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PSU_PROP_DC_FAIL,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock pip->spsi_dc_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PSU_PROP_AC_FAIL,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock pip->spsi_ac_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PSU_PROP_TEMP_WARN,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock pip->spsi_temp_warn);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PSU_PROP_OVERTEMP_FAIL,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock pip->spsi_overtmp_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_OFF, pip->spsi_off);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_REQUESTED_ON,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock pip->spsi_rqsted_on);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, pip->spsi_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_HOT_SWAP,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock pip->spsi_hot_swap);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_cooling(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_cooling_status_impl_t *cip = (ses2_cooling_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_COOLING_PROP_FAN_SPEED,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES2_ES_COOLING_ST_FAN_SPEED(cip));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock cip->scsi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_COOLING_PROP_SPEED_CODE,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock cip->scsi_actual_speed_code);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_OFF, cip->scsi_off);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_REQUESTED_ON,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock cip->scsi_requested_on);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, cip->scsi_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_temp(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_temp_status_impl_t *tip = (ses2_temp_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT, tip->stsi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, tip->stsi_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(int64, nverr, nvl, SES_TEMP_PROP_TEMP,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES2_ES_TEMP_ST_TEMPERATURE(tip));
9af3851a3a831b4de34b42482c22351e14f33f16eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_WARN_UNDER,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock tip->stsi_ut_warn);
9af3851a3a831b4de34b42482c22351e14f33f16eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_CRIT_UNDER,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock tip->stsi_ut_fail);
9af3851a3a831b4de34b42482c22351e14f33f16eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_WARN_OVER,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock tip->stsi_ot_warn);
9af3851a3a831b4de34b42482c22351e14f33f16eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_CRIT_OVER,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock tip->stsi_ot_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_lock(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_lock_status_impl_t *lip = (ses2_lock_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock lip->slsi_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock lip->slsi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_LOCK_PROP_UNLOCKED,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock lip->slsi_unlocked);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_alarm(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_alarm_status_impl_t *aip = (ses2_alarm_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, aip->sasi_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sasi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_ALARM_PROP_UNRECOV,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sasi_unrecov);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_ALARM_PROP_CRIT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sasi_crit);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_ALARM_PROP_NONCRIT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sasi_noncrit);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_ALARM_PROP_INFO,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sasi_info);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_ALARM_PROP_REMIND,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sasi_remind);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_ALARM_PROP_MUTED,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sasi_muted);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_ALARM_PROP_RQST_MUTE,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sasi_rqst_mute);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_esc(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_controller_status_impl_t *cip =
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock (ses2_controller_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, cip->scsi_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT, cip->scsi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_REPORT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock cip->scsi_report);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_HOT_SWAP,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock cip->scsi_hot_swap);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_scc(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_scc_status_impl_t *sip = (ses2_scc_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, sip->sss_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT, sip->sss_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_REPORT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock sip->sss_report);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_cache(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_nvcache_status_impl_t *np = (ses2_nvcache_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, np->snsi_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock np->snsi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_CACHE_PROP_SIZE,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES2_NVCACHE_SIZE(np));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_ups(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_ups_status_impl_t *uip = (ses2_ups_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_UPS_PROP_TIMELEFT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock uip->susi_battery_status);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_UPS_PROP_INTF_FAIL,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock uip->susi_intf_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_UPS_PROP_WARN,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock uip->susi_warn);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_UPS_PROP_UPS_FAIL,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock uip->susi_ups_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_UPS_PROP_DC_FAIL,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock uip->susi_dc_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_UPS_PROP_AC_FAIL,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock uip->susi_ac_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_UPS_PROP_AC_QUAL,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock uip->susi_ac_qual);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_UPS_PROP_AC_HI,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock uip->susi_ac_hi);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_UPS_PROP_AC_LO,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock uip->susi_ac_lo);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_UPS_PROP_BPF, uip->susi_bpf);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_UPS_PROP_BATT_FAIL,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock uip->susi_batt_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, uip->susi_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT, uip->susi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_display(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_display_status_impl_t *dip = (ses2_display_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_DPY_PROP_MODE,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_display_mode_status);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, dip->sdsi_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT, dip->sdsi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint16, nverr, nvl, SES_DPY_PROP_CHAR,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sdsi_display_character_status);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_keypad(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_keypad_status_impl_t *kip = (ses2_keypad_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, kip->sksi_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT, kip->sksi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_px(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_port_status_impl_t *pip = (ses2_port_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, pip->spsi_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT, pip->spsi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_REPORT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock pip->spsi_report);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PX_PROP_XMIT_FAIL,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock pip->spsi_xmit_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PX_PROP_LOL, pip->spsi_lol);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_DISABLED,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock pip->spsi_disabled);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_lang(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_lang_status_impl_t *lip = (ses2_lang_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock lip->slsi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_LANG_PROP_LANGCODE,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SCSI_READ16(&lip->slsi_language_code));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_comm(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_comm_status_impl_t *cip = (ses2_comm_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, cip->scsi_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock cip->scsi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_DISABLED,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock cip->scsi_disabled);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_voltage(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_voltage_status_impl_t *vip = (ses2_voltage_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
9af3851a3a831b4de34b42482c22351e14f33f16eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_CRIT_UNDER,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock vip->svsi_crit_under);
9af3851a3a831b4de34b42482c22351e14f33f16eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_CRIT_OVER,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock vip->svsi_crit_over);
9af3851a3a831b4de34b42482c22351e14f33f16eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_WARN_UNDER,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock vip->svsi_warn_under);
9af3851a3a831b4de34b42482c22351e14f33f16eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_WARN_OVER,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock vip->svsi_warn_over);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, vip->svsi_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT, vip->svsi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(int64, nverr, nvl, SES_VS_PROP_VOLTAGE_MV,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SCSI_READ16(&vip->svsi_voltage));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_current(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_current_status_impl_t *cip = (ses2_current_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
9af3851a3a831b4de34b42482c22351e14f33f16eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_CRIT_OVER,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock cip->scsi_crit_over);
9af3851a3a831b4de34b42482c22351e14f33f16eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_WARN_OVER,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock cip->scsi_warn_over);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, cip->scsi_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT, cip->scsi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(int64, nverr, nvl, SES_CS_PROP_CURRENT_MA,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SCSI_READ16(&cip->scsi_current));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_itp(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_itp_status_impl_t *iip = (ses2_itp_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, iip->sisi_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock iip->sisi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_REPORT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock iip->sisi_report);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_ITP_PROP_ENABLED,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock iip->sisi_enabled);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_sse(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_ss_status_impl_t *sip = (ses2_ss_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, sip->sss_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT, sip->sss_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_SS_PROP_SHORT_STATUS,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock sip->sss_short_status);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_arraydev(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_array_device_status_impl_t *aip =
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock (ses2_array_device_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_AD_PROP_RR_ABORT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_rr_abort);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_AD_PROP_REBUILD,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_rebuild);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_AD_PROP_IN_FAILED_ARRAY,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_in_failed_array);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_AD_PROP_IN_CRIT_ARRAY,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_in_crit_array);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_AD_PROP_CONS_CHK,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_cons_chk);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_AD_PROP_HOT_SPARE,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_hot_spare);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_AD_PROP_RSVD_DEVICE,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_rsvd_device);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_AD_PROP_OK, aip->sadsi_ok);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_REPORT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_report);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT, aip->sadsi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_RMV, aip->sadsi_rmv);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_READY_TO_INSERT,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_ready_to_insert);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_ENC_BYP_B,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_enclosure_bypassed_b);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_ENC_BYP_A,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_enclosure_bypassed_a);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_DO_NOT_REMOVE,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_do_not_remove);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_APP_BYP_A,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_app_client_bypassed_a);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_DEV_BYP_B,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_device_bypassed_b);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_DEV_BYP_A,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_device_bypassed_a);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_BYP_B,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_bypassed_b);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_BYP_A,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_bypassed_a);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_OFF,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_device_off);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_FAULT_RQSTD,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_fault_reqstd);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_FAULT_SENSED,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_fault_sensed);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_APP_BYP_B,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock aip->sadsi_app_client_bypassed_b);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_expander(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_expander_status_impl_t *eip = (ses2_expander_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, eip->sesi_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT, eip->sesi_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_sasconn(const ses2_elem_status_impl_t *esip, nvlist_t *nvl)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_sasconn_status_impl_t *sip = (ses2_sasconn_status_impl_t *)esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_FAIL, sip->sss_fail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_IDENT, sip->sss_ident);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_SC_PROP_CONNECTOR_TYPE,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock sip->sss_connector_type);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_SC_PROP_PHYSICAL_LINK,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock sip->sss_connector_physical_link);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic const struct status_parser {
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_element_type_t type;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int (*func)(const ses2_elem_status_impl_t *, nvlist_t *);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock} status_parsers[] = {
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_DEVICE, elem_parse_device },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_POWER_SUPPLY, elem_parse_psu },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_COOLING, elem_parse_cooling },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_TEMPERATURE_SENSOR, elem_parse_temp },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_DOOR_LOCK, elem_parse_lock },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_AUDIBLE_ALARM, elem_parse_alarm },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_ESC_ELECTRONICS, elem_parse_esc },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_SCC_ELECTRONICS, elem_parse_scc },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_NONVOLATILE_CACHE, elem_parse_cache },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_UPS, elem_parse_ups },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_DISPLAY, elem_parse_display },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_KEY_PAD_ENTRY, elem_parse_keypad },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_SCSI_PORT_XCVR, elem_parse_px },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_LANGUAGE, elem_parse_lang },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_COMMUNICATION_PORT, elem_parse_comm },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_VOLTAGE_SENSOR, elem_parse_voltage },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_CURRENT_SENSOR, elem_parse_current },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_SCSI_TARGET_PORT, elem_parse_itp },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_SCSI_INITIATOR_PORT, elem_parse_itp },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_SIMPLE_SUBENCLOSURE, elem_parse_sse },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_ARRAY_DEVICE, elem_parse_arraydev },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_SAS_EXPANDER, elem_parse_expander },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_SAS_CONNECTOR, elem_parse_sasconn },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { (ses2_element_type_t)-1, NULL }
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock};
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_sd(ses_plugin_t *spp, ses_node_t *np)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_elem_status_impl_t *esip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock const struct status_parser *sp;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nvlist_t *nvl = ses_node_props(np);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock size_t len;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock uint64_t type;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((esip = ses_plugin_page_lookup(spp,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses_node_snapshot(np), SES2_DIAGPAGE_ENCLOSURE_CTL_STATUS,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock np, &len)) == NULL)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock VERIFY(nvlist_lookup_uint64(nvl, SES_PROP_ELEMENT_TYPE,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock &type) == 0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_PROP_STATUS_CODE,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock esip->sesi_common.sesi_status_code);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_SWAP,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock esip->sesi_common.sesi_swap);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_DISABLED,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock esip->sesi_common.sesi_disabled);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_PROP_PRDFAIL,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock esip->sesi_common.sesi_prdfail);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock for (sp = &status_parsers[0]; sp->type != (ses2_element_type_t)-1; sp++)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (sp->type == type && sp->func != NULL)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (sp->func(esip, nvl));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_descr(ses_plugin_t *sp, ses_node_t *np)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock char *desc;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock size_t len;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nvlist_t *props = ses_node_props(np);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((desc = ses_plugin_page_lookup(sp, ses_node_snapshot(np),
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES2_DIAGPAGE_ELEMENT_DESC, np, &len)) == NULL)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(fixed_string, nverr, props, SES_PROP_DESCRIPTION,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock desc, len);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_aes_fc(const ses2_aes_descr_fc_eip_impl_t *fp,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nvlist_t *nvl, size_t len)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr, i;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nvlist_t **nva;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nports;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (len < offsetof(ses2_aes_descr_fc_eip_impl_t,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock sadfi_ports))
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_PROP_BAY_NUMBER,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock fp->sadfi_bay_number);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_FC_PROP_NODE_NAME,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SCSI_READ64(&fp->sadfi_node_name));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nports = MIN(fp->sadfi_n_ports,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock (len - offsetof(ses2_aes_descr_fc_eip_impl_t,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock sadfi_ports)) / sizeof (ses2_aes_port_descr_impl_t));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (nports == 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nva = ses_zalloc(nports * sizeof (nvlist_t *));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (nva == NULL)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (-1);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock for (i = 0; i < nports; i++) {
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_alloc(&nva[i], NV_UNIQUE_NAME, 0)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_uint64(nva[i], SES_FC_PROP_LOOP_POS,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock fp->sadfi_ports[i].sapdi_port_loop_position)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_uint64(nva[i], SES_FC_PROP_REQ_HARDADDR,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock fp->sadfi_ports[i].sapdi_port_requested_hard_address)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nverr = nvlist_add_uint64(nva[i], SES_FC_PROP_N_PORT_ID,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SCSI_READ24(fp->sadfi_ports[i].sapdi_n_port_identifier));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (nverr != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_uint64(nva[i], SES_FC_PROP_N_PORT_NAME,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SCSI_READ64(&fp->sadfi_ports[i].sapdi_n_port_name))) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock }
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_nvlist_array(nvl, SES_FC_PROP_PORTS,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nva, nports)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock for (i = 0; i < nports && nva[i] != NULL; i++)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nvlist_free(nva[i]);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses_free(nva);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockfail:
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock for (i = 0; i < nports && nva[i] != NULL; i++)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nvlist_free(nva[i]);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses_free(nva);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (ses_set_nverrno(nverr, NULL));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_aes_device(const ses2_aes_descr_eip_impl_t *dep, nvlist_t *nvl,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock size_t len)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_aes_descr_fc_eip_impl_t *fp;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_aes_descr_sas0_eip_impl_t *s0ep;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_aes_descr_sas0_impl_t *s0p;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_aes_descr_impl_t *dip;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nvlist_t **nva;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr, i;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock size_t nphy;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (dep->sadei_eip) {
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock s0ep = (ses2_aes_descr_sas0_eip_impl_t *)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dep->sadei_protocol_specific;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock s0p = (ses2_aes_descr_sas0_impl_t *)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dep->sadei_protocol_specific;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock } else {
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip = (ses2_aes_descr_impl_t *)dep;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock s0ep = NULL;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock s0p = (ses2_aes_descr_sas0_impl_t *)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dip->sadei_protocol_specific;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock }
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (dep->sadei_invalid)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (dep->sadei_protocol_identifier == SPC4_PROTO_FIBRE_CHANNEL) {
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock fp = (ses2_aes_descr_fc_eip_impl_t *)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dep->sadei_protocol_specific;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (!SES_WITHIN_PAGE_STRUCT(fp, dep, len))
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (elem_parse_aes_fc(fp, nvl, len -
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock offsetof(ses2_aes_descr_eip_impl_t,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock sadei_protocol_specific)));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock } else if (dep->sadei_protocol_identifier != SPC4_PROTO_SAS) {
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock }
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (s0p->sadsi_descriptor_type != SES2_AESD_SAS_DEVICE)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(boolean_value, nverr, nvl, SES_DEV_PROP_SAS_NOT_ALL_PHYS,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock s0p->sadsi_not_all_phys);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (s0ep != NULL) {
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_PROP_BAY_NUMBER,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock s0ep->sadsi_bay_number);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nphy = MIN(s0ep->sadsi_n_phy_descriptors,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock (len - offsetof(ses2_aes_descr_sas0_eip_impl_t,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock sadsi_phys)) / sizeof (ses2_aes_phy0_descr_impl_t));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock } else {
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nphy = MIN(s0p->sadsi_n_phy_descriptors,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock (len - offsetof(ses2_aes_descr_sas0_impl_t,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock sadsi_phys)) / sizeof (ses2_aes_phy0_descr_impl_t));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock }
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (nphy == 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nva = ses_zalloc(nphy * sizeof (nvlist_t *));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (nva == NULL)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (-1);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock for (i = 0; i < nphy; i++) {
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_aes_phy0_descr_impl_t *pp;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock pp = s0ep != NULL ? &s0ep->sadsi_phys[i] : &s0p->sadsi_phys[i];
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_alloc(&nva[i], NV_UNIQUE_NAME, 0)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_uint64(nva[i], SES_SAS_PROP_DEVICE_TYPE,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock pp->sapdi_device_type)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_boolean_value(nva[i],
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_SAS_PROP_SMPI_PORT, pp->sapdi_smp_initiator_port)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_boolean_value(nva[i],
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_SAS_PROP_STPI_PORT, pp->sapdi_stp_initiator_port)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_boolean_value(nva[i],
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_SAS_PROP_SSPI_PORT, pp->sapdi_ssp_initiator_port)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_boolean_value(nva[i],
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_SAS_PROP_SATA_DEVICE, pp->sapdi_sata_device)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_boolean_value(nva[i],
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_SAS_PROP_SMPT_PORT, pp->sapdi_smp_target_port)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_boolean_value(nva[i],
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_SAS_PROP_STPT_PORT, pp->sapdi_stp_target_port)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_boolean_value(nva[i],
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_SAS_PROP_SSPT_PORT, pp->sapdi_ssp_target_port)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nverr = nvlist_add_uint64(nva[i], SES_SAS_PROP_ATT_ADDR,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SCSI_READ64(&pp->sapdi_attached_sas_address));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (nverr != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nverr = nvlist_add_uint64(nva[i], SES_SAS_PROP_ADDR,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SCSI_READ64(&pp->sapdi_sas_address));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (nverr != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_uint64(nva[i], SES_SAS_PROP_PHY_ID,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock pp->sapdi_phy_identifier)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock }
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_nvlist_array(nvl, SES_SAS_PROP_PHYS,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nva, nphy)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock for (i = 0; i < nphy && nva[i] != NULL; i++)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nvlist_free(nva[i]);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses_free(nva);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockfail:
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock for (i = 0; i < nphy && nva[i] != NULL; i++)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nvlist_free(nva[i]);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses_free(nva);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (ses_set_nverrno(nverr, NULL));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_aes_expander(const ses2_aes_descr_eip_impl_t *dep, nvlist_t *nvl,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock size_t len)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_aes_descr_exp_impl_t *sep;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nvlist_t **nva;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr, i;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock size_t nphy;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (dep->sadei_invalid)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock /*
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * This should never happen; no current SAS expander can have any
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * other kind of ports. But maybe someday - one could envision a
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock * SAS expander with iSCSI target ports, for example.
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock */
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (dep->sadei_protocol_identifier != SPC4_PROTO_SAS)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock sep = (ses2_aes_descr_exp_impl_t *)dep->sadei_protocol_specific;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (sep->sadei_descriptor_type != SES2_AESD_SAS_OTHER)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_EXP_PROP_SAS_ADDR,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SCSI_READ64(&sep->sadei_sas_address));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nphy = MIN(sep->sadei_n_exp_phy_descriptors,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock (len - offsetof(ses2_aes_descr_exp_impl_t,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock sadei_phys)) / sizeof (ses2_aes_exp_phy_descr_impl_t));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (nphy == 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nva = ses_zalloc(nphy * sizeof (nvlist_t *));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (nva == NULL)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (-1);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock for (i = 0; i < nphy; i++) {
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_alloc(&nva[i], NV_UNIQUE_NAME, 0)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_uint64(nva[i], SES_PROP_CE_IDX,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock sep->sadei_phys[i].saepdi_connector_element_index)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_uint64(nva[i], SES_PROP_OE_IDX,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock sep->sadei_phys[i].saepdi_other_element_index)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock }
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_nvlist_array(nvl, SES_SAS_PROP_PHYS,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nva, nphy)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock for (i = 0; i < nphy && nva[i] != NULL; i++)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nvlist_free(nva[i]);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses_free(nva);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockfail:
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock for (i = 0; i < nphy && nva[i] != NULL; i++)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nvlist_free(nva[i]);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses_free(nva);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (ses_set_nverrno(nverr, NULL));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_aes_misc(const ses2_aes_descr_eip_impl_t *dep, nvlist_t *nvl,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock size_t len)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_aes_descr_fc_eip_impl_t *fp;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_aes_descr_sas1_impl_t *s1p;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nvlist_t **nva;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr, i;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock size_t nphy;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (dep->sadei_invalid)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (dep->sadei_protocol_identifier == SPC4_PROTO_FIBRE_CHANNEL) {
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock fp = (ses2_aes_descr_fc_eip_impl_t *)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock dep->sadei_protocol_specific;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (!SES_WITHIN_PAGE_STRUCT(fp, dep, len))
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (elem_parse_aes_fc(fp, nvl, len -
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock offsetof(ses2_aes_descr_eip_impl_t,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock sadei_protocol_specific)));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock } else if (dep->sadei_protocol_identifier != SPC4_PROTO_SAS) {
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock }
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock s1p = (ses2_aes_descr_sas1_impl_t *)dep->sadei_protocol_specific;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (s1p->sadsi_descriptor_type == SES2_AESD_SAS_DEVICE)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nphy = MIN(s1p->sadsi_n_phy_descriptors,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock (len - offsetof(ses2_aes_descr_sas1_impl_t,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock sadsi_phys)) / sizeof (ses2_aes_phy1_descr_impl_t));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nva = ses_zalloc(nphy * sizeof (nvlist_t *));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (nva == NULL)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (-1);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock for (i = 0; i < nphy; i++) {
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_alloc(&nva[i], NV_UNIQUE_NAME, 0)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_uint64(nva[i], SES_PROP_CE_IDX,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock s1p->sadsi_phys[i].sapdi_connector_element_index)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_uint64(nva[i], SES_PROP_OE_IDX,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock s1p->sadsi_phys[i].sapdi_other_element_index)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_uint64(nva[i], SES_SAS_PROP_ADDR,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SCSI_READ64(&s1p->sadsi_phys[i].sapdi_sas_address))) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock }
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((nverr = nvlist_add_nvlist_array(nvl, SES_SAS_PROP_PHYS,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nva, nphy)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock goto fail;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock for (i = 0; i < nphy && nva[i] != NULL; i++)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nvlist_free(nva[i]);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses_free(nva);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockfail:
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock for (i = 0; i < nphy && nva[i] != NULL; i++)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nvlist_free(nva[i]);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses_free(nva);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (nverr);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic const struct aes_parser {
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_element_type_t type;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int (*func)(const ses2_aes_descr_eip_impl_t *, nvlist_t *, size_t);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock} aes_parsers[] = {
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_DEVICE, elem_parse_aes_device },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_SCSI_TARGET_PORT, elem_parse_aes_misc },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_SCSI_INITIATOR_PORT, elem_parse_aes_misc },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_ESC_ELECTRONICS, elem_parse_aes_misc },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_ARRAY_DEVICE, elem_parse_aes_device },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { SES_ET_SAS_EXPANDER, elem_parse_aes_expander },
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock { (ses2_element_type_t)-1, NULL }
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock};
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_aes(ses_plugin_t *sp, ses_node_t *np)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_aes_descr_eip_impl_t *dep;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nvlist_t *props = ses_node_props(np);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock const struct aes_parser *app;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock uint64_t type;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock size_t len;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (ses_node_type(np) == SES_NODE_AGGREGATE)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock VERIFY(nvlist_lookup_uint64(props, SES_PROP_ELEMENT_TYPE,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock &type) == 0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock for (app = &aes_parsers[0]; app->func != NULL; app++)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (app->type == type)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock break;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if (app->func == NULL)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((dep = ses_plugin_page_lookup(sp, ses_node_snapshot(np),
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES2_DIAGPAGE_ADDL_ELEM_STATUS, np, &len)) == NULL)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (app->func(dep, props, len));
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockstatic int
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockelem_parse_threshold(ses_plugin_t *sp, ses_node_t *np)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses_snap_t *snap = ses_node_snapshot(np);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock ses2_threshold_impl_t *tp;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock nvlist_t *nvl = ses_node_props(np);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int nverr;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock uint64_t type;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock size_t len;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock VERIFY(nvlist_lookup_uint64(nvl, SES_PROP_ELEMENT_TYPE,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock &type) == 0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock switch (type) {
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock case SES_ET_TEMPERATURE_SENSOR:
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock case SES_ET_UPS:
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock case SES_ET_VOLTAGE_SENSOR:
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock case SES_ET_CURRENT_SENSOR:
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock break;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock default:
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock }
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((tp = ses_plugin_page_lookup(sp, snap,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES2_DIAGPAGE_THRESHOLD_IO, np, &len)) == NULL)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_PROP_THRESH_CRIT_HI,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock tp->sti_high_crit);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_PROP_THRESH_WARN_HI,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock tp->sti_high_warn);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_PROP_THRESH_CRIT_LO,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock tp->sti_low_crit);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock SES_NV_ADD(uint64, nverr, nvl, SES_PROP_THRESH_WARN_LO,
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock tp->sti_low_warn);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockint
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrockses2_fill_element_node(ses_plugin_t *sp, ses_node_t *np)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock{
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock int err;
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((err = elem_parse_sd(sp, np)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (err);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((err = elem_parse_descr(sp, np)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (err);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((err = elem_parse_aes(sp, np)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (err);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock if ((err = elem_parse_threshold(sp, np)) != 0)
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (err);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock return (0);
275c9da86e89f8abf71135cf63d9fc23671b2e60eschrock}