diff options
-rw-r--r-- | drivers/video/s3fb.c | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/drivers/video/s3fb.c b/drivers/video/s3fb.c index 9f9be9f37f2e..be12145681f6 100644 --- a/drivers/video/s3fb.c +++ b/drivers/video/s3fb.c | |||
@@ -64,6 +64,8 @@ static const struct svga_fb_format s3fb_formats[] = { | |||
64 | 64 | ||
65 | static const struct svga_pll s3_pll = {3, 129, 3, 33, 0, 3, | 65 | static const struct svga_pll s3_pll = {3, 129, 3, 33, 0, 3, |
66 | 35000, 240000, 14318}; | 66 | 35000, 240000, 14318}; |
67 | static const struct svga_pll s3_trio3d_pll = {3, 129, 3, 31, 0, 4, | ||
68 | 230000, 460000, 14318}; | ||
67 | 69 | ||
68 | static const int s3_memsizes[] = {4096, 0, 3072, 8192, 2048, 6144, 1024, 512}; | 70 | static const int s3_memsizes[] = {4096, 0, 3072, 8192, 2048, 6144, 1024, 512}; |
69 | 71 | ||
@@ -72,7 +74,8 @@ static const char * const s3_names[] = {"S3 Unknown", "S3 Trio32", "S3 Trio64", | |||
72 | "S3 Plato/PX", "S3 Aurora64VP", "S3 Virge", | 74 | "S3 Plato/PX", "S3 Aurora64VP", "S3 Virge", |
73 | "S3 Virge/VX", "S3 Virge/DX", "S3 Virge/GX", | 75 | "S3 Virge/VX", "S3 Virge/DX", "S3 Virge/GX", |
74 | "S3 Virge/GX2", "S3 Virge/GX2P", "S3 Virge/GX2P", | 76 | "S3 Virge/GX2", "S3 Virge/GX2P", "S3 Virge/GX2P", |
75 | "S3 Trio3D/1X", "S3 Trio3D/2X", "S3 Trio3D/2X"}; | 77 | "S3 Trio3D/1X", "S3 Trio3D/2X", "S3 Trio3D/2X", |
78 | "S3 Trio3D"}; | ||
76 | 79 | ||
77 | #define CHIP_UNKNOWN 0x00 | 80 | #define CHIP_UNKNOWN 0x00 |
78 | #define CHIP_732_TRIO32 0x01 | 81 | #define CHIP_732_TRIO32 0x01 |
@@ -93,6 +96,7 @@ static const char * const s3_names[] = {"S3 Unknown", "S3 Trio32", "S3 Trio64", | |||
93 | #define CHIP_360_TRIO3D_1X 0x10 | 96 | #define CHIP_360_TRIO3D_1X 0x10 |
94 | #define CHIP_362_TRIO3D_2X 0x11 | 97 | #define CHIP_362_TRIO3D_2X 0x11 |
95 | #define CHIP_368_TRIO3D_2X 0x12 | 98 | #define CHIP_368_TRIO3D_2X 0x12 |
99 | #define CHIP_365_TRIO3D 0x13 | ||
96 | 100 | ||
97 | #define CHIP_XXX_TRIO 0x80 | 101 | #define CHIP_XXX_TRIO 0x80 |
98 | #define CHIP_XXX_TRIO64V2_DXGX 0x81 | 102 | #define CHIP_XXX_TRIO64V2_DXGX 0x81 |
@@ -341,7 +345,8 @@ static void s3_set_pixclock(struct fb_info *info, u32 pixclock) | |||
341 | u8 regval; | 345 | u8 regval; |
342 | int rv; | 346 | int rv; |
343 | 347 | ||
344 | rv = svga_compute_pll(&s3_pll, 1000000000 / pixclock, &m, &n, &r, info->node); | 348 | rv = svga_compute_pll((par->chip == CHIP_365_TRIO3D) ? &s3_trio3d_pll : &s3_pll, |
349 | 1000000000 / pixclock, &m, &n, &r, info->node); | ||
345 | if (rv < 0) { | 350 | if (rv < 0) { |
346 | printk(KERN_ERR "fb%d: cannot set requested pixclock, keeping old value\n", info->node); | 351 | printk(KERN_ERR "fb%d: cannot set requested pixclock, keeping old value\n", info->node); |
347 | return; | 352 | return; |
@@ -598,7 +603,8 @@ static int s3fb_set_par(struct fb_info *info) | |||
598 | 603 | ||
599 | if (par->chip == CHIP_360_TRIO3D_1X || | 604 | if (par->chip == CHIP_360_TRIO3D_1X || |
600 | par->chip == CHIP_362_TRIO3D_2X || | 605 | par->chip == CHIP_362_TRIO3D_2X || |
601 | par->chip == CHIP_368_TRIO3D_2X) { | 606 | par->chip == CHIP_368_TRIO3D_2X || |
607 | par->chip == CHIP_365_TRIO3D) { | ||
602 | dbytes = info->var.xres * ((bpp+7)/8); | 608 | dbytes = info->var.xres * ((bpp+7)/8); |
603 | vga_wcrt(par->state.vgabase, 0x91, (dbytes + 7) / 8); | 609 | vga_wcrt(par->state.vgabase, 0x91, (dbytes + 7) / 8); |
604 | vga_wcrt(par->state.vgabase, 0x90, (((dbytes + 7) / 8) >> 8) | 0x80); | 610 | vga_wcrt(par->state.vgabase, 0x90, (((dbytes + 7) / 8) >> 8) | 0x80); |
@@ -1012,13 +1018,15 @@ static int __devinit s3_pci_probe(struct pci_dev *dev, const struct pci_device_i | |||
1012 | regval = vga_rcrt(par->state.vgabase, 0x36); | 1018 | regval = vga_rcrt(par->state.vgabase, 0x36); |
1013 | if (par->chip == CHIP_360_TRIO3D_1X || | 1019 | if (par->chip == CHIP_360_TRIO3D_1X || |
1014 | par->chip == CHIP_362_TRIO3D_2X || | 1020 | par->chip == CHIP_362_TRIO3D_2X || |
1015 | par->chip == CHIP_368_TRIO3D_2X) { | 1021 | par->chip == CHIP_368_TRIO3D_2X || |
1022 | par->chip == CHIP_365_TRIO3D) { | ||
1016 | switch ((regval & 0xE0) >> 5) { | 1023 | switch ((regval & 0xE0) >> 5) { |
1017 | case 0: /* 8MB -- only 4MB usable for display */ | 1024 | case 0: /* 8MB -- only 4MB usable for display */ |
1018 | case 1: /* 4MB with 32-bit bus */ | 1025 | case 1: /* 4MB with 32-bit bus */ |
1019 | case 2: /* 4MB */ | 1026 | case 2: /* 4MB */ |
1020 | info->screen_size = 4 << 20; | 1027 | info->screen_size = 4 << 20; |
1021 | break; | 1028 | break; |
1029 | case 4: /* 2MB on 365 Trio3D */ | ||
1022 | case 6: /* 2MB */ | 1030 | case 6: /* 2MB */ |
1023 | info->screen_size = 2 << 20; | 1031 | info->screen_size = 2 << 20; |
1024 | break; | 1032 | break; |
@@ -1226,6 +1234,7 @@ static struct pci_device_id s3_devices[] __devinitdata = { | |||
1226 | {PCI_DEVICE(PCI_VENDOR_ID_S3, 0x8A11), .driver_data = CHIP_357_VIRGE_GX2P}, | 1234 | {PCI_DEVICE(PCI_VENDOR_ID_S3, 0x8A11), .driver_data = CHIP_357_VIRGE_GX2P}, |
1227 | {PCI_DEVICE(PCI_VENDOR_ID_S3, 0x8A12), .driver_data = CHIP_359_VIRGE_GX2P}, | 1235 | {PCI_DEVICE(PCI_VENDOR_ID_S3, 0x8A12), .driver_data = CHIP_359_VIRGE_GX2P}, |
1228 | {PCI_DEVICE(PCI_VENDOR_ID_S3, 0x8A13), .driver_data = CHIP_36X_TRIO3D_1X_2X}, | 1236 | {PCI_DEVICE(PCI_VENDOR_ID_S3, 0x8A13), .driver_data = CHIP_36X_TRIO3D_1X_2X}, |
1237 | {PCI_DEVICE(PCI_VENDOR_ID_S3, 0x8904), .driver_data = CHIP_365_TRIO3D}, | ||
1229 | 1238 | ||
1230 | {0, 0, 0, 0, 0, 0, 0} | 1239 | {0, 0, 0, 0, 0, 0, 0} |
1231 | }; | 1240 | }; |