patch-2.3.35 linux/arch/sparc64/kernel/auxio.c
Next file: linux/arch/sparc64/kernel/central.c
Previous file: linux/arch/sparc64/kernel/Makefile
Back to the patch index
Back to the overall index
- Lines: 55
- Date:
Mon Dec 20 22:05:52 1999
- Orig file:
v2.3.34/linux/arch/sparc64/kernel/auxio.c
- Orig date:
Tue Aug 31 17:29:13 1999
diff -u --recursive --new-file v2.3.34/linux/arch/sparc64/kernel/auxio.c linux/arch/sparc64/kernel/auxio.c
@@ -20,22 +20,21 @@
#include <asm/fhc.h>
/* Probe and map in the Auxiliary I/O register */
-unsigned char *auxio_register;
+unsigned long auxio_register = 0;
void __init auxio_probe(void)
{
- struct linux_sbus *bus;
- struct linux_sbus_device *sdev = 0;
- struct linux_prom_registers auxregs[1];
-
- for_each_sbus(bus) {
- for_each_sbusdev(sdev, bus) {
- if(!strcmp(sdev->prom_name, "auxio")) {
- break;
- }
+ struct sbus_bus *sbus;
+ struct sbus_dev *sdev = 0;
+
+ for_each_sbus(sbus) {
+ for_each_sbusdev(sdev, sbus) {
+ if(!strcmp(sdev->prom_name, "auxio"))
+ goto found_sdev;
}
}
+found_sdev:
if (!sdev) {
#ifdef CONFIG_PCI
struct linux_ebus *ebus;
@@ -57,19 +56,15 @@
}
#endif
if(central_bus) {
- auxio_register = NULL;
+ auxio_register = 0UL;
return;
}
prom_printf("Cannot find auxio node, cannot continue...\n");
prom_halt();
}
- prom_getproperty(sdev->prom_node, "reg", (char *) auxregs, sizeof(auxregs));
- prom_apply_sbus_ranges(sdev->my_bus, auxregs, 0x1, sdev);
/* Map the register both read and write */
- auxio_register = (unsigned char *) sparc_alloc_io(auxregs[0].phys_addr, 0,
- auxregs[0].reg_size,
- "auxiliaryIO",
- auxregs[0].which_io, 0x0);
+ auxio_register = sbus_ioremap(&sdev->resource[0], 0,
+ sdev->reg_addrs[0].reg_size, "auxiliaryIO");
TURN_ON_LED;
}
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)