Commit cc406341 authored by Tormod Volden's avatar Tormod Volden Committed by Paul Mundt

savagefb: New S3_TWISTER and S3_PROSAVAGEDDR chip families

Realign the chip families with the Xorg DDX
Signed-off-by: default avatarTormod Volden <debian.tormod@gmail.com>
Signed-off-by: default avatarPaul Mundt <lethal@linux-sh.org>
parent 1db41e03
...@@ -171,6 +171,8 @@ void savagefb_create_i2c_busses(struct fb_info *info) ...@@ -171,6 +171,8 @@ void savagefb_create_i2c_busses(struct fb_info *info)
switch (par->chip) { switch (par->chip) {
case S3_PROSAVAGE: case S3_PROSAVAGE:
case S3_PROSAVAGEDDR:
case S3_TWISTER:
par->chan.reg = CR_SERIAL2; par->chan.reg = CR_SERIAL2;
par->chan.ioaddr = par->mmio.vbase; par->chan.ioaddr = par->mmio.vbase;
par->chan.algo.setsda = prosavage_gpio_setsda; par->chan.algo.setsda = prosavage_gpio_setsda;
......
...@@ -36,7 +36,6 @@ ...@@ -36,7 +36,6 @@
#define PCI_CHIP_SAVAGE_IX 0x8c13 #define PCI_CHIP_SAVAGE_IX 0x8c13
#define PCI_CHIP_PROSAVAGE_PM 0x8a25 #define PCI_CHIP_PROSAVAGE_PM 0x8a25
#define PCI_CHIP_PROSAVAGE_KM 0x8a26 #define PCI_CHIP_PROSAVAGE_KM 0x8a26
/* Twister is a code name; hope I get the real name soon. */
#define PCI_CHIP_S3TWISTER_P 0x8d01 #define PCI_CHIP_S3TWISTER_P 0x8d01
#define PCI_CHIP_S3TWISTER_K 0x8d02 #define PCI_CHIP_S3TWISTER_K 0x8d02
#define PCI_CHIP_PROSAVAGE_DDR 0x8d03 #define PCI_CHIP_PROSAVAGE_DDR 0x8d03
...@@ -52,14 +51,15 @@ ...@@ -52,14 +51,15 @@
#define PCI_CHIP_SUPSAV_IXCDDR 0x8c2f #define PCI_CHIP_SUPSAV_IXCDDR 0x8c2f
#define S3_SAVAGE_SERIES(chip) ((chip>=S3_SAVAGE3D) && (chip<=S3_SAVAGE2000))
#define S3_SAVAGE3D_SERIES(chip) ((chip>=S3_SAVAGE3D) && (chip<=S3_SAVAGE_MX)) #define S3_SAVAGE3D_SERIES(chip) ((chip>=S3_SAVAGE3D) && (chip<=S3_SAVAGE_MX))
#define S3_SAVAGE4_SERIES(chip) ((chip==S3_SAVAGE4) || (chip==S3_PROSAVAGE)) #define S3_SAVAGE4_SERIES(chip) ((chip>=S3_SAVAGE4) || (chip<=S3_PROSAVAGEDDR))
#define S3_SAVAGE_MOBILE_SERIES(chip) ((chip==S3_SAVAGE_MX) || (chip==S3_SUPERSAVAGE)) #define S3_SAVAGE_MOBILE_SERIES(chip) ((chip==S3_SAVAGE_MX) || (chip==S3_SUPERSAVAGE))
#define S3_SAVAGE_SERIES(chip) ((chip>=S3_SAVAGE3D) && (chip<=S3_SAVAGE2000)) #define S3_MOBILE_TWISTER_SERIES(chip) ((chip==S3_TWISTER) || (chip==S3_PROSAVAGEDDR))
/* Chip tags. These are used to group the adapters into /* Chip tags. These are used to group the adapters into
* related families. * related families.
...@@ -71,6 +71,8 @@ typedef enum { ...@@ -71,6 +71,8 @@ typedef enum {
S3_SAVAGE_MX, S3_SAVAGE_MX,
S3_SAVAGE4, S3_SAVAGE4,
S3_PROSAVAGE, S3_PROSAVAGE,
S3_TWISTER,
S3_PROSAVAGEDDR,
S3_SUPERSAVAGE, S3_SUPERSAVAGE,
S3_SAVAGE2000, S3_SAVAGE2000,
S3_LAST S3_LAST
......
...@@ -328,7 +328,9 @@ SavageSetup2DEngine(struct savagefb_par *par) ...@@ -328,7 +328,9 @@ SavageSetup2DEngine(struct savagefb_par *par)
savage_out32(0x48C18, savage_in32(0x48C18, par) | 0x0C, par); savage_out32(0x48C18, savage_in32(0x48C18, par) | 0x0C, par);
break; break;
case S3_SAVAGE4: case S3_SAVAGE4:
case S3_TWISTER:
case S3_PROSAVAGE: case S3_PROSAVAGE:
case S3_PROSAVAGEDDR:
case S3_SUPERSAVAGE: case S3_SUPERSAVAGE:
/* Disable BCI */ /* Disable BCI */
savage_out32(0x48C18, savage_in32(0x48C18, par) & 0x3FF0, par); savage_out32(0x48C18, savage_in32(0x48C18, par) & 0x3FF0, par);
...@@ -1886,6 +1888,8 @@ static int savage_init_hw(struct savagefb_par *par) ...@@ -1886,6 +1888,8 @@ static int savage_init_hw(struct savagefb_par *par)
break; break;
case S3_PROSAVAGE: case S3_PROSAVAGE:
case S3_PROSAVAGEDDR:
case S3_TWISTER:
videoRam = RamSavageNB[(config1 & 0xE0) >> 5] * 1024; videoRam = RamSavageNB[(config1 & 0xE0) >> 5] * 1024;
break; break;
...@@ -2111,19 +2115,19 @@ static int __devinit savage_init_fb_info(struct fb_info *info, ...@@ -2111,19 +2115,19 @@ static int __devinit savage_init_fb_info(struct fb_info *info,
snprintf(info->fix.id, 16, "ProSavageKM"); snprintf(info->fix.id, 16, "ProSavageKM");
break; break;
case FB_ACCEL_S3TWISTER_P: case FB_ACCEL_S3TWISTER_P:
par->chip = S3_PROSAVAGE; par->chip = S3_TWISTER;
snprintf(info->fix.id, 16, "TwisterP"); snprintf(info->fix.id, 16, "TwisterP");
break; break;
case FB_ACCEL_S3TWISTER_K: case FB_ACCEL_S3TWISTER_K:
par->chip = S3_PROSAVAGE; par->chip = S3_TWISTER;
snprintf(info->fix.id, 16, "TwisterK"); snprintf(info->fix.id, 16, "TwisterK");
break; break;
case FB_ACCEL_PROSAVAGE_DDR: case FB_ACCEL_PROSAVAGE_DDR:
par->chip = S3_PROSAVAGE; par->chip = S3_PROSAVAGEDDR;
snprintf(info->fix.id, 16, "ProSavageDDR"); snprintf(info->fix.id, 16, "ProSavageDDR");
break; break;
case FB_ACCEL_PROSAVAGE_DDRK: case FB_ACCEL_PROSAVAGE_DDRK:
par->chip = S3_PROSAVAGE; par->chip = S3_PROSAVAGEDDR;
snprintf(info->fix.id, 16, "ProSavage8"); snprintf(info->fix.id, 16, "ProSavage8");
break; break;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment