mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 52269718dc
			
		
	
	
		52269718dc
		
	
	
	
	
		
			
			- removal of the old dma_alloc_noncoherent interface
  - remove unused flags to dma_declare_coherent_memory
  - restrict OF DMA configuration to specific physical busses
  - use the iommu mailing list for dma-mapping questions and
    patches
 -----BEGIN PGP SIGNATURE-----
 
 iQI/BAABCAApFiEEgdbnc3r/njty3Iq9D55TZVIEUYMFAlm38VMLHGhjaEBsc3Qu
 ZGUACgkQD55TZVIEUYNa+BAAjlTbZ2DhEmBDKHDYjQepnqdw7oY/5B/6A3GKArbR
 psXDmWR8HetbJC1+Yg2aaCvSWdza9cR36juI4WSsA2+4FVLU0nj5elkX9QEN/eP4
 kiUuwUXCKi3MNd55ESIiVQos0RKvQ8us7rLDfug2h/8dVP5EdLNI//axHY4Y/R7k
 6j6ymal9QdHxLj8wdkAQ332womV2jQH44ISIy/Eu/eF1DmWJ1HZvgO/PNeSyVpwB
 bP8CRfMAnQDFqB0XiwCXyukNKntvBe7ZpazMdQKH6bObiLOa8DT2Ex/UeG6VBtb3
 TXeLW9aSJDG9FfzlqwDlySZWqQlvcEEK7DWm7kNka9tiHx+AKZW+utlrS7Pvofut
 ufqD9NRrmutBzgXsZiri/x9b5+UsREKsdHNyLHVfjYo9PlEsZwMjaXxExAlEdgvl
 L0pU4EpLP8kK5pRV5K8IXCEVMyoejI2ZIrtu5DHlc3mblUApXkKx1TG81gJsncHh
 fDLARilSgCN6g8wQjSiBiXwS6ynBRcmvpeIxrh3x7xQ7OqmqDMS5JcgJCNvBQEKm
 yEMCKd8vf30Jpva3VRmQXyUiDMwebguUqSJUDJW0JeDFFGQ7O39JeOwB72LzVHjZ
 N9VMh3gCvtkF2ZPV+HIPNbTFnfydzyjNW/BpGt4r5cyvfd2TjEDSPFeIOWZ+chVQ
 j68=
 =qHNs
 -----END PGP SIGNATURE-----
Merge tag 'dma-mapping-4.14' of git://git.infradead.org/users/hch/dma-mapping
Pull dma-mapping updates from Christoph Hellwig:
 - removal of the old dma_alloc_noncoherent interface
 - remove unused flags to dma_declare_coherent_memory
 - restrict OF DMA configuration to specific physical busses
 - use the iommu mailing list for dma-mapping questions and patches
* tag 'dma-mapping-4.14' of git://git.infradead.org/users/hch/dma-mapping:
  dma-coherent: fix dma_declare_coherent_memory() logic error
  ARM: imx: mx31moboard: Remove unused 'dma' variable
  dma-coherent: remove an unused variable
  MAINTAINERS: use the iommu list for the dma-mapping subsystem
  dma-coherent: remove the DMA_MEMORY_MAP and DMA_MEMORY_IO flags
  dma-coherent: remove the DMA_MEMORY_INCLUDES_CHILDREN flag
  of: restrict DMA configuration
  dma-mapping: remove dma_alloc_noncoherent and dma_free_noncoherent
  i825xx: switch to switch to dma_alloc_attrs
  au1000_eth: switch to dma_alloc_attrs
  sgiseeq: switch to dma_alloc_attrs
  dma-mapping: reduce dma_mapping_error inline bloat
		
	
			
		
			
				
	
	
		
			89 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * arch/sh/drivers/pci/fixups-dreamcast.c
 | |
|  *
 | |
|  * PCI fixups for the Sega Dreamcast
 | |
|  *
 | |
|  * Copyright (C) 2001, 2002  M. R. Brown
 | |
|  * Copyright (C) 2002, 2003, 2006  Paul Mundt
 | |
|  *
 | |
|  * This file originally bore the message (with enclosed-$):
 | |
