03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * CDDL HEADER START
03831d35f7499c87d51205817c93e9a8d42c4baestevel *
03831d35f7499c87d51205817c93e9a8d42c4baestevel * The contents of this file are subject to the terms of the
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Common Development and Distribution License (the "License").
03831d35f7499c87d51205817c93e9a8d42c4baestevel * You may not use this file except in compliance with the License.
03831d35f7499c87d51205817c93e9a8d42c4baestevel *
03831d35f7499c87d51205817c93e9a8d42c4baestevel * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
03831d35f7499c87d51205817c93e9a8d42c4baestevel * or http://www.opensolaris.org/os/licensing.
03831d35f7499c87d51205817c93e9a8d42c4baestevel * See the License for the specific language governing permissions
03831d35f7499c87d51205817c93e9a8d42c4baestevel * and limitations under the License.
03831d35f7499c87d51205817c93e9a8d42c4baestevel *
03831d35f7499c87d51205817c93e9a8d42c4baestevel * When distributing Covered Code, include this CDDL HEADER in each
03831d35f7499c87d51205817c93e9a8d42c4baestevel * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
03831d35f7499c87d51205817c93e9a8d42c4baestevel * If applicable, add the following below this CDDL HEADER, with the
03831d35f7499c87d51205817c93e9a8d42c4baestevel * fields enclosed by brackets "[]" replaced with your own identifying
03831d35f7499c87d51205817c93e9a8d42c4baestevel * information: Portions Copyright [yyyy] [name of copyright owner]
03831d35f7499c87d51205817c93e9a8d42c4baestevel *
03831d35f7499c87d51205817c93e9a8d42c4baestevel * CDDL HEADER END
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Copyright 2001 Sun Microsystems, Inc. All rights reserved.
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Use is subject to license terms.
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel#ifndef _SBDP_MBOX_H
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define _SBDP_MBOX_H
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel#pragma ident "%Z%%M% %I% %E% SMI"
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel#ifdef __cplusplus
03831d35f7499c87d51205817c93e9a8d42c4baestevelextern "C" {
03831d35f7499c87d51205817c93e9a8d42c4baestevel#endif
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SBDP_POWER_OFF 0x0
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SBDP_POWER_ON 0x1
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SBDP_UNASSIGN 0x0
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SBDP_ASSIGN 0x1
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * DR Mailbox definitions
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define DR_MBOX_SHOW_BOARD 0x2002
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define DR_MBOX_POWER 0x2003
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define DR_MBOX_ASSIGN 0x2004
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define DR_MBOX_TEST_BD 0x2005
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define DR_MBOX_STICK_ADM 0x2006
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define DR_MBOX_SWAP_SLICES 0x2007
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define DR_MBOX_START_CPU 0x2008
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define DR_MBOX_STOP_CPU 0x2009
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define DR_MBOX_START_CPU_PAIRS 0x2010
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define DR_MBOX_CLAIM 0x2011
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define DR_MBOX_UNCLAIM 0x2012
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define DR_MBOX_NOOP 0x2013
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * DR Mailbox data structures
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baesteveltypedef struct {
03831d35f7499c87d51205817c93e9a8d42c4baestevel int revision; /* temp */
03831d35f7499c87d51205817c93e9a8d42c4baestevel int node; /* Node ID */
03831d35f7499c87d51205817c93e9a8d42c4baestevel int board; /* Board number */
03831d35f7499c87d51205817c93e9a8d42c4baestevel int extra; /* for assign and power */
03831d35f7499c87d51205817c93e9a8d42c4baestevel} info2_t;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baesteveltypedef struct {
03831d35f7499c87d51205817c93e9a8d42c4baestevel info2_t info; /* Normal information */
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t flag; /* Force operation */
03831d35f7499c87d51205817c93e9a8d42c4baestevel} testb_t;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baesteveltypedef struct {
03831d35f7499c87d51205817c93e9a8d42c4baestevel int revision; /* temp */
03831d35f7499c87d51205817c93e9a8d42c4baestevel int node; /* Node ID */
03831d35f7499c87d51205817c93e9a8d42c4baestevel int board; /* Board number */
03831d35f7499c87d51205817c93e9a8d42c4baestevel} info_t;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baesteveltypedef struct {
03831d35f7499c87d51205817c93e9a8d42c4baestevel int revision;
03831d35f7499c87d51205817c93e9a8d42c4baestevel int s_cond; /* 0 = unknown, 1 = ok, 2 = failing, */
03831d35f7499c87d51205817c93e9a8d42c4baestevel /* 3 = failed, 4 = unusable */
03831d35f7499c87d51205817c93e9a8d42c4baestevel int s_power; /* 0 = off, 1 = on */
03831d35f7499c87d51205817c93e9a8d42c4baestevel int s_assigned; /* 0 = unassigned, 1 = assigned */
03831d35f7499c87d51205817c93e9a8d42c4baestevel int s_claimed; /* 0 = unclaimed, 1 = claimed */
03831d35f7499c87d51205817c93e9a8d42c4baestevel int s_present; /* 0 = slot empty 1 = present */
03831d35f7499c87d51205817c93e9a8d42c4baestevel int s_ledstatus; /* LEDs status */
03831d35f7499c87d51205817c93e9a8d42c4baestevel char s_type[12]; /* type of board */
03831d35f7499c87d51205817c93e9a8d42c4baestevel char s_info[64]; /* TBD */
03831d35f7499c87d51205817c93e9a8d42c4baestevel} show_board_t;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baesteveltypedef struct {
03831d35f7499c87d51205817c93e9a8d42c4baestevel int board1;
03831d35f7499c87d51205817c93e9a8d42c4baestevel int board2;
03831d35f7499c87d51205817c93e9a8d42c4baestevel} swap_slices_t;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevelint sbdp_start_cpu(processorid_t);
03831d35f7499c87d51205817c93e9a8d42c4baestevelint sbdp_start_cpu_pairs(processorid_t);
03831d35f7499c87d51205817c93e9a8d42c4baestevelint sbdp_stop_cpu(processorid_t);
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel#ifdef __cplusplus
03831d35f7499c87d51205817c93e9a8d42c4baestevel}
03831d35f7499c87d51205817c93e9a8d42c4baestevel#endif
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel#endif /* _SBDP_MBOX_H */