1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport/*
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * CDDL HEADER START
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport *
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * The contents of this file are subject to the terms of the
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * Common Development and Distribution License (the "License").
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * You may not use this file except in compliance with the License.
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport *
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * or http://www.opensolaris.org/os/licensing.
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * See the License for the specific language governing permissions
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * and limitations under the License.
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport *
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * When distributing Covered Code, include this CDDL HEADER in each
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * If applicable, add the following below this CDDL HEADER, with the
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * fields enclosed by brackets "[]" replaced with your own identifying
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * information: Portions Copyright [yyyy] [name of copyright owner]
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport *
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * CDDL HEADER END
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport */
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport/*
d4ac42a1cd3016618a9ba0330862d410f0058f89Trang Do * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport */
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <gmem_state.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <gmem_mem.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <gmem_page.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <gmem_dimm.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <gmem.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <errno.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <string.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <unistd.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <strings.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <fm/fmd_api.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <fm/libtopo.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <sys/fm/protocol.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <sys/async.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportgmem_t gmem;
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenporttypedef struct gmem_subscriber {
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport const char *subr_class;
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem_evdisp_t (*subr_func)(fmd_hdl_t *, fmd_event_t *, nvlist_t *,
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport const char *);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem_evdisp_stat_t subr_stat;
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport} gmem_subscriber_t;
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportstatic gmem_subscriber_t gmem_subscribers[] = {
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "ereport.cpu.generic-sparc.mem-is", gmem_ce },
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "ereport.cpu.generic-sparc.mem-unk", gmem_ce },
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "ereport.cpu.generic-sparc.mem-cs", gmem_ce },
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "ereport.cpu.generic-sparc.mem-ss", gmem_ce },
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { NULL, NULL }
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport};
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportstatic void
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportgmem_recv(fmd_hdl_t *hdl, fmd_event_t *ep, nvlist_t *nvl, const char *class)
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport{
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem_subscriber_t *sp;
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport int disp;
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport fmd_hdl_debug(hdl, "gmem_recv: begin: %s\n", strrchr(class, '.') + 1);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport for (sp = gmem_subscribers; sp->subr_class != NULL; sp++) {
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport if (fmd_nvl_class_match(hdl, nvl, sp->subr_class)) {
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport disp = sp->subr_func(hdl, ep, nvl, class);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport ((fmd_stat_t *)&sp->subr_stat)[disp].fmds_value.ui64++;
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport fmd_hdl_debug(hdl, "gmem_recv: done: %s (disp %d)\n",
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport strrchr(class, '.') + 1, disp);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport return;
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport }
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport }
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport fmd_hdl_debug(hdl, "gmem_recv: dropping %s - unable to handle\n",
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport class);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport}
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportstatic void
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportgmem_close(fmd_hdl_t *hdl, fmd_case_t *cp)
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport{
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem_case_closer_t *cl = fmd_case_getspecific(hdl, cp);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport const char *uuid = fmd_case_uuid(hdl, cp);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport /*
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * Our active cases all have closers registered in case-specific data.
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * Cases in the process of closing (for which we've freed all associated
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * data, but which haven't had an fmd-initiated fmdo_close callback)
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * have had their case-specific data nulled out.
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport */
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport fmd_hdl_debug(hdl, "close case %s%s\n", uuid,
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport (cl == NULL ? " (no cl)" : ""));
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport if (cl != NULL)
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport cl->cl_func(hdl, cl->cl_arg);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport}
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportstatic void
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportgmem_gc(fmd_hdl_t *hdl)
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport{
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem_mem_gc(hdl);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport}
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportstatic gmem_stat_t gm_stats = {
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "bad_mem_resource", FMD_TYPE_UINT64,
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport "memory resource missing or malformed" },
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "bad_close", FMD_TYPE_UINT64, "case close for nonexistent case" },
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "old_erpt", FMD_TYPE_UINT64, "ereport out of date wrt hardware" },
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "dimm_creat", FMD_TYPE_UINT64, "created new mem module structure" },
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "page_creat", FMD_TYPE_UINT64, "created new page structure" },
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "ce_unknown", FMD_TYPE_UINT64, "unknown CEs" },
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "ce_interm", FMD_TYPE_UINT64, "intermittent CEs" },
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "ce_clearable_persis", FMD_TYPE_UINT64, "clearable persistent CEs" },
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "ce_sticky", FMD_TYPE_UINT64, "sticky CEs" },
d4ac42a1cd3016618a9ba0330862d410f0058f89Trang Do { "dimm_migrat", FMD_TYPE_UINT64, "DIMMs migrated to new version" }
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport};
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportstatic const fmd_prop_t fmd_props[] = {
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "ce_n", FMD_TYPE_UINT32, "3" },
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "ce_t", FMD_TYPE_TIME, "72h" },
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "filter_ratio", FMD_TYPE_UINT32, "0" },
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "max_retired_pages", FMD_TYPE_UINT32, "512" },
d4ac42a1cd3016618a9ba0330862d410f0058f89Trang Do { "low_ce_thresh", FMD_TYPE_UINT32, "128"},
d4ac42a1cd3016618a9ba0330862d410f0058f89Trang Do { "nupos", FMD_TYPE_UINT32, "4"},
d4ac42a1cd3016618a9ba0330862d410f0058f89Trang Do { "dupce", FMD_TYPE_UINT32, "120"},
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { NULL, 0, NULL }
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport};
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportstatic const fmd_hdl_ops_t fmd_ops = {
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem_recv, /* fmdo_recv */
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport NULL,
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem_close, /* fmdo_close */
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport NULL, /* fmdo_stats */
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem_gc /* fmdo_gc */
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport};
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportstatic const fmd_hdl_info_t fmd_info = {
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport "SPARC-Generic-Memory Diagnosis", GMEM_VERSION, &fmd_ops, fmd_props
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport};
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportstatic const struct gmem_evdisp_name {
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport const char *evn_name;
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport const char *evn_desc;
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport} gmem_evdisp_names[] = {
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "%s", "ok %s ereports" }, /* GMEM_EVD_OK */
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "bad_%s", "bad %s ereports" }, /* GMEM_EVD_BAD */
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "unused_%s", "unused %s ereports" }, /* GMEM_EVD_UNUSED */
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport { "redun_%s", "redundant %s ereports" }, /* GMEM_EVD_REDUN */
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport};
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportvoid
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport_fmd_fini(fmd_hdl_t *hdl)
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport{
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem_mem_fini(hdl);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem_page_fini(hdl);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport}
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportvoid
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport_fmd_init(fmd_hdl_t *hdl)
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport{
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem_subscriber_t *sp;
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport if (fmd_hdl_register(hdl, FMD_API_VERSION, &fmd_info) != 0)
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport return; /* error in configuration file or fmd_info */
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport for (sp = gmem_subscribers; sp->subr_class != NULL; sp++)
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport fmd_hdl_subscribe(hdl, sp->subr_class);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport bzero(&gmem, sizeof (gmem_t));
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem.gm_stats = (gmem_stat_t *)fmd_stat_create(hdl, FMD_STAT_NOALLOC,
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport sizeof (gm_stats) / sizeof (fmd_stat_t),
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport (fmd_stat_t *)&gm_stats);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport for (sp = gmem_subscribers; sp->subr_class != NULL; sp++) {
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport const char *type = strrchr(sp->subr_class, '.') + 1;
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport int i;
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport for (i = 0; i < sizeof (gmem_evdisp_names) /
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport sizeof (struct gmem_evdisp_name); i++) {
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport fmd_stat_t *stat = ((fmd_stat_t *)&sp->subr_stat) + i;
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport (void) snprintf(stat->fmds_name,
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport sizeof (stat->fmds_name),
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem_evdisp_names[i].evn_name, type);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport stat->fmds_type = FMD_TYPE_UINT64;
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport (void) snprintf(stat->fmds_desc,
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport sizeof (stat->fmds_desc),
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem_evdisp_names[i].evn_desc, type);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport (void) fmd_stat_create(hdl, FMD_STAT_NOALLOC, 1, stat);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport }
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport }
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem.gm_pagesize = sysconf(_SC_PAGESIZE);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem.gm_pagemask = ~((uint64_t)gmem.gm_pagesize - 1);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem.gm_max_retired_pages = fmd_prop_get_int32(hdl,
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport "max_retired_pages");
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem.gm_ce_n = fmd_prop_get_int32(hdl, "ce_n");
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem.gm_ce_t = fmd_prop_get_int64(hdl, "ce_t");
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport gmem.gm_filter_ratio = fmd_prop_get_int32(hdl, "filter_ratio");
d4ac42a1cd3016618a9ba0330862d410f0058f89Trang Do gmem.gm_low_ce_thresh = fmd_prop_get_int32(hdl, "low_ce_thresh");
d4ac42a1cd3016618a9ba0330862d410f0058f89Trang Do gmem.gm_nupos = fmd_prop_get_int32(hdl, "nupos");
d4ac42a1cd3016618a9ba0330862d410f0058f89Trang Do gmem.gm_dupce = fmd_prop_get_int32(hdl, "dupce");
d4ac42a1cd3016618a9ba0330862d410f0058f89Trang Do
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport if (gmem_state_restore(hdl) < 0) {
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport _fmd_fini(hdl);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport fmd_hdl_abort(hdl, "failed to restore saved state\n");
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport }
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport}