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#ifndef _GMEM_MEM_H
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define _GMEM_MEM_H
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport/*
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * Support routines for managing state related to memory modules.
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * Correctable errors generally cause changes to the DIMM-related state.
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport */
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <gmem.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <gmem_page.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <gmem_state.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <gmem_fmri.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#include <sys/errclassify.h>
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#ifdef __cplusplus
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportextern "C" {
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#endif
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define GMEM_ERPT_PAYLOAD_DIAGNOSE "diagnose"
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define GMEM_ERPT_PAYLOAD_RESOURCE "resource"
d4ac42a1cd3016618a9ba0330862d410f0058f89Trang Do#define GMEM_ERPT_PAYLOAD_DETECTOR "detector"
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define GMEM_ERPT_PAYLOAD_PHYSADDR "phys-addr"
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define GMEM_ERPT_PAYLOAD_OFFSET "offset"
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define GMEM_ERPT_PAYLOAD_SERDN "serd_n"
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define GMEM_ERPT_PAYLOAD_SERDT "serd_t"
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define GMEM_ERPT_PAYLOAD_SYMBOLPOS "symbol-pos"
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define GMEM_ERPT_PAYLOAD_DRAM "dram"
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define GMEM_ERPT_PAYLOAD_FILTER_RATIO "filter_ratio"
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define GMEM_ERPT_PAYLOAD_CKW "relative-ckword"
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define GMEM_F_FAULTING 0x1
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define GMEM_FAULT_DIMM_PAGES "fault.memory.dimm-page-retires-excessive"
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define GMEM_FAULT_DIMM_4A "fault.memory.dimm-ue-imminent"
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define GMEM_FAULT_DIMM_4B "fault.memory.dram-ue-imminent"
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define GMEM_FAULT_PAGE "fault.memory.page"
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define INVALID_DRAM -1
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define DEFAULT_SERDN 0x2
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#define DEFAULT_SERDT 0xebbdb3ed0000ULL
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenporttypedef struct gmem_dimm gmem_dimm_t;
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport/*
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * Correctable memory errors
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * "unknown symbol" (mem-us) and "intermittent symbol" (mem-is) CEs are
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * not used in diagnosis, except for rules 4A & 4B checking.
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport *
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * "clearable symbol" (mem-cs) CEs are added to the SERD engines. When the
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * engine the page corresponding to the CE that caused the engine to
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * fire is retired
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport *
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport * "sticky symbol" (mem-ss) CEs trigger immediate page retirement.
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport *
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport */
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportextern gmem_evdisp_t gmem_ce(fmd_hdl_t *, fmd_event_t *, nvlist_t *,
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport const char *);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportextern void gmem_dimm_close(fmd_hdl_t *, void *);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportextern void gmem_mem_case_restore(fmd_hdl_t *, gmem_case_t *, fmd_case_t *,
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport const char *, const char *);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportextern char *gmem_mem_serdnm_create(fmd_hdl_t *, const char *, const char *);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportextern char *gmem_page_serdnm_create(fmd_hdl_t *, const char *, uint64_t);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportextern char *gmem_mq_serdnm_create(fmd_hdl_t *, const char *, uint64_t,
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport uint16_t, uint16_t);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportextern void gmem_page_serd_create(fmd_hdl_t *, gmem_page_t *, nvlist_t *);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportextern uint32_t gmem_get_serd_filter_ratio(nvlist_t *);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportextern int gmem_serd_record(fmd_hdl_t *, const char *, uint32_t, fmd_event_t *);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportextern void gmem_mem_retirestat_create(fmd_hdl_t *, fmd_stat_t *, const char *,
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport uint64_t, const char *);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportextern void gmem_mem_gc(fmd_hdl_t *);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenportextern void gmem_mem_fini(fmd_hdl_t *);
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#ifdef __cplusplus
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport}
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#endif
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport
1529f529004c61fcfd0d95ab79b0f257d6ad4451Scott Davenport#endif /* _GMEM_MEM_H */