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

TOMOYO Linux Cross Reference
Linux/arch/mips/pci/fixup-cobalt.c

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ 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.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /arch/mips/pci/fixup-cobalt.c (Version linux-6.12-rc7) and /arch/sparc64/pci/fixup-cobalt.c (Version linux-4.13.16)


  1 /*                                                  1 
  2  * Cobalt Qube/Raq PCI support                    
  3  *                                                
  4  * This file is subject to the terms and condi    
  5  * License.  See the file "COPYING" in the mai    
  6  * for more details.                              
  7  *                                                
  8  * Copyright (C) 1995, 1996, 1997, 2002, 2003     
  9  * Copyright (C) 2001, 2002, 2003 by Liam Davi    
 10  */                                               
 11 #include <linux/types.h>                          
 12 #include <linux/pci.h>                            
 13 #include <linux/kernel.h>                         
 14 #include <linux/init.h>                           
 15                                                   
 16 #include <asm/io.h>                               
 17 #include <asm/gt64120.h>                          
 18                                                   
 19 #include <cobalt.h>                               
 20 #include <irq.h>                                  
 21                                                   
 22 /*                                                
 23  * PCI slot numbers                               
 24  */                                               
 25 #define COBALT_PCICONF_CPU      0x06              
 26 #define COBALT_PCICONF_ETH0     0x07              
 27 #define COBALT_PCICONF_RAQSCSI  0x08              
 28 #define COBALT_PCICONF_VIA      0x09              
 29 #define COBALT_PCICONF_PCISLOT  0x0A              
 30 #define COBALT_PCICONF_ETH1     0x0C              
 31                                                   
 32 /*                                                
 33  * The Cobalt board ID information.  The board    
 34  * into the VIA that is available in the high     
 35  */                                               
 36 #define VIA_COBALT_BRD_ID_REG  0x94               
 37 #define VIA_COBALT_BRD_REG_to_ID(reg)   ((unsi    
 38                                                   
 39 /*                                                
 40  * Default value of PCI Class Code on GT64111     
 41  * instead of PCI_CLASS_BRIDGE_HOST (0x0600).     
 42  * document "GT-64111 System Controller for RC    
 43  * section "6.5.3 PCI Autoconfiguration at RES    
 44  *                                                
 45  *   Some PCs refuse to configure host bridges    
 46  *   a PCI slot (ask the BIOS vendors why...).    
 47  *   Code does not cause a problem for these n    
 48  *   this as the default in the GT-64111.         
 49  *                                                
 50  * So fix the incorrect default value of PCI C    
 51  * https://lore.kernel.org/r/20211102154831.xt    
 52  * https://lore.kernel.org/r/20211102150201.GA    
 53  */                                               
 54 static void qube_raq_galileo_early_fixup(struc    
 55 {                                                 
 56         if (dev->devfn == PCI_DEVFN(0, 0) &&      
 57                 (dev->class >> 8) == PCI_CLASS    
 58                                                   
 59                 dev->class = (PCI_CLASS_BRIDGE    
 60                                                   
 61                 printk(KERN_INFO "Galileo: fix    
 62         }                                         
 63 }                                                 
 64                                                   
 65 DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_MARVELL,    
 66          qube_raq_galileo_early_fixup);           
 67                                                   
 68 static void qube_raq_via_bmIDE_fixup(struct pc    
 69 {                                                 
 70         unsigned short cfgword;                   
 71         unsigned char lt;                         
 72                                                   
 73         /* Enable Bus Mastering and fast back     
 74         pci_read_config_word(dev, PCI_COMMAND,    
 75         cfgword |= (PCI_COMMAND_FAST_BACK | PC    
 76         pci_write_config_word(dev, PCI_COMMAND    
 77                                                   
 78         /* Enable both ide interfaces. ROM onl    
 79         pci_write_config_byte(dev, 0x40, 0xb);    
 80                                                   
 81         /* Set latency timer to reasonable val    
 82         pci_read_config_byte(dev, PCI_LATENCY_    
 83         if (lt < 64)                              
 84                 pci_write_config_byte(dev, PCI    
 85         pci_write_config_byte(dev, PCI_CACHE_L    
 86 }                                                 
 87                                                   
 88 DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_VIA, PC    
 89          qube_raq_via_bmIDE_fixup);               
 90                                                   
 91 static void qube_raq_galileo_fixup(struct pci_    
 92 {                                                 
 93         if (dev->devfn != PCI_DEVFN(0, 0))        
 94                 return;                           
 95                                                   
 96         /* Fix PCI latency-timer and cache-lin    
 97          * host bridge.                           
 98          */                                       
 99         pci_write_config_byte(dev, PCI_LATENCY    
100         pci_write_config_byte(dev, PCI_CACHE_L    
101                                                   
102         /*                                        
103          * The code described by the comment b    
104          * as it causes bus mastering by the E    
105          * to break under any kind of network     
106          * the retry timeouts to their maximum    
107          *                                        
108          * --x--x--x--x--x--x--x--x--x--x--x--    
109          *                                        
110          * On all machines prior to Q2, we had    
111          * from Galileo to VIA on PCI.  The ne    
112          * correctly unless we have it connect    
113          *                                        
114          * Therefore we must set the disconnec    
115          * something sensible when using the n    
116          */                                       
117                                                   
118         printk(KERN_INFO "Galileo: revision %u    
119                                                   
120 #if 0                                             
121         if (dev->revision >= 0x10) {              
122                 /* New Galileo, assumes PCI st    
123                 GT_WRITE(GT_PCI0_TOR_OFS, 0x40    
124         } else if (dev->revision == 0x1 || dev    
125 #endif                                            
126         {                                         
127                 signed int timeo;                 
128                 /* XXX WE MUST DO THIS ELSE GA    
129                 timeo = GT_READ(GT_PCI0_TOR_OF    
130                 /* Old Galileo, assumes PCI ST    
131                 GT_WRITE(GT_PCI0_TOR_OFS,         
132                         (0xff << 16) |            
133                         (0xff << 8) |             
134                         0xff);                    
135                                                   
136                 /* enable PCI retry exceeded i    
137                 GT_WRITE(GT_INTRMASK_OFS, GT_I    
138         }                                         
139 }                                                 
140                                                   
141 DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_MARVELL    
142          qube_raq_galileo_fixup);                 
143                                                   
144 int cobalt_board_id;                              
145                                                   
146 static void qube_raq_via_board_id_fixup(struct    
147 {                                                 
148         u8 id;                                    
149         int retval;                               
150                                                   
151         retval = pci_read_config_byte(dev, VIA    
152         if (retval) {                             
153                 panic("Cannot read board ID");    
154                 return;                           
155         }                                         
156                                                   
157         cobalt_board_id = VIA_COBALT_BRD_REG_t    
158                                                   
159         printk(KERN_INFO "Cobalt board ID: %d\    
160 }                                                 
161                                                   
162 DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_VIA, PC    
163          qube_raq_via_board_id_fixup);            
164                                                   
165 static char irq_tab_qube1[] = {                   
166   [COBALT_PCICONF_CPU]     = 0,                   
167   [COBALT_PCICONF_ETH0]    = QUBE1_ETH0_IRQ,      
168   [COBALT_PCICONF_RAQSCSI] = SCSI_IRQ,            
169   [COBALT_PCICONF_VIA]     = 0,                   
170   [COBALT_PCICONF_PCISLOT] = PCISLOT_IRQ,         
171   [COBALT_PCICONF_ETH1]    = 0                    
172 };                                                
173                                                   
174 static char irq_tab_cobalt[] = {                  
175   [COBALT_PCICONF_CPU]     = 0,                   
176   [COBALT_PCICONF_ETH0]    = ETH0_IRQ,            
177   [COBALT_PCICONF_RAQSCSI] = SCSI_IRQ,            
178   [COBALT_PCICONF_VIA]     = 0,                   
179   [COBALT_PCICONF_PCISLOT] = PCISLOT_IRQ,         
180   [COBALT_PCICONF_ETH1]    = ETH1_IRQ             
181 };                                                
182                                                   
183 static char irq_tab_raq2[] = {                    
184   [COBALT_PCICONF_CPU]     = 0,                   
185   [COBALT_PCICONF_ETH0]    = ETH0_IRQ,            
186   [COBALT_PCICONF_RAQSCSI] = RAQ2_SCSI_IRQ,       
187   [COBALT_PCICONF_VIA]     = 0,                   
188   [COBALT_PCICONF_PCISLOT] = PCISLOT_IRQ,         
189   [COBALT_PCICONF_ETH1]    = ETH1_IRQ             
190 };                                                
191                                                   
192 int pcibios_map_irq(const struct pci_dev *dev,    
193 {                                                 
194         if (cobalt_board_id <= COBALT_BRD_ID_Q    
195                 return irq_tab_qube1[slot];       
196                                                   
197         if (cobalt_board_id == COBALT_BRD_ID_R    
198                 return irq_tab_raq2[slot];        
199                                                   
200         return irq_tab_cobalt[slot];              
201 }                                                 
202                                                   
203 /* Do platform specific device initialization     
204 int pcibios_plat_dev_init(struct pci_dev *dev)    
205 {                                                 
206         return 0;                                 
207 }                                                 
208                                                   

~ [ 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