VM_WARN(!arch_irqs_disabled(), "%s called with irq enabled\n", __func__);
pte = __find_linux_pte(pgdir, ea, is_thp, hshift);
#ifdefined(CONFIG_DEBUG_VM) && \
!(defined(CONFIG_HUGETLB_PAGE) || defined(CONFIG_TRANSPARENT_HUGEPAGE)) /* * We should not find huge page if these configs are not enabled.
*/ if (hshift)
WARN_ON(*hshift); #endif return pte;
}
/* * Convert a kernel vmap virtual address (vmalloc or ioremap space) to a * physical address, without taking locks. This can be used in real-mode.
*/ staticinline phys_addr_t ppc_find_vmap_phys(unsignedlong addr)
{
pte_t *ptep;
phys_addr_t pa; int hugepage_shift;
/* * init_mm does not free page tables, and does not do THP. It may * have huge pages from huge vmalloc / ioremap etc.
*/
ptep = find_init_mm_pte(addr, &hugepage_shift); if (WARN_ON(!ptep)) return 0;
pa = PFN_PHYS(pte_pfn(*ptep));
if (!hugepage_shift)
hugepage_shift = PAGE_SHIFT;
pa |= addr & ((1ul << hugepage_shift) - 1);
return pa;
}
#endif/* _ASM_POWERPC_PTE_WALK_H */
Messung V0.5
¤ Dauer der Verarbeitung: 0.11 Sekunden
(vorverarbeitet)
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.