|  *	Id: pci.c,v 1.3 2003/05/04 19:29:46 lethal Exp
 | |
|  *	Dreamcast PCI: Supports SEGA Broadband Adaptor only.
 | |
|  *
 | |
|  * This file is subject to the terms and conditions of the GNU General Public
 | |
|  * License.  See the file "COPYING" in the main directory of this archive
 | |
|  * for more details.
 | |
|  */
 | |
| 
 | |
| #include <linux/sched.h>
 | |
| #include <linux/kernel.h>
 | |
| #include <linux/param.h>
 | |
| #include <linux/interrupt.h>
 | |
| #include <linux/init.h>
 | |
| #include <linux/irq.h>
 | |
| #include <linux/pci.h>
 | |
| #include <linux/dma-mapping.h>
 | |
| 
 | |
| #include <asm/io.h>
 | |
| #include <asm/irq.h>
 | |
| #include <mach/pci.h>
 | |
| 
 | |
| static void gapspci_fixup_resources(struct pci_dev *dev)
 | |
| {
 | |
| 	struct pci_channel *p = dev->sysdata;
 | |
| 	struct resource res;
 | |
| 	struct pci_bus_region region;
 | |
| 
 | |
| 	printk(KERN_NOTICE "PCI: Fixing up device %s\n", pci_name(dev));
 | |
| 
 | |
| 	switch (dev->device) {
 | |
| 	case PCI_DEVICE_ID_SEGA_BBA:
 | |
| 		/*
 | |
| 		 * We also assume that dev->devfn == 0
 | |
| 		 */
 | |
| 		dev->resource[1].start	= p->resources[0].start  + 0x100;
 | |
| 		dev->resource[1].end	= dev->resource[1].start + 0x200 - 1;
 | |
| 
 | |
| 		/*
 | |
| 		 * This is not a normal BAR, prevent any attempts to move
 | |
| 		 * the BAR, as this will result in a bus lock.
 | |
| 		 */
 | |
| 		dev->resource[1].flags |= IORESOURCE_PCI_FIXED;
 | |
| 
 | |
| 		/*
 | |
| 		 * Redirect dma memory allocations to special memory window.
 | |
| 		 *
 | |
| 		 * If this GAPSPCI region were mapped by a BAR, the CPU
 | |
| 		 * phys_addr_t would be pci_resource_start(), and the bus
 | |
| 		 * address would be pci_bus_address(pci_resource_start()).
 | |
| 		 * But apparently there's no BAR mapping it, so we just
 | |
| 		 * "know" its CPU address is GAPSPCI_DMA_BASE.
 | |
| 		 */
 | |
| 		res.start = GAPSPCI_DMA_BASE;
 | |
| 		res.end = GAPSPCI_DMA_BASE + GAPSPCI_DMA_SIZE - 1;
 | |
| 		res.flags = IORESOURCE_MEM;
 | |
| 		pcibios_resource_to_bus(dev->bus, ®ion, &res);
 | |
| 		BUG_ON(dma_declare_coherent_memory(&dev->dev,
 | |
| 						res.start,
 | |
| 						region.start,
 | |
| 						resource_size(&res),
 | |
| 						DMA_MEMORY_EXCLUSIVE));
 | |
| 		break;
 | |
| 	default:
 | |
| 		printk("PCI: Failed resource fixup\n");
 | |
| 	}
 | |
| }
 | |
| DECLARE_PCI_FIXUP_HEADER(PCI_ANY_ID, PCI_ANY_ID, gapspci_fixup_resources);
 | |
| 
 | |
| int pcibios_map_platform_irq(const struct pci_dev *dev, u8 slot, u8 pin)
 | |
| {
 | |
| 	/*
 | |
| 	 * The interrupt routing semantics here are quite trivial.
 | |
| 	 *
 | |
| 	 * We basically only support one interrupt, so we only bother
 | |
| 	 * updating a device's interrupt line with this single shared
 | |
| 	 * interrupt. Keeps routing quite simple, doesn't it?
 | |
| 	 */
 | |
| 	return GAPSPCI_IRQ;
 | |
| }
 |