1 /* $NetBSD: types.h,v 1.66 2021/04/01 04:35:46 simonb Exp $ */ 2 3 /*- 4 * Copyright (C) 1995 Wolfgang Solfrank. 5 * Copyright (C) 1995 TooLs GmbH. 6 * All rights reserved. 7 * 8 * Redistribution and use in source and binary forms, with or without 9 * modification, are permitted provided that the following conditions 10 * are met: 11 * 1. Redistributions of source code must retain the above copyright 12 * notice, this list of conditions and the following disclaimer. 13 * 2. Redistributions in binary form must reproduce the above copyright 14 * notice, this list of conditions and the following disclaimer in the 15 * documentation and/or other materials provided with the distribution. 16 * 3. All advertising materials mentioning features or use of this software 17 * must display the following acknowledgement: 18 * This product includes software developed by TooLs GmbH. 19 * 4. The name of TooLs GmbH may not be used to endorse or promote products 20 * derived from this software without specific prior written permission. 21 * 22 * THIS SOFTWARE IS PROVIDED BY TOOLS GMBH ``AS IS'' AND ANY EXPRESS OR 23 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 24 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 25 * IN NO EVENT SHALL TOOLS GMBH BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 26 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 27 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 28 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 29 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 30 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 31 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 32 */ 33 34 #ifndef _POWERPC_TYPES_H_ 35 #define _POWERPC_TYPES_H_ 36 37 #ifdef _KERNEL_OPT 38 #include "opt_ppcarch.h" 39 #endif 40 41 #include <sys/cdefs.h> 42 #include <sys/featuretest.h> 43 #include <powerpc/int_types.h> 44 45 typedef int __cpu_simple_lock_nv_t; 46 typedef unsigned long __register_t; /* frame.h */ 47 typedef __uint32_t __register32_t; /* frame.h */ 48 49 #if defined(_KERNEL) || defined(_KMEMUSER) || defined(_KERNTYPES) || defined(_STANDALONE) 50 typedef unsigned long paddr_t, vaddr_t; 51 typedef unsigned long psize_t, vsize_t; 52 #define PRIxPADDR "lx" 53 #define PRIxPSIZE "lx" 54 #define PRIuPSIZE "lu" 55 #define PRIxVADDR "lx" 56 #define PRIxVSIZE "lx" 57 #define PRIuVSIZE "lu" 58 59 /* 60 * Because lwz etal don't sign extend, it's best to make registers unsigned. 61 */ 62 typedef __register_t register_t; 63 typedef __register32_t register32_t; 64 typedef __uint64_t register64_t; 65 #define PRIxREGISTER "lx" 66 #define PRIxREGISTER64 PRIx64 67 #define PRIxREGISTER32 PRIx32 68 #endif 69 70 #if defined(_KERNEL) 71 typedef struct label_t { 72 register_t val[40]; /* double check this XXX */ 73 } label_t; 74 75 typedef __uint32_t tlb_asid_t; /* for booke */ 76 #endif 77 78 #define __SIMPLELOCK_LOCKED 1 79 #define __SIMPLELOCK_UNLOCKED 0 80 81 #define __HAVE_CPU_COUNTER 82 #define __HAVE_NEW_STYLE_BUS_H 83 #define __HAVE_SYSCALL_INTERN 84 #define __HAVE_CPU_DATA_FIRST 85 #define __HAVE_CPU_UAREA_ROUTINES 86 #ifdef _LP64 87 #define __HAVE_ATOMIC64_OPS 88 #endif 89 #define __HAVE_CPU_LWP_SETPRIVATE 90 #define __HAVE_COMMON___TLS_GET_ADDR 91 #define __HAVE___LWP_GETTCB_FAST 92 #define __HAVE___LWP_SETTCB 93 #define __HAVE_TLS_VARIANT_I 94 #define __HAVE_BUS_SPACE_8 95 96 #if defined(_KERNEL) || defined(_KMEMUSER) 97 #define PCU_FPU 0 /* FPU */ 98 #define PCU_VEC 1 /* AltiVec/SPE */ 99 #define PCU_UNIT_COUNT 2 100 #endif 101 102 #define __HAVE_MM_MD_DIRECT_MAPPED_PHYS 103 #define __HAVE_MM_MD_KERNACC 104 #if 0 /* XXX CPU configuration spaghetti */ 105 #define __HAVE_UCAS_FULL 106 #endif 107 #if defined(_KERNEL) 108 #define __HAVE_RAS 109 #endif 110 111 #ifndef PPC_IBM4XX 112 /* XXX temporary */ 113 #define __HAVE_UNLOCKED_PMAP 114 #endif 115 116 #endif /* _POWERPC_TYPES_H_ */ 117