2008-10-16 09:03:23 +04:00
/*
* Copyright 1998 - 2008 VIA Technologies , Inc . All Rights Reserved .
* Copyright 2001 - 2008 S3 Graphics , Inc . All Rights Reserved .
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public
* License as published by the Free Software Foundation ;
* either version 2 , or ( at your option ) any later version .
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTIES OR REPRESENTATIONS ; without even
* the implied warranty of MERCHANTABILITY or FITNESS FOR
* A PARTICULAR PURPOSE . See the GNU General Public License
* for more details .
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . ,
* 59 Temple Place - Suite 330 , Boston , MA 02111 - 1307 , USA .
*/
2010-05-06 00:44:55 +04:00
# include <linux/via-core.h>
# include <linux/via_i2c.h>
2008-10-16 09:03:23 +04:00
# include "global.h"
static void tmds_register_write ( int index , u8 data ) ;
static int tmds_register_read ( int index ) ;
static int tmds_register_read_bytes ( int index , u8 * buff , int buff_len ) ;
2010-03-11 02:21:30 +03:00
static void dvi_get_panel_size_from_DDCv1 ( struct tmds_chip_information
* tmds_chip , struct tmds_setting_information * tmds_setting ) ;
static void dvi_get_panel_size_from_DDCv2 ( struct tmds_chip_information
* tmds_chip , struct tmds_setting_information * tmds_setting ) ;
2008-10-16 09:03:23 +04:00
static int viafb_dvi_query_EDID ( void ) ;
static int check_tmds_chip ( int device_id_subaddr , int device_id )
{
if ( tmds_register_read ( device_id_subaddr ) = = device_id )
return OK ;
else
return FAIL ;
}
2010-03-11 02:21:30 +03:00
void viafb_init_dvi_size ( struct tmds_chip_information * tmds_chip ,
struct tmds_setting_information * tmds_setting )
2008-10-16 09:03:23 +04:00
{
DEBUG_MSG ( KERN_INFO " viafb_init_dvi_size() \n " ) ;
2010-03-11 02:21:30 +03:00
viafb_dvi_sense ( ) ;
switch ( viafb_dvi_query_EDID ( ) ) {
case 1 :
dvi_get_panel_size_from_DDCv1 ( tmds_chip , tmds_setting ) ;
2008-10-16 09:03:23 +04:00
break ;
2010-03-11 02:21:30 +03:00
case 2 :
dvi_get_panel_size_from_DDCv2 ( tmds_chip , tmds_setting ) ;
2008-10-16 09:03:23 +04:00
break ;
default :
2010-03-11 02:21:30 +03:00
printk ( KERN_WARNING " viafb_init_dvi_size: DVI panel size undetected! \n " ) ;
2008-10-16 09:03:23 +04:00
break ;
}
2010-03-11 02:21:30 +03:00
2008-10-16 09:03:23 +04:00
return ;
}
int viafb_tmds_trasmitter_identify ( void )
{
unsigned char sr2a = 0 , sr1e = 0 , sr3e = 0 ;
/* Turn on ouputting pad */
switch ( viaparinfo - > chip_info - > gfx_chip_name ) {
case UNICHROME_K8M890 :
/*=* DFP Low Pad on *=*/
sr2a = viafb_read_reg ( VIASR , SR2A ) ;
viafb_write_reg_mask ( SR2A , VIASR , 0x03 , BIT0 + BIT1 ) ;
break ;
case UNICHROME_P4M900 :
case UNICHROME_P4M890 :
/* DFP Low Pad on */
sr2a = viafb_read_reg ( VIASR , SR2A ) ;
viafb_write_reg_mask ( SR2A , VIASR , 0x03 , BIT0 + BIT1 ) ;
/* DVP0 Pad on */
sr1e = viafb_read_reg ( VIASR , SR1E ) ;
viafb_write_reg_mask ( SR1E , VIASR , 0xC0 , BIT6 + BIT7 ) ;
break ;
default :
/* DVP0/DVP1 Pad on */
sr1e = viafb_read_reg ( VIASR , SR1E ) ;
viafb_write_reg_mask ( SR1E , VIASR , 0xF0 , BIT4 +
BIT5 + BIT6 + BIT7 ) ;
/* SR3E[1]Multi-function selection:
0 = Emulate I2C and DDC bus by GPIO2 / 3 / 4. */
sr3e = viafb_read_reg ( VIASR , SR3E ) ;
viafb_write_reg_mask ( SR3E , VIASR , 0x0 , BIT5 ) ;
break ;
}
/* Check for VT1632: */
viaparinfo - > chip_info - > tmds_chip_info . tmds_chip_name = VT1632_TMDS ;
viaparinfo - > chip_info - >
tmds_chip_info . tmds_chip_slave_addr = VT1632_TMDS_I2C_ADDR ;
2009-12-02 06:29:39 +03:00
viaparinfo - > chip_info - > tmds_chip_info . i2c_port = VIA_PORT_31 ;
2008-10-16 09:03:23 +04:00
if ( check_tmds_chip ( VT1632_DEVICE_ID_REG , VT1632_DEVICE_ID ) ! = FAIL ) {
/*
* Currently only support 12 bits , dual edge , add 24 bits mode later
*/
tmds_register_write ( 0x08 , 0x3b ) ;
DEBUG_MSG ( KERN_INFO " \n VT1632 TMDS ! \n " ) ;
DEBUG_MSG ( KERN_INFO " \n %2d " ,
viaparinfo - > chip_info - > tmds_chip_info . tmds_chip_name ) ;
DEBUG_MSG ( KERN_INFO " \n %2d " ,
viaparinfo - > chip_info - > tmds_chip_info . i2c_port ) ;
return OK ;
} else {
2009-12-02 06:29:39 +03:00
viaparinfo - > chip_info - > tmds_chip_info . i2c_port = VIA_PORT_2C ;
2008-10-16 09:03:23 +04:00
if ( check_tmds_chip ( VT1632_DEVICE_ID_REG , VT1632_DEVICE_ID )
! = FAIL ) {
tmds_register_write ( 0x08 , 0x3b ) ;
DEBUG_MSG ( KERN_INFO " \n VT1632 TMDS ! \n " ) ;
DEBUG_MSG ( KERN_INFO " \n %2d " ,
viaparinfo - > chip_info - >
tmds_chip_info . tmds_chip_name ) ;
DEBUG_MSG ( KERN_INFO " \n %2d " ,
viaparinfo - > chip_info - >
tmds_chip_info . i2c_port ) ;
return OK ;
}
}
viaparinfo - > chip_info - > tmds_chip_info . tmds_chip_name = INTEGRATED_TMDS ;
if ( ( viaparinfo - > chip_info - > gfx_chip_name = = UNICHROME_CX700 ) & &
( ( viafb_display_hardware_layout = = HW_LAYOUT_DVI_ONLY ) | |
( viafb_display_hardware_layout = = HW_LAYOUT_LCD_DVI ) ) ) {
DEBUG_MSG ( KERN_INFO " \n Integrated TMDS ! \n " ) ;
return OK ;
}
switch ( viaparinfo - > chip_info - > gfx_chip_name ) {
case UNICHROME_K8M890 :
viafb_write_reg ( SR2A , VIASR , sr2a ) ;
break ;
case UNICHROME_P4M900 :
case UNICHROME_P4M890 :
viafb_write_reg ( SR2A , VIASR , sr2a ) ;
viafb_write_reg ( SR1E , VIASR , sr1e ) ;
break ;
default :
viafb_write_reg ( SR1E , VIASR , sr1e ) ;
viafb_write_reg ( SR3E , VIASR , sr3e ) ;
break ;
}
viaparinfo - > chip_info - >
tmds_chip_info . tmds_chip_name = NON_TMDS_TRANSMITTER ;
viaparinfo - > chip_info - > tmds_chip_info .
tmds_chip_slave_addr = VT1632_TMDS_I2C_ADDR ;
return FAIL ;
}
static void tmds_register_write ( int index , u8 data )
{
2009-05-22 20:35:39 +04:00
viafb_i2c_writebyte ( viaparinfo - > chip_info - > tmds_chip_info . i2c_port ,
viaparinfo - > chip_info - > tmds_chip_info . tmds_chip_slave_addr ,
index , data ) ;
2008-10-16 09:03:23 +04:00
}
static int tmds_register_read ( int index )
{
u8 data ;
2009-05-22 20:35:39 +04:00
viafb_i2c_readbyte ( viaparinfo - > chip_info - > tmds_chip_info . i2c_port ,
( u8 ) viaparinfo - > chip_info - > tmds_chip_info . tmds_chip_slave_addr ,
( u8 ) index , & data ) ;
2008-10-16 09:03:23 +04:00
return data ;
}
static int tmds_register_read_bytes ( int index , u8 * buff , int buff_len )
{
2009-05-22 20:35:39 +04:00
viafb_i2c_readbytes ( viaparinfo - > chip_info - > tmds_chip_info . i2c_port ,
( u8 ) viaparinfo - > chip_info - > tmds_chip_info . tmds_chip_slave_addr ,
( u8 ) index , buff , buff_len ) ;
2008-10-16 09:03:23 +04:00
return 0 ;
}
/* DVI Set Mode */
2010-03-11 02:21:28 +03:00
void viafb_dvi_set_mode ( struct VideoModeTable * mode , int mode_bpp ,
int set_iga )
2008-10-16 09:03:23 +04:00
{
2010-03-11 02:21:28 +03:00
struct VideoModeTable * rb_mode ;
2008-10-16 09:03:23 +04:00
struct crt_mode_table * pDviTiming ;
unsigned long desirePixelClock , maxPixelClock ;
2010-03-11 02:21:28 +03:00
pDviTiming = mode - > crtc ;
2008-10-16 09:03:23 +04:00
desirePixelClock = pDviTiming - > clk / 1000000 ;
maxPixelClock = ( unsigned long ) viaparinfo - >
tmds_setting_info - > max_pixel_clock ;
DEBUG_MSG ( KERN_INFO " \n DVI_set_mode!! \n " ) ;
if ( ( maxPixelClock ! = 0 ) & & ( desirePixelClock > maxPixelClock ) ) {
2010-03-11 02:21:28 +03:00
rb_mode = viafb_get_rb_mode ( mode - > crtc [ 0 ] . crtc . hor_addr ,
mode - > crtc [ 0 ] . crtc . ver_addr ) ;
if ( rb_mode ) {
mode = rb_mode ;
pDviTiming = rb_mode - > crtc ;
2008-10-16 09:03:23 +04:00
}
}
2010-03-11 02:21:28 +03:00
viafb_fill_crtc_timing ( pDviTiming , mode , mode_bpp / 8 , set_iga ) ;
2008-10-16 09:03:23 +04:00
viafb_set_output_path ( DEVICE_DVI , set_iga ,
viaparinfo - > chip_info - > tmds_chip_info . output_interface ) ;
}
/* Sense DVI Connector */
int viafb_dvi_sense ( void )
{
u8 RegSR1E = 0 , RegSR3E = 0 , RegCR6B = 0 , RegCR91 = 0 ,
RegCR93 = 0 , RegCR9B = 0 , data ;
int ret = false ;
DEBUG_MSG ( KERN_INFO " viafb_dvi_sense!! \n " ) ;
if ( viaparinfo - > chip_info - > gfx_chip_name = = UNICHROME_CLE266 ) {
/* DI1 Pad on */
RegSR1E = viafb_read_reg ( VIASR , SR1E ) ;
viafb_write_reg ( SR1E , VIASR , RegSR1E | 0x30 ) ;
/* CR6B[0]VCK Input Selection: 1 = External clock. */
RegCR6B = viafb_read_reg ( VIACR , CR6B ) ;
viafb_write_reg ( CR6B , VIACR , RegCR6B | 0x08 ) ;
/* CR91[4] VDD On [3] Data On [2] VEE On [1] Back Light Off
[ 0 ] Software Control Power Sequence */
RegCR91 = viafb_read_reg ( VIACR , CR91 ) ;
viafb_write_reg ( CR91 , VIACR , 0x1D ) ;
/* CR93[7] DI1 Data Source Selection: 1 = DSP2.
CR93 [ 5 ] DI1 Clock Source : 1 = internal .
CR93 [ 4 ] DI1 Clock Polarity .
CR93 [ 3 : 1 ] DI1 Clock Adjust . CR93 [ 0 ] DI1 enable */
RegCR93 = viafb_read_reg ( VIACR , CR93 ) ;
viafb_write_reg ( CR93 , VIACR , 0x01 ) ;
} else {
/* DVP0/DVP1 Pad on */
RegSR1E = viafb_read_reg ( VIASR , SR1E ) ;
viafb_write_reg ( SR1E , VIASR , RegSR1E | 0xF0 ) ;
/* SR3E[1]Multi-function selection:
0 = Emulate I2C and DDC bus by GPIO2 / 3 / 4. */
RegSR3E = viafb_read_reg ( VIASR , SR3E ) ;
viafb_write_reg ( SR3E , VIASR , RegSR3E & ( ~ 0x20 ) ) ;
/* CR91[4] VDD On [3] Data On [2] VEE On [1] Back Light Off
[ 0 ] Software Control Power Sequence */
RegCR91 = viafb_read_reg ( VIACR , CR91 ) ;
viafb_write_reg ( CR91 , VIACR , 0x1D ) ;
/*CR9B[4] DVP1 Data Source Selection: 1 = From secondary
display . CR9B [ 2 : 0 ] DVP1 Clock Adjust */
RegCR9B = viafb_read_reg ( VIACR , CR9B ) ;
viafb_write_reg ( CR9B , VIACR , 0x01 ) ;
}
data = ( u8 ) tmds_register_read ( 0x09 ) ;
if ( data & 0x04 )
ret = true ;
if ( ret = = false ) {
if ( viafb_dvi_query_EDID ( ) )
ret = true ;
}
/* Restore status */
viafb_write_reg ( SR1E , VIASR , RegSR1E ) ;
viafb_write_reg ( CR91 , VIACR , RegCR91 ) ;
if ( viaparinfo - > chip_info - > gfx_chip_name = = UNICHROME_CLE266 ) {
viafb_write_reg ( CR6B , VIACR , RegCR6B ) ;
viafb_write_reg ( CR93 , VIACR , RegCR93 ) ;
} else {
viafb_write_reg ( SR3E , VIASR , RegSR3E ) ;
viafb_write_reg ( CR9B , VIACR , RegCR9B ) ;
}
return ret ;
}
/* Query Flat Panel's EDID Table Version Through DVI Connector */
static int viafb_dvi_query_EDID ( void )
{
u8 data0 , data1 ;
int restore ;
DEBUG_MSG ( KERN_INFO " viafb_dvi_query_EDID!! \n " ) ;
restore = viaparinfo - > chip_info - > tmds_chip_info . tmds_chip_slave_addr ;
viaparinfo - > chip_info - > tmds_chip_info . tmds_chip_slave_addr = 0xA0 ;
data0 = ( u8 ) tmds_register_read ( 0x00 ) ;
data1 = ( u8 ) tmds_register_read ( 0x01 ) ;
if ( ( data0 = = 0 ) & & ( data1 = = 0xFF ) ) {
viaparinfo - > chip_info - >
tmds_chip_info . tmds_chip_slave_addr = restore ;
return EDID_VERSION_1 ; /* Found EDID1 Table */
}
data0 = ( u8 ) tmds_register_read ( 0x00 ) ;
viaparinfo - > chip_info - > tmds_chip_info . tmds_chip_slave_addr = restore ;
if ( data0 = = 0x20 )
return EDID_VERSION_2 ; /* Found EDID2 Table */
else
return false ;
}
2010-03-11 02:21:30 +03:00
/* Get Panel Size Using EDID1 Table */
static void dvi_get_panel_size_from_DDCv1 ( struct tmds_chip_information
* tmds_chip , struct tmds_setting_information * tmds_setting )
2008-10-16 09:03:23 +04:00
{
2010-03-11 02:21:29 +03:00
int i , max_h = 0 , tmp , restore ;
2008-10-16 09:03:23 +04:00
unsigned char rData ;
unsigned char EDID_DATA [ 18 ] ;
DEBUG_MSG ( KERN_INFO " \n dvi_get_panel_size_from_DDCv1 \n " ) ;
2010-03-11 02:21:30 +03:00
restore = tmds_chip - > tmds_chip_slave_addr ;
tmds_chip - > tmds_chip_slave_addr = 0xA0 ;
2008-10-16 09:03:23 +04:00
rData = tmds_register_read ( 0x23 ) ;
if ( rData & 0x3C )
max_h = 640 ;
if ( rData & 0xC0 )
max_h = 720 ;
if ( rData & 0x03 )
max_h = 800 ;
rData = tmds_register_read ( 0x24 ) ;
if ( rData & 0xC0 )
max_h = 800 ;
if ( rData & 0x1E )
max_h = 1024 ;
if ( rData & 0x01 )
max_h = 1280 ;
for ( i = 0x25 ; i < 0x6D ; i + + ) {
switch ( i ) {
case 0x26 :
case 0x28 :
case 0x2A :
case 0x2C :
case 0x2E :
case 0x30 :
case 0x32 :
case 0x34 :
rData = tmds_register_read ( i ) ;
if ( rData = = 1 )
break ;
/* data = (data + 31) * 8 */
tmp = ( rData + 31 ) < < 3 ;
if ( tmp > max_h )
max_h = tmp ;
break ;
case 0x36 :
case 0x48 :
case 0x5A :
case 0x6C :
tmds_register_read_bytes ( i , EDID_DATA , 10 ) ;
if ( ! ( EDID_DATA [ 0 ] | | EDID_DATA [ 1 ] ) ) {
/* The first two byte must be zero. */
if ( EDID_DATA [ 3 ] = = 0xFD ) {
/* To get max pixel clock. */
2010-03-11 02:21:30 +03:00
tmds_setting - > max_pixel_clock =
EDID_DATA [ 9 ] * 10 ;
2008-10-16 09:03:23 +04:00
}
}
break ;
default :
break ;
}
}
2010-03-11 02:21:30 +03:00
tmds_setting - > max_hres = max_h ;
2008-10-16 09:03:23 +04:00
switch ( max_h ) {
case 640 :
2010-03-11 02:21:30 +03:00
tmds_setting - > max_vres = 480 ;
2008-10-16 09:03:23 +04:00
break ;
case 800 :
2010-03-11 02:21:30 +03:00
tmds_setting - > max_vres = 600 ;
2008-10-16 09:03:23 +04:00
break ;
case 1024 :
2010-03-11 02:21:30 +03:00
tmds_setting - > max_vres = 768 ;
2008-10-16 09:03:23 +04:00
break ;
case 1280 :
2010-03-11 02:21:30 +03:00
tmds_setting - > max_vres = 1024 ;
2008-10-16 09:03:23 +04:00
break ;
case 1400 :
2010-03-11 02:21:30 +03:00
tmds_setting - > max_vres = 1050 ;
2008-10-16 09:03:23 +04:00
break ;
case 1440 :
2010-03-11 02:21:30 +03:00
tmds_setting - > max_vres = 1050 ;
2008-10-16 09:03:23 +04:00
break ;
case 1600 :
2010-03-11 02:21:30 +03:00
tmds_setting - > max_vres = 1200 ;
2008-10-16 09:03:23 +04:00
break ;
case 1920 :
2010-03-11 02:21:30 +03:00
tmds_setting - > max_vres = 1080 ;
2008-10-16 09:03:23 +04:00
break ;
default :
2010-03-11 02:21:48 +03:00
DEBUG_MSG ( KERN_INFO " Unknown panel size max resolution = %d ! "
" set default panel size. \n " , max_h ) ;
2008-10-16 09:03:23 +04:00
break ;
}
DEBUG_MSG ( KERN_INFO " DVI max pixelclock = %d \n " ,
2010-03-11 02:21:30 +03:00
tmds_setting - > max_pixel_clock ) ;
tmds_chip - > tmds_chip_slave_addr = restore ;
2008-10-16 09:03:23 +04:00
}
2010-03-11 02:21:30 +03:00
/* Get Panel Size Using EDID2 Table */
static void dvi_get_panel_size_from_DDCv2 ( struct tmds_chip_information
* tmds_chip , struct tmds_setting_information * tmds_setting )
2008-10-16 09:03:23 +04:00
{
2010-03-11 02:21:30 +03:00
int restore ;
2008-10-16 09:03:23 +04:00
unsigned char R_Buffer [ 2 ] ;
DEBUG_MSG ( KERN_INFO " \n dvi_get_panel_size_from_DDCv2 \n " ) ;
2010-03-11 02:21:30 +03:00
restore = tmds_chip - > tmds_chip_slave_addr ;
tmds_chip - > tmds_chip_slave_addr = 0xA2 ;
2008-10-16 09:03:23 +04:00
/* Horizontal: 0x76, 0x77 */
tmds_register_read_bytes ( 0x76 , R_Buffer , 2 ) ;
2010-03-11 02:21:30 +03:00
tmds_setting - > max_hres = R_Buffer [ 0 ] + ( R_Buffer [ 1 ] < < 8 ) ;
2008-10-16 09:03:23 +04:00
2010-03-11 02:21:30 +03:00
switch ( tmds_setting - > max_hres ) {
2008-10-16 09:03:23 +04:00
case 640 :
2010-03-11 02:21:30 +03:00
tmds_setting - > max_vres = 480 ;
2008-10-16 09:03:23 +04:00
break ;
case 800 :
2010-03-11 02:21:30 +03:00
tmds_setting - > max_vres = 600 ;
2008-10-16 09:03:23 +04:00
break ;
case 1024 :
2010-03-11 02:21:30 +03:00
tmds_setting - > max_vres = 768 ;
2008-10-16 09:03:23 +04:00
break ;
case 1280 :
2010-03-11 02:21:30 +03:00
tmds_setting - > max_vres = 1024 ;
2008-10-16 09:03:23 +04:00
break ;
case 1400 :
2010-03-11 02:21:30 +03:00
tmds_setting - > max_vres = 1050 ;
2008-10-16 09:03:23 +04:00
break ;
case 1440 :
2010-03-11 02:21:30 +03:00
tmds_setting - > max_vres = 1050 ;
2008-10-16 09:03:23 +04:00
break ;
case 1600 :
2010-03-11 02:21:30 +03:00
tmds_setting - > max_vres = 1200 ;
2008-10-16 09:03:23 +04:00
break ;
default :
2010-03-11 02:21:48 +03:00
DEBUG_MSG ( KERN_INFO " Unknown panel size max resolution = %d! "
" set default panel size. \n " , tmds_setting - > max_hres ) ;
2008-10-16 09:03:23 +04:00
break ;
}
2010-03-11 02:21:30 +03:00
tmds_chip - > tmds_chip_slave_addr = restore ;
2008-10-16 09:03:23 +04:00
}
/* If Disable DVI, turn off pad */
void viafb_dvi_disable ( void )
{
if ( viaparinfo - > chip_info - >
tmds_chip_info . output_interface = = INTERFACE_DVP0 )
viafb_write_reg ( SR1E , VIASR ,
viafb_read_reg ( VIASR , SR1E ) & ( ~ 0xC0 ) ) ;
if ( viaparinfo - > chip_info - >
tmds_chip_info . output_interface = = INTERFACE_DVP1 )
viafb_write_reg ( SR1E , VIASR ,
viafb_read_reg ( VIASR , SR1E ) & ( ~ 0x30 ) ) ;
if ( viaparinfo - > chip_info - >
tmds_chip_info . output_interface = = INTERFACE_DFP_HIGH )
viafb_write_reg ( SR2A , VIASR ,
viafb_read_reg ( VIASR , SR2A ) & ( ~ 0x0C ) ) ;
if ( viaparinfo - > chip_info - >
tmds_chip_info . output_interface = = INTERFACE_DFP_LOW )
viafb_write_reg ( SR2A , VIASR ,
viafb_read_reg ( VIASR , SR2A ) & ( ~ 0x03 ) ) ;
if ( viaparinfo - > chip_info - >
tmds_chip_info . output_interface = = INTERFACE_TMDS )
/* Turn off TMDS power. */
viafb_write_reg ( CRD2 , VIACR ,
viafb_read_reg ( VIACR , CRD2 ) | 0x08 ) ;
}
/* If Enable DVI, turn off pad */
void viafb_dvi_enable ( void )
{
u8 data ;
if ( viaparinfo - > chip_info - >
tmds_chip_info . output_interface = = INTERFACE_DVP0 ) {
viafb_write_reg ( SR1E , VIASR ,
viafb_read_reg ( VIASR , SR1E ) | 0xC0 ) ;
if ( viaparinfo - > chip_info - > gfx_chip_name = = UNICHROME_CLE266 )
tmds_register_write ( 0x88 , 0x3b ) ;
else
/*clear CR91[5] to direct on display period
in the secondary diplay path */
viafb_write_reg ( CR91 , VIACR ,
viafb_read_reg ( VIACR , CR91 ) & 0xDF ) ;
}
if ( viaparinfo - > chip_info - >
tmds_chip_info . output_interface = = INTERFACE_DVP1 ) {
viafb_write_reg ( SR1E , VIASR ,
viafb_read_reg ( VIASR , SR1E ) | 0x30 ) ;
/*fix dvi cann't be enabled with MB VT5718C4 - Al Zhang */
if ( viaparinfo - > chip_info - > gfx_chip_name = = UNICHROME_CLE266 ) {
tmds_register_write ( 0x88 , 0x3b ) ;
} else {
/*clear CR91[5] to direct on display period
in the secondary diplay path */
viafb_write_reg ( CR91 , VIACR ,
viafb_read_reg ( VIACR , CR91 ) & 0xDF ) ;
}
/*fix DVI cannot enable on EPIA-M board */
if ( viafb_platform_epia_dvi = = 1 ) {
viafb_write_reg_mask ( CR91 , VIACR , 0x1f , 0x1f ) ;
viafb_write_reg_mask ( CR88 , VIACR , 0x00 , BIT6 + BIT0 ) ;
if ( viafb_bus_width = = 24 ) {
if ( viafb_device_lcd_dualedge = = 1 )
data = 0x3F ;
else
data = 0x37 ;
viafb_i2c_writebyte ( viaparinfo - > chip_info - >
2009-05-22 20:35:39 +04:00
tmds_chip_info . i2c_port ,
viaparinfo - > chip_info - >
tmds_chip_info . tmds_chip_slave_addr ,
0x08 , data ) ;
2008-10-16 09:03:23 +04:00
}
}
}
if ( viaparinfo - > chip_info - >
tmds_chip_info . output_interface = = INTERFACE_DFP_HIGH ) {
viafb_write_reg ( SR2A , VIASR ,
viafb_read_reg ( VIASR , SR2A ) | 0x0C ) ;
viafb_write_reg ( CR91 , VIACR ,
viafb_read_reg ( VIACR , CR91 ) & 0xDF ) ;
}
if ( viaparinfo - > chip_info - >
tmds_chip_info . output_interface = = INTERFACE_DFP_LOW ) {
viafb_write_reg ( SR2A , VIASR ,
viafb_read_reg ( VIASR , SR2A ) | 0x03 ) ;
viafb_write_reg ( CR91 , VIACR ,
viafb_read_reg ( VIACR , CR91 ) & 0xDF ) ;
}
if ( viaparinfo - > chip_info - >
tmds_chip_info . output_interface = = INTERFACE_TMDS ) {
/* Turn on Display period in the panel path. */
viafb_write_reg_mask ( CR91 , VIACR , 0 , BIT7 ) ;
/* Turn on TMDS power. */
viafb_write_reg_mask ( CRD2 , VIACR , 0 , BIT3 ) ;
}
}