mirror of
				https://github.com/AetherDroid/android_kernel_samsung_on5xelte.git
				synced 2025-10-30 23:58:51 +01:00 
			
		
		
		
	Fixed MTP to work with TWRP
This commit is contained in:
		
						commit
						f6dfaef42e
					
				
					 50820 changed files with 20846062 additions and 0 deletions
				
			
		
							
								
								
									
										110
									
								
								arch/sh/drivers/pci/pci-sh5.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										110
									
								
								arch/sh/drivers/pci/pci-sh5.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,110 @@ | |||
| /*
 | ||||
|  * Copyright (C) 2001 David J. Mckay (david.mckay@st.com) | ||||
|  * | ||||
|  * May be copied or modified under the terms of the GNU General Public | ||||
|  * License.  See linux/COPYING for more information. | ||||
|  * | ||||
|  * Definitions for the SH5 PCI hardware. | ||||
|  */ | ||||
| #ifndef __PCI_SH5_H | ||||
| #define __PCI_SH5_H | ||||
| 
 | ||||
| /* Product ID */ | ||||
| #define PCISH5_PID		0x350d | ||||
| 
 | ||||
| /* vendor ID */ | ||||
| #define PCISH5_VID		0x1054 | ||||
| 
 | ||||
| /* Configuration types */ | ||||
| #define ST_TYPE0                0x00    /* Configuration cycle type 0 */ | ||||
| #define ST_TYPE1                0x01    /* Configuration cycle type 1 */ | ||||
| 
 | ||||
| /* VCR data */ | ||||
| #define PCISH5_VCR_STATUS      0x00 | ||||
| #define PCISH5_VCR_VERSION     0x08 | ||||
| 
 | ||||
| /*
 | ||||
| ** ICR register offsets and bits | ||||
| */ | ||||
| #define PCISH5_ICR_CR          0x100   /* PCI control register values */ | ||||
| #define CR_PBAM                 (1<<12) | ||||
| #define CR_PFCS                 (1<<11) | ||||
| #define CR_FTO                  (1<<10) | ||||
| #define CR_PFE                  (1<<9) | ||||
| #define CR_TBS                  (1<<8) | ||||
| #define CR_SPUE                 (1<<7) | ||||
| #define CR_BMAM                 (1<<6) | ||||
| #define CR_HOST                 (1<<5) | ||||
| #define CR_CLKEN                (1<<4) | ||||
| #define CR_SOCS                 (1<<3) | ||||
| #define CR_IOCS                 (1<<2) | ||||
| #define CR_RSTCTL               (1<<1) | ||||
| #define CR_CFINT                (1<<0) | ||||
| #define CR_LOCK_MASK            0xa5000000 | ||||
| 
 | ||||
| #define PCISH5_ICR_INT         0x114   /* Interrupt registert values     */ | ||||
| #define INT_MADIM               (1<<2) | ||||
| 
 | ||||
| #define PCISH5_ICR_LSR0        0X104   /* Local space register values    */ | ||||
| #define PCISH5_ICR_LSR1        0X108   /* Local space register values    */ | ||||
| #define PCISH5_ICR_LAR0        0x10c   /* Local address register values  */ | ||||
| #define PCISH5_ICR_LAR1        0x110   /* Local address register values  */ | ||||
| #define PCISH5_ICR_INTM        0x118   /* Interrupt mask register values                         */ | ||||
| #define PCISH5_ICR_AIR         0x11c   /* Interrupt error address information register values    */ | ||||
| #define PCISH5_ICR_CIR         0x120   /* Interrupt error command information register values    */ | ||||
| #define PCISH5_ICR_AINT        0x130   /* Interrupt error arbiter interrupt register values      */ | ||||
| #define PCISH5_ICR_AINTM       0x134   /* Interrupt error arbiter interrupt mask register values */ | ||||
| #define PCISH5_ICR_BMIR        0x138   /* Interrupt error info register of bus master values     */ | ||||
| #define PCISH5_ICR_PAR         0x1c0   /* Pio address register values                            */ | ||||
| #define PCISH5_ICR_MBR         0x1c4   /* Memory space bank register values                      */ | ||||
| #define PCISH5_ICR_IOBR        0x1c8   /* I/O space bank register values                         */ | ||||
| #define PCISH5_ICR_PINT        0x1cc   /* power management interrupt register values             */ | ||||
| #define PCISH5_ICR_PINTM       0x1d0   /* power management interrupt mask register values        */ | ||||
| #define PCISH5_ICR_MBMR        0x1d8   /* memory space bank mask register values                 */ | ||||
| #define PCISH5_ICR_IOBMR       0x1dc   /* I/O space bank mask register values                    */ | ||||
| #define PCISH5_ICR_CSCR0       0x210   /* PCI cache snoop control register 0                     */ | ||||
| #define PCISH5_ICR_CSCR1       0x214   /* PCI cache snoop control register 1                     */ | ||||
| #define PCISH5_ICR_PDR         0x220   /* Pio data register values                               */ | ||||
| 
 | ||||
