select ARCH_HAS_SYSCALL_WRAPPER
        select ARCH_HAS_UBSAN_SANITIZE_ALL
        select ARCH_HAS_VDSO_DATA
+       select ARCH_HAS_VM_GET_PAGE_PROT
        select ARCH_HAVE_NMI_SAFE_CMPXCHG
        select ARCH_INLINE_READ_LOCK
        select ARCH_INLINE_READ_LOCK_BH
 
  * implies read permission.
  */
          /*xwr*/
-#define __P000 PAGE_NONE
-#define __P001 PAGE_RO
-#define __P010 PAGE_RO
-#define __P011 PAGE_RO
-#define __P100 PAGE_RX
-#define __P101 PAGE_RX
-#define __P110 PAGE_RX
-#define __P111 PAGE_RX
-
-#define __S000 PAGE_NONE
-#define __S001 PAGE_RO
-#define __S010 PAGE_RW
-#define __S011 PAGE_RW
-#define __S100 PAGE_RX
-#define __S101 PAGE_RX
-#define __S110 PAGE_RWX
-#define __S111 PAGE_RWX
 
 /*
  * Segment entry (large page) protection definitions.
 
                mm->get_unmapped_area = arch_get_unmapped_area_topdown;
        }
 }
+
+static const pgprot_t protection_map[16] = {
+       [VM_NONE]                                       = PAGE_NONE,
+       [VM_READ]                                       = PAGE_RO,
+       [VM_WRITE]                                      = PAGE_RO,
+       [VM_WRITE | VM_READ]                            = PAGE_RO,
+       [VM_EXEC]                                       = PAGE_RX,
+       [VM_EXEC | VM_READ]                             = PAGE_RX,
+       [VM_EXEC | VM_WRITE]                            = PAGE_RX,
+       [VM_EXEC | VM_WRITE | VM_READ]                  = PAGE_RX,
+       [VM_SHARED]                                     = PAGE_NONE,
+       [VM_SHARED | VM_READ]                           = PAGE_RO,
+       [VM_SHARED | VM_WRITE]                          = PAGE_RW,
+       [VM_SHARED | VM_WRITE | VM_READ]                = PAGE_RW,
+       [VM_SHARED | VM_EXEC]                           = PAGE_RX,
+       [VM_SHARED | VM_EXEC | VM_READ]                 = PAGE_RX,
+       [VM_SHARED | VM_EXEC | VM_WRITE]                = PAGE_RWX,
+       [VM_SHARED | VM_EXEC | VM_WRITE | VM_READ]      = PAGE_RWX
+};
+DECLARE_VM_GET_PAGE_PROT