~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/arch/sh/drivers/pci/ops-sh7786.c

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /arch/sh/drivers/pci/ops-sh7786.c (Version linux-6.11.5) and /arch/i386/drivers/pci/ops-sh7786.c (Version linux-6.0.19)


  1 // SPDX-License-Identifier: GPL-2.0                 1 
  2 /*                                                
  3  * Generic SH7786 PCI-Express operations.         
  4  *                                                
  5  *  Copyright (C) 2009 - 2010  Paul Mundt         
  6  */                                               
  7 #include <linux/kernel.h>                         
  8 #include <linux/init.h>                           
  9 #include <linux/pci.h>                            
 10 #include <linux/io.h>                             
 11 #include <linux/spinlock.h>                       
 12 #include "pcie-sh7786.h"                          
 13                                                   
 14 enum {                                            
 15         PCI_ACCESS_READ,                          
 16         PCI_ACCESS_WRITE,                         
 17 };                                                
 18                                                   
 19 static int sh7786_pcie_config_access(unsigned     
 20                 struct pci_bus *bus, unsigned     
 21 {                                                 
 22         struct pci_channel *chan = bus->sysdat    
 23         int dev, func, type, reg;                 
 24                                                   
 25         dev = PCI_SLOT(devfn);                    
 26         func = PCI_FUNC(devfn);                   
 27         type = !!bus->parent;                     
 28         reg = where & ~3;                         
 29                                                   
 30         if (bus->number > 255 || dev > 31 || f    
 31                 return PCIBIOS_FUNC_NOT_SUPPOR    
 32                                                   
 33         /*                                        
 34          * While each channel has its own memo    
 35          * space, it's generally only accessib    
 36          * When in root complex mode, the cont    
 37          * itself with either type 0 or type 1    
 38          * controller initiated target transfe    
 39          * result in a completer abort.           
 40          *                                        
 41          * Each channel effectively only suppo    
 42          * the same channel <-> device access     
 43          * value, we cheat a bit here and bind    
 44          * space to devfn 0 in order to enable    
 45          * case the regular PAR/PDR path is si    
 46          * config access itself is initiated a    
 47          */                                       
 48         if (pci_is_root_bus(bus)) {               
 49                 if (dev == 0) {                   
 50                         if (access_type == PCI    
 51                                 *data = pci_re    
 52                         else                      
 53                                 pci_write_reg(    
 54                                                   
 55                         return PCIBIOS_SUCCESS    
 56                 } else if (dev > 1)               
 57                         return PCIBIOS_DEVICE_    
 58         }                                         
 59                                                   
 60         /* Clear errors */                        
 61         pci_write_reg(chan, pci_read_reg(chan,    
 62                                                   
 63         /* Set the PIO address */                 
 64         pci_write_reg(chan, (bus->number << 24    
 65                                 (func << 16) |    
 66                                                   
 67         /* Enable the configuration access */     
 68         pci_write_reg(chan, (1 << 31) | (type     
 69                                                   
 70         /* Check for errors */                    
 71         if (pci_read_reg(chan, SH4A_PCIEERRFR)    
 72                 return PCIBIOS_DEVICE_NOT_FOUN    
 73                                                   
 74         /* Check for master and target aborts     
 75         if (pci_read_reg(chan, SH4A_PCIEPCICON    
 76                 return PCIBIOS_DEVICE_NOT_FOUN    
 77                                                   
 78         if (access_type == PCI_ACCESS_READ)       
 79                 *data = pci_read_reg(chan, SH4    
 80         else                                      
 81                 pci_write_reg(chan, *data, SH4    
 82                                                   
 83         /* Disable the configuration access */    
 84         pci_write_reg(chan, 0, SH4A_PCIEPCTLR)    
 85                                                   
 86         return PCIBIOS_SUCCESSFUL;                
 87 }                                                 
 88                                                   
 89 static int sh7786_pcie_read(struct pci_bus *bu    
 90                             int where, int siz    
 91 {                                                 
 92         unsigned long flags;                      
 93         int ret;                                  
 94         u32 data;                                 
 95                                                   
 96         if ((size == 2) && (where & 1))           
 97                 return PCIBIOS_BAD_REGISTER_NU    
 98         else if ((size == 4) && (where & 3))      
 99                 return PCIBIOS_BAD_REGISTER_NU    
100                                                   
101         raw_spin_lock_irqsave(&pci_config_lock    
102         ret = sh7786_pcie_config_access(PCI_AC    
103                                         devfn,    
104         if (ret != PCIBIOS_SUCCESSFUL) {          
105                 *val = 0xffffffff;                
106                 goto out;                         
107         }                                         
108                                                   
109         if (size == 1)                            
110                 *val = (data >> ((where & 3) <    
111         else if (size == 2)                       
112                 *val = (data >> ((where & 2) <    
113         else                                      
114                 *val = data;                      
115                                                   
116         dev_dbg(&bus->dev, "pcie-config-read:     
117                 "where=0x%04x size=%d val=0x%0    
118                 devfn, where, size, (unsigned     
119                                                   
120 out:                                              
121         raw_spin_unlock_irqrestore(&pci_config    
122         return ret;                               
123 }                                                 
124                                                   
125 static int sh7786_pcie_write(struct pci_bus *b    
126                              int where, int si    
127 {                                                 
128         unsigned long flags;                      
129         int shift, ret;                           
130         u32 data;                                 
131                                                   
132         if ((size == 2) && (where & 1))           
133                 return PCIBIOS_BAD_REGISTER_NU    
134         else if ((size == 4) && (where & 3))      
135                 return PCIBIOS_BAD_REGISTER_NU    
136                                                   
137         raw_spin_lock_irqsave(&pci_config_lock    
138         ret = sh7786_pcie_config_access(PCI_AC    
139                                         devfn,    
140         if (ret != PCIBIOS_SUCCESSFUL)            
141                 goto out;                         
142                                                   
143         dev_dbg(&bus->dev, "pcie-config-write:    
144                 "where=0x%04x size=%d val=%08l    
145                 devfn, where, size, (unsigned     
146                                                   
147         if (size == 1) {                          
148                 shift = (where & 3) << 3;         
149                 data &= ~(0xff << shift);         
150                 data |= ((val & 0xff) << shift    
151         } else if (size == 2) {                   
152                 shift = (where & 2) << 3;         
153                 data &= ~(0xffff << shift);       
154                 data |= ((val & 0xffff) << shi    
155         } else                                    
156                 data = val;                       
157                                                   
158         ret = sh7786_pcie_config_access(PCI_AC    
159                                         devfn,    
160 out:                                              
161         raw_spin_unlock_irqrestore(&pci_config    
162         return ret;                               
163 }                                                 
164                                                   
165 struct pci_ops sh7786_pci_ops = {                 
166         .read   = sh7786_pcie_read,               
167         .write  = sh7786_pcie_write,              
168 };                                                
169                                                   

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php