Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit ee1ef82c authored by Harald Welte's avatar Harald Welte Committed by Linus Torvalds
Browse files

viafb: make it work on x86_64



Fix a bug in viafb on x86_64 builds (e.g. for VIA Nano CPU).

You cannot make the assumption that sizeof(unsigned int) ==
sizeof(unsigned long), so the parsing of the default mode (640x480) fails,
leading to a division by zero during insmod of the driver.

Signed-off-by: default avatarHarald Welte <HaraldWelte@viatech.com>
Cc: <JosephChan@via.com.tw>
Cc: <ScottFang@viatech.com.cn>
Cc: Acked-by: Krzysztof Helt <krzysztof.h1@wp.pl>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent ee83126b
Loading
Loading
Loading
Loading
+3 −3
Original line number Diff line number Diff line
@@ -2103,7 +2103,7 @@ static void viafb_remove_proc(struct proc_dir_entry *viafb_entry)

static int __devinit via_pci_probe(void)
{
	unsigned int default_xres, default_yres;
	unsigned long default_xres, default_yres;
	char *tmpc, *tmpm;
	char *tmpc_sec, *tmpm_sec;
	int vmode_index;
@@ -2196,8 +2196,8 @@ static int __devinit via_pci_probe(void)
	viafb_FB_MM = viaparinfo->fbmem_virt;
	tmpm = viafb_mode;
	tmpc = strsep(&tmpm, "x");
	strict_strtoul(tmpc, 0, (unsigned long *)&default_xres);
	strict_strtoul(tmpm, 0, (unsigned long *)&default_yres);
	strict_strtoul(tmpc, 0, &default_xres);
	strict_strtoul(tmpm, 0, &default_yres);

	vmode_index = viafb_get_mode_index(default_xres, default_yres, 0);
	DEBUG_MSG(KERN_INFO "0->index=%d\n", vmode_index);