diff options
author | Bartlomiej Zolnierkiewicz <bzolnier@gmail.com> | 2008-07-23 13:55:57 -0400 |
---|---|---|
committer | Bartlomiej Zolnierkiewicz <bzolnier@gmail.com> | 2008-07-23 13:55:57 -0400 |
commit | 48c3c1072651922ed153bcf0a33ea82cf20df390 (patch) | |
tree | 92ad23e3869e70731eca99394c08a3bf06b8753e /drivers/ide/h8300 | |
parent | 374e042c3e767ac2e5a40b78529220e0b3de793c (diff) |
ide: add struct ide_host (take 3)
* Add struct ide_host which keeps pointers to host's ports.
* Add ide_host_alloc[_all]() and ide_host_remove() helpers.
* Pass 'struct ide_host *host' instead of 'u8 *idx' to
ide_device_add[_all]() and rename it to ide_host_register[_all]().
* Convert host drivers and core code to use struct ide_host.
* Remove no longer needed ide_find_port().
* Make ide_find_port_slot() static.
* Unexport ide_unregister().
v2:
* Add missing 'struct ide_host *host' to macide.c.
v3:
* Fix build problem in pmac.c (s/ide_alloc_host/ide_host_alloc/)
(Noticed by Stephen Rothwell).
Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
Diffstat (limited to 'drivers/ide/h8300')
-rw-r--r-- | drivers/ide/h8300/ide-h8300.c | 14 |
1 files changed, 4 insertions, 10 deletions
diff --git a/drivers/ide/h8300/ide-h8300.c b/drivers/ide/h8300/ide-h8300.c index 84644e150531..15f76690a48c 100644 --- a/drivers/ide/h8300/ide-h8300.c +++ b/drivers/ide/h8300/ide-h8300.c | |||
@@ -191,10 +191,8 @@ static const struct ide_port_info h8300_port_info = { | |||
191 | 191 | ||
192 | static int __init h8300_ide_init(void) | 192 | static int __init h8300_ide_init(void) |
193 | { | 193 | { |
194 | ide_hwif_t *hwif; | 194 | struct ide_host *host; |
195 | int index; | ||
196 | hw_regs_t hw, *hws[] = { &hw, NULL, NULL, NULL }; | 195 | hw_regs_t hw, *hws[] = { &hw, NULL, NULL, NULL }; |
197 | u8 idx[4] = { 0xff, 0xff, 0xff, 0xff }; | ||
198 | 196 | ||
199 | printk(KERN_INFO DRV_NAME ": H8/300 generic IDE interface\n"); | 197 | printk(KERN_INFO DRV_NAME ": H8/300 generic IDE interface\n"); |
200 | 198 | ||
@@ -207,15 +205,11 @@ static int __init h8300_ide_init(void) | |||
207 | 205 | ||
208 | hw_setup(&hw); | 206 | hw_setup(&hw); |
209 | 207 | ||
210 | hwif = ide_find_port_slot(&h8300_port_info); | 208 | host = ide_host_alloc(&h8300_port_info, hws); |
211 | if (hwif == NULL) | 209 | if (host == NULL) |
212 | return -ENOENT; | 210 | return -ENOENT; |
213 | 211 | ||
214 | index = hwif->index; | 212 | ide_host_register(host, &h8300_port_info, hws); |
215 | |||
216 | idx[0] = index; | ||
217 | |||
218 | ide_device_add(idx, &h8300_port_info, hws); | ||
219 | 213 | ||
220 | return 0; | 214 | return 0; |
221 | 215 | ||