*/
 int uv_destroy_owned_page(unsigned long paddr)
 {
-       struct page *page = phys_to_page(paddr);
+       struct folio *folio = phys_to_folio(paddr);
        int rc;
 
-       get_page(page);
+       /* See gmap_make_secure(): large folios cannot be secure */
+       if (unlikely(folio_test_large(folio)))
+               return 0;
+
+       folio_get(folio);
        rc = uv_destroy_page(paddr);
        if (!rc)
-               clear_bit(PG_arch_1, &page->flags);
-       put_page(page);
+               clear_bit(PG_arch_1, &folio->flags);
+       folio_put(folio);
        return rc;
 }
 
  */
 int uv_convert_owned_from_secure(unsigned long paddr)
 {
-       struct page *page = phys_to_page(paddr);
+       struct folio *folio = phys_to_folio(paddr);
        int rc;
 
-       get_page(page);
+       /* See gmap_make_secure(): large folios cannot be secure */
+       if (unlikely(folio_test_large(folio)))
+               return 0;
+
+       folio_get(folio);
        rc = uv_convert_from_secure(paddr);
        if (!rc)
-               clear_bit(PG_arch_1, &page->flags);
-       put_page(page);
+               clear_bit(PG_arch_1, &folio->flags);
+       folio_put(folio);
        return rc;
 }
 
  */
 int arch_make_page_accessible(struct page *page)
 {
+       struct folio *folio = page_folio(page);
        int rc = 0;
 
-       /* Hugepage cannot be protected, so nothing to do */
-       if (PageHuge(page))
+       /* See gmap_make_secure(): large folios cannot be secure */
+       if (unlikely(folio_test_large(folio)))
                return 0;
 
        /*
         * PG_arch_1 is used in 3 places:
         * 1. for kernel page tables during early boot
         * 2. for storage keys of huge pages and KVM
-        * 3. As an indication that this page might be secure. This can
+        * 3. As an indication that this small folio might be secure. This can
         *    overindicate, e.g. we set the bit before calling
         *    convert_to_secure.
         * As secure pages are never huge, all 3 variants can co-exists.
         */
-       if (!test_bit(PG_arch_1, &page->flags))
+       if (!test_bit(PG_arch_1, &folio->flags))
                return 0;
 
-       rc = uv_pin_shared(page_to_phys(page));
+       rc = uv_pin_shared(folio_to_phys(folio));
        if (!rc) {
-               clear_bit(PG_arch_1, &page->flags);
+               clear_bit(PG_arch_1, &folio->flags);
                return 0;
        }
 
-       rc = uv_convert_from_secure(page_to_phys(page));
+       rc = uv_convert_from_secure(folio_to_phys(folio));
        if (!rc) {
-               clear_bit(PG_arch_1, &page->flags);
+               clear_bit(PG_arch_1, &folio->flags);
                return 0;
        }