491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun/*
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun * CDDL HEADER START
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun *
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun * The contents of this file are subject to the terms of the
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun * Common Development and Distribution License (the "License").
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun * You may not use this file except in compliance with the License.
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun *
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun * or http://www.opensolaris.org/os/licensing.
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun * See the License for the specific language governing permissions
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun * and limitations under the License.
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun *
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun * When distributing Covered Code, include this CDDL HEADER in each
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun * If applicable, add the following below this CDDL HEADER, with the
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun * fields enclosed by brackets "[]" replaced with your own identifying
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun * information: Portions Copyright [yyyy] [name of copyright owner]
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun *
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun * CDDL HEADER END
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun */
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun/*
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved.
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun */
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun/*
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * FMA capability messenger
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun *
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * fdd-msg module is called once when fmd starts up. It does the following
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * based on different scenarios
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun *
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * 1. If it's on a x86 platform, fdd-msg module sends fdd running on service
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * processor a message (ILOM) which indicates the Solaris host FMA capability.
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * The message is sent via the BMC driver (KCS interface) to the IPMI stack
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * of ILOM using the IPMI Sun OEM core tunnel command. The sub-command is
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * CORE_TUNNEL_SUBCMD_HOSTCAP. The IPMI stack posts an host FMA capability
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * event to the event manager upon receiving this message. fdd subscribes to
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * the event manager for this event. Upon receving this event, fdd will adjust
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * its configuration.
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan *
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * 2. If it's on a Sparc platform, fdd-msg module just exit for now.
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun */
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun#include <errno.h>
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun#include <stdio.h>
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun#include <strings.h>
dfe4040d6edf92f7d63a1cbac17c5da83512671bLuping Quan#include <sys/systeminfo.h>
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun#include <libipmi.h>
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan#include <sys/devfm.h>
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun#include <fm/fmd_api.h>
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan#if defined(__x86)
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan#include <sys/x86_archext.h>
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan#include <fm/fmd_agent.h>
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan#include <libnvpair.h>
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan#endif
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun#define CMD_SUNOEM_CORE_TUNNEL 0x44
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun#define CORE_TUNNEL_SUBCMD_HOSTFMACAP 2
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun#define OEM_DATA_LENGTH 3
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun#define VERSION 0x10
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan#if defined(__x86)
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quantypedef struct cpu_tbl {
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan char vendor[X86_VENDOR_STRLEN];
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan int32_t family;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan int32_t model;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan char *propname;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan} cpu_tbl_t;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quanstatic cpu_tbl_t fma_cap_list[] = {
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan {"GenuineIntel", 6, 26, "NHMEP_fma_cap"},
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan {"GenuineIntel", 6, 46, "NHMEX_fma_cap"},
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan {"GenuineIntel", 6, 44, "WSMEP_fma_cap"},
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan {"GenuineIntel", 6, 47, "INTLN_fma_cap"},
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan {NULL, 0, 0, NULL}
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan};
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan#endif
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sunstatic int
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Suncheck_sunoem(ipmi_handle_t *ipmi_hdl)
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun{
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun ipmi_deviceid_t *devid;
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun if ((devid = ipmi_get_deviceid(ipmi_hdl)) == NULL)
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun return (-1);
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun if (!ipmi_is_sun_ilom(devid))
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun return (-2);
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun return (0);
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun}
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan#if defined(__x86)
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quanstatic int32_t
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quanfma_cap_cpu_info(cpu_tbl_t *ci)
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan{
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan nvlist_t **cpus, *nvl;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan uint_t ncpu, i;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan fmd_agent_hdl_t *hdl;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan char *ven;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan int32_t family, model;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan if ((hdl = fmd_agent_open(FMD_AGENT_VERSION)) == NULL)
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan return (-1);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan if (fmd_agent_physcpu_info(hdl, &cpus, &ncpu) != 0) {
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan fmd_agent_close(hdl);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan return (-1);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan }
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan fmd_agent_close(hdl);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan if (cpus == NULL)
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan return (-1);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan /*
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * There is no mixed CPU type on x86 systems, it's ok to
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * just pick the first one
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan */
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan nvl = cpus[0];
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan if (nvlist_lookup_string(nvl, FM_PHYSCPU_INFO_VENDOR_ID, &ven) != 0 ||
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan nvlist_lookup_int32(nvl, FM_PHYSCPU_INFO_FAMILY, &family) != 0 ||
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan nvlist_lookup_int32(nvl, FM_PHYSCPU_INFO_MODEL, &model) != 0) {
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan for (i = 0; i < ncpu; i++)
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan nvlist_free(cpus[i]);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan umem_free(cpus, sizeof (nvlist_t *) * ncpu);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan return (-1);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan }
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan (void) snprintf(ci->vendor, X86_VENDOR_STRLEN, "%s", ven);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan ci->family = family;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan ci->model = model;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan for (i = 0; i < ncpu; i++)
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan nvlist_free(cpus[i]);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan umem_free(cpus, sizeof (nvlist_t *) * ncpu);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan return (0);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan}
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan#endif
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quanstatic uint32_t
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quanget_cap_conf(fmd_hdl_t *hdl)
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan{
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan uint32_t fma_cap;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan#if defined(__x86)
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan int found = 0;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan cpu_tbl_t *cl, ci;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan if (fma_cap_cpu_info(&ci) == 0) {
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan fmd_hdl_debug(hdl, "Got CPU info: vendor=%s, family=%d, "
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan "model=%d\n", ci.vendor, ci.family, ci.model);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan for (cl = fma_cap_list; cl->propname != NULL; cl++) {
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan if (strncmp(ci.vendor, cl->vendor,
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan X86_VENDOR_STRLEN) == 0 &&
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan ci.family == cl->family &&
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan ci.model == cl->model) {
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan found++;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan break;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan }
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan }
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan } else {
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan fmd_hdl_debug(hdl, "Failed to get CPU info");
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan }
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan if (found) {
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan fma_cap = fmd_prop_get_int32(hdl, cl->propname);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan fmd_hdl_debug(hdl, "Found property, FMA capability=0x%x",
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan fma_cap);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan } else {
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan#endif
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan fma_cap = fmd_prop_get_int32(hdl, "default_fma_cap");
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan fmd_hdl_debug(hdl, "Didn't find FMA capability property, "
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan "use default=0x%x", fma_cap);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan#if defined(__x86)
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan }
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan#endif
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan return (fma_cap);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan}
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sunstatic void
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quansend_fma_cap_to_ilom(fmd_hdl_t *hdl, uint32_t fma_cap)
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun{
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan int error;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan char *msg;
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun ipmi_handle_t *ipmi_hdl;
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun ipmi_cmd_t cmd;
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun uint8_t oem_data[OEM_DATA_LENGTH];
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan if ((ipmi_hdl = ipmi_open(&error, &msg, IPMI_TRANSPORT_BMC, NULL))
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan == NULL) {
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan /*
989f28072d20c73ae0955d6a1e3e2fc74831cb39Jerry Jelinek * If /dev/ipmi0 doesn't exist on the system, then return
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * without doing anything.
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan */
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan if (error != EIPMI_BMC_OPEN_FAILED)
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan fmd_hdl_abort(hdl, "Failed to initialize IPMI "
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan "connection: %s\n", msg);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan fmd_hdl_debug(hdl, "Failed: no IPMI connection present");
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan return;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan }
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan /*
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * Check if it's Sun ILOM
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan */
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan if (check_sunoem(ipmi_hdl) != 0) {
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan fmd_hdl_debug(hdl, "Service Processor does not run "
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan "Sun ILOM");
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan ipmi_close(ipmi_hdl);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan return;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan }
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun oem_data[0] = CORE_TUNNEL_SUBCMD_HOSTFMACAP;
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun oem_data[1] = VERSION;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan oem_data[2] = fma_cap;
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun cmd.ic_netfn = IPMI_NETFN_OEM;
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun cmd.ic_lun = 0;
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun cmd.ic_cmd = CMD_SUNOEM_CORE_TUNNEL;
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun cmd.ic_dlen = OEM_DATA_LENGTH;
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun cmd.ic_data = oem_data;
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun if (ipmi_send(ipmi_hdl, &cmd) == NULL) {
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun fmd_hdl_debug(hdl, "Failed to send Solaris FMA "
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan "capability to ilom: %s", ipmi_errmsg(ipmi_hdl));
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun }
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun ipmi_close(ipmi_hdl);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan}
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan/*ARGSUSED*/
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quanstatic void
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quanfma_cap_init(fmd_hdl_t *hdl, id_t id, void *data)
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan{
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan uint32_t fma_cap;
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan fma_cap = get_cap_conf(hdl);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan send_fma_cap_to_ilom(hdl, fma_cap);
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun fmd_hdl_unregister(hdl);
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun}
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sunstatic const fmd_hdl_ops_t fmd_ops = {
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun NULL, /* fmdo_recv */
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan fma_cap_init, /* fmdo_timeout */
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun NULL, /* fmdo_close */
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun NULL, /* fmdo_stats */
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun NULL, /* fmdo_gc */
dfe4040d6edf92f7d63a1cbac17c5da83512671bLuping Quan NULL, /* fmdo_send */
dfe4040d6edf92f7d63a1cbac17c5da83512671bLuping Quan NULL, /* fmdo_topo */
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun};
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sunstatic const fmd_prop_t fmd_props[] = {
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun { "interval", FMD_TYPE_TIME, "1s" },
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan { "default_fma_cap", FMD_TYPE_UINT32, "0x3" },
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan { "NHMEP_fma_cap", FMD_TYPE_UINT32, "0x3" },
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan { "NHMEX_fma_cap", FMD_TYPE_UINT32, "0x2" },
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan { "WSMEP_fma_cap", FMD_TYPE_UINT32, "0x3" },
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan { "INTLN_fma_cap", FMD_TYPE_UINT32, "0x2" },
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun { NULL, 0, NULL }
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun};
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sunstatic const fmd_hdl_info_t fmd_info = {
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan "FMA Capability Messenger", "1.1", &fmd_ops, fmd_props
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun};
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sunvoid
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun_fmd_init(fmd_hdl_t *hdl)
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun{
dfe4040d6edf92f7d63a1cbac17c5da83512671bLuping Quan char isa[8];
dfe4040d6edf92f7d63a1cbac17c5da83512671bLuping Quan
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan /*
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * For now the module only sends message to ILOM on i386 platforms
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * till CR 6933053 is fixed. Module unregister may cause etm module
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan * core dump due to 6933053.
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan */
dfe4040d6edf92f7d63a1cbac17c5da83512671bLuping Quan if ((sysinfo(SI_ARCHITECTURE, isa, sizeof (isa)) == -1) ||
dfe4040d6edf92f7d63a1cbac17c5da83512671bLuping Quan (strncmp(isa, "i386", 4) != 0))
dfe4040d6edf92f7d63a1cbac17c5da83512671bLuping Quan return;
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun if (fmd_hdl_register(hdl, FMD_API_VERSION, &fmd_info) != 0)
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun return;
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun /*
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun * Setup the timer.
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun */
dfe4040d6edf92f7d63a1cbac17c5da83512671bLuping Quan (void) fmd_timer_install(hdl, NULL, NULL, 2000000000ULL);
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun}
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun
63d763c84bef3a708cb75b6de1f5f809681e788cLuping Quan/*ARGSUSED*/
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sunvoid
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun_fmd_fini(fmd_hdl_t *hdl)
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun{
491f61a1e1c1fc54a47bbcf53dbbbe1293b93b27Yanmin Sun}