mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 d70b3ef54c
			
		
	
	
		d70b3ef54c
		
	
	
	
	
		
			
			Pull x86 core updates from Ingo Molnar:
 "There were so many changes in the x86/asm, x86/apic and x86/mm topics
  in this cycle that the topical separation of -tip broke down somewhat -
  so the result is a more traditional architecture pull request,
  collected into the 'x86/core' topic.
  The topics were still maintained separately as far as possible, so
  bisectability and conceptual separation should still be pretty good -
  but there were a handful of merge points to avoid excessive
  dependencies (and conflicts) that would have been poorly tested in the
  end.
  The next cycle will hopefully be much more quiet (or at least will
  have fewer dependencies).
  The main changes in this cycle were:
   * x86/apic changes, with related IRQ core changes: (Jiang Liu, Thomas
     Gleixner)
     - This is the second and most intrusive part of changes to the x86
       interrupt handling - full conversion to hierarchical interrupt
       domains:
          [IOAPIC domain]   -----
                                 |
          [MSI domain]      --------[Remapping domain] ----- [ Vector domain ]
                                 |   (optional)          |
          [HPET MSI domain] -----                        |
                                                         |
          [DMAR domain]     -----------------------------
                                                         |
          [Legacy domain]   -----------------------------
       This now reflects the actual hardware and allowed us to distangle
       the domain specific code from the underlying parent domain, which
       can be optional in the case of interrupt remapping.  It's a clear
       separation of functionality and removes quite some duct tape
       constructs which plugged the remap code between ioapic/msi/hpet
       and the vector management.
     - Intel IOMMU IRQ remapping enhancements, to allow direct interrupt
       injection into guests (Feng Wu)
   * x86/asm changes:
     - Tons of cleanups and small speedups, micro-optimizations.  This
       is in preparation to move a good chunk of the low level entry
       code from assembly to C code (Denys Vlasenko, Andy Lutomirski,
       Brian Gerst)
     - Moved all system entry related code to a new home under
       arch/x86/entry/ (Ingo Molnar)
     - Removal of the fragile and ugly CFI dwarf debuginfo annotations.
       Conversion to C will reintroduce many of them - but meanwhile
       they are only getting in the way, and the upstream kernel does
       not rely on them (Ingo Molnar)
     - NOP handling refinements. (Borislav Petkov)
   * x86/mm changes:
     - Big PAT and MTRR rework: making the code more robust and
       preparing to phase out exposing direct MTRR interfaces to drivers -
       in favor of using PAT driven interfaces (Toshi Kani, Luis R
       Rodriguez, Borislav Petkov)
     - New ioremap_wt()/set_memory_wt() interfaces to support
       Write-Through cached memory mappings.  This is especially
       important for good performance on NVDIMM hardware (Toshi Kani)
   * x86/ras changes:
     - Add support for deferred errors on AMD (Aravind Gopalakrishnan)
       This is an important RAS feature which adds hardware support for
       poisoned data.  That means roughly that the hardware marks data
       which it has detected as corrupted but wasn't able to correct, as
       poisoned data and raises an APIC interrupt to signal that in the
       form of a deferred error.  It is the OS's responsibility then to
       take proper recovery action and thus prolonge system lifetime as
       far as possible.
     - Add support for Intel "Local MCE"s: upcoming CPUs will support
       CPU-local MCE interrupts, as opposed to the traditional system-
       wide broadcasted MCE interrupts (Ashok Raj)
     - Misc cleanups (Borislav Petkov)
   * x86/platform changes:
     - Intel Atom SoC updates
  ... and lots of other cleanups, fixlets and other changes - see the
  shortlog and the Git log for details"
* 'x86-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (222 commits)
  x86/hpet: Use proper hpet device number for MSI allocation
  x86/hpet: Check for irq==0 when allocating hpet MSI interrupts
  x86/mm/pat, drivers/infiniband/ipath: Use arch_phys_wc_add() and require PAT disabled
  x86/mm/pat, drivers/media/ivtv: Use arch_phys_wc_add() and require PAT disabled
  x86/platform/intel/baytrail: Add comments about why we disabled HPET on Baytrail
  genirq: Prevent crash in irq_move_irq()
  genirq: Enhance irq_data_to_desc() to support hierarchy irqdomain
  iommu, x86: Properly handle posted interrupts for IOMMU hotplug
  iommu, x86: Provide irq_remapping_cap() interface
  iommu, x86: Setup Posted-Interrupts capability for Intel iommu
  iommu, x86: Add cap_pi_support() to detect VT-d PI capability
  iommu, x86: Avoid migrating VT-d posted interrupts
  iommu, x86: Save the mode (posted or remapped) of an IRTE
  iommu, x86: Implement irq_set_vcpu_affinity for intel_ir_chip
  iommu: dmar: Provide helper to copy shared irte fields
  iommu: dmar: Extend struct irte for VT-d Posted-Interrupts
  iommu: Add new member capability to struct irq_remap_ops
  x86/asm/entry/64: Disentangle error_entry/exit gsbase/ebx/usermode code
  x86/asm/entry/32: Shorten __audit_syscall_entry() args preparation
  x86/asm/entry/32: Explain reloading of registers after __audit_syscall_entry()
  ...
		
	
			
		
			
				
	
	
		
			124 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			124 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright © 2008 Ingo Molnar
 | |
|  *
 | |
|  * This program is free software; you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU General Public License as published by
 | |
|  * the Free Software Foundation; either version 2 of the License, or
 | |
