1*e4624435SJonathan Corbet.. include:: ../../disclaimer-zh_CN.rst 2*e4624435SJonathan Corbet 3*e4624435SJonathan Corbet:Original: :ref:`Documentation/arch/arm64/hugetlbpage.rst <hugetlbpage_index>` 4*e4624435SJonathan Corbet 5*e4624435SJonathan CorbetTranslator: Bailu Lin <bailu.lin@vivo.com> 6*e4624435SJonathan Corbet 7*e4624435SJonathan Corbet===================== 8*e4624435SJonathan CorbetARM64中的 HugeTLBpage 9*e4624435SJonathan Corbet===================== 10*e4624435SJonathan Corbet 11*e4624435SJonathan Corbet大页依靠有效利用 TLBs 来提高地址翻译的性能。这取决于以下 12*e4624435SJonathan Corbet两点 - 13*e4624435SJonathan Corbet 14*e4624435SJonathan Corbet - 大页的大小 15*e4624435SJonathan Corbet - TLBs 支持的条目大小 16*e4624435SJonathan Corbet 17*e4624435SJonathan CorbetARM64 接口支持2种大页方式。 18*e4624435SJonathan Corbet 19*e4624435SJonathan Corbet1) pud/pmd 级别的块映射 20*e4624435SJonathan Corbet----------------------- 21*e4624435SJonathan Corbet 22*e4624435SJonathan Corbet这是常规大页,他们的 pmd 或 pud 页面表条目指向一个内存块。 23*e4624435SJonathan Corbet不管 TLB 中支持的条目大小如何,块映射可以减少翻译大页地址 24*e4624435SJonathan Corbet所需遍历的页表深度。 25*e4624435SJonathan Corbet 26*e4624435SJonathan Corbet2) 使用连续位 27*e4624435SJonathan Corbet------------- 28*e4624435SJonathan Corbet 29*e4624435SJonathan Corbet架构中转换页表条目(D4.5.3, ARM DDI 0487C.a)中提供一个连续 30*e4624435SJonathan Corbet位告诉 MMU 这个条目是一个连续条目集的一员,它可以被缓存在单 31*e4624435SJonathan Corbet个 TLB 条目中。 32*e4624435SJonathan Corbet 33*e4624435SJonathan Corbet在 Linux 中连续位用来增加 pmd 和 pte(最后一级)级别映射的大 34*e4624435SJonathan Corbet小。受支持的连续页表条目数量因页面大小和页表级别而异。 35*e4624435SJonathan Corbet 36*e4624435SJonathan Corbet 37*e4624435SJonathan Corbet支持以下大页尺寸配置 - 38*e4624435SJonathan Corbet 39*e4624435SJonathan Corbet ====== ======== ==== ======== === 40*e4624435SJonathan Corbet - CONT PTE PMD CONT PMD PUD 41*e4624435SJonathan Corbet ====== ======== ==== ======== === 42*e4624435SJonathan Corbet 4K: 64K 2M 32M 1G 43*e4624435SJonathan Corbet 16K: 2M 32M 1G 44*e4624435SJonathan Corbet 64K: 2M 512M 16G 45*e4624435SJonathan Corbet ====== ======== ==== ======== === 46