| /* These are configs space registers */ | ||||
| #define PCISH5_ICR_CSR_VID     0x000	/* Vendor id                           */ | ||||
| #define PCISH5_ICR_CSR_DID     0x002   /* Device id                           */ | ||||
| #define PCISH5_ICR_CSR_CMD     0x004   /* Command register                    */ | ||||
| #define PCISH5_ICR_CSR_STATUS  0x006   /* Stautus                             */ | ||||
| #define PCISH5_ICR_CSR_IBAR0   0x010   /* I/O base address register           */ | ||||
| #define PCISH5_ICR_CSR_MBAR0   0x014   /* First  Memory base address register */ | ||||
| #define PCISH5_ICR_CSR_MBAR1   0x018   /* Second Memory base address register */ | ||||
| 
 | ||||
| /* Base address of registers */ | ||||
| #define SH5PCI_ICR_BASE (PHYS_PCI_BLOCK + 0x00040000) | ||||
| #define SH5PCI_IO_BASE  (PHYS_PCI_BLOCK + 0x00800000) | ||||
| /* #define SH5PCI_VCR_BASE (P2SEG_PCICB_BLOCK + P2SEG)    */ | ||||
| 
 | ||||
| extern unsigned long pcicr_virt; | ||||
| /* Register selection macro */ | ||||
| #define PCISH5_ICR_REG(x)                ( pcicr_virt + (PCISH5_ICR_##x)) | ||||
| /* #define PCISH5_VCR_REG(x)                ( SH5PCI_VCR_BASE (PCISH5_VCR_##x)) */ | ||||
| 
 | ||||
| /* Write I/O functions */ | ||||
| #define SH5PCI_WRITE(reg,val)        __raw_writel((u32)(val),PCISH5_ICR_REG(reg)) | ||||
| #define SH5PCI_WRITE_SHORT(reg,val)  __raw_writew((u16)(val),PCISH5_ICR_REG(reg)) | ||||
| #define SH5PCI_WRITE_BYTE(reg,val)   __raw_writeb((u8)(val),PCISH5_ICR_REG(reg)) | ||||
| 
 | ||||
| /* Read I/O functions */ | ||||
| #define SH5PCI_READ(reg)             __raw_readl(PCISH5_ICR_REG(reg)) | ||||
| #define SH5PCI_READ_SHORT(reg)       __raw_readw(PCISH5_ICR_REG(reg)) | ||||
| #define SH5PCI_READ_BYTE(reg)        __raw_readb(PCISH5_ICR_REG(reg)) | ||||
| 
 | ||||
| /* Set PCI config bits */ | ||||
| #define SET_CONFIG_BITS(bus,devfn,where)  ((((bus) << 16) | ((devfn) << 8) | ((where) & ~3)) | 0x80000000) | ||||
| 
 | ||||
| /* Set PCI command register */ | ||||
| #define CONFIG_CMD(bus, devfn, where)            SET_CONFIG_BITS(bus->number,devfn,where) | ||||
| 
 | ||||
| /* Size converters */ | ||||
| #define PCISH5_MEM_SIZCONV(x)		  (((x / 0x40000) - 1) << 18) | ||||
| #define PCISH5_IO_SIZCONV(x)		  (((x / 0x40000) - 1) << 18) | ||||
| 
 | ||||
| extern struct pci_ops sh5_pci_ops; | ||||
| 
 | ||||
| #endif /* __PCI_SH5_H */ | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 awab228
						awab228