1
0
mirror of https://github.com/mpv-player/mpv synced 2025-01-11 17:39:38 +00:00

Partial sync with linux stuff (Linux driver is still buggy for me)

git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@3556 b3059339-0415-0410-9bf9-f77b7e298cf2
This commit is contained in:
nick 2001-12-17 09:07:12 +00:00
parent 3e767bad3e
commit 0bfbe3afe6

View File

@ -33,6 +33,14 @@
* 0.1.0-ve.1 * 0.1.0-ve.1
* 2001-09-25 MTRR support (by NK) * 2001-09-25 MTRR support (by NK)
* 0.1.0-ve.2 * 0.1.0-ve.2
* 2001-12-17 sync with 0.1.1:
* PanelYRes - module parameter
* - rage theatre (please see gatos.sf.net)
* - buggy tvout detection (need radeon_i2c)
* + better powerpc support
* + better radeon2 pll computing
* * Note: my stuff still work better for me than official
* linux driver :(
* Special thanks to ATI DevRel team for their hardware donations. * Special thanks to ATI DevRel team for their hardware donations.
* *
* LIMITATIONS: on dualhead Radeons (VE, M6, M7) driver doesn't work in * LIMITATIONS: on dualhead Radeons (VE, M6, M7) driver doesn't work in
@ -50,7 +58,7 @@
* *
*/ */
#define RADEON_VERSION "0.1.0-ve.2" #define RADEON_VERSION "0.1.1-ve"
#include <linux/config.h> #include <linux/config.h>
#include <linux/module.h> #include <linux/module.h>
@ -80,6 +88,9 @@
#ifdef CONFIG_MTRR #ifdef CONFIG_MTRR
#include <asm/mtrr.h> #include <asm/mtrr.h>
#endif #endif
#if defined(__powerpc__)
#include <asm/prom.h>
#endif
#include "radeon.h" #include "radeon.h"
@ -92,6 +103,14 @@
#define RTRACE(...) ((void)0) #define RTRACE(...) ((void)0)
#endif #endif
MODULE_AUTHOR("Ani Joshi. (Radeon VE extensions by Nick Kurshev)");
MODULE_DESCRIPTION("framebuffer driver for ATI Radeon chipset. Ver: "RADEON_VERSION);
#ifdef CONFIG_MTRR
MODULE_PARM(nomtrr, "i");
MODULE_PARM_DESC(nomtrr, "Don't touch MTRR (touch=0(default))");
#endif
MODULE_PARM(yres_panel, "i");
MODULE_PARM_DESC(yres_panel, "Force DFP height");
enum radeon_chips { enum radeon_chips {
@ -118,24 +137,6 @@ enum radeon_montype
MT_STV /* S-Video TV out (probably in VE only) */ MT_STV /* S-Video TV out (probably in VE only) */
}; };
enum radeon_ddctype
{
DDC_NONE_DETECTED,
DDC_MONID,
DDC_DVI,
DDC_VGA,
DDC_CRT2
};
enum radeon_connectortype
{
CONNECTOR_NONE,
CONNECTOR_PROPRIETARY,
CONNECTOR_CRT,
CONNECTOR_DVI_I,
CONNECTOR_DVI_D
};
static struct pci_device_id radeonfb_pci_table[] __devinitdata = { static struct pci_device_id radeonfb_pci_table[] __devinitdata = {
{ PCI_VENDOR_ID_ATI, PCI_DEVICE_ID_RADEON_QD, PCI_ANY_ID, PCI_ANY_ID, 0, 0, RADEON_QD}, { PCI_VENDOR_ID_ATI, PCI_DEVICE_ID_RADEON_QD, PCI_ANY_ID, PCI_ANY_ID, 0, 0, RADEON_QD},
{ PCI_VENDOR_ID_ATI, PCI_DEVICE_ID_RADEON_QE, PCI_ANY_ID, PCI_ANY_ID, 0, 0, RADEON_QE}, { PCI_VENDOR_ID_ATI, PCI_DEVICE_ID_RADEON_QE, PCI_ANY_ID, PCI_ANY_ID, 0, 0, RADEON_QE},
@ -218,7 +219,6 @@ struct radeon_regs {
u32 mpp_tb_config; u32 mpp_tb_config;
u32 mpp_gp_config; u32 mpp_gp_config;
u32 subpic_cntl; u32 subpic_cntl;
u32 viph_control;
u32 i2c_cntl_1; u32 i2c_cntl_1;
u32 gen_int_cntl; u32 gen_int_cntl;
u32 cap0_trig_cntl; u32 cap0_trig_cntl;
@ -313,11 +313,9 @@ struct radeonfb_info {
int hasCRTC2; int hasCRTC2;
int crtDispType; int crtDispType;
int dviDispType; int dviDispType;
int hasTVout;
int isM7; int isM7;
int isM6; int isM6;
int isR200; int isR200;
int theatre_num;
/* Computed values for FPs */ /* Computed values for FPs */
int PanelXRes; int PanelXRes;
int PanelYRes; int PanelYRes;
@ -381,7 +379,10 @@ struct radeonfb_info {
/*#define DUAL_MONITOR(rinfo) (rinfo->crtDispType != MT_NONE && rinfo->dviDispType != MT_NONE)*/ /*#define DUAL_MONITOR(rinfo) (rinfo->crtDispType != MT_NONE && rinfo->dviDispType != MT_NONE)*/
/* Disable DUAL monitor support for now */ /* Disable DUAL monitor support for now */
#define DUAL_MONITOR(rinfo) (0) #define DUAL_MONITOR(rinfo) (0)
#define PRIMARY_MONITOR(rinfo) (rinfo->dviDispType != MT_NONE && rinfo->dviDispType != MT_STV && rinfo->dviDispType != MT_CTV ? rinfo->dviDispType : rinfo->crtDispType) #define PRIMARY_MONITOR(rinfo) (rinfo->dviDispType != MT_NONE &&\
rinfo->dviDispType != MT_STV &&\
rinfo->dviDispType != MT_CTV ?\
rinfo->dviDispType : rinfo->crtDispType)
static struct fb_var_screeninfo radeonfb_default_var = { static struct fb_var_screeninfo radeonfb_default_var = {
640, 480, 640, 480, 0, 0, 8, 0, 640, 480, 640, 480, 0, 0, 8, 0,
@ -613,6 +614,8 @@ static char fontname[40] __initdata;
static char *mode_option __initdata; static char *mode_option __initdata;
static char noaccel __initdata = 0; static char noaccel __initdata = 0;
static int nomtrr __initdata = 0; static int nomtrr __initdata = 0;
static int yres_panel __initdata = 0;
static char panel_yres __initdata = 0;
#if 0 #if 0
#ifdef FBCON_HAS_CFB8 #ifdef FBCON_HAS_CFB8
@ -676,6 +679,9 @@ static int radeonfb_do_maximize(struct radeonfb_info *rinfo,
struct fb_var_screeninfo *var, struct fb_var_screeninfo *var,
struct fb_var_screeninfo *v, struct fb_var_screeninfo *v,
int nom, int den); int nom, int den);
#if defined(__powerpc__)
extern struct device_node *pci_device_to_OF_node(struct pci_dev *dev);
#endif
static struct fb_ops radeon_fb_ops = { static struct fb_ops radeon_fb_ops = {
fb_get_fix: radeonfb_get_fix, fb_get_fix: radeonfb_get_fix,
@ -777,25 +783,6 @@ static void _radeon_wait_for_idle(struct radeonfb_info *rinfo)
} }
} }
static u32 RADEONVIP_idle(struct radeonfb_info *rinfo)
{
u32 timeout;
_radeon_wait_for_idle(rinfo);
timeout = INREG(VIPH_TIMEOUT_STAT);
if(timeout & VIPH_TIMEOUT_STAT__VIPH_REG_STAT) /* lockup ?? */
{
radeon_fifo_wait(2);
OUTREG(VIPH_TIMEOUT_STAT, (timeout & 0xffffff00) | VIPH_TIMEOUT_STAT__VIPH_REG_AK);
_radeon_wait_for_idle(rinfo);
return (INREG(VIPH_CONTROL) & 0x2000) ? VIP_BUSY : VIP_RESET;
}
_radeon_wait_for_idle(rinfo);
return (INREG(VIPH_CONTROL) & 0x2000) ? VIP_BUSY : VIP_IDLE ;
}
int __init radeonfb_init (void) int __init radeonfb_init (void)
{ {
#ifdef CONFIG_MTRR #ifdef CONFIG_MTRR
@ -804,6 +791,7 @@ int __init radeonfb_init (void)
printk("radeonfb: Parameter NOMTRR set\n"); printk("radeonfb: Parameter NOMTRR set\n");
} }
#endif #endif
if (yres_panel) panel_yres = yres_panel;
return pci_module_init (&radeonfb_driver); return pci_module_init (&radeonfb_driver);
} }
@ -821,8 +809,9 @@ int __init radeonfb_setup (char *options)
if (!options || !*options) if (!options || !*options)
return 0; return 0;
for (this_opt = strtok (options, ","); this_opt; while ((this_opt = strsep (&options, ",")) != NULL) {
this_opt = strtok (NULL, ",")) { if (!*this_opt)
continue;
if (!strncmp (this_opt, "font:", 5)) { if (!strncmp (this_opt, "font:", 5)) {
char *p; char *p;
int i; int i;
@ -840,7 +829,10 @@ int __init radeonfb_setup (char *options)
mtrr = 0; mtrr = 0;
} }
#endif #endif
else mode_option = this_opt; else if (!strncmp(this_opt, "panel_yres:", 11)) {
panel_yres = simple_strtoul((this_opt+11), NULL, 0);
} else
mode_option = this_opt;
} }
return 0; return 0;
@ -851,83 +843,6 @@ module_init(radeonfb_init);
module_exit(radeonfb_exit); module_exit(radeonfb_exit);
#endif #endif
MODULE_AUTHOR("Ani Joshi. (Radeon VE extensions by Nick Kurshev)");
MODULE_DESCRIPTION("framebuffer driver for ATI Radeon chipset. Ver: "RADEON_VERSION);
#ifdef CONFIG_MTRR
MODULE_PARM(nomtrr, "i");
MODULE_PARM_DESC(nomtrr, "Don't touch MTRR (touch=0(default))");
#endif
/* address format:
((device & 0x3)<<14) | (fifo << 12) | (addr)
*/
static int RADEONVIP_read(struct radeonfb_info *rinfo, u32 address, u32 count, u8 *buffer)
{
u32 status,tmp;
if((count!=1) && (count!=2) && (count!=4))
{
printk("radeonfb: Attempt to access VIP bus with non-stadard transaction length\n");
return 0;
}
radeon_fifo_wait(2);
OUTREG(VIPH_REG_ADDR, address | 0x2000);
while(VIP_BUSY == (status = RADEONVIP_idle(rinfo)));
if(VIP_IDLE != status) return 0;
/*
disable VIPH_REGR_DIS to enable VIP cycle.
The LSB of VIPH_TIMEOUT_STAT are set to 0
because 1 would have acknowledged various VIP
interrupts unexpectedly
*/
radeon_fifo_wait(2);
OUTREG(VIPH_TIMEOUT_STAT, INREG(VIPH_TIMEOUT_STAT) & (0xffffff00 & ~VIPH_TIMEOUT_STAT__VIPH_REGR_DIS) );
/*
the value returned here is garbage. The read merely initiates
a register cycle
*/
_radeon_wait_for_idle(rinfo);
INREG(VIPH_REG_DATA);
while(VIP_BUSY == (status = RADEONVIP_idle(rinfo)));
if(VIP_IDLE != status) return 0;
/*
set VIPH_REGR_DIS so that the read won't take too long.
*/
_radeon_wait_for_idle(rinfo);
tmp=INREG(VIPH_TIMEOUT_STAT);
OUTREG(VIPH_TIMEOUT_STAT, (tmp & 0xffffff00) | VIPH_TIMEOUT_STAT__VIPH_REGR_DIS);
_radeon_wait_for_idle(rinfo);
switch(count){
case 1:
*buffer=(u8)(INREG(VIPH_REG_DATA) & 0xff);
break;
case 2:
*(u16 *)buffer=(u16) (INREG(VIPH_REG_DATA) & 0xffff);
break;
case 4:
*(u32 *)buffer=(u32) ( INREG(VIPH_REG_DATA) & 0xffffffff);
break;
}
while(VIP_BUSY == (status = RADEONVIP_idle(rinfo)));
if(VIP_IDLE != status) return 0;
/*
so that reading VIPH_REG_DATA would not trigger unnecessary vip cycles.
*/
OUTREG(VIPH_TIMEOUT_STAT, (INREG(VIPH_TIMEOUT_STAT) & 0xffffff00) | VIPH_TIMEOUT_STAT__VIPH_REGR_DIS);
return 1;
}
static int theatre_read(struct radeonfb_info *rinfo,u32 reg, u32 *data)
{
if(rinfo->theatre_num<0) return 0;
return RADEONVIP_read(rinfo, ((rinfo->theatre_num & 0x3)<<14) | reg,4, (u8 *) data);
}
static char * GET_MON_NAME(int type) static char * GET_MON_NAME(int type)
{ {
char *pret; char *pret;
@ -958,10 +873,13 @@ static int radeon_get_dfp_info(struct radeonfb_info *rinfo)
unsigned long r; unsigned long r;
unsigned short a, b; unsigned short a, b;
r = INREG(FP_VERT_STRETCH); if (panel_yres) {
r &= 0x00fff000; rinfo->PanelYRes = panel_yres;
rinfo->PanelYRes = (unsigned short)(r >> 0x0c) + 1; } else {
r = INREG(FP_VERT_STRETCH);
r &= 0x00fff000;
rinfo->PanelYRes = (unsigned short)(r >> 0x0c) + 1;
}
switch(rinfo->PanelYRes) switch(rinfo->PanelYRes)
{ {
case 480: rinfo->PanelXRes = 640; case 480: rinfo->PanelXRes = 640;
@ -1008,10 +926,52 @@ static int radeon_get_dfp_info(struct radeonfb_info *rinfo)
- b + 1; - b + 1;
rinfo->VSyncWidth = (unsigned short)((r & FP_V_SYNC_WID_MASK) rinfo->VSyncWidth = (unsigned short)((r & FP_V_SYNC_WID_MASK)
>> FP_V_SYNC_WID_SHIFT); >> FP_V_SYNC_WID_SHIFT);
return 1; return 1;
} }
static void radeon_get_moninfo (struct radeonfb_info *rinfo)
{
unsigned int tmp;
tmp = INREG(RADEON_BIOS_4_SCRATCH);
if (rinfo->hasCRTC2) {
/* primary DVI port */
if (tmp & 0x08)
rinfo->dviDispType = MT_DFP;
else if (tmp & 0x4)
rinfo->dviDispType = MT_LCD;
else if (tmp & 0x200)
rinfo->dviDispType = MT_CRT;
else if (tmp & 0x10)
rinfo->dviDispType = MT_CTV;
else if (tmp & 0x20)
rinfo->dviDispType = MT_STV;
/* secondary CRT port */
if (tmp & 0x2)
rinfo->crtDispType = MT_CRT;
else if (tmp & 0x800)
rinfo->crtDispType = MT_DFP;
else if (tmp & 0x400)
rinfo->crtDispType = MT_LCD;
else if (tmp & 0x1000)
rinfo->crtDispType = MT_CTV;
else if (tmp & 0x2000)
rinfo->crtDispType = MT_STV;
} else {
rinfo->dviDispType = MT_NONE;
tmp = INREG(FP_GEN_CNTL);
if (tmp & FP_EN_TMDS)
rinfo->crtDispType = MT_DFP;
else
rinfo->crtDispType = MT_CRT;
}
}
static int radeonfb_pci_register (struct pci_dev *pdev, static int radeonfb_pci_register (struct pci_dev *pdev,
const struct pci_device_id *ent) const struct pci_device_id *ent)
{ {
@ -1028,6 +988,8 @@ static int radeonfb_pci_register (struct pci_dev *pdev,
memset (rinfo, 0, sizeof (struct radeonfb_info)); memset (rinfo, 0, sizeof (struct radeonfb_info));
rinfo->pdev = pdev;
/* enable device */ /* enable device */
{ {
int err; int err;
@ -1073,6 +1035,8 @@ static int radeonfb_pci_register (struct pci_dev *pdev,
return -ENODEV; return -ENODEV;
} }
rinfo->chipset = pdev->device;
/* chipset */ /* chipset */
switch (pdev->device) { switch (pdev->device) {
case PCI_DEVICE_ID_RADEON_QD: case PCI_DEVICE_ID_RADEON_QD:
@ -1193,60 +1157,7 @@ static int radeonfb_pci_register (struct pci_dev *pdev,
RTRACE("radeonfb: probed %s %dk videoram\n", (rinfo->ram_type), (rinfo->video_ram/1024)); RTRACE("radeonfb: probed %s %dk videoram\n", (rinfo->ram_type), (rinfo->video_ram/1024));
/***** radeon_get_moninfo(rinfo);
VE and M6 have both DVI and CRT ports (for M6 DVI port can be switch to
DFP port). The DVI port can also be conneted to a CRT with an adapter.
Here is the definition of ports for this driver---
(1) If both port are connected, DVI port will be treated as the Primary
port (uses CRTC1) and CRT port will be treated as the Secondary port
(uses CRTC2)
(2) If only one port is connected, it will treated as the Primary port
(??? uses CRTC1 ???)
*****/
if(rinfo->hasCRTC2) {
/* Using BIOS scratch registers works with for VE/M6,
no such registers in regular RADEON!!!*/
tmp = INREG(RADEON_BIOS_4_SCRATCH);
/*check Primary (DVI/DFP port)*/
if(tmp & 0x08) rinfo->dviDispType = MT_DFP;
else if(tmp & 0x04) rinfo->dviDispType = MT_LCD;
else if(tmp & 0x0200) rinfo->dviDispType = MT_CRT;
else if(tmp & 0x10) rinfo->dviDispType = MT_CTV;
else if(tmp & 0x20) rinfo->dviDispType = MT_STV;
/*check Secondary (CRT port).*/
if(tmp & 0x02) rinfo->crtDispType = MT_CRT;
else if(tmp & 0x800) rinfo->crtDispType = MT_DFP;
else if(tmp & 0x400) rinfo->crtDispType = MT_LCD;
else if(tmp & 0x1000) rinfo->crtDispType = MT_CTV;
else if(tmp & 0x2000) rinfo->crtDispType = MT_STV;
if(rinfo->dviDispType == MT_NONE &&
rinfo->crtDispType == MT_NONE) {
printk("radeonfb: No monitor detected!!!\n");
release_mem_region (rinfo->mmio_base_phys,
pci_resource_len(pdev, 2));
release_mem_region (rinfo->fb_base_phys,
pci_resource_len(pdev, 0));
kfree (rinfo);
return -ENODEV;
}
}
else {
/*Regular Radeon ASIC, only one CRTC, but it could be
used for DFP with a DVI output, like AIW board*/
rinfo->dviDispType = MT_NONE;
tmp = INREG(FP_GEN_CNTL);
if(tmp & FP_EN_TMDS) rinfo->crtDispType = MT_DFP;
else rinfo->crtDispType = MT_CRT;
}
if(bios_seg) {
/*
FIXME!!! TVout support currently is incomplete
On Radeon VE TVout is recognized as STV monitor on DVI port.
*/
char * bios_ptr = bios_seg + 0x48L;
rinfo->hasTVout = readw(bios_ptr+0x32);
}
if((rinfo->dviDispType == MT_DFP || rinfo->dviDispType == MT_LCD || if((rinfo->dviDispType == MT_DFP || rinfo->dviDispType == MT_LCD ||
rinfo->crtDispType == MT_DFP)) rinfo->crtDispType == MT_DFP))
@ -1284,7 +1195,7 @@ static int radeonfb_pci_register (struct pci_dev *pdev,
rinfo->palette[i].blue = default_blu[j]; rinfo->palette[i].blue = default_blu[j];
} }
pdev->driver_data = rinfo; pci_set_drvdata(pdev, rinfo);
if (register_framebuffer ((struct fb_info *) rinfo) < 0) { if (register_framebuffer ((struct fb_info *) rinfo) < 0) {
printk ("radeonfb: could not register framebuffer\n"); printk ("radeonfb: could not register framebuffer\n");
@ -1311,7 +1222,6 @@ static int radeonfb_pci_register (struct pci_dev *pdev,
} }
else else
printk("radeonfb: CRT port has %s monitor connected\n",GET_MON_NAME(rinfo->crtDispType)); printk("radeonfb: CRT port has %s monitor connected\n",GET_MON_NAME(rinfo->crtDispType));
printk("radeonfb: This card has %sTVout\n",rinfo->hasTVout ? "" : "no ");
#ifdef CONFIG_MTRR #ifdef CONFIG_MTRR
if (mtrr) { if (mtrr) {
rinfo->mtrr.vram = mtrr_add(rinfo->fb_base_phys, rinfo->mtrr.vram = mtrr_add(rinfo->fb_base_phys,
@ -1321,22 +1231,6 @@ static int radeonfb_pci_register (struct pci_dev *pdev,
printk("radeonfb: MTRR set to ON\n"); printk("radeonfb: MTRR set to ON\n");
} }
#endif /* CONFIG_MTRR */ #endif /* CONFIG_MTRR */
rinfo->theatre_num = -1;
for(i=0;i<4;i++)
{
if(RADEONVIP_read(rinfo, ((i & 0x03)<<14) | VIP_VIP_VENDOR_DEVICE_ID, 4, (u8 *)&tmp) &&
(tmp==RT_ATI_ID))
{
rinfo->theatre_num=i;
break;
}
}
if(rinfo->theatre_num >= 0) {
printk("radeonfb: Device %d on VIP bus ids as %x\n",i,tmp);
theatre_read(rinfo,VIP_VIP_REVISION_ID, &tmp);
printk("radeonfb: Detected Rage Theatre revision %8.8X\n", tmp);
}
else printk("radeonfb: Rage Theatre was not detected\n");
return 0; return 0;
} }
@ -1344,7 +1238,7 @@ static int radeonfb_pci_register (struct pci_dev *pdev,
static void __devexit radeonfb_pci_unregister (struct pci_dev *pdev) static void __devexit radeonfb_pci_unregister (struct pci_dev *pdev)
{ {
struct radeonfb_info *rinfo = pdev->driver_data; struct radeonfb_info *rinfo = pci_get_drvdata(pdev);
if (!rinfo) if (!rinfo)
return; return;
@ -1436,7 +1330,24 @@ static char *radeon_find_rom(struct radeonfb_info *rinfo)
return NULL; return NULL;
} }
#if defined(__powerpc__)
static int radeon_read_OF (struct radeonfb_info *rinfo)
{
struct device_node *dp;
unsigned int *xtal;
dp = pci_device_to_OF_node(rinfo->pdev);
xtal = (unsigned int *) get_property(dp, "ATY,RefCLK", 0);
rinfo->pll.ref_clk = *xtal / 10;
if (*xtal)
return 1;
else
return 0;
}
#endif
static void radeon_get_pllinfo(struct radeonfb_info *rinfo, char *bios_seg) static void radeon_get_pllinfo(struct radeonfb_info *rinfo, char *bios_seg)
{ {
@ -1465,13 +1376,57 @@ static void radeon_get_pllinfo(struct radeonfb_info *rinfo, char *bios_seg)
rinfo->pll.ppll_min = pll.PCLK_min_freq; rinfo->pll.ppll_min = pll.PCLK_min_freq;
rinfo->pll.ppll_max = pll.PCLK_max_freq; rinfo->pll.ppll_max = pll.PCLK_max_freq;
} else { } else {
#if defined(__powerpc__)
if (radeon_read_OF(rinfo)) {
unsigned int tmp, Nx, M, ref_div, xclk;
tmp = INPLL(M_SPLL_REF_FB_DIV);
ref_div = INPLL(PPLL_REF_DIV) & 0x3ff;
Nx = (tmp & 0xff00) >> 8;
M = (tmp & 0xff);
xclk = ((((2 * Nx * rinfo->pll.ref_clk) + (M)) /
(2 * M)));
rinfo->pll.xclk = xclk;
rinfo->pll.ref_div = ref_div;
rinfo->pll.ppll_min = 12000;
rinfo->pll.ppll_max = 35000;
printk("radeonfb: ref_clk=%d, ref_div=%d, xclk=%d from OF\n",
rinfo->pll.ref_clk, rinfo->pll.ref_div, rinfo->pll.xclk);
return;
}
#endif
/* no BIOS or BIOS not found, use defaults */ /* no BIOS or BIOS not found, use defaults */
rinfo->pll.ppll_max = 35000; switch (rinfo->chipset) {
rinfo->pll.ppll_min = 12000; case PCI_DEVICE_ID_RV200_QW:
rinfo->pll.xclk = 16600; rinfo->pll.ppll_max = 35000;
rinfo->pll.ref_div = 67; rinfo->pll.ppll_min = 12000;
rinfo->pll.ref_clk = 2700; rinfo->pll.xclk = 23000;
rinfo->pll.ref_div = 12;
rinfo->pll.ref_clk = 2700;
break;
case PCI_DEVICE_ID_R200_QL:
rinfo->pll.ppll_max = 35000;
rinfo->pll.ppll_min = 12000;
rinfo->pll.xclk = 27500;
rinfo->pll.ref_div = 12;
rinfo->pll.ref_clk = 2700;
break;
case PCI_DEVICE_ID_RADEON_QD:
case PCI_DEVICE_ID_RADEON_QE:
case PCI_DEVICE_ID_RADEON_QF:
case PCI_DEVICE_ID_RADEON_QG:
default:
rinfo->pll.ppll_max = 35000;
rinfo->pll.ppll_min = 12000;
rinfo->pll.xclk = 16600;
rinfo->pll.ref_div = 67;
rinfo->pll.ref_clk = 2700;
};
} }
} }
@ -1486,7 +1441,6 @@ RTRACE("radeonfb: radeon_init_common_regs is called\n");
save->mpp_tb_config = 0; save->mpp_tb_config = 0;
save->mpp_gp_config = 0; save->mpp_gp_config = 0;
save->subpic_cntl = 0; save->subpic_cntl = 0;
save->viph_control = 0;
save->i2c_cntl_1 = 0; save->i2c_cntl_1 = 0;
save->rbbm_soft_reset = 0; save->rbbm_soft_reset = 0;
save->cap0_trig_cntl = 0; save->cap0_trig_cntl = 0;
@ -2190,7 +2144,7 @@ static void radeon_set_dispsw (struct radeonfb_info *rinfo, struct display *disp
disp->line_length = disp->var.xres_virtual * 2; disp->line_length = disp->var.xres_virtual * 2;
break; break;
#endif #endif
#ifdef FBCON_HAS_CFB32 #ifdef FBCON_HAS_CFB24
case 24: case 24:
disp->dispsw = &fbcon_cfb24; disp->dispsw = &fbcon_cfb24;
disp->dispsw_data = &rinfo->con_cmap.cfb24; disp->dispsw_data = &rinfo->con_cmap.cfb24;
@ -2744,28 +2698,6 @@ static int radeon_setcolreg (unsigned regno, unsigned red, unsigned green,
OUTREG(PALETTE_DATA, (red << 16) | (green << 8) | blue); OUTREG(PALETTE_DATA, (red << 16) | (green << 8) | blue);
} }
#if 0
col = (red << 16) | (green << 8) | blue;
if (rinfo->depth == 16) {
pindex = regno << 3;
if ((rinfo->depth == 16) && (regno >= 32)) {
pindex -= 252;
col = (rinfo->palette[regno >> 1].red << 16) |
(green << 8) |
(rinfo->palette[regno >> 1].blue);
} else {
col = (red << 16) | (green << 8) | blue;
}
}
OUTREG8(PALETTE_INDEX, pindex);
radeon_fifo_wait(32);
OUTREG(PALETTE_DATA, col);
#endif
#if defined(FBCON_HAS_CFB16) || defined(FBCON_HAS_CFB32) #if defined(FBCON_HAS_CFB16) || defined(FBCON_HAS_CFB32)
if (regno < 32) { if (regno < 32) {
switch (rinfo->depth) { switch (rinfo->depth) {
@ -2806,7 +2738,6 @@ RTRACE("radeonfb: radeon_save_common_regs is called\n");
save->mpp_tb_config = INREG(MPP_TB_CONFIG); save->mpp_tb_config = INREG(MPP_TB_CONFIG);
save->mpp_gp_config = INREG(MPP_GP_CONFIG); save->mpp_gp_config = INREG(MPP_GP_CONFIG);
save->subpic_cntl = INREG(SUBPIC_CNTL); save->subpic_cntl = INREG(SUBPIC_CNTL);
save->viph_control = INREG(VIPH_CONTROL);
save->i2c_cntl_1 = INREG(I2C_CNTL_1); save->i2c_cntl_1 = INREG(I2C_CNTL_1);
save->gen_int_cntl = INREG(GEN_INT_CNTL); save->gen_int_cntl = INREG(GEN_INT_CNTL);
save->cap0_trig_cntl = INREG(CAP0_TRIG_CNTL); save->cap0_trig_cntl = INREG(CAP0_TRIG_CNTL);
@ -2889,21 +2820,6 @@ RTRACE("radeonfb: radeon_save_dda_regs is called\n");
save->dda_on_off = INREG(DDA_ON_OFF); save->dda_on_off = INREG(DDA_ON_OFF);
} }
#if 0
static void radeon_save_palette(struct radeonfb_info *rinfo,
struct radeon_regs *save)
{
int i;
RTRACE("radeonfb: radeon_save_palette is called\n");
PAL_SELECT(1);
INPAL_START(0);
for (i = 0; i < 256; i++) save->palette2[i] = INPAL_NEXT();
PAL_SELECT(0);
INPAL_START(0);
for (i = 0; i < 256; i++) save->palette[i] = INPAL_NEXT();
}
#endif
static void radeon_write_common_regs(struct radeonfb_info *rinfo, static void radeon_write_common_regs(struct radeonfb_info *rinfo,
struct radeon_regs *restore) struct radeon_regs *restore)
{ {
@ -2915,7 +2831,6 @@ RTRACE("radeonfb: radeon_write_common_regs is called\n");
OUTREG(MPP_TB_CONFIG, restore->mpp_tb_config ); OUTREG(MPP_TB_CONFIG, restore->mpp_tb_config );
OUTREG(MPP_GP_CONFIG, restore->mpp_gp_config ); OUTREG(MPP_GP_CONFIG, restore->mpp_gp_config );
OUTREG(SUBPIC_CNTL, restore->subpic_cntl); OUTREG(SUBPIC_CNTL, restore->subpic_cntl);
OUTREG(VIPH_CONTROL, restore->viph_control);
OUTREG(I2C_CNTL_1, restore->i2c_cntl_1); OUTREG(I2C_CNTL_1, restore->i2c_cntl_1);
OUTREG(GEN_INT_CNTL, restore->gen_int_cntl); OUTREG(GEN_INT_CNTL, restore->gen_int_cntl);
OUTREG(CAP0_TRIG_CNTL, restore->cap0_trig_cntl); OUTREG(CAP0_TRIG_CNTL, restore->cap0_trig_cntl);
@ -3067,29 +2982,6 @@ RTRACE("radeonfb: radeon_write_dda_regs is called\n");
OUTREG(DDA_ON_OFF, restore->dda_on_off); OUTREG(DDA_ON_OFF, restore->dda_on_off);
} }
#if 0
static void radeon_write_palette(struct radeonfb_info *rinfo,
struct radeon_regs *restore)
{
int i;
RTRACE("radeonfb: radeon_write_palette is called\n");
PAL_SELECT(1);
OUTPAL_START(0);
for (i = 0; i < 256; i++) {
RADEONWaitForFifo(32); /* delay */
OUTPAL_NEXT_CARD32(restore->palette2[i]);
}
PAL_SELECT(0);
OUTPAL_START(0);
for (i = 0; i < 256; i++) {
RADEONWaitForFifo(32); /* delay */
OUTPAL_NEXT_CARD32(restore->palette[i]);
}
}
#endif
static void radeon_save_mode (struct radeonfb_info *rinfo, static void radeon_save_mode (struct radeonfb_info *rinfo,
struct radeon_regs *save) struct radeon_regs *save)
{ {
@ -3120,7 +3012,7 @@ RTRACE("radeonfb: radeon_save_state is called\n");
radeon_save_mode(rinfo,save); radeon_save_mode(rinfo,save);
} }
static int radeon_load_video_mode (struct radeonfb_info *rinfo, static int radeon_load_video_mode (struct radeonfb_info *rinfo,
struct fb_var_screeninfo *mode) struct fb_var_screeninfo *mode)
{ {
@ -3178,7 +3070,6 @@ RTRACE("radeonfb: radeon_write_state is called\n");
} }
#if 0 #if 0
/* /*
* text console acceleration * text console acceleration
*/ */
@ -3222,8 +3113,6 @@ static void fbcon_radeon_bmove(struct display *p, int srcy, int srcx,
OUTREG(DST_HEIGHT_WIDTH, (height << 16) | width); OUTREG(DST_HEIGHT_WIDTH, (height << 16) | width);
} }
static void fbcon_radeon_clear(struct vc_data *conp, struct display *p, static void fbcon_radeon_clear(struct vc_data *conp, struct display *p,
int srcy, int srcx, int height, int width) int srcy, int srcx, int height, int width)
{ {
@ -3251,14 +3140,11 @@ static void fbcon_radeon_clear(struct vc_data *conp, struct display *p,
OUTREG(DST_WIDTH_HEIGHT, (width << 16) | height); OUTREG(DST_WIDTH_HEIGHT, (width << 16) | height);
} }
#ifdef FBCON_HAS_CFB8 #ifdef FBCON_HAS_CFB8
static struct display_switch fbcon_radeon8 = { static struct display_switch fbcon_radeon8 = {
setup: fbcon_cfb8_setup, setup: fbcon_cfb8_setup,
bmove: fbcon_radeon_bmove, bmove: fbcon_radeon_bmove,
clear: fbcon_cfb8_clear, clear: fbcon_radeon_clear,
putc: fbcon_cfb8_putc, putc: fbcon_cfb8_putc,
putcs: fbcon_cfb8_putcs, putcs: fbcon_cfb8_putcs,
revc: fbcon_cfb8_revc, revc: fbcon_cfb8_revc,
@ -3266,5 +3152,4 @@ static struct display_switch fbcon_radeon8 = {
fontwidthmask: FONTWIDTH(4)|FONTWIDTH(8)|FONTWIDTH(12)|FONTWIDTH(16) fontwidthmask: FONTWIDTH(4)|FONTWIDTH(8)|FONTWIDTH(12)|FONTWIDTH(16)
}; };
#endif #endif
#endif
#endif /* 0 */