diff options
author | Bartlomiej Zolnierkiewicz <bzolnier@gmail.com> | 2008-04-17 18:46:35 -0400 |
---|---|---|
committer | Bartlomiej Zolnierkiewicz <bzolnier@gmail.com> | 2008-04-17 18:46:35 -0400 |
commit | 486c92e2900d618c650a7099536310651aa6cf1b (patch) | |
tree | f78f54a5df2c3f93b73913652b2a7209b2bf11da /drivers/ide/ide.c | |
parent | f01674e459923c6df540e6c983d37e5fc94d43b8 (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.c | 17 |
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 | ||