1*03831d35Sstevel /* 2*03831d35Sstevel * CDDL HEADER START 3*03831d35Sstevel * 4*03831d35Sstevel * The contents of this file are subject to the terms of the 5*03831d35Sstevel * Common Development and Distribution License (the "License"). 6*03831d35Sstevel * You may not use this file except in compliance with the License. 7*03831d35Sstevel * 8*03831d35Sstevel * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9*03831d35Sstevel * or http://www.opensolaris.org/os/licensing. 10*03831d35Sstevel * See the License for the specific language governing permissions 11*03831d35Sstevel * and limitations under the License. 12*03831d35Sstevel * 13*03831d35Sstevel * When distributing Covered Code, include this CDDL HEADER in each 14*03831d35Sstevel * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15*03831d35Sstevel * If applicable, add the following below this CDDL HEADER, with the 16*03831d35Sstevel * fields enclosed by brackets "[]" replaced with your own identifying 17*03831d35Sstevel * information: Portions Copyright [yyyy] [name of copyright owner] 18*03831d35Sstevel * 19*03831d35Sstevel * CDDL HEADER END 20*03831d35Sstevel */ 21*03831d35Sstevel 22*03831d35Sstevel /* 23*03831d35Sstevel * Copyright 2001 Sun Microsystems, Inc. All rights reserved. 24*03831d35Sstevel * Use is subject to license terms. 25*03831d35Sstevel */ 26*03831d35Sstevel 27*03831d35Sstevel #ifndef _SBDP_MBOX_H 28*03831d35Sstevel #define _SBDP_MBOX_H 29*03831d35Sstevel 30*03831d35Sstevel #pragma ident "%Z%%M% %I% %E% SMI" 31*03831d35Sstevel 32*03831d35Sstevel #ifdef __cplusplus 33*03831d35Sstevel extern "C" { 34*03831d35Sstevel #endif 35*03831d35Sstevel 36*03831d35Sstevel #define SBDP_POWER_OFF 0x0 37*03831d35Sstevel #define SBDP_POWER_ON 0x1 38*03831d35Sstevel #define SBDP_UNASSIGN 0x0 39*03831d35Sstevel #define SBDP_ASSIGN 0x1 40*03831d35Sstevel 41*03831d35Sstevel /* 42*03831d35Sstevel * DR Mailbox definitions 43*03831d35Sstevel */ 44*03831d35Sstevel #define DR_MBOX_SHOW_BOARD 0x2002 45*03831d35Sstevel #define DR_MBOX_POWER 0x2003 46*03831d35Sstevel #define DR_MBOX_ASSIGN 0x2004 47*03831d35Sstevel #define DR_MBOX_TEST_BD 0x2005 48*03831d35Sstevel #define DR_MBOX_STICK_ADM 0x2006 49*03831d35Sstevel #define DR_MBOX_SWAP_SLICES 0x2007 50*03831d35Sstevel #define DR_MBOX_START_CPU 0x2008 51*03831d35Sstevel #define DR_MBOX_STOP_CPU 0x2009 52*03831d35Sstevel #define DR_MBOX_START_CPU_PAIRS 0x2010 53*03831d35Sstevel #define DR_MBOX_CLAIM 0x2011 54*03831d35Sstevel #define DR_MBOX_UNCLAIM 0x2012 55*03831d35Sstevel #define DR_MBOX_NOOP 0x2013 56*03831d35Sstevel 57*03831d35Sstevel /* 58*03831d35Sstevel * DR Mailbox data structures 59*03831d35Sstevel */ 60*03831d35Sstevel typedef struct { 61*03831d35Sstevel int revision; /* temp */ 62*03831d35Sstevel int node; /* Node ID */ 63*03831d35Sstevel int board; /* Board number */ 64*03831d35Sstevel int extra; /* for assign and power */ 65*03831d35Sstevel } info2_t; 66*03831d35Sstevel 67*03831d35Sstevel typedef struct { 68*03831d35Sstevel info2_t info; /* Normal information */ 69*03831d35Sstevel uint32_t flag; /* Force operation */ 70*03831d35Sstevel } testb_t; 71*03831d35Sstevel 72*03831d35Sstevel typedef struct { 73*03831d35Sstevel int revision; /* temp */ 74*03831d35Sstevel int node; /* Node ID */ 75*03831d35Sstevel int board; /* Board number */ 76*03831d35Sstevel } info_t; 77*03831d35Sstevel 78*03831d35Sstevel typedef struct { 79*03831d35Sstevel int revision; 80*03831d35Sstevel int s_cond; /* 0 = unknown, 1 = ok, 2 = failing, */ 81*03831d35Sstevel /* 3 = failed, 4 = unusable */ 82*03831d35Sstevel int s_power; /* 0 = off, 1 = on */ 83*03831d35Sstevel int s_assigned; /* 0 = unassigned, 1 = assigned */ 84*03831d35Sstevel int s_claimed; /* 0 = unclaimed, 1 = claimed */ 85*03831d35Sstevel int s_present; /* 0 = slot empty 1 = present */ 86*03831d35Sstevel int s_ledstatus; /* LEDs status */ 87*03831d35Sstevel char s_type[12]; /* type of board */ 88*03831d35Sstevel char s_info[64]; /* TBD */ 89*03831d35Sstevel } show_board_t; 90*03831d35Sstevel 91*03831d35Sstevel typedef struct { 92*03831d35Sstevel int board1; 93*03831d35Sstevel int board2; 94*03831d35Sstevel } swap_slices_t; 95*03831d35Sstevel 96*03831d35Sstevel 97*03831d35Sstevel int sbdp_start_cpu(processorid_t); 98*03831d35Sstevel int sbdp_start_cpu_pairs(processorid_t); 99*03831d35Sstevel int sbdp_stop_cpu(processorid_t); 100*03831d35Sstevel 101*03831d35Sstevel #ifdef __cplusplus 102*03831d35Sstevel } 103*03831d35Sstevel #endif 104*03831d35Sstevel 105*03831d35Sstevel #endif /* _SBDP_MBOX_H */ 106