1*4a5d661aSToomas Soome /*- 2*4a5d661aSToomas Soome * Copyright (c) 2002 David E. O'Brien. All rights reserved. 3*4a5d661aSToomas Soome * Copyright (c) 1992, 1993 4*4a5d661aSToomas Soome * The Regents of the University of California. All rights reserved. 5*4a5d661aSToomas Soome * 6*4a5d661aSToomas Soome * This code is derived from software contributed to Berkeley by 7*4a5d661aSToomas Soome * the Systems Programming Group of the University of Utah Computer 8*4a5d661aSToomas Soome * Science Department and Ralph Campbell. 9*4a5d661aSToomas Soome * 10*4a5d661aSToomas Soome * Redistribution and use in source and binary forms, with or without 11*4a5d661aSToomas Soome * modification, are permitted provided that the following conditions 12*4a5d661aSToomas Soome * are met: 13*4a5d661aSToomas Soome * 1. Redistributions of source code must retain the above copyright 14*4a5d661aSToomas Soome * notice, this list of conditions and the following disclaimer. 15*4a5d661aSToomas Soome * 2. Redistributions in binary form must reproduce the above copyright 16*4a5d661aSToomas Soome * notice, this list of conditions and the following disclaimer in the 17*4a5d661aSToomas Soome * documentation and/or other materials provided with the distribution. 18*4a5d661aSToomas Soome * 3. All advertising materials mentioning features or use of this software 19*4a5d661aSToomas Soome * must display the following acknowledgement: 20*4a5d661aSToomas Soome * This product includes software developed by the University of 21*4a5d661aSToomas Soome * California, Berkeley and its contributors. 22*4a5d661aSToomas Soome * 4. Neither the name of the University nor the names of its contributors 23*4a5d661aSToomas Soome * may be used to endorse or promote products derived from this software 24*4a5d661aSToomas Soome * without specific prior written permission. 25*4a5d661aSToomas Soome * 26*4a5d661aSToomas Soome * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 27*4a5d661aSToomas Soome * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 28*4a5d661aSToomas Soome * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 29*4a5d661aSToomas Soome * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 30*4a5d661aSToomas Soome * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 31*4a5d661aSToomas Soome * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 32*4a5d661aSToomas Soome * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 33*4a5d661aSToomas Soome * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 34*4a5d661aSToomas Soome * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 35*4a5d661aSToomas Soome * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 36*4a5d661aSToomas Soome * SUCH DAMAGE. 37*4a5d661aSToomas Soome * 38*4a5d661aSToomas Soome * @(#)param.h 8.1 (Berkeley) 6/10/93 39*4a5d661aSToomas Soome * $FreeBSD$ 40*4a5d661aSToomas Soome */ 41*4a5d661aSToomas Soome 42*4a5d661aSToomas Soome 43*4a5d661aSToomas Soome #ifndef _AMD64_INCLUDE_PARAM_H_ 44*4a5d661aSToomas Soome #define _AMD64_INCLUDE_PARAM_H_ 45*4a5d661aSToomas Soome 46*4a5d661aSToomas Soome #include <machine/_align.h> 47*4a5d661aSToomas Soome 48*4a5d661aSToomas Soome /* 49*4a5d661aSToomas Soome * Machine dependent constants for AMD64. 50*4a5d661aSToomas Soome */ 51*4a5d661aSToomas Soome 52*4a5d661aSToomas Soome 53*4a5d661aSToomas Soome #define __HAVE_ACPI 54*4a5d661aSToomas Soome #define __PCI_REROUTE_INTERRUPT 55*4a5d661aSToomas Soome 56*4a5d661aSToomas Soome #ifndef MACHINE 57*4a5d661aSToomas Soome #define MACHINE "amd64" 58*4a5d661aSToomas Soome #endif 59*4a5d661aSToomas Soome #ifndef MACHINE_ARCH 60*4a5d661aSToomas Soome #define MACHINE_ARCH "amd64" 61*4a5d661aSToomas Soome #endif 62*4a5d661aSToomas Soome #ifndef MACHINE_ARCH32 63*4a5d661aSToomas Soome #define MACHINE_ARCH32 "i386" 64*4a5d661aSToomas Soome #endif 65*4a5d661aSToomas Soome 66*4a5d661aSToomas Soome #if defined(SMP) || defined(KLD_MODULE) 67*4a5d661aSToomas Soome #ifndef MAXCPU 68*4a5d661aSToomas Soome #define MAXCPU 256 69*4a5d661aSToomas Soome #endif 70*4a5d661aSToomas Soome #else 71*4a5d661aSToomas Soome #define MAXCPU 1 72*4a5d661aSToomas Soome #endif 73*4a5d661aSToomas Soome 74*4a5d661aSToomas Soome #ifndef MAXMEMDOM 75*4a5d661aSToomas Soome #define MAXMEMDOM 1 76*4a5d661aSToomas Soome #endif 77*4a5d661aSToomas Soome 78*4a5d661aSToomas Soome #define ALIGNBYTES _ALIGNBYTES 79*4a5d661aSToomas Soome #define ALIGN(p) _ALIGN(p) 80*4a5d661aSToomas Soome /* 81*4a5d661aSToomas Soome * ALIGNED_POINTER is a boolean macro that checks whether an address 82*4a5d661aSToomas Soome * is valid to fetch data elements of type t from on this architecture. 83*4a5d661aSToomas Soome * This does not reflect the optimal alignment, just the possibility 84*4a5d661aSToomas Soome * (within reasonable limits). 85*4a5d661aSToomas Soome */ 86*4a5d661aSToomas Soome #define ALIGNED_POINTER(p, t) 1 87*4a5d661aSToomas Soome 88*4a5d661aSToomas Soome /* 89*4a5d661aSToomas Soome * CACHE_LINE_SIZE is the compile-time maximum cache line size for an 90*4a5d661aSToomas Soome * architecture. It should be used with appropriate caution. 91*4a5d661aSToomas Soome */ 92*4a5d661aSToomas Soome #define CACHE_LINE_SHIFT 7 93*4a5d661aSToomas Soome #define CACHE_LINE_SIZE (1 << CACHE_LINE_SHIFT) 94*4a5d661aSToomas Soome 95*4a5d661aSToomas Soome /* Size of the level 1 page table units */ 96*4a5d661aSToomas Soome #define NPTEPG (PAGE_SIZE/(sizeof (pt_entry_t))) 97*4a5d661aSToomas Soome #define NPTEPGSHIFT 9 /* LOG2(NPTEPG) */ 98*4a5d661aSToomas Soome #define PAGE_SHIFT 12 /* LOG2(PAGE_SIZE) */ 99*4a5d661aSToomas Soome #define PAGE_SIZE (1<<PAGE_SHIFT) /* bytes/page */ 100*4a5d661aSToomas Soome #define PAGE_MASK (PAGE_SIZE-1) 101*4a5d661aSToomas Soome /* Size of the level 2 page directory units */ 102*4a5d661aSToomas Soome #define NPDEPG (PAGE_SIZE/(sizeof (pd_entry_t))) 103*4a5d661aSToomas Soome #define NPDEPGSHIFT 9 /* LOG2(NPDEPG) */ 104*4a5d661aSToomas Soome #define PDRSHIFT 21 /* LOG2(NBPDR) */ 105*4a5d661aSToomas Soome #define NBPDR (1<<PDRSHIFT) /* bytes/page dir */ 106*4a5d661aSToomas Soome #define PDRMASK (NBPDR-1) 107*4a5d661aSToomas Soome /* Size of the level 3 page directory pointer table units */ 108*4a5d661aSToomas Soome #define NPDPEPG (PAGE_SIZE/(sizeof (pdp_entry_t))) 109*4a5d661aSToomas Soome #define NPDPEPGSHIFT 9 /* LOG2(NPDPEPG) */ 110*4a5d661aSToomas Soome #define PDPSHIFT 30 /* LOG2(NBPDP) */ 111*4a5d661aSToomas Soome #define NBPDP (1<<PDPSHIFT) /* bytes/page dir ptr table */ 112*4a5d661aSToomas Soome #define PDPMASK (NBPDP-1) 113*4a5d661aSToomas Soome /* Size of the level 4 page-map level-4 table units */ 114*4a5d661aSToomas Soome #define NPML4EPG (PAGE_SIZE/(sizeof (pml4_entry_t))) 115*4a5d661aSToomas Soome #define NPML4EPGSHIFT 9 /* LOG2(NPML4EPG) */ 116*4a5d661aSToomas Soome #define PML4SHIFT 39 /* LOG2(NBPML4) */ 117*4a5d661aSToomas Soome #define NBPML4 (1UL<<PML4SHIFT)/* bytes/page map lev4 table */ 118*4a5d661aSToomas Soome #define PML4MASK (NBPML4-1) 119*4a5d661aSToomas Soome 120*4a5d661aSToomas Soome #define MAXPAGESIZES 3 /* maximum number of supported page sizes */ 121*4a5d661aSToomas Soome 122*4a5d661aSToomas Soome #define IOPAGES 2 /* pages of i/o permission bitmap */ 123*4a5d661aSToomas Soome /* 124*4a5d661aSToomas Soome * I/O permission bitmap has a bit for each I/O port plus an additional 125*4a5d661aSToomas Soome * byte at the end with all bits set. See section "I/O Permission Bit Map" 126*4a5d661aSToomas Soome * in the Intel SDM for more details. 127*4a5d661aSToomas Soome */ 128*4a5d661aSToomas Soome #define IOPERM_BITMAP_SIZE (IOPAGES * PAGE_SIZE + 1) 129*4a5d661aSToomas Soome 130*4a5d661aSToomas Soome #ifndef KSTACK_PAGES 131*4a5d661aSToomas Soome #define KSTACK_PAGES 4 /* pages of kstack (with pcb) */ 132*4a5d661aSToomas Soome #endif 133*4a5d661aSToomas Soome #define KSTACK_GUARD_PAGES 1 /* pages of kstack guard; 0 disables */ 134*4a5d661aSToomas Soome 135*4a5d661aSToomas Soome /* 136*4a5d661aSToomas Soome * Mach derived conversion macros 137*4a5d661aSToomas Soome */ 138*4a5d661aSToomas Soome #define round_page(x) ((((unsigned long)(x)) + PAGE_MASK) & ~(PAGE_MASK)) 139*4a5d661aSToomas Soome #define trunc_page(x) ((unsigned long)(x) & ~(PAGE_MASK)) 140*4a5d661aSToomas Soome #define trunc_2mpage(x) ((unsigned long)(x) & ~PDRMASK) 141*4a5d661aSToomas Soome #define round_2mpage(x) ((((unsigned long)(x)) + PDRMASK) & ~PDRMASK) 142*4a5d661aSToomas Soome #define trunc_1gpage(x) ((unsigned long)(x) & ~PDPMASK) 143*4a5d661aSToomas Soome 144*4a5d661aSToomas Soome #define atop(x) ((unsigned long)(x) >> PAGE_SHIFT) 145*4a5d661aSToomas Soome #define ptoa(x) ((unsigned long)(x) << PAGE_SHIFT) 146*4a5d661aSToomas Soome 147*4a5d661aSToomas Soome #define amd64_btop(x) ((unsigned long)(x) >> PAGE_SHIFT) 148*4a5d661aSToomas Soome #define amd64_ptob(x) ((unsigned long)(x) << PAGE_SHIFT) 149*4a5d661aSToomas Soome 150*4a5d661aSToomas Soome #define pgtok(x) ((unsigned long)(x) * (PAGE_SIZE / 1024)) 151*4a5d661aSToomas Soome 152*4a5d661aSToomas Soome #define INKERNEL(va) (((va) >= DMAP_MIN_ADDRESS && (va) < DMAP_MAX_ADDRESS) \ 153*4a5d661aSToomas Soome || ((va) >= VM_MIN_KERNEL_ADDRESS && (va) < VM_MAX_KERNEL_ADDRESS)) 154*4a5d661aSToomas Soome 155*4a5d661aSToomas Soome #endif /* !_AMD64_INCLUDE_PARAM_H_ */ 156