Avoid beyond bounds copy while caching ACL
[zen-stable.git] / drivers / video / via / ioctl.c
blobea1c51428823e3bdc14e73bfaefa42dac283b0af
1 /*
2 * Copyright 1998-2008 VIA Technologies, Inc. All Rights Reserved.
3 * Copyright 2001-2008 S3 Graphics, Inc. All Rights Reserved.
5 * This program is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU General Public
7 * License as published by the Free Software Foundation;
8 * either version 2, or (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTIES OR REPRESENTATIONS; without even
12 * the implied warranty of MERCHANTABILITY or FITNESS FOR
13 * A PARTICULAR PURPOSE.See the GNU General Public License
14 * for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc.,
19 * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
22 #include "global.h"
24 int viafb_ioctl_get_viafb_info(u_long arg)
26 struct viafb_ioctl_info viainfo;
28 memset(&viainfo, 0, sizeof(struct viafb_ioctl_info));
30 viainfo.viafb_id = VIAID;
31 viainfo.vendor_id = PCI_VIA_VENDOR_ID;
33 switch (viaparinfo->chip_info->gfx_chip_name) {
34 case UNICHROME_CLE266:
35 viainfo.device_id = UNICHROME_CLE266_DID;
36 break;
38 case UNICHROME_K400:
39 viainfo.device_id = UNICHROME_K400_DID;
40 break;
42 case UNICHROME_K800:
43 viainfo.device_id = UNICHROME_K800_DID;
44 break;
46 case UNICHROME_PM800:
47 viainfo.device_id = UNICHROME_PM800_DID;
48 break;
50 case UNICHROME_CN700:
51 viainfo.device_id = UNICHROME_CN700_DID;
52 break;
54 case UNICHROME_CX700:
55 viainfo.device_id = UNICHROME_CX700_DID;
56 break;
58 case UNICHROME_K8M890:
59 viainfo.device_id = UNICHROME_K8M890_DID;
60 break;
62 case UNICHROME_P4M890:
63 viainfo.device_id = UNICHROME_P4M890_DID;
64 break;
66 case UNICHROME_P4M900:
67 viainfo.device_id = UNICHROME_P4M900_DID;
68 break;
71 viainfo.version = VERSION_MAJOR;
72 viainfo.revision = VERSION_MINOR;
74 if (copy_to_user((void __user *)arg, &viainfo, sizeof(viainfo)))
75 return -EFAULT;
77 return 0;
80 /* Hot-Plug Priority: DVI > CRT*/
81 int viafb_ioctl_hotplug(int hres, int vres, int bpp)
83 int DVIsense, status = 0;
84 DEBUG_MSG(KERN_INFO "viafb_ioctl_hotplug!!\n");
86 if (viaparinfo->chip_info->tmds_chip_info.tmds_chip_name !=
87 NON_TMDS_TRANSMITTER) {
88 DVIsense = viafb_dvi_sense();
90 if (DVIsense) {
91 DEBUG_MSG(KERN_INFO "DVI Attached...\n");
92 if (viafb_DeviceStatus != DVI_Device) {
93 viafb_DVI_ON = 1;
94 viafb_CRT_ON = 0;
95 viafb_LCD_ON = 0;
96 viafb_DeviceStatus = DVI_Device;
97 viafb_set_iga_path();
98 return viafb_DeviceStatus;
100 status = 1;
101 } else
102 DEBUG_MSG(KERN_INFO "DVI De-attached...\n");
105 if ((viafb_DeviceStatus != CRT_Device) && (status == 0)) {
106 viafb_CRT_ON = 1;
107 viafb_DVI_ON = 0;
108 viafb_LCD_ON = 0;
110 viafb_DeviceStatus = CRT_Device;
111 viafb_set_iga_path();
112 return viafb_DeviceStatus;
115 return 0;