aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/ide/ide.c
diff options
context:
space:
mode:
authorBartlomiej Zolnierkiewicz <bzolnier@gmail.com>2008-04-17 18:46:35 -0400
committerBartlomiej Zolnierkiewicz <bzolnier@gmail.com>2008-04-17 18:46:35 -0400
commit486c92e2900d618c650a7099536310651aa6cf1b (patch)
treef78f54a5df2c3f93b73913652b2a7209b2bf11da /drivers/ide/ide.c
parentf01674e459923c6df540e6c983d37e5fc94d43b8 (diff)
ide: move default IDE ports setup to ide_generic host driver
* Make CONFIG_IDE_GENERIC depended on CONFIG_IDE_ARCH_OBSOLETE_DEFAULTS. * Move default IDE ports setup from init_ide_data() to ide_generic. * Use ide_init_port_hw() in ide_generic. * Remove no longer needed CONFIG_IDE_ARCH_OBSOLETE_DEFAULTS. Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
Diffstat (limited to 'drivers/ide/ide.c')
-rw-r--r--drivers/ide/ide.c17
1 files changed, 0 insertions, 17 deletions
diff --git a/drivers/ide/ide.c b/drivers/ide/ide.c
index aa809aded87f..917c72dcd33d 100644
--- a/drivers/ide/ide.c
+++ b/drivers/ide/ide.c
@@ -165,11 +165,6 @@ static void ide_port_init_devices_data(ide_hwif_t *hwif)
165 } 165 }
166} 166}
167 167
168#ifndef CONFIG_IDE_ARCH_OBSOLETE_DEFAULTS
169# define ide_default_io_base(index) (0)
170# define ide_init_default_irq(base) (0)
171#endif
172
173/* 168/*
174 * init_ide_data() sets reasonable default values into all fields 169 * init_ide_data() sets reasonable default values into all fields
175 * of all instances of the hwifs and drives, but only on the first call. 170 * of all instances of the hwifs and drives, but only on the first call.
@@ -192,7 +187,6 @@ static void __init init_ide_data (void)
192{ 187{
193 unsigned int index; 188 unsigned int index;
194 static unsigned long magic_cookie = MAGIC_COOKIE; 189 static unsigned long magic_cookie = MAGIC_COOKIE;
195 hw_regs_t hw;
196 190
197 if (magic_cookie != MAGIC_COOKIE) 191 if (magic_cookie != MAGIC_COOKIE)
198 return; /* already initialized */ 192 return; /* already initialized */
@@ -201,19 +195,8 @@ static void __init init_ide_data (void)
201 /* Initialise all interface structures */ 195 /* Initialise all interface structures */
202 for (index = 0; index < MAX_HWIFS; ++index) { 196 for (index = 0; index < MAX_HWIFS; ++index) {
203 ide_hwif_t *hwif = &ide_hwifs[index]; 197 ide_hwif_t *hwif = &ide_hwifs[index];
204 unsigned long io_addr = ide_default_io_base(index);
205 unsigned long ctl_addr = io_addr + 0x206;
206 198
207 ide_init_port_data(hwif, index); 199 ide_init_port_data(hwif, index);
208
209#ifdef CONFIG_IDE_ARCH_OBSOLETE_DEFAULTS
210 memset(&hw, 0, sizeof(hw));
211 ide_std_init_ports(&hw, io_addr, ctl_addr);
212 memcpy(hwif->io_ports, hw.io_ports, sizeof(hw.io_ports));
213 hwif->noprobe = !hwif->io_ports[IDE_DATA_OFFSET];
214 hwif->irq =
215 ide_init_default_irq(hwif->io_ports[IDE_DATA_OFFSET]);
216#endif
217 } 200 }
218} 201}
219 202