提交 4ec3fd71 编写于 作者: V Ville Syrjala 提交者: Linus Torvalds

[PATCH] atyfb: Improve atyfb_atari_probe()

Improve atyfb_atari_probe():
* Call correct_chipset() so that more par members, par->features in
  particular, get initialized.
* If probe fails iounmap() the mapped regions and continue probing for more
  adapters.

Only verified to cross-compile due to lack of hardware.
Signed-off-by: NVille Syrjala <syrjala@sci.fi>
Cc: "Antonino A. Daplas" <adaplas@pol.net>
Signed-off-by: NAndrew Morton <akpm@osdl.org>
Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
上级 cab5901e
...@@ -3629,6 +3629,7 @@ static int __init atyfb_atari_probe(void) ...@@ -3629,6 +3629,7 @@ static int __init atyfb_atari_probe(void)
struct fb_info *info; struct fb_info *info;
int m64_num; int m64_num;
u32 clock_r; u32 clock_r;
int num_found = 0;
for (m64_num = 0; m64_num < mach64_count; m64_num++) { for (m64_num = 0; m64_num < mach64_count; m64_num++) {
if (!phys_vmembase[m64_num] || !phys_size[m64_num] || if (!phys_vmembase[m64_num] || !phys_size[m64_num] ||
...@@ -3676,16 +3677,28 @@ static int __init atyfb_atari_probe(void) ...@@ -3676,16 +3677,28 @@ static int __init atyfb_atari_probe(void)
break; break;
} }
if (aty_init(info)) { /* Fake pci_id for correct_chipset() */
if (info->screen_base) switch (aty_ld_le32(CONFIG_CHIP_ID, par) & CFG_CHIP_TYPE) {
iounmap(info->screen_base); case 0x00d7:
if (par->ati_regbase) par->pci_id = PCI_CHIP_MACH64GX;
iounmap(par->ati_regbase); break;
case 0x0057:
par->pci_id = PCI_CHIP_MACH64CX;
break;
default:
break;
}
if (correct_chipset(par) || aty_init(info)) {
iounmap(info->screen_base);
iounmap(par->ati_regbase);
framebuffer_release(info); framebuffer_release(info);
/* This is insufficient! kernel_map has added two large chunks!! */ } else {
return -ENXIO; num_found++;
} }
} }
return num_found ? 0 : -ENXIO;
} }
#endif /* CONFIG_ATARI */ #endif /* CONFIG_ATARI */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册