|  * (at your option) any later version.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful, but
 | |
|  * WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
|  * General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License along
 | |
|  * with this program; if not, write to the Free Software Foundation, Inc.,
 | |
|  * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
 | |
|  */
 | |
| 
 | |
| #include <asm/iomap.h>
 | |
| #include <asm/pat.h>
 | |
| #include <linux/module.h>
 | |
| #include <linux/highmem.h>
 | |
| 
 | |
| static int is_io_mapping_possible(resource_size_t base, unsigned long size)
 | |
| {
 | |
| #if !defined(CONFIG_X86_PAE) && defined(CONFIG_PHYS_ADDR_T_64BIT)
 | |
| 	/* There is no way to map greater than 1 << 32 address without PAE */
 | |
| 	if (base + size > 0x100000000ULL)
 | |
| 		return 0;
 | |
| #endif
 | |
| 	return 1;
 | |
| }
 | |
| 
 | |
| int iomap_create_wc(resource_size_t base, unsigned long size, pgprot_t *prot)
 | |
| {
 | |
| 	enum page_cache_mode pcm = _PAGE_CACHE_MODE_WC;
 | |
| 	int ret;
 | |
| 
 | |
| 	if (!is_io_mapping_possible(base, size))
 | |
| 		return -EINVAL;
 | |
| 
 | |
| 	ret = io_reserve_memtype(base, base + size, &pcm);
 | |
| 	if (ret)
 | |
| 		return ret;
 | |
| 
 | |
| 	*prot = __pgprot(__PAGE_KERNEL | cachemode2protval(pcm));
 | |
| 	return 0;
 | |
| }
 | |
| EXPORT_SYMBOL_GPL(iomap_create_wc);
 | |
| 
 | |
| void iomap_free(resource_size_t base, unsigned long size)
 | |
| {
 | |
| 	io_free_memtype(base, base + size);
 | |
| }
 | |
| EXPORT_SYMBOL_GPL(iomap_free);
 | |
| 
 | |
| void *kmap_atomic_prot_pfn(unsigned long pfn, pgprot_t prot)
 | |
| {
 | |
| 	unsigned long vaddr;
 | |
| 	int idx, type;
 | |
| 
 | |
| 	preempt_disable();
 | |
| 	pagefault_disable();
 | |
| 
 | |
| 	type = kmap_atomic_idx_push();
 | |
| 	idx = type + KM_TYPE_NR * smp_processor_id();
 | |
| 	vaddr = __fix_to_virt(FIX_KMAP_BEGIN + idx);
 | |
| 	set_pte(kmap_pte - idx, pfn_pte(pfn, prot));
 | |
| 	arch_flush_lazy_mmu_mode();
 | |
| 
 | |
| 	return (void *)vaddr;
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * Map 'pfn' using protections 'prot'
 | |
|  */
 | |
| void __iomem *
 | |
| iomap_atomic_prot_pfn(unsigned long pfn, pgprot_t prot)
 | |
| {
 | |
| 	/*
 | |
| 	 * For non-PAT systems, translate non-WB request to UC- just in
 | |
| 	 * case the caller set the PWT bit to prot directly without using
 | |
| 	 * pgprot_writecombine(). UC- translates to uncached if the MTRR
 | |
| 	 * is UC or WC. UC- gets the real intention, of the user, which is
 | |
| 	 * "WC if the MTRR is WC, UC if you can't do that."
 | |
| 	 */
 | |
| 	if (!pat_enabled() && pgprot2cachemode(prot) != _PAGE_CACHE_MODE_WB)
 | |
| 		prot = __pgprot(__PAGE_KERNEL |
 | |
| 				cachemode2protval(_PAGE_CACHE_MODE_UC_MINUS));
 | |
| 
 | |
| 	return (void __force __iomem *) kmap_atomic_prot_pfn(pfn, prot);
 | |
| }
 | |
| EXPORT_SYMBOL_GPL(iomap_atomic_prot_pfn);
 | |
| 
 | |
| void
 | |
| iounmap_atomic(void __iomem *kvaddr)
 | |
| {
 | |
| 	unsigned long vaddr = (unsigned long) kvaddr & PAGE_MASK;
 | |
| 
 | |
| 	if (vaddr >= __fix_to_virt(FIX_KMAP_END) &&
 | |
| 	    vaddr <= __fix_to_virt(FIX_KMAP_BEGIN)) {
 | |
| 		int idx, type;
 | |
| 
 | |
| 		type = kmap_atomic_idx();
 | |
| 		idx = type + KM_TYPE_NR * smp_processor_id();
 | |
| 
 | |
| #ifdef CONFIG_DEBUG_HIGHMEM
 | |
| 		WARN_ON_ONCE(vaddr != __fix_to_virt(FIX_KMAP_BEGIN + idx));
 | |
| #endif
 | |
| 		/*
 | |
| 		 * Force other mappings to Oops if they'll try to access this
 | |
| 		 * pte without first remap it.  Keeping stale mappings around
 | |
| 		 * is a bad idea also, in case the page changes cacheability
 | |
| 		 * attributes or becomes a protected page in a hypervisor.
 | |
| 		 */
 | |
| 		kpte_clear_flush(kmap_pte-idx, vaddr);
 | |
| 		kmap_atomic_idx_pop();
 | |
| 	}
 | |
| 
 | |
| 	pagefault_enable();
 | |
| 	preempt_enable();
 | |
| }
 | |
| EXPORT_SYMBOL_GPL(iounmap_atomic);
 |