1*1708Sstevel /* 2*1708Sstevel * CDDL HEADER START 3*1708Sstevel * 4*1708Sstevel * The contents of this file are subject to the terms of the 5*1708Sstevel * Common Development and Distribution License (the "License"). 6*1708Sstevel * You may not use this file except in compliance with the License. 7*1708Sstevel * 8*1708Sstevel * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9*1708Sstevel * or http://www.opensolaris.org/os/licensing. 10*1708Sstevel * See the License for the specific language governing permissions 11*1708Sstevel * and limitations under the License. 12*1708Sstevel * 13*1708Sstevel * When distributing Covered Code, include this CDDL HEADER in each 14*1708Sstevel * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15*1708Sstevel * If applicable, add the following below this CDDL HEADER, with the 16*1708Sstevel * fields enclosed by brackets "[]" replaced with your own identifying 17*1708Sstevel * information: Portions Copyright [yyyy] [name of copyright owner] 18*1708Sstevel * 19*1708Sstevel * CDDL HEADER END 20*1708Sstevel */ 21*1708Sstevel 22*1708Sstevel /* 23*1708Sstevel * Copyright 2000 Sun Microsystems, Inc. All rights reserved. 24*1708Sstevel * Use is subject to license terms. 25*1708Sstevel */ 26*1708Sstevel 27*1708Sstevel #ifndef _MONTERCARLO_SYS_SCSBIOCTL_H 28*1708Sstevel #define _MONTERCARLO_SYS_SCSBIOCTL_H 29*1708Sstevel 30*1708Sstevel #pragma ident "%Z%%M% %I% %E% SMI" 31*1708Sstevel 32*1708Sstevel #ifdef __cplusplus 33*1708Sstevel extern "C" { 34*1708Sstevel #endif 35*1708Sstevel 36*1708Sstevel /* 37*1708Sstevel * SCB HW information, which is needed in scsb.h for scsb.c. 38*1708Sstevel * there are 32 data registers on the system controller board 39*1708Sstevel * most are used in P1.0, all are used in P1.5 40*1708Sstevel */ 41*1708Sstevel #define SCSB_DATA_REGISTERS 48 42*1708Sstevel 43*1708Sstevel 44*1708Sstevel #define _SCSBIOC ('s' << 8) 45*1708Sstevel 46*1708Sstevel #define SCSBIOC_GET_STATUS (_SCSBIOC | 1) /* Internal */ 47*1708Sstevel #define SCSBIOC_I2C_XFER (_SCSBIOC | 2) /* Internal */ 48*1708Sstevel 49*1708Sstevel #define SCSBIOC_ALL_LEDS_ON (_SCSBIOC | 3) /* Diagnostics */ 50*1708Sstevel #define SCSBIOC_ALL_LEDS_OFF (_SCSBIOC | 4) /* Diagnostics */ 51*1708Sstevel 52*1708Sstevel #define SCSBIOC_FREEZE (_SCSBIOC | 5) /* Internal */ 53*1708Sstevel #define SCSBIOC_RESTORE (_SCSBIOC | 6) /* Internal */ 54*1708Sstevel 55*1708Sstevel #define SCSBIOC_LED_NOK_SET (_SCSBIOC | 7) /* Diagnostics */ 56*1708Sstevel #define SCSBIOC_LED_NOK_GET (_SCSBIOC | 8) /* Diagnostics */ 57*1708Sstevel #define SCSBIOC_LED_OK_SET (_SCSBIOC | 9) /* Diagnostics */ 58*1708Sstevel #define SCSBIOC_LED_OK_GET (_SCSBIOC | 10) /* Diagnostics */ 59*1708Sstevel #define SCSBIOC_GET_FAN_STATUS (_SCSBIOC | 11) /* Internal */ 60*1708Sstevel #define SCSBIOC_RESET_UNIT (_SCSBIOC | 12) /* Diagnostics */ 61*1708Sstevel #define SCSBIOC_FAKE_INTR (_SCSBIOC | 13) /* Internal */ 62*1708Sstevel #define SCSBIOC_BSELECT_SET (_SCSBIOC | 14) /* Internal */ 63*1708Sstevel #define SCSBIOC_BSELECT_GET (_SCSBIOC | 15) /* Internal */ 64*1708Sstevel #define SCSBIOC_BHEALTHY_SET (_SCSBIOC | 16) /* Internal */ 65*1708Sstevel #define SCSBIOC_BHEALTHY_GET (_SCSBIOC | 17) /* Internal */ 66*1708Sstevel #define SCSBIOC_GET_INTR_ARRAY (_SCSBIOC | 18) /* Internal */ 67*1708Sstevel 68*1708Sstevel #define ENVC_IOC_ACQUIRE_SLOT_LED_CTRL (_SCSBIOC | 21) /* EnvMon */ 69*1708Sstevel #define ENVC_IOC_RELEASE_SLOT_LED_CTRL (_SCSBIOC | 22) /* EnvMon */ 70*1708Sstevel #define ENVC_IOC_SETFSP (_SCSBIOC | 23) /* EnvMon */ 71*1708Sstevel #define ENVC_IOC_GETDSKLED (_SCSBIOC | 24) /* EnvMon */ 72*1708Sstevel #define ENVC_IOC_SETDSKLED (_SCSBIOC | 25) /* EnvMon */ 73*1708Sstevel #define ENVC_IOC_REGISTER_PID (_SCSBIOC | 26) /* EnvMon */ 74*1708Sstevel #define ENVC_IOC_UNREGISTER_PID (_SCSBIOC | 27) /* EnvMon */ 75*1708Sstevel #define ENVC_IOC_ACCONF_RESTORED (_SCSBIOC | 28) /* EnvMon */ 76*1708Sstevel #define ENVC_IOC_ACCONF_STORED (_SCSBIOC | 29) /* EnvMon */ 77*1708Sstevel 78*1708Sstevel #define SCSBIOC_REG_READ (_SCSBIOC | 31) /* Diagnostic */ 79*1708Sstevel #define SCSBIOC_REG_WRITE (_SCSBIOC | 32) /* Diagnostic */ 80*1708Sstevel #define SCSBIOC_GET_VERSIONS (_SCSBIOC | 33) /* Diagnostic */ 81*1708Sstevel 82*1708Sstevel /* these are for debug/testing and may be temporary */ 83*1708Sstevel #define SCSBIOC_SHUTDOWN_POLL (_SCSBIOC | 41) /* Internal */ 84*1708Sstevel #define SCSBIOC_SLOT_OCCUPANCY (_SCSBIOC | 42) /* Internal */ 85*1708Sstevel #define SCSBIOC_INTEVENT_POLL (_SCSBIOC | 43) /* Internal */ 86*1708Sstevel #define SCSBIOC_TOPOLOGY_DUMP (_SCSBIOC | 44) /* Internal */ 87*1708Sstevel #define SCSBIOC_VALUE_MODE (_SCSBIOC | 45) /* Internal */ 88*1708Sstevel #define SCSBIOC_GET_SLOT_INFO (_SCSBIOC | 46) /* Internal */ 89*1708Sstevel #define SCSBIOC_DEBUG_MODE (_SCSBIOC | 52) /* Internal */ 90*1708Sstevel 91*1708Sstevel /* 92*1708Sstevel * SCSBIOC_GET_VERSIONS structure 93*1708Sstevel */ 94*1708Sstevel #define SCSB_MODSTR_LEN 64 95*1708Sstevel #define SCSB_VERSTR_LEN 12 96*1708Sstevel typedef struct scsb_ids { 97*1708Sstevel char modldrv_string[SCSB_MODSTR_LEN]; 98*1708Sstevel char scsb_version[SCSB_VERSTR_LEN]; 99*1708Sstevel uint8_t promid; 100*1708Sstevel uint8_t pad[3]; 101*1708Sstevel } scsb_ids_t; 102*1708Sstevel 103*1708Sstevel 104*1708Sstevel typedef enum { 105*1708Sstevel GET = 0, 106*1708Sstevel SET = 1 107*1708Sstevel } scsb_op_t; 108*1708Sstevel 109*1708Sstevel typedef enum { 110*1708Sstevel NOK = 0, 111*1708Sstevel OK = 1, 112*1708Sstevel NOUSE = 2 113*1708Sstevel } scsb_led_t; 114*1708Sstevel 115*1708Sstevel #define SCSB_LED_TYPES 2 116*1708Sstevel 117*1708Sstevel typedef enum { 118*1708Sstevel OFF = 0, 119*1708Sstevel ON = 1, 120*1708Sstevel BLINK = 2 121*1708Sstevel } scsb_ustate_t; 122*1708Sstevel 123*1708Sstevel typedef struct { 124*1708Sstevel scsb_unum_t unit_number; 125*1708Sstevel scsb_utype_t unit_type; 126*1708Sstevel scsb_ustate_t unit_state; 127*1708Sstevel scsb_led_t led_type; 128*1708Sstevel } scsb_uinfo_t; 129*1708Sstevel 130*1708Sstevel 131*1708Sstevel /* SCSBIOC_GET_STATUS data */ 132*1708Sstevel typedef struct { 133*1708Sstevel uchar_t scsb_reg[SCSB_DATA_REGISTERS]; 134*1708Sstevel } scsb_status_t; 135*1708Sstevel 136*1708Sstevel 137*1708Sstevel /* SCSBIOC_REG_READ / SCSBIOC_REG_WRITE data */ 138*1708Sstevel typedef struct { 139*1708Sstevel int16_t ioc_result; /* O: return value */ 140*1708Sstevel uint16_t ioc_resio; /* O: bytes not transfered */ 141*1708Sstevel uint16_t ioc_wlen; /* I: length of write buffer */ 142*1708Sstevel uint16_t ioc_rlen; /* I: length of read buffer */ 143*1708Sstevel uchar_t ioc_rbuf[64]; 144*1708Sstevel uchar_t ioc_wbuf[64]; 145*1708Sstevel uchar_t ioc_regindex; 146*1708Sstevel } scsb_ioc_rdwr_t; 147*1708Sstevel 148*1708Sstevel 149*1708Sstevel #ifdef __cplusplus 150*1708Sstevel } 151*1708Sstevel #endif 152*1708Sstevel 153*1708Sstevel #endif /* _MONTERCARLO_SYS_SCSBIOCTL_H */ 154