Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
903c38a4
Commit
903c38a4
authored
Dec 27, 2002
by
James Simmons
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Radeon driver port to final api. Cleanup of vga16fb.
parent
fd07f74e
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
159 additions
and
87 deletions
+159
-87
drivers/video/Makefile
drivers/video/Makefile
+1
-1
drivers/video/console/fbcon.c
drivers/video/console/fbcon.c
+0
-1
drivers/video/radeonfb.c
drivers/video/radeonfb.c
+27
-11
drivers/video/vga16fb.c
drivers/video/vga16fb.c
+1
-69
include/video/radeon.h
include/video/radeon.h
+130
-5
No files found.
drivers/video/Makefile
View file @
903c38a4
...
@@ -26,7 +26,7 @@ obj-$(CONFIG_FB_APOLLO) += dnfb.o cfbfillrect.o cfbimgblt.o
...
@@ -26,7 +26,7 @@ obj-$(CONFIG_FB_APOLLO) += dnfb.o cfbfillrect.o cfbimgblt.o
obj-$(CONFIG_FB_Q40)
+=
q40fb.o cfbfillrect.o cfbcopyarea.o cfbimgblt.o
obj-$(CONFIG_FB_Q40)
+=
q40fb.o cfbfillrect.o cfbcopyarea.o cfbimgblt.o
obj-$(CONFIG_FB_ATARI)
+=
atafb.o
obj-$(CONFIG_FB_ATARI)
+=
atafb.o
obj-$(CONFIG_FB_ATY128)
+=
aty128fb.o cfbfillrect.o cfbcopyarea.o cfbimgblt.o
obj-$(CONFIG_FB_ATY128)
+=
aty128fb.o cfbfillrect.o cfbcopyarea.o cfbimgblt.o
obj-$(CONFIG_FB_RADEON)
+=
radeonfb.o
obj-$(CONFIG_FB_RADEON)
+=
radeonfb.o
cfbfillrect.o cfbcopyarea.o cfbimgblt.o
obj-$(CONFIG_FB_NEOMAGIC)
+=
neofb.o cfbfillrect.o cfbcopyarea.o cfbimgblt.o
obj-$(CONFIG_FB_NEOMAGIC)
+=
neofb.o cfbfillrect.o cfbcopyarea.o cfbimgblt.o
obj-$(CONFIG_FB_IGA)
+=
igafb.o cfbfillrect.o cfbcopyarea.o cfbimgblt.o
obj-$(CONFIG_FB_IGA)
+=
igafb.o cfbfillrect.o cfbcopyarea.o cfbimgblt.o
obj-$(CONFIG_FB_CONTROL)
+=
controlfb.o
obj-$(CONFIG_FB_CONTROL)
+=
controlfb.o
...
...
drivers/video/console/fbcon.c
View file @
903c38a4
...
@@ -2543,7 +2543,6 @@ int __init fb_console_init(void)
...
@@ -2543,7 +2543,6 @@ int __init fb_console_init(void)
if
(
!
num_registered_fb
)
if
(
!
num_registered_fb
)
return
-
ENODEV
;
return
-
ENODEV
;
take_over_console
(
&
fb_con
,
first_fb_vc
,
last_fb_vc
,
fbcon_is_default
);
take_over_console
(
&
fb_con
,
first_fb_vc
,
last_fb_vc
,
fbcon_is_default
);
__unsafe
(
THIS_MODULE
);
return
0
;
return
0
;
}
}
...
...
drivers/video/radeonfb.c
View file @
903c38a4
...
@@ -361,8 +361,6 @@ struct radeonfb_info {
...
@@ -361,8 +361,6 @@ struct radeonfb_info {
unsigned
char
*
EDID
;
unsigned
char
*
EDID
;
unsigned
char
*
bios_seg
;
unsigned
char
*
bios_seg
;
struct
display
disp
;
/* Will disappear */
u32
pseudo_palette
[
17
];
u32
pseudo_palette
[
17
];
struct
{
u8
red
,
green
,
blue
,
pad
;
}
palette
[
256
];
struct
{
u8
red
,
green
,
blue
,
pad
;
}
palette
[
256
];
...
@@ -1289,7 +1287,7 @@ static int __devinit radeon_init_disp (struct radeonfb_info *rinfo)
...
@@ -1289,7 +1287,7 @@ static int __devinit radeon_init_disp (struct radeonfb_info *rinfo)
fb_alloc_cmap
(
&
info
->
cmap
,
256
,
0
);
fb_alloc_cmap
(
&
info
->
cmap
,
256
,
0
);
var
.
activate
=
FB_ACTIVATE_NOW
;
var
.
activate
=
FB_ACTIVATE_NOW
;
gen_set_var
(
&
var
,
-
1
,
info
);
fb_set_var
(
&
var
,
info
);
return
0
;
return
0
;
}
}
...
@@ -1508,7 +1506,7 @@ static int radeonfb_pan_display (struct fb_var_screeninfo *var,
...
@@ -1508,7 +1506,7 @@ static int radeonfb_pan_display (struct fb_var_screeninfo *var,
static
int
radeonfb_ioctl
(
struct
inode
*
inode
,
struct
file
*
file
,
unsigned
int
cmd
,
static
int
radeonfb_ioctl
(
struct
inode
*
inode
,
struct
file
*
file
,
unsigned
int
cmd
,
unsigned
long
arg
,
int
con
,
struct
fb_info
*
info
)
unsigned
long
arg
,
struct
fb_info
*
info
)
{
{
struct
radeonfb_info
*
rinfo
=
(
struct
radeonfb_info
*
)
info
;
struct
radeonfb_info
*
rinfo
=
(
struct
radeonfb_info
*
)
info
;
unsigned
int
tmp
;
unsigned
int
tmp
;
...
@@ -1872,14 +1870,26 @@ static int radeonfb_set_par (struct fb_info *info)
...
@@ -1872,14 +1870,26 @@ static int radeonfb_set_par (struct fb_info *info)
newmode
.
crtc_pitch
|=
(
newmode
.
crtc_pitch
<<
16
);
newmode
.
crtc_pitch
|=
(
newmode
.
crtc_pitch
<<
16
);
#if defined(__BIG_ENDIAN)
#if defined(__BIG_ENDIAN)
newmode
.
surface_cntl
=
SURF_TRANSLATION_DIS
;
/*
* It looks like recent chips have a problem with SURFACE_CNTL,
* setting SURF_TRANSLATION_DIS completely disables the
* swapper as well, so we leave it unset now.
*/
newmode
.
surface_cntl
=
0
;
/* Setup swapping on both apertures, though we currently
* only use aperture 0, enabling swapper on aperture 1
* won't harm
*/
switch
(
mode
->
bits_per_pixel
)
{
switch
(
mode
->
bits_per_pixel
)
{
case
16
:
case
16
:
newmode
.
surface_cntl
|=
NONSURF_AP0_SWP_16BPP
;
newmode
.
surface_cntl
|=
NONSURF_AP0_SWP_16BPP
;
newmode
.
surface_cntl
|=
NONSURF_AP1_SWP_16BPP
;
break
;
break
;
case
24
:
case
24
:
case
32
:
case
32
:
newmode
.
surface_cntl
|=
NONSURF_AP0_SWP_32BPP
;
newmode
.
surface_cntl
|=
NONSURF_AP0_SWP_32BPP
;
newmode
.
surface_cntl
|=
NONSURF_AP1_SWP_32BPP
;
break
;
break
;
}
}
#endif
#endif
...
@@ -1934,7 +1944,12 @@ static int radeonfb_set_par (struct fb_info *info)
...
@@ -1934,7 +1944,12 @@ static int radeonfb_set_par (struct fb_info *info)
newmode
.
ppll_div_3
=
rinfo
->
fb_div
|
(
post_div
->
bitvalue
<<
16
);
newmode
.
ppll_div_3
=
rinfo
->
fb_div
|
(
post_div
->
bitvalue
<<
16
);
}
}
newmode
.
vclk_ecp_cntl
=
rinfo
->
init_state
.
vclk_ecp_cntl
;
newmode
.
vclk_ecp_cntl
=
rinfo
->
init_state
.
vclk_ecp_cntl
;
#ifdef CONFIG_ALL_PPC
/* Gross hack for iBook with M7 until I find out a proper fix */
if
(
machine_is_compatible
(
"PowerBook4,3"
)
&&
rinfo
->
arch
==
RADEON_M7
)
newmode
.
ppll_div_3
=
0x000600ad
;
#endif
/* CONFIG_ALL_PPC */
RTRACE
(
"post div = 0x%x
\n
"
,
rinfo
->
post_div
);
RTRACE
(
"post div = 0x%x
\n
"
,
rinfo
->
post_div
);
RTRACE
(
"fb_div = 0x%x
\n
"
,
rinfo
->
fb_div
);
RTRACE
(
"fb_div = 0x%x
\n
"
,
rinfo
->
fb_div
);
...
@@ -2206,12 +2221,8 @@ static int __devinit radeon_set_fbinfo (struct radeonfb_info *rinfo)
...
@@ -2206,12 +2221,8 @@ static int __devinit radeon_set_fbinfo (struct radeonfb_info *rinfo)
info
=
&
rinfo
->
info
;
info
=
&
rinfo
->
info
;
// XXX ???
strncpy
(
info
->
modename
,
rinfo
->
name
,
sizeof
(
info
->
modename
));
info
->
currcon
=
-
1
;
info
->
currcon
=
-
1
;
info
->
par
=
rinfo
;
info
->
par
=
rinfo
;
info
->
disp
=
&
rinfo
->
disp
;
info
->
pseudo_palette
=
rinfo
->
pseudo_palette
;
info
->
pseudo_palette
=
rinfo
->
pseudo_palette
;
info
->
node
=
NODEV
;
info
->
node
=
NODEV
;
info
->
flags
=
FBINFO_FLAG_DEFAULT
;
info
->
flags
=
FBINFO_FLAG_DEFAULT
;
...
@@ -2273,7 +2284,12 @@ static int radeon_set_backlight_enable(int on, int level, void *data)
...
@@ -2273,7 +2284,12 @@ static int radeon_set_backlight_enable(int on, int level, void *data)
unsigned
int
lvds_gen_cntl
=
INREG
(
LVDS_GEN_CNTL
);
unsigned
int
lvds_gen_cntl
=
INREG
(
LVDS_GEN_CNTL
);
int
*
conv_table
;
int
*
conv_table
;
if
(
rinfo
->
arch
==
RADEON_M7
)
/* Pardon me for that hack... maybe some day we can figure
* out in what direction backlight should work on a given
* panel ?
*/
if
((
rinfo
->
arch
==
RADEON_M7
||
rinfo
->
arch
==
RADEON_M9
)
&&
!
machine_is_compatible
(
"PowerBook4,3"
))
conv_table
=
backlight_conv_m7
;
conv_table
=
backlight_conv_m7
;
else
else
conv_table
=
backlight_conv_m6
;
conv_table
=
backlight_conv_m6
;
...
...
drivers/video/vga16fb.c
View file @
903c38a4
...
@@ -329,9 +329,6 @@ static int vga16fb_release(struct fb_info *info, int user)
...
@@ -329,9 +329,6 @@ static int vga16fb_release(struct fb_info *info, int user)
static
int
vga16fb_check_var
(
struct
fb_var_screeninfo
*
var
,
static
int
vga16fb_check_var
(
struct
fb_var_screeninfo
*
var
,
struct
fb_info
*
info
)
struct
fb_info
*
info
)
{
{
#ifdef FBCON_HAS_VGA
struct
display
*
p
=
(
info
->
currcon
<
0
)
?
info
->
disp
:
(
fb_display
+
info
->
currcon
);
#endif
struct
vga16fb_par
*
par
=
(
struct
vga16fb_par
*
)
info
->
par
;
struct
vga16fb_par
*
par
=
(
struct
vga16fb_par
*
)
info
->
par
;
u32
xres
,
right
,
hslen
,
left
,
xtotal
;
u32
xres
,
right
,
hslen
,
left
,
xtotal
;
u32
yres
,
lower
,
vslen
,
upper
,
ytotal
;
u32
yres
,
lower
,
vslen
,
upper
,
ytotal
;
...
@@ -368,20 +365,7 @@ static int vga16fb_check_var(struct fb_var_screeninfo *var,
...
@@ -368,20 +365,7 @@ static int vga16fb_check_var(struct fb_var_screeninfo *var,
mode
=
MODE_SKIP4
|
MODE_8BPP
|
MODE_CFB
;
mode
=
MODE_SKIP4
|
MODE_8BPP
|
MODE_CFB
;
maxmem
=
16384
;
maxmem
=
16384
;
}
}
}
}
else
#ifdef FBCON_HAS_VGA
else
if
(
var
->
bits_per_pixel
==
0
)
{
int
fh
;
shift
=
3
;
mode
=
MODE_TEXT
;
fh
=
fontheight
(
p
);
if
(
!
fh
)
fh
=
16
;
maxmem
=
32768
*
fh
;
}
#endif
else
return
-
EINVAL
;
return
-
EINVAL
;
xres
=
(
var
->
xres
+
7
)
&
~
7
;
xres
=
(
var
->
xres
+
7
)
&
~
7
;
...
@@ -548,42 +532,6 @@ static int vga16fb_check_var(struct fb_var_screeninfo *var,
...
@@ -548,42 +532,6 @@ static int vga16fb_check_var(struct fb_var_screeninfo *var,
}
}
#undef FAIL
#undef FAIL
#ifdef FBCON_HAS_VGA
static
void
vga16fb_load_font
(
struct
display
*
p
)
{
int
chars
;
unsigned
char
*
font
;
unsigned
char
*
dest
;
int
chars
;
if
(
!
p
||
!
p
->
fontdata
)
return
;
chars
=
256
;
font
=
p
->
fontdata
;
dest
=
vga16fb
.
screen_base
;
vga_io_wseq
(
0x00
,
0x01
);
vga_io_wseq
(
VGA_SEQ_PLANE_WRITE
,
0x04
);
vga_io_wseq
(
VGA_SEQ_MEMORY_MODE
,
0x07
);
vga_io_wseq
(
0x00
,
0x03
);
vga_io_wgfx
(
VGA_GFX_MODE
,
0x00
);
vga_io_wgfx
(
VGA_GFX_MISC
,
0x04
);
while
(
chars
--
)
{
int
i
;
for
(
i
=
fontheight
(
p
);
i
>
0
;
i
--
)
writeb
(
*
font
++
,
dest
++
);
dest
+=
32
-
fontheight
(
p
);
}
vga_io_wseq
(
0x00
,
0x01
);
vga_io_wseq
(
VGA_SEQ_PLANE_WRITE
,
0x03
);
vga_io_wseq
(
VGA_SEQ_MEMORY_MODE
,
0x03
);
vga_io_wseq
(
0x00
,
0x03
);
vga_io_wgfx
(
VGA_GFX_MODE
,
0x10
);
vga_io_wgfx
(
VGA_GFX_MISC
,
0x06
);
}
#endif
static
int
vga16fb_set_par
(
struct
fb_info
*
info
)
static
int
vga16fb_set_par
(
struct
fb_info
*
info
)
{
{
struct
vga16fb_par
*
par
=
(
struct
vga16fb_par
*
)
info
->
par
;
struct
vga16fb_par
*
par
=
(
struct
vga16fb_par
*
)
info
->
par
;
...
@@ -690,10 +638,6 @@ static int vga16fb_set_par(struct fb_info *info)
...
@@ -690,10 +638,6 @@ static int vga16fb_set_par(struct fb_info *info)
vga_io_wattr
(
i
,
atc
[
i
]);
vga_io_wattr
(
i
,
atc
[
i
]);
}
}
#ifdef FBCON_HAS_VGA
if
(
par
->
mode
&
MODE_TEXT
)
vga16fb_load_font
(
p
);
#endif
/* Wait for screen to stabilize. */
/* Wait for screen to stabilize. */
mdelay
(
50
);
mdelay
(
50
);
...
@@ -1051,10 +995,6 @@ void vga16fb_fillrect(struct fb_info *info, struct fb_fillrect *rect)
...
@@ -1051,10 +995,6 @@ void vga16fb_fillrect(struct fb_info *info, struct fb_fillrect *rect)
}
else
}
else
vga_8planes_fillrect
(
info
,
rect
);
vga_8planes_fillrect
(
info
,
rect
);
break
;
break
;
#ifdef FBCON_HAS_VGA
case
FB_TYPE_TEXT
:
break
;
#endif
case
FB_TYPE_PACKED_PIXELS
:
case
FB_TYPE_PACKED_PIXELS
:
default:
default:
cfb_fillrect
(
info
,
rect
);
cfb_fillrect
(
info
,
rect
);
...
@@ -1198,10 +1138,6 @@ void vga16fb_copyarea(struct fb_info *info, struct fb_copyarea *area)
...
@@ -1198,10 +1138,6 @@ void vga16fb_copyarea(struct fb_info *info, struct fb_copyarea *area)
}
else
}
else
vga_8planes_copyarea
(
info
,
area
);
vga_8planes_copyarea
(
info
,
area
);
break
;
break
;
#ifdef FBCON_HAS_VGA
case
FB_TYPE_TEXT
:
break
;
#endif
case
FB_TYPE_PACKED_PIXELS
:
case
FB_TYPE_PACKED_PIXELS
:
default:
default:
cfb_copyarea
(
info
,
area
);
cfb_copyarea
(
info
,
area
);
...
@@ -1313,10 +1249,6 @@ void vga_imageblit_expand(struct fb_info *info, struct fb_image *image)
...
@@ -1313,10 +1249,6 @@ void vga_imageblit_expand(struct fb_info *info, struct fb_image *image)
}
else
}
else
vga_8planes_imageblit
(
info
,
image
);
vga_8planes_imageblit
(
info
,
image
);
break
;
break
;
#ifdef FBCON_HAS_VGA
case
FB_TYPE_TEXT
:
break
;
#endif
case
FB_TYPE_PACKED_PIXELS
:
case
FB_TYPE_PACKED_PIXELS
:
default:
default:
cfb_imageblit
(
info
,
image
);
cfb_imageblit
(
info
,
image
);
...
...
include/video/radeon.h
View file @
903c38a4
#ifndef _RADEON_H
#ifndef _RADEON_H
#define _RADEON_H
#define _RADEON_H
#define RADEON_REGSIZE 0x4000
#define RADEON_REGSIZE 0x4000
#define MM_INDEX 0x0000
#define MM_INDEX 0x0000
#define MM_DATA 0x0004
#define MM_DATA 0x0004
#define BUS_CNTL 0x0030
#define BUS_CNTL 0x0030
...
@@ -62,6 +64,7 @@
...
@@ -62,6 +64,7 @@
#define AIC_TLB_ADDR 0x01E4
#define AIC_TLB_ADDR 0x01E4
#define AIC_TLB_DATA 0x01E8
#define AIC_TLB_DATA 0x01E8
#define DAC_CNTL 0x0058
#define DAC_CNTL 0x0058
#define DAC_CNTL2 0x007c
#define CRTC_GEN_CNTL 0x0050
#define CRTC_GEN_CNTL 0x0050
#define MEM_CNTL 0x0140
#define MEM_CNTL 0x0140
#define EXT_MEM_CNTL 0x0144
#define EXT_MEM_CNTL 0x0144
...
@@ -81,7 +84,9 @@
...
@@ -81,7 +84,9 @@
#define MEM_VGA_WP_SEL 0x0038
#define MEM_VGA_WP_SEL 0x0038
#define MEM_VGA_RP_SEL 0x003C
#define MEM_VGA_RP_SEL 0x003C
#define HDP_DEBUG 0x0138
#define HDP_DEBUG 0x0138
#define SW_SEMAPHORE 0x013C
#define SW_SEMAPHORE 0x013C
#define CRTC2_GEN_CNTL 0x03f8
#define CRTC2_DISPLAY_BASE_ADDR 0x033c
#define SURFACE_CNTL 0x0B00
#define SURFACE_CNTL 0x0B00
#define SURFACE0_LOWER_BOUND 0x0B04
#define SURFACE0_LOWER_BOUND 0x0B04
#define SURFACE1_LOWER_BOUND 0x0B14
#define SURFACE1_LOWER_BOUND 0x0B14
...
@@ -132,6 +137,7 @@
...
@@ -132,6 +137,7 @@
#define GPIO_VGA_DDC 0x0060
#define GPIO_VGA_DDC 0x0060
#define GPIO_DVI_DDC 0x0064
#define GPIO_DVI_DDC 0x0064
#define GPIO_MONID 0x0068
#define GPIO_MONID 0x0068
#define GPIO_CRT2_DDC 0x006c
#define PALETTE_INDEX 0x00B0
#define PALETTE_INDEX 0x00B0
#define PALETTE_DATA 0x00B4
#define PALETTE_DATA 0x00B4
#define PALETTE_30_DATA 0x00B8
#define PALETTE_30_DATA 0x00B8
...
@@ -174,8 +180,9 @@
...
@@ -174,8 +180,9 @@
#define FP_V_SYNC_STRT_WID 0x02C8
#define FP_V_SYNC_STRT_WID 0x02C8
#define AUX_WINDOW_HORZ_CNTL 0x02D8
#define AUX_WINDOW_HORZ_CNTL 0x02D8
#define AUX_WINDOW_VERT_CNTL 0x02DC
#define AUX_WINDOW_VERT_CNTL 0x02DC
#define DDA_CONFIG 0x02e0
//#define DDA_CONFIG 0x02e0
#define DDA_ON_OFF 0x02e4
//#define DDA_ON_OFF 0x02e4
#define DVI_I2C_CNTL_1 0x02e4
#define GRPH_BUFFER_CNTL 0x02F0
#define GRPH_BUFFER_CNTL 0x02F0
#define VGA_BUFFER_CNTL 0x02F4
#define VGA_BUFFER_CNTL 0x02F4
#define OV0_Y_X_START 0x0400
#define OV0_Y_X_START 0x0400
...
@@ -322,6 +329,7 @@
...
@@ -322,6 +329,7 @@
#define DST_Y_X 0x1438
#define DST_Y_X 0x1438
#define DST_WIDTH_HEIGHT 0x1598
#define DST_WIDTH_HEIGHT 0x1598
#define DST_HEIGHT_WIDTH 0x143c
#define DST_HEIGHT_WIDTH 0x143c
#define DST_OFFSET 0x1404
#define SRC_CLUT_ADDRESS 0x1780
#define SRC_CLUT_ADDRESS 0x1780
#define SRC_CLUT_DATA 0x1784
#define SRC_CLUT_DATA 0x1784
#define SRC_CLUT_DATA_RD 0x1788
#define SRC_CLUT_DATA_RD 0x1788
...
@@ -361,10 +369,12 @@
...
@@ -361,10 +369,12 @@
#define SC_TOP_LEFT 0x16EC
#define SC_TOP_LEFT 0x16EC
#define SC_BOTTOM_RIGHT 0x16F0
#define SC_BOTTOM_RIGHT 0x16F0
#define SRC_SC_BOTTOM_RIGHT 0x16F4
#define SRC_SC_BOTTOM_RIGHT 0x16F4
#define RB2D_DSTCACHE_MODE 0x3428
#define RB2D_DSTCACHE_CTLSTAT 0x342C
#define RB2D_DSTCACHE_CTLSTAT 0x342C
#define LVDS_GEN_CNTL 0x02d0
#define LVDS_GEN_CNTL 0x02d0
#define LVDS_PLL_CNTL 0x02d4
#define LVDS_PLL_CNTL 0x02d4
#define TMDS_CRC 0x02a0
#define TMDS_CRC 0x02a0
#define TMDS_TRANSMITTER_CNTL 0x02a4
#define RADEON_BASE_CODE 0x0f0b
#define RADEON_BASE_CODE 0x0f0b
#define RADEON_BIOS_0_SCRATCH 0x0010
#define RADEON_BIOS_0_SCRATCH 0x0010
...
@@ -376,7 +386,17 @@
...
@@ -376,7 +386,17 @@
#define RADEON_BIOS_6_SCRATCH 0x0028
#define RADEON_BIOS_6_SCRATCH 0x0028
#define RADEON_BIOS_7_SCRATCH 0x002c
#define RADEON_BIOS_7_SCRATCH 0x002c
#define TV_DAC_CNTL 0x088c
#define GPIOPAD_MASK 0x0198
#define GPIOPAD_A 0x019c
#define GPIOPAD_EN 0x01a0
#define GPIOPAD_Y 0x01a4
#define ZV_LCDPAD_MASK 0x01a8
#define ZV_LCDPAD_A 0x01ac
#define ZV_LCDPAD_EN 0x01b0
#define ZV_LCDPAD_Y 0x01b4
/* PLL Registers */
#define CLK_PIN_CNTL 0x0001
#define CLK_PIN_CNTL 0x0001
#define PPLL_CNTL 0x0002
#define PPLL_CNTL 0x0002
#define PPLL_REF_DIV 0x0003
#define PPLL_REF_DIV 0x0003
...
@@ -391,10 +411,17 @@
...
@@ -391,10 +411,17 @@
#define SPLL_CNTL 0x000c
#define SPLL_CNTL 0x000c
#define SCLK_CNTL 0x000d
#define SCLK_CNTL 0x000d
#define MPLL_CNTL 0x000e
#define MPLL_CNTL 0x000e
#define MDLL_CKO 0x000f
#define MDLL_RDCKA 0x0010
#define MCLK_CNTL 0x0012
#define MCLK_CNTL 0x0012
#define AGP_PLL_CNTL 0x000b
#define AGP_PLL_CNTL 0x000b
#define PLL_TEST_CNTL 0x0013
#define PLL_TEST_CNTL 0x0013
#define CLK_PWRMGT_CNTL 0x0014
#define PLL_PWRMGT_CNTL 0x0015
#define MCLK_MISC 0x001f
#define P2PLL_CNTL 0x002a
#define P2PLL_REF_DIV 0x002b
#define PIXCLKS_CNTL 0x002d
/* MCLK_CNTL bit constants */
/* MCLK_CNTL bit constants */
#define FORCEON_MCLKA (1 << 16)
#define FORCEON_MCLKA (1 << 16)
...
@@ -459,10 +486,17 @@
...
@@ -459,10 +486,17 @@
#define CRTC_INTERLACE_EN (1 << 1)
#define CRTC_INTERLACE_EN (1 << 1)
#define CRTC_EXT_DISP_EN (1 << 24)
#define CRTC_EXT_DISP_EN (1 << 24)
#define CRTC_EN (1 << 25)
#define CRTC_EN (1 << 25)
#define CRTC_DISP_REQ_EN_B (1 << 26)
/* CRTC_STATUS bit constants */
/* CRTC_STATUS bit constants */
#define CRTC_VBLANK 0x00000001
#define CRTC_VBLANK 0x00000001
/* CRTC2_GEN_CNTL bit constants */
#define CRT2_ON (1 << 7)
#define CRTC2_DISPLAY_DIS (1 << 23)
#define CRTC2_EN (1 << 25)
#define CRTC2_DISP_REQ_EN_B (1 << 26)
/* CUR_OFFSET, CUR_HORZ_VERT_POSN, CUR_HORZ_VERT_OFF bit constants */
/* CUR_OFFSET, CUR_HORZ_VERT_POSN, CUR_HORZ_VERT_OFF bit constants */
#define CUR_LOCK 0x80000000
#define CUR_LOCK 0x80000000
...
@@ -508,14 +542,26 @@
...
@@ -508,14 +542,26 @@
#define LVDS_PANEL_TYPE (1 << 2)
#define LVDS_PANEL_TYPE (1 << 2)
#define LVDS_PANEL_FORMAT (1 << 3)
#define LVDS_PANEL_FORMAT (1 << 3)
#define LVDS_EN (1 << 7)
#define LVDS_EN (1 << 7)
#define LVDS_BL_MOD_LEVEL_MASK 0x0000ff00
#define LVDS_BL_MOD_LEVEL_SHIFT 8
#define LVDS_BL_MOD_EN (1 << 16)
#define LVDS_DIGON (1 << 18)
#define LVDS_DIGON (1 << 18)
#define LVDS_BLON (1 << 19)
#define LVDS_BLON (1 << 19)
#define LVDS_SEL_CRTC2 (1 << 23)
#define LVDS_SEL_CRTC2 (1 << 23)
#define LVDS_STATE_MASK \
(LVDS_ON | LVDS_DISPLAY_DIS | LVDS_BL_MOD_LEVEL_MASK | \
LVDS_EN | LVDS_DIGON | LVDS_BLON)
/* LVDS_PLL_CNTL bit constatns */
/* LVDS_PLL_CNTL bit constatns */
#define HSYNC_DELAY_SHIFT 0x1c
#define HSYNC_DELAY_SHIFT 0x1c
#define HSYNC_DELAY_MASK (0xf << 0x1c)
#define HSYNC_DELAY_MASK (0xf << 0x1c)
/* TMDS_TRANSMITTER_CNTL bit constants */
#define TMDS_PLL_EN (1 << 0)
#define TMDS_PLLRST (1 << 1)
#define TMDS_RAN_PAT_RST (1 << 7)
#define ICHCSEL (1 << 28)
/* FP_HORZ_STRETCH bit constants */
/* FP_HORZ_STRETCH bit constants */
#define HORZ_STRETCH_RATIO_MASK 0xffff
#define HORZ_STRETCH_RATIO_MASK 0xffff
#define HORZ_STRETCH_RATIO_MAX 4096
#define HORZ_STRETCH_RATIO_MAX 4096
...
@@ -546,9 +592,14 @@
...
@@ -546,9 +592,14 @@
#define DAC_4BPP_PIX_ORDER 0x00000200
#define DAC_4BPP_PIX_ORDER 0x00000200
#define DAC_CRC_EN 0x00080000
#define DAC_CRC_EN 0x00080000
#define DAC_MASK_ALL (0xff << 24)
#define DAC_MASK_ALL (0xff << 24)
#define DAC_EXPAND_MODE (1 << 14)
#define DAC_VGA_ADR_EN (1 << 13)
#define DAC_VGA_ADR_EN (1 << 13)
#define DAC_RANGE_CNTL (3 << 0)
#define DAC_RANGE_CNTL (3 << 0)
#define DAC_BLANKING (1 << 2)
#define DAC_BLANKING (1 << 2)
#define DAC_CMP_EN (1 << 3)
/* DAC_CNTL2 bit constants */
#define DAC2_CMP_EN (1 << 7)
/* GEN_RESET_CNTL bit constants */
/* GEN_RESET_CNTL bit constants */
#define SOFT_RESET_GUI 0x00000001
#define SOFT_RESET_GUI 0x00000001
...
@@ -582,6 +633,8 @@
...
@@ -582,6 +633,8 @@
#define SURF_TRANSLATION_DIS (1 << 8)
#define SURF_TRANSLATION_DIS (1 << 8)
#define NONSURF_AP0_SWP_16BPP (1 << 20)
#define NONSURF_AP0_SWP_16BPP (1 << 20)
#define NONSURF_AP0_SWP_32BPP (1 << 21)
#define NONSURF_AP0_SWP_32BPP (1 << 21)
#define NONSURF_AP1_SWP_16BPP (1 << 22)
#define NONSURF_AP1_SWP_32BPP (1 << 23)
/* DEFAULT_SC_BOTTOM_RIGHT bit constants */
/* DEFAULT_SC_BOTTOM_RIGHT bit constants */
#define DEFAULT_SC_RIGHT_MAX (0x1fff << 0)
#define DEFAULT_SC_RIGHT_MAX (0x1fff << 0)
...
@@ -727,6 +780,78 @@
...
@@ -727,6 +780,78 @@
#define DP_SRC_HOST 0x00000300
#define DP_SRC_HOST 0x00000300
#define DP_SRC_HOST_BYTEALIGN 0x00000400
#define DP_SRC_HOST_BYTEALIGN 0x00000400
/* MPLL_CNTL bit constants */
#define MPLL_RESET 0x00000001
/* MDLL_CKO bit constants */
#define MCKOA_SLEEP 0x00000001
#define MCKOA_RESET 0x00000002
#define MCKOA_REF_SKEW_MASK 0x00000700
#define MCKOA_FB_SKEW_MASK 0x00007000
/* MDLL_RDCKA bit constants */
#define MRDCKA0_SLEEP 0x00000001
#define MRDCKA0_RESET 0x00000002
#define MRDCKA1_SLEEP 0x00010000
#define MRDCKA1_RESET 0x00020000
/* VCLK_ECP_CNTL constants */
#define PIXCLK_ALWAYS_ONb 0x00000040
#define PIXCLK_DAC_ALWAYS_ONb 0x00000080
/* BUS_CNTL1 constants */
#define BUS_CNTL1_MOBILE_PLATFORM_SEL_MASK 0x0c000000
#define BUS_CNTL1_MOBILE_PLATFORM_SEL_SHIFT 26
#define BUS_CNTL1_AGPCLK_VALID 0x80000000
/* PLL_PWRMGT_CNTL constants */
#define PLL_PWRMGT_CNTL_SPLL_TURNOFF 0x00000002
#define PLL_PWRMGT_CNTL_PPLL_TURNOFF 0x00000004
#define PLL_PWRMGT_CNTL_P2PLL_TURNOFF 0x00000008
#define PLL_PWRMGT_CNTL_TVPLL_TURNOFF 0x00000010
#define PLL_PWRMGT_CNTL_MOBILE_SU 0x00010000
#define PLL_PWRMGT_CNTL_SU_SCLK_USE_BCLK 0x00020000
#define PLL_PWRMGT_CNTL_SU_MCLK_USE_BCLK 0x00040000
/* TV_DAC_CNTL constants */
#define TV_DAC_CNTL_BGSLEEP 0x00000040
#define TV_DAC_CNTL_DETECT 0x00000010
#define TV_DAC_CNTL_BGADJ_MASK 0x000f0000
#define TV_DAC_CNTL_DACADJ_MASK 0x00f00000
#define TV_DAC_CNTL_BGADJ__SHIFT 16
#define TV_DAC_CNTL_DACADJ__SHIFT 20
#define TV_DAC_CNTL_RDACPD 0x01000000
#define TV_DAC_CNTL_GDACPD 0x02000000
#define TV_DAC_CNTL_BDACPD 0x04000000
/* DISP_MISC_CNTL constants */
#define DISP_MISC_CNTL_SOFT_RESET_GRPH_PP (1 << 0)
#define DISP_MISC_CNTL_SOFT_RESET_SUBPIC_PP (1 << 1)
#define DISP_MISC_CNTL_SOFT_RESET_OV0_PP (1 << 2)
#define DISP_MISC_CNTL_SOFT_RESET_GRPH_SCLK (1 << 4)
#define DISP_MISC_CNTL_SOFT_RESET_SUBPIC_SCLK (1 << 5)
#define DISP_MISC_CNTL_SOFT_RESET_OV0_SCLK (1 << 6)
#define DISP_MISC_CNTL_SOFT_RESET_GRPH2_PP (1 << 12)
#define DISP_MISC_CNTL_SOFT_RESET_GRPH2_SCLK (1 << 15)
#define DISP_MISC_CNTL_SOFT_RESET_LVDS (1 << 16)
#define DISP_MISC_CNTL_SOFT_RESET_TMDS (1 << 17)
#define DISP_MISC_CNTL_SOFT_RESET_DIG_TMDS (1 << 18)
#define DISP_MISC_CNTL_SOFT_RESET_TV (1 << 19)
/* DISP_PWR_MAN constants */
#define DISP_PWR_MAN_DISP_PWR_MAN_D3_CRTC_EN (1 << 0)
#define DISP_PWR_MAN_DISP2_PWR_MAN_D3_CRTC2_EN (1 << 4)
#define DISP_PWR_MAN_DISP_D3_RST (1 << 16)
#define DISP_PWR_MAN_DISP_D3_REG_RST (1 << 17)
#define DISP_PWR_MAN_DISP_D3_GRPH_RST (1 << 18)
#define DISP_PWR_MAN_DISP_D3_SUBPIC_RST (1 << 19)
#define DISP_PWR_MAN_DISP_D3_OV0_RST (1 << 20)
#define DISP_PWR_MAN_DISP_D1D2_GRPH_RST (1 << 21)
#define DISP_PWR_MAN_DISP_D1D2_SUBPIC_RST (1 << 22)
#define DISP_PWR_MAN_DISP_D1D2_OV0_RST (1 << 23)
#define DISP_PWR_MAN_DIG_TMDS_ENABLE_RST (1 << 24)
#define DISP_PWR_MAN_TV_ENABLE_RST (1 << 25)
#define DISP_PWR_MAN_AUTO_PWRUP_EN (1 << 26)
/* masks */
/* masks */
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment