fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd/*
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * CDDL HEADER START
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd *
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * The contents of this file are subject to the terms of the
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * Common Development and Distribution License (the "License").
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * You may not use this file except in compliance with the License.
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd *
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * or http://www.opensolaris.org/os/licensing.
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * See the License for the specific language governing permissions
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * and limitations under the License.
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd *
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * When distributing Covered Code, include this CDDL HEADER in each
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * If applicable, add the following below this CDDL HEADER, with the
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * fields enclosed by brackets "[]" replaced with your own identifying
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * information: Portions Copyright [yyyy] [name of copyright owner]
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd *
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * CDDL HEADER END
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd */
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd/*
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * Copyright 2007 Sun Microsystems, Inc. All rights reserved.
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * Use is subject to license terms.
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd */
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#ifndef _CMD_BRANCH_H
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#define _CMD_BRANCH_H
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#pragma ident "%Z%%M% %I% %E% SMI"
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd/*
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * Memory modules are described by the cmd_branch general-purpose state
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * structure. This structure is used to track FBR errors
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd *
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * Data structures:
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd *
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * ,--------. ,--------.
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * |branch | <---- |case_ptr| (CMD_PTR_BRANCH_CASE)
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * | | `--------'
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * |,-------| ,-------------.
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * ,->||asru_t | ----> |packed nvlist|
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * | |`-------| `-------------'
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * `--| |
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * | dimms | ----> cmd_branch_memb_t -----> cmd_branch_memb_t -----> ...
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * `--------' | |
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * cmd_dimm_t cmd_dimm_t
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd *
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * Data structure P? Case? Notes
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * ---------------- --- ----- ----------------------------------------------
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * cmd_branch_pers_t Yes No Name is derived from the unum ("branch_%s")
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * cmd_case_ptr_t Yes Yes Name is case's UUID
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * branch_asru Yes No Name is derived from the unum
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * ("branch_asru_%d")
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * branch_unum No No Pointer into ASRU - relinked during restore
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd * branch_dimms No No Recreated during restore
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd */
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#include <cmd_mem.h>
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#ifdef __cplusplus
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sdextern "C" {
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#endif
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#define MAX_CHANNELS_ON_CHIP 4
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#define MAX_DIMMS_IN_CHANNEL 4
13faa91230bde46da937bf33010b9accc5bdeb59sd#define BTK_MAX_CHANNEL 2
13faa91230bde46da937bf33010b9accc5bdeb59sd#define CMD_BOARDS_CERT 30
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sdtypedef struct cmd_branch_memb {
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd cmd_list_t bm_list;
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd cmd_dimm_t *dimm;
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd} cmd_branch_memb_t;
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#define CMD_BRANCH_VERSION_0 0
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#define CMD_BRANCH_VERSION CMD_BRANCH_VERSION_0
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sdtypedef struct cmd_branch_pers {
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd cmd_header_t branchp_header; /* Nodetype must be CMD_NT_BRANCH */
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd uint_t branchp_version;
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd cmd_fmri_t branchp_asru; /* ASRU for this BRANCH */
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd uint_t branchp_flags; /* CMD_MEM_F_* */
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd} cmd_branch_pers_t;
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sdstruct cmd_branch {
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd cmd_branch_pers_t branch_pers;
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd const char *branch_unum; /* This BRANCH's name */
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd cmd_case_t branch_case; /* Open link errors case against */
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd /* this BRANCH */
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd cmd_list_t branch_dimms; /* This BRANCH's dimms */
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd};
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#define CMD_BRANCH_MAXSIZE sizeof (cmd_branch_pers_t)
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#define CMD_BRANCH_MINSIZE sizeof (cmd_branch_pers_t)
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#define branch_header branch_pers.branchp_header
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#define branch_nodetype branch_pers.branchp_header.hdr_nodetype
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#define branch_bufname branch_pers.branchp_header.hdr_bufname
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#define branch_version branch_pers.branchp_version
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#define branch_asru branch_pers.branchp_asru
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#define branch_asru_nvl branch_pers.branchp_asru.fmri_nvl
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#define branch_flags branch_pers.branchp_flags
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sdextern cmd_branch_t *cmd_branch_lookup(fmd_hdl_t *, nvlist_t *);
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sdextern cmd_branch_t *cmd_branch_create(fmd_hdl_t *, nvlist_t *);
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sdextern cmd_branch_t *cmd_branch_lookup_by_unum(fmd_hdl_t *, const char *);
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sdextern void cmd_branch_create_fault(fmd_hdl_t *, cmd_branch_t *,
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd const char *, nvlist_t *);
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sdextern void cmd_branch_add_dimm(fmd_hdl_t *, cmd_branch_t *, cmd_dimm_t *);
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sdextern void cmd_branch_remove_dimm(fmd_hdl_t *, cmd_branch_t *, cmd_dimm_t *);
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sdextern void *cmd_branch_restore(fmd_hdl_t *, fmd_case_t *, cmd_case_ptr_t *);
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sdextern void cmd_branch_destroy(fmd_hdl_t *, cmd_branch_t *);
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sdextern void cmd_branch_validate(fmd_hdl_t *);
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sdextern void cmd_branch_gc(fmd_hdl_t *);
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sdextern void cmd_branch_fini(fmd_hdl_t *);
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sdextern void cmd_branch_dirty(fmd_hdl_t *, cmd_branch_t *);
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#ifdef __cplusplus
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd}
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#endif
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd
fbd1c0dae6f4a2ccc2ce0527c7f19d3dd5ea90b8sd#endif /* _CMD_BRANCH_H */