patch-2.4.9 linux/include/asm-arm/arch-anakin/ide.h

Next file: linux/include/asm-arm/arch-anakin/io.h
Previous file: linux/include/asm-arm/arch-anakin/hardware.h
Back to the patch index
Back to the overall index

diff -u --recursive --new-file v2.4.8/linux/include/asm-arm/arch-anakin/ide.h linux/include/asm-arm/arch-anakin/ide.h
@@ -0,0 +1,56 @@
+/*
+ * linux/include/asm-arm/arch-anakin/ide.h
+ *
+ * Copyright 2001 Blue Mug Inc. for Acunia N.V.
+ *
+ * 08-jun-2001: Initial clone of arch-sa1100/ide.h by Jon McClintock
+ *              (jonm@bluemug.com).
+ */
+ 
+#include <linux/config.h>
+#include <asm/irq.h>
+#include <asm/hardware.h>
+
+/*
+ * Set up a hw structure for a specified data port, control port and IRQ.
+ * This should follow whatever the default interface uses.
+ */
+static __inline__ void
+ide_init_hwif_ports(hw_regs_t *hw, int data_port, int ctrl_port, int *irq)
+{
+	ide_ioreg_t reg;
+	int i;
+	int regincr = 4;
+	
+	memset(hw, 0, sizeof(*hw));
+
+	reg = (ide_ioreg_t)data_port;
+
+	for (i = IDE_DATA_OFFSET; i <= IDE_STATUS_OFFSET; i++) {
+		hw->io_ports[i] = reg;
+		reg += regincr;
+	}
+	
+	hw->io_ports[IDE_CONTROL_OFFSET] = (ide_ioreg_t) ctrl_port;
+	
+	if (irq)
+		*irq = 0;
+}
+
+
+/*
+ * This registers the standard ports for this architecture with the IDE
+ * driver.
+ */
+static __inline__ void
+ide_init_default_hwifs(void)
+{
+    hw_regs_t hw;
+
+    ide_init_hwif_ports(&hw, IO_BASE + COMPACTFLASH, 
+    			IO_BASE + COMPACTFLASH + IDE_CONTROL_OFFSET, NULL);
+    hw.irq = IRQ_COMPACTFLASH;
+    ide_register_hw(&hw, NULL);
+}
+
+

FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)