- ``PAGE_IS_PFNZERO`` - Page has zero PFN
 - ``PAGE_IS_HUGE`` - Page is PMD-mapped THP or Hugetlb backed
 - ``PAGE_IS_SOFT_DIRTY`` - Page is soft-dirty
+- ``PAGE_IS_GUARD`` - Page is a part of a guard region
 
 The ``struct pm_scan_arg`` is used as the argument of the IOCTL.
 
 
 #define PM_SCAN_CATEGORIES     (PAGE_IS_WPALLOWED | PAGE_IS_WRITTEN |  \
                                 PAGE_IS_FILE | PAGE_IS_PRESENT |       \
                                 PAGE_IS_SWAPPED | PAGE_IS_PFNZERO |    \
-                                PAGE_IS_HUGE | PAGE_IS_SOFT_DIRTY)
+                                PAGE_IS_HUGE | PAGE_IS_SOFT_DIRTY |    \
+                                PAGE_IS_GUARD)
 #define PM_SCAN_FLAGS          (PM_SCAN_WP_MATCHING | PM_SCAN_CHECK_WPASYNC)
 
 struct pagemap_scan_private {
                if (!pte_swp_uffd_wp_any(pte))
                        categories |= PAGE_IS_WRITTEN;
 
-               if (p->masks_of_interest & PAGE_IS_FILE) {
-                       swp = pte_to_swp_entry(pte);
-                       if (is_pfn_swap_entry(swp) &&
-                           !folio_test_anon(pfn_swap_entry_folio(swp)))
-                               categories |= PAGE_IS_FILE;
-               }
+               swp = pte_to_swp_entry(pte);
+               if (is_guard_swp_entry(swp))
+                       categories |= PAGE_IS_GUARD;
+               else if ((p->masks_of_interest & PAGE_IS_FILE) &&
+                        is_pfn_swap_entry(swp) &&
+                        !folio_test_anon(pfn_swap_entry_folio(swp)))
+                       categories |= PAGE_IS_FILE;
+
                if (pte_swp_soft_dirty(pte))
                        categories |= PAGE_IS_SOFT_DIRTY;
        }
 
 #define PAGE_IS_PFNZERO                (1 << 5)
 #define PAGE_IS_HUGE           (1 << 6)
 #define PAGE_IS_SOFT_DIRTY     (1 << 7)
+#define PAGE_IS_GUARD          (1 << 8)
 
 /*
  * struct page_region - Page region with flags