1 // SPDX-License-Identifier: GPL-2.0
3 * linux/arch/alpha/kernel/core_tsunami.c
5 * Based on code written by David A. Rusling (david.rusling@reo.mts.dec.com).
7 * Code common to all TSUNAMI core logic chips.
10 #define __EXTERN_INLINE inline
12 #include <asm/core_tsunami.h>
13 #undef __EXTERN_INLINE
15 #include <linux/module.h>
16 #include <linux/types.h>
17 #include <linux/pci.h>
18 #include <linux/sched.h>
19 #include <linux/init.h>
20 #include <linux/memblock.h>
22 #include <asm/ptrace.h>
29 /* Save Tsunami configuration data as the console had it set up. */
33 unsigned long wsba
[4];
36 } saved_config
[2] __attribute__((common
));
39 * NOTE: Herein lie back-to-back mb instructions. They are magic.
40 * One plausible explanation is that the I/O controller does not properly
41 * handle the system transaction. Another involves timing. Ho hum.
45 * BIOS32-style PCI interface:
48 #define DEBUG_CONFIG 0
51 # define DBG_CFG(args) printk args
53 # define DBG_CFG(args)
58 * Given a bus, device, and function number, compute resulting
59 * configuration space address
60 * accordingly. It is therefore not safe to have concurrent
61 * invocations to configuration space access routines, but there
62 * really shouldn't be any need for this.
64 * Note that all config space accesses use Type 1 address format.
66 * Note also that type 1 is determined by non-zero bus number.
70 * 3 3|3 3 2 2|2 2 2 2|2 2 2 2|1 1 1 1|1 1 1 1|1 1
71 * 3 2|1 0 9 8|7 6 5 4|3 2 1 0|9 8 7 6|5 4 3 2|1 0 9 8|7 6 5 4|3 2 1 0
72 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
73 * | | | | | | | | | | |B|B|B|B|B|B|B|B|D|D|D|D|D|F|F|F|R|R|R|R|R|R|0|1|
74 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
77 * 23:16 bus number (8 bits = 128 possible buses)
78 * 15:11 Device number (5 bits)
79 * 10:8 function number
83 * The function number selects which function of a multi-function device
84 * (e.g., SCSI and Ethernet).
86 * The register selects a DWORD (32 bit) register offset. Hence it
87 * doesn't get shifted by 2 bits as we want to "drop" the bottom two
92 mk_conf_addr(struct pci_bus
*pbus
, unsigned int device_fn
, int where
,
93 unsigned long *pci_addr
, unsigned char *type1
)
95 struct pci_controller
*hose
= pbus
->sysdata
;
97 u8 bus
= pbus
->number
;
99 DBG_CFG(("mk_conf_addr(bus=%d ,device_fn=0x%x, where=0x%x, "
100 "pci_addr=0x%p, type1=0x%p)\n",
101 bus
, device_fn
, where
, pci_addr
, type1
));
103 if (!pbus
->parent
) /* No parent means peer PCI bus. */
107 addr
= (bus
<< 16) | (device_fn
<< 8) | where
;
108 addr
|= hose
->config_space_base
;
111 DBG_CFG(("mk_conf_addr: returning pci_addr 0x%lx\n", addr
));
116 tsunami_read_config(struct pci_bus
*bus
, unsigned int devfn
, int where
,
117 int size
, u32
*value
)
122 if (mk_conf_addr(bus
, devfn
, where
, &addr
, &type1
))
123 return PCIBIOS_DEVICE_NOT_FOUND
;
127 *value
= __kernel_ldbu(*(vucp
)addr
);
130 *value
= __kernel_ldwu(*(vusp
)addr
);
133 *value
= *(vuip
)addr
;
137 return PCIBIOS_SUCCESSFUL
;
141 tsunami_write_config(struct pci_bus
*bus
, unsigned int devfn
, int where
,
147 if (mk_conf_addr(bus
, devfn
, where
, &addr
, &type1
))
148 return PCIBIOS_DEVICE_NOT_FOUND
;
152 __kernel_stb(value
, *(vucp
)addr
);
154 __kernel_ldbu(*(vucp
)addr
);
157 __kernel_stw(value
, *(vusp
)addr
);
159 __kernel_ldwu(*(vusp
)addr
);
168 return PCIBIOS_SUCCESSFUL
;
171 struct pci_ops tsunami_pci_ops
=
173 .read
= tsunami_read_config
,
174 .write
= tsunami_write_config
,
178 tsunami_pci_tbi(struct pci_controller
*hose
, dma_addr_t start
, dma_addr_t end
)
180 tsunami_pchip
*pchip
= hose
->index
? TSUNAMI_pchip1
: TSUNAMI_pchip0
;
181 volatile unsigned long *csr
;
184 /* We can invalidate up to 8 tlb entries in a go. The flush
185 matches against <31:16> in the pci address. */
186 csr
= &pchip
->tlbia
.csr
;
187 if (((start
^ end
) & 0xffff0000) == 0)
188 csr
= &pchip
->tlbiv
.csr
;
190 /* For TBIA, it doesn't matter what value we write. For TBI,
191 it's the shifted tag bits. */
192 value
= (start
& 0xffff0000) >> 12;
199 #ifdef NXM_MACHINE_CHECKS_ON_TSUNAMI
201 tsunami_probe_read(volatile unsigned long *vaddr
)
203 long dont_care
, probe_result
;
204 int cpu
= smp_processor_id();
205 int s
= swpipl(IPL_MCHECK
- 1);
207 mcheck_taken(cpu
) = 0;
208 mcheck_expected(cpu
) = 1;
212 mcheck_expected(cpu
) = 0;
213 probe_result
= !mcheck_taken(cpu
);
214 mcheck_taken(cpu
) = 0;
217 printk("dont_care == 0x%lx\n", dont_care
);
223 tsunami_probe_write(volatile unsigned long *vaddr
)
225 long true_contents
, probe_result
= 1;
227 TSUNAMI_cchip
->misc
.csr
|= (1L << 28); /* clear NXM... */
228 true_contents
= *vaddr
;
231 if (TSUNAMI_cchip
->misc
.csr
& (1L << 28)) {
232 int source
= (TSUNAMI_cchip
->misc
.csr
>> 29) & 7;
233 TSUNAMI_cchip
->misc
.csr
|= (1L << 28); /* ...and unlock NXS. */
235 printk("tsunami_probe_write: unit %d at 0x%016lx\n", source
,
236 (unsigned long)vaddr
);
239 *vaddr
= true_contents
;
243 #define tsunami_probe_read(ADDR) 1
244 #endif /* NXM_MACHINE_CHECKS_ON_TSUNAMI */
247 tsunami_init_one_pchip(tsunami_pchip
*pchip
, int index
)
249 struct pci_controller
*hose
;
251 if (tsunami_probe_read(&pchip
->pctl
.csr
) == 0)
254 hose
= alloc_pci_controller();
257 hose
->io_space
= alloc_resource();
258 hose
->mem_space
= alloc_resource();
260 /* This is for userland consumption. For some reason, the 40-bit
261 PIO bias that we use in the kernel through KSEG didn't work for
262 the page table based user mappings. So make sure we get the
264 hose
->sparse_mem_base
= 0;
265 hose
->sparse_io_base
= 0;
267 = (TSUNAMI_MEM(index
) & 0xffffffffffL
) | 0x80000000000L
;
269 = (TSUNAMI_IO(index
) & 0xffffffffffL
) | 0x80000000000L
;
271 hose
->config_space_base
= TSUNAMI_CONF(index
);
274 hose
->io_space
->start
= TSUNAMI_IO(index
) - TSUNAMI_IO_BIAS
;
275 hose
->io_space
->end
= hose
->io_space
->start
+ TSUNAMI_IO_SPACE
- 1;
276 hose
->io_space
->name
= pci_io_names
[index
];
277 hose
->io_space
->flags
= IORESOURCE_IO
;
279 hose
->mem_space
->start
= TSUNAMI_MEM(index
) - TSUNAMI_MEM_BIAS
;
280 hose
->mem_space
->end
= hose
->mem_space
->start
+ 0xffffffff;
281 hose
->mem_space
->name
= pci_mem_names
[index
];
282 hose
->mem_space
->flags
= IORESOURCE_MEM
;
284 if (request_resource(&ioport_resource
, hose
->io_space
) < 0)
285 printk(KERN_ERR
"Failed to request IO on hose %d\n", index
);
286 if (request_resource(&iomem_resource
, hose
->mem_space
) < 0)
287 printk(KERN_ERR
"Failed to request MEM on hose %d\n", index
);
290 * Save the existing PCI window translations. SRM will
291 * need them when we go to reboot.
294 saved_config
[index
].wsba
[0] = pchip
->wsba
[0].csr
;
295 saved_config
[index
].wsm
[0] = pchip
->wsm
[0].csr
;
296 saved_config
[index
].tba
[0] = pchip
->tba
[0].csr
;
298 saved_config
[index
].wsba
[1] = pchip
->wsba
[1].csr
;
299 saved_config
[index
].wsm
[1] = pchip
->wsm
[1].csr
;
300 saved_config
[index
].tba
[1] = pchip
->tba
[1].csr
;
302 saved_config
[index
].wsba
[2] = pchip
->wsba
[2].csr
;
303 saved_config
[index
].wsm
[2] = pchip
->wsm
[2].csr
;
304 saved_config
[index
].tba
[2] = pchip
->tba
[2].csr
;
306 saved_config
[index
].wsba
[3] = pchip
->wsba
[3].csr
;
307 saved_config
[index
].wsm
[3] = pchip
->wsm
[3].csr
;
308 saved_config
[index
].tba
[3] = pchip
->tba
[3].csr
;
311 * Set up the PCI to main memory translation windows.
313 * Note: Window 3 is scatter-gather only
315 * Window 0 is scatter-gather 8MB at 8MB (for isa)
316 * Window 1 is scatter-gather (up to) 1GB at 1GB
317 * Window 2 is direct access 2GB at 2GB
319 * NOTE: we need the align_entry settings for Acer devices on ES40,
320 * specifically floppy and IDE when memory is larger than 2GB.
322 hose
->sg_isa
= iommu_arena_new(hose
, 0x00800000, 0x00800000,
324 /* Initially set for 4 PTEs, but will be overridden to 64K for ISA. */
325 hose
->sg_isa
->align_entry
= 4;
327 hose
->sg_pci
= iommu_arena_new(hose
, 0x40000000,
328 size_for_memory(0x40000000),
330 hose
->sg_pci
->align_entry
= 4; /* Tsunami caches 4 PTEs at a time */
332 __direct_map_base
= 0x80000000;
333 __direct_map_size
= 0x80000000;
335 pchip
->wsba
[0].csr
= hose
->sg_isa
->dma_base
| 3;
336 pchip
->wsm
[0].csr
= (hose
->sg_isa
->size
- 1) & 0xfff00000;
337 pchip
->tba
[0].csr
= virt_to_phys(hose
->sg_isa
->ptes
);
339 pchip
->wsba
[1].csr
= hose
->sg_pci
->dma_base
| 3;
340 pchip
->wsm
[1].csr
= (hose
->sg_pci
->size
- 1) & 0xfff00000;
341 pchip
->tba
[1].csr
= virt_to_phys(hose
->sg_pci
->ptes
);
343 pchip
->wsba
[2].csr
= 0x80000000 | 1;
344 pchip
->wsm
[2].csr
= (0x80000000 - 1) & 0xfff00000;
345 pchip
->tba
[2].csr
= 0;
347 pchip
->wsba
[3].csr
= 0;
349 /* Enable the Monster Window to make DAC pci64 possible. */
350 pchip
->pctl
.csr
|= pctl_m_mwin
;
352 tsunami_pci_tbi(hose
, 0, -1);
357 tsunami_ioportmap(unsigned long addr
)
359 FIXUP_IOADDR_VGA(addr
);
360 return (void __iomem
*)(addr
+ TSUNAMI_IO_BIAS
);
364 tsunami_ioremap(unsigned long addr
, unsigned long size
)
366 FIXUP_MEMADDR_VGA(addr
);
367 return (void __iomem
*)(addr
+ TSUNAMI_MEM_BIAS
);
370 #ifndef CONFIG_ALPHA_GENERIC
371 EXPORT_SYMBOL(tsunami_ioportmap
);
372 EXPORT_SYMBOL(tsunami_ioremap
);
376 tsunami_init_arch(void)
378 #ifdef NXM_MACHINE_CHECKS_ON_TSUNAMI
381 /* Ho hum.. init_arch is called before init_IRQ, but we need to be
382 able to handle machine checks. So install the handler now. */
385 /* NXMs just don't matter to Tsunami--unless they make it
387 tmp
= (unsigned long)(TSUNAMI_cchip
- 1);
388 printk("%s: probing bogus address: 0x%016lx\n", __func__
, bogus_addr
);
389 printk("\tprobe %s\n",
390 tsunami_probe_write((unsigned long *)bogus_addr
)
391 ? "succeeded" : "failed");
392 #endif /* NXM_MACHINE_CHECKS_ON_TSUNAMI */
395 printk("%s: CChip registers:\n", __func__
);
396 printk("%s: CSR_CSC 0x%lx\n", __func__
, TSUNAMI_cchip
->csc
.csr
);
397 printk("%s: CSR_MTR 0x%lx\n", __func__
, TSUNAMI_cchip
.mtr
.csr
);
398 printk("%s: CSR_MISC 0x%lx\n", __func__
, TSUNAMI_cchip
->misc
.csr
);
399 printk("%s: CSR_DIM0 0x%lx\n", __func__
, TSUNAMI_cchip
->dim0
.csr
);
400 printk("%s: CSR_DIM1 0x%lx\n", __func__
, TSUNAMI_cchip
->dim1
.csr
);
401 printk("%s: CSR_DIR0 0x%lx\n", __func__
, TSUNAMI_cchip
->dir0
.csr
);
402 printk("%s: CSR_DIR1 0x%lx\n", __func__
, TSUNAMI_cchip
->dir1
.csr
);
403 printk("%s: CSR_DRIR 0x%lx\n", __func__
, TSUNAMI_cchip
->drir
.csr
);
405 printk("%s: DChip registers:\n");
406 printk("%s: CSR_DSC 0x%lx\n", __func__
, TSUNAMI_dchip
->dsc
.csr
);
407 printk("%s: CSR_STR 0x%lx\n", __func__
, TSUNAMI_dchip
->str
.csr
);
408 printk("%s: CSR_DREV 0x%lx\n", __func__
, TSUNAMI_dchip
->drev
.csr
);
410 /* With multiple PCI busses, we play with I/O as physical addrs. */
411 ioport_resource
.end
= ~0UL;
413 /* Find how many hoses we have, and initialize them. TSUNAMI
414 and TYPHOON can have 2, but might only have 1 (DS10). */
416 tsunami_init_one_pchip(TSUNAMI_pchip0
, 0);
417 if (TSUNAMI_cchip
->csc
.csr
& 1L<<14)
418 tsunami_init_one_pchip(TSUNAMI_pchip1
, 1);
420 /* Check for graphic console location (if any). */
421 find_console_vga_hose();
425 tsunami_kill_one_pchip(tsunami_pchip
*pchip
, int index
)
427 pchip
->wsba
[0].csr
= saved_config
[index
].wsba
[0];
428 pchip
->wsm
[0].csr
= saved_config
[index
].wsm
[0];
429 pchip
->tba
[0].csr
= saved_config
[index
].tba
[0];
431 pchip
->wsba
[1].csr
= saved_config
[index
].wsba
[1];
432 pchip
->wsm
[1].csr
= saved_config
[index
].wsm
[1];
433 pchip
->tba
[1].csr
= saved_config
[index
].tba
[1];
435 pchip
->wsba
[2].csr
= saved_config
[index
].wsba
[2];
436 pchip
->wsm
[2].csr
= saved_config
[index
].wsm
[2];
437 pchip
->tba
[2].csr
= saved_config
[index
].tba
[2];
439 pchip
->wsba
[3].csr
= saved_config
[index
].wsba
[3];
440 pchip
->wsm
[3].csr
= saved_config
[index
].wsm
[3];
441 pchip
->tba
[3].csr
= saved_config
[index
].tba
[3];
445 tsunami_kill_arch(int mode
)
447 tsunami_kill_one_pchip(TSUNAMI_pchip0
, 0);
448 if (TSUNAMI_cchip
->csc
.csr
& 1L<<14)
449 tsunami_kill_one_pchip(TSUNAMI_pchip1
, 1);
453 tsunami_pci_clr_err_1(tsunami_pchip
*pchip
)
456 pchip
->perror
.csr
= 0x040;
462 tsunami_pci_clr_err(void)
464 tsunami_pci_clr_err_1(TSUNAMI_pchip0
);
466 /* TSUNAMI and TYPHOON can have 2, but might only have 1 (DS10) */
467 if (TSUNAMI_cchip
->csc
.csr
& 1L<<14)
468 tsunami_pci_clr_err_1(TSUNAMI_pchip1
);
472 tsunami_machine_check(unsigned long vector
, unsigned long la_ptr
)
474 /* Clear error before any reporting. */
478 tsunami_pci_clr_err();
482 process_mcheck_info(vector
, la_ptr
, "TSUNAMI",
483 mcheck_expected(smp_processor_id()));