1*7c478bd9Sstevel@tonic-gate /* 2*7c478bd9Sstevel@tonic-gate * CDDL HEADER START 3*7c478bd9Sstevel@tonic-gate * 4*7c478bd9Sstevel@tonic-gate * The contents of this file are subject to the terms of the 5*7c478bd9Sstevel@tonic-gate * Common Development and Distribution License, Version 1.0 only 6*7c478bd9Sstevel@tonic-gate * (the "License"). You may not use this file except in compliance 7*7c478bd9Sstevel@tonic-gate * with the License. 8*7c478bd9Sstevel@tonic-gate * 9*7c478bd9Sstevel@tonic-gate * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 10*7c478bd9Sstevel@tonic-gate * or http://www.opensolaris.org/os/licensing. 11*7c478bd9Sstevel@tonic-gate * See the License for the specific language governing permissions 12*7c478bd9Sstevel@tonic-gate * and limitations under the License. 13*7c478bd9Sstevel@tonic-gate * 14*7c478bd9Sstevel@tonic-gate * When distributing Covered Code, include this CDDL HEADER in each 15*7c478bd9Sstevel@tonic-gate * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 16*7c478bd9Sstevel@tonic-gate * If applicable, add the following below this CDDL HEADER, with the 17*7c478bd9Sstevel@tonic-gate * fields enclosed by brackets "[]" replaced with your own identifying 18*7c478bd9Sstevel@tonic-gate * information: Portions Copyright [yyyy] [name of copyright owner] 19*7c478bd9Sstevel@tonic-gate * 20*7c478bd9Sstevel@tonic-gate * CDDL HEADER END 21*7c478bd9Sstevel@tonic-gate */ 22*7c478bd9Sstevel@tonic-gate /* 23*7c478bd9Sstevel@tonic-gate * Copyright 1999-2003 Sun Microsystems, Inc. All rights reserved. 24*7c478bd9Sstevel@tonic-gate * Use is subject to license terms. 25*7c478bd9Sstevel@tonic-gate */ 26*7c478bd9Sstevel@tonic-gate 27*7c478bd9Sstevel@tonic-gate #ifndef _SYS_SAFARI_PCD_H 28*7c478bd9Sstevel@tonic-gate #define _SYS_SAFARI_PCD_H 29*7c478bd9Sstevel@tonic-gate 30*7c478bd9Sstevel@tonic-gate #pragma ident "%Z%%M% %I% %E% SMI" 31*7c478bd9Sstevel@tonic-gate 32*7c478bd9Sstevel@tonic-gate /* 33*7c478bd9Sstevel@tonic-gate * This file contains definitions of the structure spcd_t, Port Configuration 34*7c478bd9Sstevel@tonic-gate * Descriptor, which is part of the information handed off to OBP and 35*7c478bd9Sstevel@tonic-gate * the OS by POST in the "golden" I/O SRAM. 36*7c478bd9Sstevel@tonic-gate * It is very similar in function to, and borrows heavily from, the spd 37*7c478bd9Sstevel@tonic-gate */ 38*7c478bd9Sstevel@tonic-gate 39*7c478bd9Sstevel@tonic-gate #include <sys/types.h> 40*7c478bd9Sstevel@tonic-gate 41*7c478bd9Sstevel@tonic-gate #ifdef __cplusplus 42*7c478bd9Sstevel@tonic-gate extern "C" { 43*7c478bd9Sstevel@tonic-gate #endif 44*7c478bd9Sstevel@tonic-gate 45*7c478bd9Sstevel@tonic-gate #define MAX_BANKS_PER_PORT 4 /* Physical and Logical */ 46*7c478bd9Sstevel@tonic-gate #define MAX_DIMMS_PER_PORT 8 47*7c478bd9Sstevel@tonic-gate #define IOBUS_PER_PORT 2 48*7c478bd9Sstevel@tonic-gate #define IOCARD_PER_BUS 4 49*7c478bd9Sstevel@tonic-gate #define LINKS_PER_PORT 5 50*7c478bd9Sstevel@tonic-gate #define UPADEV_PER_PORT 2 51*7c478bd9Sstevel@tonic-gate #define AGENTS_PER_PORT 2 52*7c478bd9Sstevel@tonic-gate 53*7c478bd9Sstevel@tonic-gate #define PCD_VERSION 1 54*7c478bd9Sstevel@tonic-gate #define PCD_MAGIC ('P'<<24 |'C'<<16 |'D'<<8 | 0) 55*7c478bd9Sstevel@tonic-gate 56*7c478bd9Sstevel@tonic-gate 57*7c478bd9Sstevel@tonic-gate /* Types of Safari ports */ 58*7c478bd9Sstevel@tonic-gate #define SAFPTYPE_NULL 0 59*7c478bd9Sstevel@tonic-gate #define SAFPTYPE_CPU 1 60*7c478bd9Sstevel@tonic-gate #define SAFPTYPE_sPCI 2 61*7c478bd9Sstevel@tonic-gate #define SAFPTYPE_cPCI 3 62*7c478bd9Sstevel@tonic-gate #define SAFPTYPE_WCI 4 63*7c478bd9Sstevel@tonic-gate #define SAFPTYPE_PCIX 5 64*7c478bd9Sstevel@tonic-gate 65*7c478bd9Sstevel@tonic-gate /* 66*7c478bd9Sstevel@tonic-gate * RSV stands for Resource Status Value. 67*7c478bd9Sstevel@tonic-gate * These are the values used in all cases where the status of 68*7c478bd9Sstevel@tonic-gate * a resource is maintained in a byte element of a structure. 69*7c478bd9Sstevel@tonic-gate * These are ordered in terms of preserving interesting information 70*7c478bd9Sstevel@tonic-gate * in POST displays where all configurations are displayed in a 71*7c478bd9Sstevel@tonic-gate * single value. 72*7c478bd9Sstevel@tonic-gate */ 73*7c478bd9Sstevel@tonic-gate 74*7c478bd9Sstevel@tonic-gate typedef uint8_t spcdrsv_t; 75*7c478bd9Sstevel@tonic-gate 76*7c478bd9Sstevel@tonic-gate #define SPCD_RSV_PASS 0x1 /* Passed some sort of test */ 77*7c478bd9Sstevel@tonic-gate #define SPCD_RSV_FAIL 0xff 78*7c478bd9Sstevel@tonic-gate 79*7c478bd9Sstevel@tonic-gate typedef struct { 80*7c478bd9Sstevel@tonic-gate uint32_t spcd_magic; /* PCD_MAGIC */ 81*7c478bd9Sstevel@tonic-gate uint8_t spcd_version; /* structure version: PCD_VERSION */ 82*7c478bd9Sstevel@tonic-gate uint64_t spcd_ver_reg; /* port version register */ 83*7c478bd9Sstevel@tonic-gate uint16_t spcd_afreq; /* actual operating frequency Mhz */ 84*7c478bd9Sstevel@tonic-gate 85*7c478bd9Sstevel@tonic-gate uint8_t spcd_ptype; /* port type. See SAFPTYPE_ below */ 86*7c478bd9Sstevel@tonic-gate uint8_t spcd_cache; /* external cache size (MByte?) */ 87*7c478bd9Sstevel@tonic-gate spcdrsv_t spcd_prsv; /* The entire port status */ 88*7c478bd9Sstevel@tonic-gate spcdrsv_t spcd_agent[AGENTS_PER_PORT]; 89*7c478bd9Sstevel@tonic-gate uint16_t spcd_cpuid[AGENTS_PER_PORT]; 90*7c478bd9Sstevel@tonic-gate 91*7c478bd9Sstevel@tonic-gate /* for ports with UPA device */ 92*7c478bd9Sstevel@tonic-gate spcdrsv_t spcd_upadev[UPADEV_PER_PORT]; 93*7c478bd9Sstevel@tonic-gate 94*7c478bd9Sstevel@tonic-gate /* for ports with IO buses */ 95*7c478bd9Sstevel@tonic-gate spcdrsv_t spcd_iobus_rsv[IOBUS_PER_PORT]; 96*7c478bd9Sstevel@tonic-gate /* status of each IO card on port */ 97*7c478bd9Sstevel@tonic-gate spcdrsv_t spcd_iocard_rsv[IOBUS_PER_PORT][IOCARD_PER_BUS]; 98*7c478bd9Sstevel@tonic-gate 99*7c478bd9Sstevel@tonic-gate /* for ports with WIC links */ 100*7c478bd9Sstevel@tonic-gate spcdrsv_t spcd_wic_links[LINKS_PER_PORT]; 101*7c478bd9Sstevel@tonic-gate /* status of each WIC link on port */ 102*7c478bd9Sstevel@tonic-gate 103*7c478bd9Sstevel@tonic-gate uint32_t memory_layout_size; /* size of memory-layout */ 104*7c478bd9Sstevel@tonic-gate uint8_t *memory_layout; /* ptr to memory-layout data */ 105*7c478bd9Sstevel@tonic-gate 106*7c478bd9Sstevel@tonic-gate char *sprd_bank_rsv[MAX_BANKS_PER_PORT]; 107*7c478bd9Sstevel@tonic-gate /* status of each bank */ 108*7c478bd9Sstevel@tonic-gate char *sprd_dimm[MAX_DIMMS_PER_PORT]; 109*7c478bd9Sstevel@tonic-gate /* status of each dimm */ 110*7c478bd9Sstevel@tonic-gate char *sprd_ecache_dimm_label[MAX_DIMMS_PER_PORT]; 111*7c478bd9Sstevel@tonic-gate /* labels for ecache dimms */ 112*7c478bd9Sstevel@tonic-gate 113*7c478bd9Sstevel@tonic-gate } spcd_t; 114*7c478bd9Sstevel@tonic-gate 115*7c478bd9Sstevel@tonic-gate #ifdef __cplusplus 116*7c478bd9Sstevel@tonic-gate } 117*7c478bd9Sstevel@tonic-gate #endif 118*7c478bd9Sstevel@tonic-gate 119*7c478bd9Sstevel@tonic-gate #endif /* _SYS_SAFARI_PCD_H */ 120