param.h 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. /*-
  2. * SPDX-License-Identifier: BSD-4-Clause
  3. *
  4. * Copyright (c) 2001 David E. O'Brien
  5. * Copyright (c) 1990 The Regents of the University of California.
  6. * All rights reserved.
  7. *
  8. * This code is derived from software contributed to Berkeley by
  9. * William Jolitz.
  10. *
  11. * Redistribution and use in source and binary forms, with or without
  12. * modification, are permitted provided that the following conditions
  13. * are met:
  14. * 1. Redistributions of source code must retain the above copyright
  15. * notice, this list of conditions and the following disclaimer.
  16. * 2. Redistributions in binary form must reproduce the above copyright
  17. * notice, this list of conditions and the following disclaimer in the
  18. * documentation and/or other materials provided with the distribution.
  19. * 3. All advertising materials mentioning features or use of this software
  20. * must display the following acknowledgement:
  21. * This product includes software developed by the University of
  22. * California, Berkeley and its contributors.
  23. * 4. Neither the name of the University nor the names of its contributors
  24. * may be used to endorse or promote products derived from this software
  25. * without specific prior written permission.
  26. *
  27. * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  28. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  29. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  30. * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  31. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  32. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  33. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  34. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  35. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  36. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  37. * SUCH DAMAGE.
  38. *
  39. * from: @(#)param.h 5.8 (Berkeley) 6/28/91
  40. * $FreeBSD$
  41. */
  42. #ifndef _POWERPC_INCLUDE_PARAM_H_
  43. #define _POWERPC_INCLUDE_PARAM_H_
  44. /*
  45. * Machine dependent constants for PowerPC
  46. */
  47. #include <machine/_align.h>
  48. /* Needed to display interrupts on OFW PCI */
  49. #define __PCI_REROUTE_INTERRUPT
  50. #ifndef MACHINE
  51. #define MACHINE "powerpc"
  52. #endif
  53. #ifndef MACHINE_ARCH
  54. #ifdef __powerpc64__
  55. #if defined(__LITTLE_ENDIAN__)
  56. #define MACHINE_ARCH "powerpc64le"
  57. #else
  58. #define MACHINE_ARCH "powerpc64"
  59. #endif
  60. #else
  61. #ifdef __SPE__
  62. #define MACHINE_ARCH "powerpcspe"
  63. #else
  64. #define MACHINE_ARCH "powerpc"
  65. #endif
  66. #endif
  67. #endif
  68. #define MID_MACHINE MID_POWERPC
  69. #ifdef __powerpc64__
  70. #ifndef MACHINE_ARCH32
  71. #define MACHINE_ARCH32 "powerpc"
  72. #endif
  73. #endif
  74. #ifdef SMP
  75. #ifndef MAXCPU
  76. #define MAXCPU 256
  77. #endif
  78. #else
  79. #define MAXCPU 1
  80. #endif
  81. #ifndef MAXMEMDOM
  82. #define MAXMEMDOM 8
  83. #endif
  84. #define ALIGNBYTES _ALIGNBYTES
  85. #define ALIGN(p) _ALIGN(p)
  86. /*
  87. * ALIGNED_POINTER is a boolean macro that checks whether an address
  88. * is valid to fetch data elements of type t from on this architecture.
  89. * This does not reflect the optimal alignment, just the possibility
  90. * (within reasonable limits).
  91. */
  92. #define ALIGNED_POINTER(p, t) ((((uintptr_t)(p)) & (sizeof (t) - 1)) == 0)
  93. /*
  94. * CACHE_LINE_SIZE is the compile-time maximum cache line size for an
  95. * architecture. It should be used with appropriate caution.
  96. */
  97. #define CACHE_LINE_SHIFT 7
  98. #define CACHE_LINE_SIZE (1 << CACHE_LINE_SHIFT)
  99. #define PAGE_SHIFT 12
  100. #define PAGE_SIZE (1 << PAGE_SHIFT) /* Page size */
  101. #define PAGE_MASK (PAGE_SIZE - 1)
  102. #define NPTEPG (PAGE_SIZE/(sizeof (pt_entry_t)))
  103. #define NPDEPG (PAGE_SIZE/(sizeof (pt_entry_t)))
  104. #define L1_PAGE_SIZE_SHIFT 39
  105. #define L1_PAGE_SIZE (1UL<<L1_PAGE_SIZE_SHIFT)
  106. #define L1_PAGE_MASK (L1_PAGE_SIZE-1)
  107. #define L2_PAGE_SIZE_SHIFT 30
  108. #define L2_PAGE_SIZE (1UL<<L2_PAGE_SIZE_SHIFT)
  109. #define L2_PAGE_MASK (L2_PAGE_SIZE-1)
  110. #define L3_PAGE_SIZE_SHIFT 21
  111. #define L3_PAGE_SIZE (1UL<<L3_PAGE_SIZE_SHIFT)
  112. #define L3_PAGE_MASK (L3_PAGE_SIZE-1)
  113. #define MAXPAGESIZES 3 /* maximum number of supported page sizes */
  114. #define RELOCATABLE_KERNEL 1 /* kernel may relocate during startup */
  115. #ifndef KSTACK_PAGES
  116. #ifdef __powerpc64__
  117. #define KSTACK_PAGES 12 /* includes pcb */
  118. #else
  119. #define KSTACK_PAGES 4 /* includes pcb */
  120. #endif
  121. #endif
  122. #define KSTACK_GUARD_PAGES 1 /* pages of kstack guard; 0 disables */
  123. #define USPACE (kstack_pages * PAGE_SIZE) /* total size of pcb */
  124. #define COPYFAULT 0x1
  125. #define FUSUFAULT 0x2
  126. /*
  127. * Mach derived conversion macros
  128. */
  129. #define trunc_page(x) ((x) & ~(PAGE_MASK))
  130. #define round_page(x) (((x) + PAGE_MASK) & ~PAGE_MASK)
  131. #define trunc_2mpage(x) ((unsigned long)(x) & ~L3_PAGE_MASK)
  132. #define round_2mpage(x) ((((unsigned long)(x)) + L3_PAGE_MASK) & ~L3_PAGE_MASK)
  133. #define trunc_1gpage(x) ((unsigned long)(x) & ~L2_PAGE_MASK)
  134. #define atop(x) ((x) >> PAGE_SHIFT)
  135. #define ptoa(x) ((x) << PAGE_SHIFT)
  136. #define powerpc_btop(x) ((x) >> PAGE_SHIFT)
  137. #define powerpc_ptob(x) ((x) << PAGE_SHIFT)
  138. #define pgtok(x) ((x) * (PAGE_SIZE / 1024UL))
  139. #define btoc(x) ((vm_offset_t)(((x)+PAGE_MASK)>>PAGE_SHIFT))
  140. #endif /* !_POWERPC_INCLUDE_PARAM_H_ */