From mboxrd@z Thu Jan 1 00:00:00 1970 From: bill4carson@gmail.com (bill4carson) Date: Fri, 03 Feb 2012 09:41:18 +0800 Subject: [RFC] ARM hugetlb support In-Reply-To: References: <1327910238-18704-1-git-send-email-bill4carson@gmail.com> <4F289BE2.9020404@gmail.com> Message-ID: <4F2B3B3E.6080807@gmail.com> To: linux-arm-kernel@lists.infradead.org List-Id: linux-arm-kernel.lists.infradead.org On 2012?02?02? 22:38, Catalin Marinas wrote: > On 1 February 2012 01:56, bill4carson wrote: >> On 2012?01?31? 17:29, Catalin Marinas wrote: >>> It also doesn't >>> help much with the TLB hit rate since the micro-TLB most likely only >>> support 1MB sections. >> I am afraid I can't agree with you on this. >> Truly there is no specific statement about whether micro-TLB support 16MB >> super-sections, >> but main-TLB actually helps the hit rate, and main-TLB support all page size >> mapping. > The feedback over time was that 16MB didn't help much in terms of TLB > misses compared to 1MB but that was for standard usage. I guess the > hugetlbfs has specific scenarios that may benefit. > > Anyway, could you make the 2MB/16MB huge page size configurable at > boot time (command line option like on other architectures)? Actually, only X86 supports multiple page size configuration at boot time, other architectures will has fixed huge page size once build. I'm not sure it's a MUST to support multiple page size at boot time, but I'm sure this will make marco "pte_pfn" much more complicated. > And also > check the ID_MMFR0[31:28] for whether supersections are supported. > Thanks for your tips :) >>> BTW, I have a (simpler) implementation of hugetlbfs with 2MB sections >>> but for LPAE only: >>> >>> >>> http://git.kernel.org/?p=linux/kernel/git/cmarinas/linux-arm-arch.git;a=shortlog;h=refs/heads/hugetlb >>> >> Thanks for your information, I will study your code carefully :) > Most of the simplicity comes from the fact that LPAE doesn't need a > separate Linux PTE table. > -- I am a slow learner but I will keep trying to fight for my dreams! --bill