scsbioctl.h revision 03831d35f7499c87d51205817c93e9a8d42c4bae
/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License (the "License").
* You may not use this file except in compliance with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* or http://www.opensolaris.org/os/licensing.
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* Copyright 2000 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
#ifndef _MONTERCARLO_SYS_SCSBIOCTL_H
#define _MONTERCARLO_SYS_SCSBIOCTL_H
#pragma ident "%Z%%M% %I% %E% SMI"
#ifdef __cplusplus
extern "C" {
#endif
/*
* SCB HW information, which is needed in scsb.h for scsb.c.
* there are 32 data registers on the system controller board
* most are used in P1.0, all are used in P1.5
*/
#define SCSB_DATA_REGISTERS 48
#define _SCSBIOC ('s' << 8)
#define SCSBIOC_GET_STATUS (_SCSBIOC | 1) /* Internal */
#define SCSBIOC_I2C_XFER (_SCSBIOC | 2) /* Internal */
#define SCSBIOC_ALL_LEDS_ON (_SCSBIOC | 3) /* Diagnostics */
#define SCSBIOC_ALL_LEDS_OFF (_SCSBIOC | 4) /* Diagnostics */
#define SCSBIOC_FREEZE (_SCSBIOC | 5) /* Internal */
#define SCSBIOC_RESTORE (_SCSBIOC | 6) /* Internal */
#define SCSBIOC_LED_NOK_SET (_SCSBIOC | 7) /* Diagnostics */
#define SCSBIOC_LED_NOK_GET (_SCSBIOC | 8) /* Diagnostics */
#define SCSBIOC_LED_OK_SET (_SCSBIOC | 9) /* Diagnostics */
#define SCSBIOC_LED_OK_GET (_SCSBIOC | 10) /* Diagnostics */
#define SCSBIOC_GET_FAN_STATUS (_SCSBIOC | 11) /* Internal */
#define SCSBIOC_RESET_UNIT (_SCSBIOC | 12) /* Diagnostics */
#define SCSBIOC_FAKE_INTR (_SCSBIOC | 13) /* Internal */
#define SCSBIOC_BSELECT_SET (_SCSBIOC | 14) /* Internal */
#define SCSBIOC_BSELECT_GET (_SCSBIOC | 15) /* Internal */
#define SCSBIOC_BHEALTHY_SET (_SCSBIOC | 16) /* Internal */
#define SCSBIOC_BHEALTHY_GET (_SCSBIOC | 17) /* Internal */
#define SCSBIOC_GET_INTR_ARRAY (_SCSBIOC | 18) /* Internal */
#define ENVC_IOC_ACQUIRE_SLOT_LED_CTRL (_SCSBIOC | 21) /* EnvMon */
#define ENVC_IOC_RELEASE_SLOT_LED_CTRL (_SCSBIOC | 22) /* EnvMon */
#define ENVC_IOC_SETFSP (_SCSBIOC | 23) /* EnvMon */
#define ENVC_IOC_GETDSKLED (_SCSBIOC | 24) /* EnvMon */
#define ENVC_IOC_SETDSKLED (_SCSBIOC | 25) /* EnvMon */
#define ENVC_IOC_REGISTER_PID (_SCSBIOC | 26) /* EnvMon */
#define ENVC_IOC_UNREGISTER_PID (_SCSBIOC | 27) /* EnvMon */
#define ENVC_IOC_ACCONF_RESTORED (_SCSBIOC | 28) /* EnvMon */
#define ENVC_IOC_ACCONF_STORED (_SCSBIOC | 29) /* EnvMon */
#define SCSBIOC_REG_READ (_SCSBIOC | 31) /* Diagnostic */
#define SCSBIOC_REG_WRITE (_SCSBIOC | 32) /* Diagnostic */
#define SCSBIOC_GET_VERSIONS (_SCSBIOC | 33) /* Diagnostic */
/* these are for debug/testing and may be temporary */
#define SCSBIOC_SHUTDOWN_POLL (_SCSBIOC | 41) /* Internal */
#define SCSBIOC_SLOT_OCCUPANCY (_SCSBIOC | 42) /* Internal */
#define SCSBIOC_INTEVENT_POLL (_SCSBIOC | 43) /* Internal */
#define SCSBIOC_TOPOLOGY_DUMP (_SCSBIOC | 44) /* Internal */
#define SCSBIOC_VALUE_MODE (_SCSBIOC | 45) /* Internal */
#define SCSBIOC_GET_SLOT_INFO (_SCSBIOC | 46) /* Internal */
#define SCSBIOC_DEBUG_MODE (_SCSBIOC | 52) /* Internal */
/*
* SCSBIOC_GET_VERSIONS structure
*/
#define SCSB_MODSTR_LEN 64
#define SCSB_VERSTR_LEN 12
typedef struct scsb_ids {
char modldrv_string[SCSB_MODSTR_LEN];
char scsb_version[SCSB_VERSTR_LEN];
uint8_t promid;
uint8_t pad[3];
} scsb_ids_t;
typedef enum {
GET = 0,
SET = 1
} scsb_op_t;
typedef enum {
NOK = 0,
OK = 1,
NOUSE = 2
} scsb_led_t;
#define SCSB_LED_TYPES 2
typedef enum {
OFF = 0,
ON = 1,
BLINK = 2
} scsb_ustate_t;
typedef struct {
scsb_unum_t unit_number;
scsb_utype_t unit_type;
scsb_ustate_t unit_state;
scsb_led_t led_type;
} scsb_uinfo_t;
/* SCSBIOC_GET_STATUS data */
typedef struct {
uchar_t scsb_reg[SCSB_DATA_REGISTERS];
} scsb_status_t;
/* SCSBIOC_REG_READ / SCSBIOC_REG_WRITE data */
typedef struct {
int16_t ioc_result; /* O: return value */
uint16_t ioc_resio; /* O: bytes not transfered */
uint16_t ioc_wlen; /* I: length of write buffer */
uint16_t ioc_rlen; /* I: length of read buffer */
uchar_t ioc_rbuf[64];
uchar_t ioc_wbuf[64];
uchar_t ioc_regindex;
} scsb_ioc_rdwr_t;
#ifdef __cplusplus
}
#endif
#endif /* _MONTERCARLO_SYS_SCSBIOCTL_H */