mirror of
				https://github.com/torvalds/linux.git
				synced 2025-10-31 08:38:45 +02:00 
			
		
		
		
	x86, mm: support huge I/O mapping capability I/F
Implement huge I/O mapping capability interfaces for ioremap() on x86. IOREMAP_MAX_ORDER is defined to PUD_SHIFT on x86/64 and PMD_SHIFT on x86/32, which overrides the default value defined in <linux/vmalloc.h>. Signed-off-by: Toshi Kani <toshi.kani@hp.com> Cc: "H. Peter Anvin" <hpa@zytor.com> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Ingo Molnar <mingo@redhat.com> Cc: Arnd Bergmann <arnd@arndb.de> Cc: Dave Hansen <dave.hansen@intel.com> Cc: Robert Elliott <Elliott@hp.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
		
							parent
							
								
									b9820d8f39
								
							
						
					
					
						commit
						5d72b4fba4
					
				
					 2 changed files with 23 additions and 2 deletions
				
			
		|  | @ -40,8 +40,10 @@ | ||||||
| 
 | 
 | ||||||
| #ifdef CONFIG_X86_64 | #ifdef CONFIG_X86_64 | ||||||
| #include <asm/page_64_types.h> | #include <asm/page_64_types.h> | ||||||
|  | #define IOREMAP_MAX_ORDER       (PUD_SHIFT) | ||||||
| #else | #else | ||||||
| #include <asm/page_32_types.h> | #include <asm/page_32_types.h> | ||||||
|  | #define IOREMAP_MAX_ORDER       (PMD_SHIFT) | ||||||
| #endif	/* CONFIG_X86_64 */ | #endif	/* CONFIG_X86_64 */ | ||||||
| 
 | 
 | ||||||
| #ifndef __ASSEMBLY__ | #ifndef __ASSEMBLY__ | ||||||
|  |  | ||||||
|  | @ -67,8 +67,13 @@ static int __ioremap_check_ram(unsigned long start_pfn, unsigned long nr_pages, | ||||||
| 
 | 
 | ||||||
| /*
 | /*
 | ||||||
|  * Remap an arbitrary physical address space into the kernel virtual |  * Remap an arbitrary physical address space into the kernel virtual | ||||||
|  * address space. Needed when the kernel wants to access high addresses |  * address space. It transparently creates kernel huge I/O mapping when | ||||||
|  * directly. |  * the physical address is aligned by a huge page size (1GB or 2MB) and | ||||||
|  |  * the requested size is at least the huge page size. | ||||||
|  |  * | ||||||
|  |  * NOTE: MTRRs can override PAT memory types with a 4KB granularity. | ||||||
|  |  * Therefore, the mapping code falls back to use a smaller page toward 4KB | ||||||
|  |  * when a mapping range is covered by non-WB type of MTRRs. | ||||||
|  * |  * | ||||||
|  * NOTE! We need to allow non-page-aligned mappings too: we will obviously |  * NOTE! We need to allow non-page-aligned mappings too: we will obviously | ||||||
|  * have to convert them into an offset in a page-aligned mapping, but the |  * have to convert them into an offset in a page-aligned mapping, but the | ||||||
|  | @ -326,6 +331,20 @@ void iounmap(volatile void __iomem *addr) | ||||||
| } | } | ||||||
| EXPORT_SYMBOL(iounmap); | EXPORT_SYMBOL(iounmap); | ||||||
| 
 | 
 | ||||||
|  | int arch_ioremap_pud_supported(void) | ||||||
|  | { | ||||||
|  | #ifdef CONFIG_X86_64 | ||||||
|  | 	return cpu_has_gbpages; | ||||||
|  | #else | ||||||
|  | 	return 0; | ||||||
|  | #endif | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int arch_ioremap_pmd_supported(void) | ||||||
|  | { | ||||||
|  | 	return cpu_has_pse; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /*
 | /*
 | ||||||
|  * Convert a physical pointer to a virtual kernel pointer for /dev/mem |  * Convert a physical pointer to a virtual kernel pointer for /dev/mem | ||||||
|  * access |  * access | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Toshi Kani
						Toshi Kani