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 _LPAD_H 28*1ae08745Sheppo #define _LPAD_H 29*1ae08745Sheppo 30*1ae08745Sheppo #pragma ident "%Z%%M% %I% %E% SMI" 31*1ae08745Sheppo 32*1ae08745Sheppo /* 33*1ae08745Sheppo * sun4v Landing Pad 34*1ae08745Sheppo */ 35*1ae08745Sheppo 36*1ae08745Sheppo #ifdef __cplusplus 37*1ae08745Sheppo extern "C" { 38*1ae08745Sheppo #endif 39*1ae08745Sheppo 40*1ae08745Sheppo #ifndef _ASM 41*1ae08745Sheppo 42*1ae08745Sheppo #include <sys/pte.h> 43*1ae08745Sheppo 44*1ae08745Sheppo typedef union { 45*1ae08745Sheppo struct { 46*1ae08745Sheppo unsigned int rsvd0:32; 47*1ae08745Sheppo unsigned int rsvd1:29; 48*1ae08745Sheppo unsigned int perm:1; 49*1ae08745Sheppo unsigned int mmuflags:2; 50*1ae08745Sheppo } flag_bits; 51*1ae08745Sheppo uint64_t ll; 52*1ae08745Sheppo } lpad_map_flag_t; 53*1ae08745Sheppo 54*1ae08745Sheppo typedef struct lpad_map { 55*1ae08745Sheppo lpad_map_flag_t flags; 56*1ae08745Sheppo uint64_t va; 57*1ae08745Sheppo tte_t tte; 58*1ae08745Sheppo } lpad_map_t; 59*1ae08745Sheppo 60*1ae08745Sheppo #define flag_mmuflags flags.flag_bits.mmuflags 61*1ae08745Sheppo #define flag_perm flags.flag_bits.perm 62*1ae08745Sheppo 63*1ae08745Sheppo typedef struct lpad_data { 64*1ae08745Sheppo uint64_t magic; /* magic value for sanity checking */ 65*1ae08745Sheppo uint64_t *inuse; /* clear flag when done with lpad */ 66*1ae08745Sheppo uint64_t mmfsa_ra; /* RA of MMU fault status area */ 67*1ae08745Sheppo uint64_t pc; /* VA of CPU startup function */ 68*1ae08745Sheppo uint64_t arg; /* argument to startup function */ 69*1ae08745Sheppo uint64_t nmap; /* number of mappings */ 70*1ae08745Sheppo lpad_map_t map[1]; /* array of mappings */ 71*1ae08745Sheppo } lpad_data_t; 72*1ae08745Sheppo 73*1ae08745Sheppo extern uint64_t *lpad_setup(int cpuid, uint64_t pc, uint64_t arg); 74*1ae08745Sheppo 75*1ae08745Sheppo #endif /* ! _ASM */ 76*1ae08745Sheppo 77*1ae08745Sheppo /* 78*1ae08745Sheppo * General landing pad constants 79*1ae08745Sheppo */ 80*1ae08745Sheppo #define LPAD_TEXT_SIZE 1024 81*1ae08745Sheppo #define LPAD_DATA_SIZE 1024 82*1ae08745Sheppo #define LPAD_SIZE (LPAD_TEXT_SIZE + LPAD_DATA_SIZE) 83*1ae08745Sheppo #define LPAD_MAGIC_VAL 0x4C502D4D41474943 /* "LP-MAGIC" */ 84*1ae08745Sheppo 85*1ae08745Sheppo /* 86*1ae08745Sheppo * Masks for the lpad_map_t flag bitfield 87*1ae08745Sheppo */ 88*1ae08745Sheppo #define FLAG_MMUFLAGS_MASK 0x3 89*1ae08745Sheppo #define FLAG_LOCK_MASK 0x4 90*1ae08745Sheppo 91*1ae08745Sheppo #ifdef __cplusplus 92*1ae08745Sheppo } 93*1ae08745Sheppo #endif 94*1ae08745Sheppo 95*1ae08745Sheppo #endif /* _LPAD_H */ 96