lpae_defs.h 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. /*
  2. * Linux 2.6.32 and later Kernel module for VMware MVP Hypervisor Support
  3. *
  4. * Copyright (C) 2010-2013 VMware, Inc. All rights reserved.
  5. *
  6. * This program is free software; you can redistribute it and/or modify it
  7. * under the terms of the GNU General Public License version 2 as published by
  8. * the Free Software Foundation.
  9. *
  10. * This program is distributed in the hope that it will be useful, but WITHOUT
  11. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  12. * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  13. * more details.
  14. *
  15. * You should have received a copy of the GNU General Public License along with
  16. * this program; see the file COPYING. If not, write to the Free Software
  17. * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  18. */
  19. #line 5
  20. /**
  21. * @file
  22. *
  23. * @brief Large physical address extension definitions.
  24. *
  25. * See ARM PRD03-GENC-008469 11.0.
  26. */
  27. #ifndef _LPAE_DEFS_H_
  28. #define _LPAE_DEFS_H_
  29. #define INCLUDE_ALLOW_MVPD
  30. #define INCLUDE_ALLOW_VMX
  31. #define INCLUDE_ALLOW_MODULE
  32. #define INCLUDE_ALLOW_MONITOR
  33. #define INCLUDE_ALLOW_PV
  34. #define INCLUDE_ALLOW_GPL
  35. #include "include_check.h"
  36. #define ARM_LPAE_PT_ORDER 12
  37. #define ARM_LPAE_PT_SIZE (1 << ARM_LPAE_PT_ORDER)
  38. #define ARM_LPAE_ENTRY_ORDER 3
  39. #define ARM_LPAE_PT_ENTRIES_ORDER (ARM_LPAE_PT_ORDER - ARM_LPAE_ENTRY_ORDER)
  40. #define ARM_LPAE_PT_ENTRIES (1 << ARM_LPAE_PT_ENTRIES_ORDER)
  41. #define ARM_LPAE_L1D_BLOCK_ORDER 30
  42. #define ARM_LPAE_L2D_BLOCK_ORDER 21
  43. #define ARM_LPAE_L3D_BLOCK_ORDER 12
  44. #define ARM_LPAE_L1D_BLOCK_BITS (40 - ARM_LPAE_L1D_BLOCK_ORDER)
  45. #define ARM_LPAE_L2D_BLOCK_BITS (40 - ARM_LPAE_L2D_BLOCK_ORDER)
  46. #define ARM_LPAE_L3D_BLOCK_BITS (40 - ARM_LPAE_L3D_BLOCK_ORDER)
  47. /*
  48. * Currently supporting up to 16GB PA spaces.
  49. */
  50. #define ARM_LPAE_L1PT_INDX(addr) \
  51. MVP_EXTRACT_FIELD64(addr, ARM_LPAE_L1D_BLOCK_ORDER, 4)
  52. #define ARM_LPAE_L2PT_INDX(addr) \
  53. MVP_EXTRACT_FIELD64(addr, ARM_LPAE_L2D_BLOCK_ORDER, \
  54. ARM_LPAE_PT_ENTRIES_ORDER)
  55. #define ARM_LPAE_L3PT_INDX(addr) \
  56. MVP_EXTRACT_FIELD64(addr, ARM_LPAE_L3D_BLOCK_ORDER, \
  57. ARM_LPAE_PT_ENTRIES_ORDER)
  58. #define ARM_LPAE_L1D_BLOCK_BASE_ADDR(base) ((base) << ARM_LPAE_L1D_BLOCK_ORDER)
  59. #define ARM_LPAE_L1D_BLOCK_ADDR_BASE(addr) ((addr) >> ARM_LPAE_L1D_BLOCK_ORDER)
  60. #define ARM_LPAE_L2D_BLOCK_BASE_ADDR(base) ((base) << ARM_LPAE_L2D_BLOCK_ORDER)
  61. #define ARM_LPAE_L2D_BLOCK_ADDR_BASE(addr) ((addr) >> ARM_LPAE_L2D_BLOCK_ORDER)
  62. #define ARM_LPAE_L3D_BLOCK_BASE_ADDR(base) ((base) << ARM_LPAE_L3D_BLOCK_ORDER)
  63. #define ARM_LPAE_L3D_BLOCK_ADDR_BASE(addr) ((addr) >> ARM_LPAE_L3D_BLOCK_ORDER)
  64. #define ARM_LPAE_TABLE_BASE_ADDR(base) ((base) << ARM_LPAE_PT_ORDER)
  65. #define ARM_LPAE_TABLE_ADDR_BASE(addr) ((addr) >> ARM_LPAE_PT_ORDER)
  66. #define ARM_LPAE_TYPE_INVALID 0
  67. #define ARM_LPAE_TYPE_TABLE 3
  68. #define ARM_LPAE_L1D_TYPE_BLOCK 1
  69. #define ARM_LPAE_L2D_TYPE_BLOCK 1
  70. #define ARM_LPAE_L3D_TYPE_BLOCK 3
  71. /**
  72. * @name Second stage permission model.
  73. *
  74. * @{
  75. */
  76. #define ARM_LPAE_S2_PERM_NONE 0
  77. #define ARM_LPAE_S2_PERM_RO 1
  78. #define ARM_LPAE_S2_PERM_WO 2
  79. #define ARM_LPAE_S2_PERM_RW 3
  80. /*@}*/
  81. #endif /* ifndef _LPAE_DEFS_H_ */