116 lines
2.8 KiB
C
116 lines
2.8 KiB
C
/*
|
|
* 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.
|
|
*/
|
|
|
|
#include "global.h"
|
|
|
|
int viafb_ioctl_get_viafb_info(u_long arg)
|
|
{
|
|
struct viafb_ioctl_info viainfo;
|
|
|
|
memset(&viainfo, 0, sizeof(struct viafb_ioctl_info));
|
|
|
|
viainfo.viafb_id = VIAID;
|
|
viainfo.vendor_id = PCI_VIA_VENDOR_ID;
|
|
|
|
switch (viaparinfo->chip_info->gfx_chip_name) {
|
|
case UNICHROME_CLE266:
|
|
viainfo.device_id = UNICHROME_CLE266_DID;
|
|
break;
|
|
|
|
case UNICHROME_K400:
|
|
viainfo.device_id = UNICHROME_K400_DID;
|
|
break;
|
|
|
|
case UNICHROME_K800:
|
|
viainfo.device_id = UNICHROME_K800_DID;
|
|
break;
|
|
|
|
case UNICHROME_PM800:
|
|
viainfo.device_id = UNICHROME_PM800_DID;
|
|
break;
|
|
|
|
case UNICHROME_CN700:
|
|
viainfo.device_id = UNICHROME_CN700_DID;
|
|
break;
|
|
|
|
case UNICHROME_CX700:
|
|
viainfo.device_id = UNICHROME_CX700_DID;
|
|
break;
|
|
|
|
case UNICHROME_K8M890:
|
|
viainfo.device_id = UNICHROME_K8M890_DID;
|
|
break;
|
|
|
|
case UNICHROME_P4M890:
|
|
viainfo.device_id = UNICHROME_P4M890_DID;
|
|
break;
|
|
|
|
case UNICHROME_P4M900:
|
|
viainfo.device_id = UNICHROME_P4M900_DID;
|
|
break;
|
|
}
|
|
|
|
viainfo.version = VERSION_MAJOR;
|
|
viainfo.revision = VERSION_MINOR;
|
|
|
|
if (copy_to_user((void __user *)arg, &viainfo, sizeof(viainfo)))
|
|
return -EFAULT;
|
|
|
|
return 0;
|
|
}
|
|
|
|
/* Hot-Plug Priority: DVI > CRT*/
|
|
int viafb_ioctl_hotplug(int hres, int vres, int bpp)
|
|
{
|
|
int DVIsense, status = 0;
|
|
DEBUG_MSG(KERN_INFO "viafb_ioctl_hotplug!!\n");
|
|
|
|
if (viaparinfo->chip_info->tmds_chip_info.tmds_chip_name !=
|
|
NON_TMDS_TRANSMITTER) {
|
|
DVIsense = viafb_dvi_sense();
|
|
|
|
if (DVIsense) {
|
|
DEBUG_MSG(KERN_INFO "DVI Attached...\n");
|
|
if (viafb_DeviceStatus != DVI_Device) {
|
|
viafb_DVI_ON = 1;
|
|
viafb_CRT_ON = 0;
|
|
viafb_LCD_ON = 0;
|
|
viafb_DeviceStatus = DVI_Device;
|
|
viafb_set_iga_path();
|
|
return viafb_DeviceStatus;
|
|
}
|
|
status = 1;
|
|
} else
|
|
DEBUG_MSG(KERN_INFO "DVI De-attached...\n");
|
|
}
|
|
|
|
if ((viafb_DeviceStatus != CRT_Device) && (status == 0)) {
|
|
viafb_CRT_ON = 1;
|
|
viafb_DVI_ON = 0;
|
|
viafb_LCD_ON = 0;
|
|
|
|
viafb_DeviceStatus = CRT_Device;
|
|
viafb_set_iga_path();
|
|
return viafb_DeviceStatus;
|
|
}
|
|
|
|
return 0;
|
|
}
|