#define get_cap(cap)   static_branch_unlikely(&lru_gen_caps[cap])
 #endif
 
+static bool should_walk_mmu(void)
+{
+       return arch_has_hw_pte_young() && get_cap(LRU_GEN_MM_WALK);
+}
+
+static bool should_clear_pmd_young(void)
+{
+       return arch_has_hw_nonleaf_pmd_young() && get_cap(LRU_GEN_NONLEAF_YOUNG);
+}
+
 /******************************************************************************
  *                          shorthand helpers
  ******************************************************************************/
                        goto next;
 
                if (!pmd_trans_huge(pmd[i])) {
-                       if (arch_has_hw_nonleaf_pmd_young() && get_cap(LRU_GEN_NONLEAF_YOUNG))
+                       if (should_clear_pmd_young())
                                pmdp_test_and_clear_young(vma, addr, pmd + i);
                        goto next;
                }
 #endif
                walk->mm_stats[MM_NONLEAF_TOTAL]++;
 
-               if (arch_has_hw_nonleaf_pmd_young() && get_cap(LRU_GEN_NONLEAF_YOUNG)) {
+               if (should_clear_pmd_young()) {
                        if (!pmd_young(val))
                                continue;
 
         * handful of PTEs. Spreading the work out over a period of time usually
         * is less efficient, but it avoids bursty page faults.
         */
-       if (!arch_has_hw_pte_young() || !get_cap(LRU_GEN_MM_WALK)) {
+       if (!should_walk_mmu()) {
                success = iterate_mm_list_nowalk(lruvec, max_seq);
                goto done;
        }
        if (get_cap(LRU_GEN_CORE))
                caps |= BIT(LRU_GEN_CORE);
 
-       if (arch_has_hw_pte_young() && get_cap(LRU_GEN_MM_WALK))
+       if (should_walk_mmu())
                caps |= BIT(LRU_GEN_MM_WALK);
 
-       if (arch_has_hw_nonleaf_pmd_young() && get_cap(LRU_GEN_NONLEAF_YOUNG))
+       if (should_clear_pmd_young())
                caps |= BIT(LRU_GEN_NONLEAF_YOUNG);
 
        return sysfs_emit(buf, "0x%04x\n", caps);