1*1ae08745Sheppo /* 2*1ae08745Sheppo * CDDL HEADER START 3*1ae08745Sheppo * 4*1ae08745Sheppo * The contents of this file are subject to the terms of the 5*1ae08745Sheppo * Common Development and Distribution License (the "License"). 6*1ae08745Sheppo * You may not use this file except in compliance with the License. 7*1ae08745Sheppo * 8*1ae08745Sheppo * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9*1ae08745Sheppo * or http://www.opensolaris.org/os/licensing. 10*1ae08745Sheppo * See the License for the specific language governing permissions 11*1ae08745Sheppo * and limitations under the License. 12*1ae08745Sheppo * 13*1ae08745Sheppo * When distributing Covered Code, include this CDDL HEADER in each 14*1ae08745Sheppo * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15*1ae08745Sheppo * If applicable, add the following below this CDDL HEADER, with the 16*1ae08745Sheppo * fields enclosed by brackets "[]" replaced with your own identifying 17*1ae08745Sheppo * information: Portions Copyright [yyyy] [name of copyright owner] 18*1ae08745Sheppo * 19*1ae08745Sheppo * CDDL HEADER END 20*1ae08745Sheppo */ 21*1ae08745Sheppo 22*1ae08745Sheppo /* 23*1ae08745Sheppo * Copyright 2006 Sun Microsystems, Inc. All rights reserved. 24*1ae08745Sheppo * Use is subject to license terms. 25*1ae08745Sheppo */ 26*1ae08745Sheppo 27*1ae08745Sheppo #ifndef _FAULT_ISO_H 28*1ae08745Sheppo #define _FAULT_ISO_H 29*1ae08745Sheppo 30*1ae08745Sheppo #pragma ident "%Z%%M% %I% %E% SMI" 31*1ae08745Sheppo 32*1ae08745Sheppo #ifdef __cplusplus 33*1ae08745Sheppo extern "C" { 34*1ae08745Sheppo #endif 35*1ae08745Sheppo 36*1ae08745Sheppo /* FMA CPU message numbers */ 37*1ae08745Sheppo #define FMA_CPU_REQ_STATUS 0x0 38*1ae08745Sheppo #define FMA_CPU_REQ_OFFLINE 0x1 39*1ae08745Sheppo #define FMA_CPU_REQ_ONLINE 0x2 40*1ae08745Sheppo 41*1ae08745Sheppo typedef struct { 42*1ae08745Sheppo uint64_t req_num; 43*1ae08745Sheppo uint32_t msg_type; 44*1ae08745Sheppo uint32_t cpu_id; 45*1ae08745Sheppo } fma_cpu_service_req_t; 46*1ae08745Sheppo 47*1ae08745Sheppo /* FMA CPU result codes */ 48*1ae08745Sheppo #define FMA_CPU_RESP_OK 0x0 49*1ae08745Sheppo #define FMA_CPU_RESP_FAILURE 0x1 50*1ae08745Sheppo 51*1ae08745Sheppo /* FMA CPU status codes */ 52*1ae08745Sheppo #define FMA_CPU_STAT_ONLINE 0x0 53*1ae08745Sheppo #define FMA_CPU_STAT_OFFLINE 0x1 54*1ae08745Sheppo #define FMA_CPU_STAT_ILLEGAL 0x2 55*1ae08745Sheppo 56*1ae08745Sheppo typedef struct { 57*1ae08745Sheppo uint64_t req_num; 58*1ae08745Sheppo uint32_t result; 59*1ae08745Sheppo uint32_t status; 60*1ae08745Sheppo } fma_cpu_resp_t; 61*1ae08745Sheppo 62*1ae08745Sheppo /* FMA memory services message numbers */ 63*1ae08745Sheppo #define FMA_MEM_REQ_STATUS 0x0 64*1ae08745Sheppo #define FMA_MEM_REQ_RETIRE 0x1 65*1ae08745Sheppo #define FMA_MEM_REQ_RESURRECT 0x2 66*1ae08745Sheppo 67*1ae08745Sheppo typedef struct { 68*1ae08745Sheppo uint64_t req_num; 69*1ae08745Sheppo uint32_t msg_type; 70*1ae08745Sheppo uint32_t _resvd; 71*1ae08745Sheppo uint64_t real_addr; 72*1ae08745Sheppo uint64_t length; 73*1ae08745Sheppo } fma_mem_service_req_t; 74*1ae08745Sheppo 75*1ae08745Sheppo /* FMA result codes */ 76*1ae08745Sheppo #define FMA_MEM_RESP_OK 0x0 77*1ae08745Sheppo #define FMA_MEM_RESP_FAILURE 0x1 78*1ae08745Sheppo 79*1ae08745Sheppo /* FMA status codes */ 80*1ae08745Sheppo #define FMA_MEM_STAT_NOTRETIRED 0x0 81*1ae08745Sheppo #define FMA_MEM_STAT_RETIRED 0x1 82*1ae08745Sheppo #define FMA_MEM_STAT_ILLEGAL 0x2 83*1ae08745Sheppo 84*1ae08745Sheppo typedef struct { 85*1ae08745Sheppo uint64_t req_num; 86*1ae08745Sheppo uint32_t result; 87*1ae08745Sheppo uint32_t status; 88*1ae08745Sheppo uint64_t res_addr; 89*1ae08745Sheppo uint64_t res_length; 90*1ae08745Sheppo } fma_mem_resp_t; 91*1ae08745Sheppo 92*1ae08745Sheppo #ifdef __cplusplus 93*1ae08745Sheppo } 94*1ae08745Sheppo #endif 95*1ae08745Sheppo 96*1ae08745Sheppo #endif /* _FAULT_ISO_H */ 97