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 _SYS_SGHSC_H
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define _SYS_SGHSC_H
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel#pragma ident "%Z%%M% %I% %E% SMI"
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel#ifdef __cplusplus
03831d35f7499c87d51205817c93e9a8d42c4baestevelextern "C" {
03831d35f7499c87d51205817c93e9a8d42c4baestevel#endif
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Serengeti CompactPCI Hot Swap Controller Driver header file. This file is
03831d35f7499c87d51205817c93e9a8d42c4baestevel * structured in a following way: common, sghsc data (defines and structures)
03831d35f7499c87d51205817c93e9a8d42c4baestevel * and mailbox related data (defines and structures).
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel#include <sys/hotplug/hpctrl.h>
03831d35f7499c87d51205817c93e9a8d42c4baestevel#include <sys/hotplug/hpcsvc.h>
03831d35f7499c87d51205817c93e9a8d42c4baestevel#include <sys/sgsbbc_mailbox.h>
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * sghsc node path with insert placeholders
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_PATH "/ssm@%x,0/pci@%x,%x00000"
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Mutex short hands
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_MUTEX(sghsc) \
03831d35f7499c87d51205817c93e9a8d42c4baestevel (&sghsc->sghsc_mutex)
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_MUTEX_OWNED(sghsc) \
03831d35f7499c87d51205817c93e9a8d42c4baestevel mutex_owned(SGHSC_MUTEX(sghsc))
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_MUTEX_ENTER(sghsc) \
03831d35f7499c87d51205817c93e9a8d42c4baestevel mutex_enter(SGHSC_MUTEX(sghsc))
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_MUTEX_EXIT(sghsc) \
03831d35f7499c87d51205817c93e9a8d42c4baestevel mutex_exit(SGHSC_MUTEX(sghsc))
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SLOT_MUTEX(sghsc, slot_num) \
03831d35f7499c87d51205817c93e9a8d42c4baestevel (&sghsc->sghsc_slot_table[slot_num]->slot_mutex)
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SLOT_MUTEX_OWNED(sghsc, slot_num) \
03831d35f7499c87d51205817c93e9a8d42c4baestevel mutex_owned(SGHSC_SLOT_MUTEX(sghsc, slot_num));
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SLOT_MUTEX_ENTER(sghsc, slot_num) \
03831d35f7499c87d51205817c93e9a8d42c4baestevel mutex_enter(SGHSC_SLOT_MUTEX(sghsc, slot_num));
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SLOT_MUTEX_EXIT(sghsc, slot_num) \
03831d35f7499c87d51205817c93e9a8d42c4baestevel mutex_exit(SGHSC_SLOT_MUTEX(sghsc, slot_num));
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Misc definitions
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_ALL_SLOTS_ENABLE 0x3F
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SLOT_ENABLE 0x01
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_ALL_SLOTS_DISABLE 0x02
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SLOT_DISABLE 0x03
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_ALL_LEDS_ENABLE 0x3F3F
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_LED_ENABLE 0x04
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_ALL_LEDS_DISABLE 0x05
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_LED_DISABLE 0x06
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_LED_BLINKING 0x07
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SLOT_ISOLATE 0x08
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SLOT_POWER 0x09
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_LED_ENABLE_MASK 0x0000FFFF
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SAFARI_ID_EVEN 0x3fe
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/* Individual events definitions */
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_EVENT_CARD_INSERT 0x1
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_EVENT_CARD_REMOVE 0x2
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_EVENT_LEVER_ACTION 0x3
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_EVENT_HEALTHY_LOST 0x4
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_EVENT_POWER_ON 0x5
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_EVENT_POWER_OFF 0x6
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/* Slot flags */
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SLOT_AUTO_CFG_EN 0x1
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SLOT_HEALTHY_LOST 0x2
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/* LED definitions */
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_POWER_LED 0x10
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_FAULT_LED 0x20
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_ACTIVE_LED 0x40
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_ATTN_LED 0x80
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/* Ring buffer size, has to be power of 2 */
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_RING_BUFFER_SZ 0x10
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Per Hot Swappable Slot info
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baesteveltypedef struct sghsc_slot {
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel /*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Mutex for each slots for state change
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel kmutex_t slot_mutex;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel /*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * pathname of bus node
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel char nexus_path[MAXPATHLEN];
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel /*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * property, status, cap for each slot
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel hpc_slot_info_t slot_info;
03831d35f7499c87d51205817c93e9a8d42c4baestevel hpc_slot_state_t slot_status;
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t slot_capb;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel /*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * PCI Bus number for each slot
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint8_t pci_device_num;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel /*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * dynamically allocated hpc_slot_ops_t
03831d35f7499c87d51205817c93e9a8d42c4baestevel * and register slot handle
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel hpc_slot_ops_t *slot_ops;
03831d35f7499c87d51205817c93e9a8d42c4baestevel hpc_slot_t handle;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel /*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Leds for each slot are not cached
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel /*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * slot state, flags, board type
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t flags;
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t state;
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t board_type;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel} sghsc_slot_t;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Per Serenget CompactPCI HSC instance soft state structure
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baesteveltypedef struct sghsc {
03831d35f7499c87d51205817c93e9a8d42c4baestevel dev_info_t *sghsc_dip;
03831d35f7499c87d51205817c93e9a8d42c4baestevel kmutex_t sghsc_mutex;
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t sghsc_instance;
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t sghsc_board;
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t sghsc_node_id;
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t sghsc_portid;
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t sghsc_num_slots;
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t sghsc_valid;
03831d35f7499c87d51205817c93e9a8d42c4baestevel sghsc_slot_t *sghsc_slot_table;
03831d35f7499c87d51205817c93e9a8d42c4baestevel} sghsc_t;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Slot map descriptor (slot to bus segment mapping)
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baesteveltypedef struct sdesc {
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t agent_delta;
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t off;
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t pcidev;
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t slot_type;
03831d35f7499c87d51205817c93e9a8d42c4baestevel} sdesc_t;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Mailbox related data and structures
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_GET_SLOT_STATUS 0x5000
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_SET_SLOT_FAULT_LED 0x5001
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_SET_SLOT_STATUS 0x5002
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_SET_SLOT_POWER 0x5003
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_GET_NUM_SLOTS 0x5004
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_SET_ENUM_CLEARED 0x5005
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_BOARD_TYPE 0x5006
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Bit definition for Boat Type
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define NO_BOARD_TYPE 0
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define PCI_BOARD 1
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_BOARD 2
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SP_CPCI_BOARD 3
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define WCI_CPCI_BOARD 4
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define WCI_SP_CPCI_BOARD 5
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Shifts definition for CPCI_GET_SLOT_STATUS
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define ONE_BIT 1
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define TWO_BITS 3
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define THREE_BITS 7
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_STAT_POWER_ON_SHIFT 0
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_STAT_LED_POWER_SHIFT 1
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_STAT_LED_FAULT_SHIFT 2
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_STAT_LED_HP_SHIFT 3
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_STAT_SLOT_EMPTY_SHIFT 4
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_STAT_HOT_SWAP_STATUS_SHIFT 5
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_STAT_HEALTHY_SHIFT 12 /* One bit */
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_STAT_RESET_SHIFT 13 /* One bit */
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Bit definition for CPCI_SET_SLOT_STATUS
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_SET_STATUS_SLOT_RESET 0x00001
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_SET_STATUS_SLOT_READY 0x00000
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Bit definition for CPCI_SET_SLOT_STATUS_FAULT_LED
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_SET_FAULT_LED_OFF 0x00000
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_SET_FAULT_LED_ON 0x00001
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_SET_FAULT_LED_KEEP 0x00002
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_SET_FAULT_LED_TOGGLE 0x00003
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Bit definition for CPCI_SET_SLOT_POWER
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_POWER_OFF 0x0
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define CPCI_POWER_ON 0x1
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * Mailbox timeout
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_MBX_TIMEOUT 600
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel/*
03831d35f7499c87d51205817c93e9a8d42c4baestevel * cPCI command codes (internal)
03831d35f7499c87d51205817c93e9a8d42c4baestevel */
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define _SGHSC_CODE ('N' << 16)
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_GET_SLOT_STATUS (_SGHSC_CODE | 0x14)
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SET_SLOT_STATUS_RESET (_SGHSC_CODE | 0x15)
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SET_SLOT_STATUS_READY (_SGHSC_CODE | 0x16)
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SET_SLOT_FAULT_LED_ON (_SGHSC_CODE | 0x17)
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SET_SLOT_FAULT_LED_OFF (_SGHSC_CODE | 0x18)
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SET_SLOT_FAULT_LED_KEEP (_SGHSC_CODE | 0x19)
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SET_SLOT_FAULT_LED_TOGGLE (_SGHSC_CODE | 0x1a)
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SET_SLOT_POWER_OFF (_SGHSC_CODE | 0x1b)
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SET_SLOT_POWER_ON (_SGHSC_CODE | 0x1c)
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_GET_NUM_SLOTS (_SGHSC_CODE | 0x1d)
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_SET_ENUM_CLEARED (_SGHSC_CODE | 0x1e)
03831d35f7499c87d51205817c93e9a8d42c4baestevel#define SGHSC_GET_CPCI_BOARD_TYPE (_SGHSC_CODE | 0x1f)
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baesteveltypedef struct {
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t cmd_id;
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t node_id;
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t board;
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t slot;
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t info;
03831d35f7499c87d51205817c93e9a8d42c4baestevel} bitcmd_info_t;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baesteveltypedef struct {
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t cmd_id;
03831d35f7499c87d51205817c93e9a8d42c4baestevel uint32_t result;
03831d35f7499c87d51205817c93e9a8d42c4baestevel} bitcmd_resp_t;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baesteveltypedef enum { SGHSC_RB_EMPTY, SGHSC_RB_FLOAT,
03831d35f7499c87d51205817c93e9a8d42c4baestevel SGHSC_RB_FULL } sghsc_rb_state_t;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baesteveltypedef struct sghsc_event {
03831d35f7499c87d51205817c93e9a8d42c4baestevel int type;
03831d35f7499c87d51205817c93e9a8d42c4baestevel int node_id;
03831d35f7499c87d51205817c93e9a8d42c4baestevel int board;
03831d35f7499c87d51205817c93e9a8d42c4baestevel int slot;
03831d35f7499c87d51205817c93e9a8d42c4baestevel int info;
03831d35f7499c87d51205817c93e9a8d42c4baestevel} sghsc_event_t;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baesteveltypedef struct sghsc_rb_head {
03831d35f7499c87d51205817c93e9a8d42c4baestevel sghsc_event_t *buf;
03831d35f7499c87d51205817c93e9a8d42c4baestevel int put_idx;
03831d35f7499c87d51205817c93e9a8d42c4baestevel int get_idx;
03831d35f7499c87d51205817c93e9a8d42c4baestevel int size;
03831d35f7499c87d51205817c93e9a8d42c4baestevel sghsc_rb_state_t state;
03831d35f7499c87d51205817c93e9a8d42c4baestevel} sghsc_rb_head_t;
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel#ifdef __cplusplus
03831d35f7499c87d51205817c93e9a8d42c4baestevel}
03831d35f7499c87d51205817c93e9a8d42c4baestevel#endif
03831d35f7499c87d51205817c93e9a8d42c4baestevel
03831d35f7499c87d51205817c93e9a8d42c4baestevel#endif /* _SYS_SGHSC_H */