Merge branches 'video' and 'video-edid' into release
This commit is contained in:
commit
64a4222f7e
@ -45,6 +45,7 @@
|
|||||||
#include <acpi/acpi_bus.h>
|
#include <acpi/acpi_bus.h>
|
||||||
#include <acpi/acpi_drivers.h>
|
#include <acpi/acpi_drivers.h>
|
||||||
#include <linux/suspend.h>
|
#include <linux/suspend.h>
|
||||||
|
#include <acpi/video.h>
|
||||||
|
|
||||||
#define PREFIX "ACPI: "
|
#define PREFIX "ACPI: "
|
||||||
|
|
||||||
@ -65,11 +66,6 @@
|
|||||||
|
|
||||||
#define MAX_NAME_LEN 20
|
#define MAX_NAME_LEN 20
|
||||||
|
|
||||||
#define ACPI_VIDEO_DISPLAY_CRT 1
|
|
||||||
#define ACPI_VIDEO_DISPLAY_TV 2
|
|
||||||
#define ACPI_VIDEO_DISPLAY_DVI 3
|
|
||||||
#define ACPI_VIDEO_DISPLAY_LCD 4
|
|
||||||
|
|
||||||
#define _COMPONENT ACPI_VIDEO_COMPONENT
|
#define _COMPONENT ACPI_VIDEO_COMPONENT
|
||||||
ACPI_MODULE_NAME("video");
|
ACPI_MODULE_NAME("video");
|
||||||
|
|
||||||
@ -1747,12 +1743,28 @@ acpi_video_get_device_attr(struct acpi_video_bus *video, unsigned long device_id
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
acpi_video_get_device_type(struct acpi_video_bus *video,
|
||||||
|
unsigned long device_id)
|
||||||
|
{
|
||||||
|
struct acpi_video_enumerated_device *ids;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < video->attached_count; i++) {
|
||||||
|
ids = &video->attached_array[i];
|
||||||
|
if ((ids->value.int_val & 0xffff) == device_id)
|
||||||
|
return ids->value.int_val;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
acpi_video_bus_get_one_device(struct acpi_device *device,
|
acpi_video_bus_get_one_device(struct acpi_device *device,
|
||||||
struct acpi_video_bus *video)
|
struct acpi_video_bus *video)
|
||||||
{
|
{
|
||||||
unsigned long long device_id;
|
unsigned long long device_id;
|
||||||
int status;
|
int status, device_type;
|
||||||
struct acpi_video_device *data;
|
struct acpi_video_device *data;
|
||||||
struct acpi_video_device_attrib* attribute;
|
struct acpi_video_device_attrib* attribute;
|
||||||
|
|
||||||
@ -1797,8 +1809,25 @@ acpi_video_bus_get_one_device(struct acpi_device *device,
|
|||||||
}
|
}
|
||||||
if(attribute->bios_can_detect)
|
if(attribute->bios_can_detect)
|
||||||
data->flags.bios = 1;
|
data->flags.bios = 1;
|
||||||
} else
|
} else {
|
||||||
data->flags.unknown = 1;
|
/* Check for legacy IDs */
|
||||||
|
device_type = acpi_video_get_device_type(video,
|
||||||
|
device_id);
|
||||||
|
/* Ignore bits 16 and 18-20 */
|
||||||
|
switch (device_type & 0xffe2ffff) {
|
||||||
|
case ACPI_VIDEO_DISPLAY_LEGACY_MONITOR:
|
||||||
|
data->flags.crt = 1;
|
||||||
|
break;
|
||||||
|
case ACPI_VIDEO_DISPLAY_LEGACY_PANEL:
|
||||||
|
data->flags.lcd = 1;
|
||||||
|
break;
|
||||||
|
case ACPI_VIDEO_DISPLAY_LEGACY_TV:
|
||||||
|
data->flags.tvout = 1;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
data->flags.unknown = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
acpi_video_device_bind(video, data);
|
acpi_video_device_bind(video, data);
|
||||||
acpi_video_device_find_cap(data);
|
acpi_video_device_find_cap(data);
|
||||||
@ -2032,6 +2061,71 @@ out:
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int acpi_video_get_edid(struct acpi_device *device, int type, int device_id,
|
||||||
|
void **edid)
|
||||||
|
{
|
||||||
|
struct acpi_video_bus *video;
|
||||||
|
struct acpi_video_device *video_device;
|
||||||
|
union acpi_object *buffer = NULL;
|
||||||
|
acpi_status status;
|
||||||
|
int i, length;
|
||||||
|
|
||||||
|
if (!device || !acpi_driver_data(device))
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
|
video = acpi_driver_data(device);
|
||||||
|
|
||||||
|
for (i = 0; i < video->attached_count; i++) {
|
||||||
|
video_device = video->attached_array[i].bind_info;
|
||||||
|
length = 256;
|
||||||
|
|
||||||
|
if (!video_device)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (type) {
|
||||||
|
switch (type) {
|
||||||
|
case ACPI_VIDEO_DISPLAY_CRT:
|
||||||
|
if (!video_device->flags.crt)
|
||||||
|
continue;
|
||||||
|
break;
|
||||||
|
case ACPI_VIDEO_DISPLAY_TV:
|
||||||
|
if (!video_device->flags.tvout)
|
||||||
|
continue;
|
||||||
|
break;
|
||||||
|
case ACPI_VIDEO_DISPLAY_DVI:
|
||||||
|
if (!video_device->flags.dvi)
|
||||||
|
continue;
|
||||||
|
break;
|
||||||
|
case ACPI_VIDEO_DISPLAY_LCD:
|
||||||
|
if (!video_device->flags.lcd)
|
||||||
|
continue;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else if (video_device->device_id != device_id) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
status = acpi_video_device_EDID(video_device, &buffer, length);
|
||||||
|
|
||||||
|
if (ACPI_FAILURE(status) || !buffer ||
|
||||||
|
buffer->type != ACPI_TYPE_BUFFER) {
|
||||||
|
length = 128;
|
||||||
|
status = acpi_video_device_EDID(video_device, &buffer,
|
||||||
|
length);
|
||||||
|
if (ACPI_FAILURE(status) || !buffer ||
|
||||||
|
buffer->type != ACPI_TYPE_BUFFER) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
*edid = buffer->buffer.pointer;
|
||||||
|
return length;
|
||||||
|
}
|
||||||
|
|
||||||
|
return -ENODEV;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(acpi_video_get_edid);
|
||||||
|
|
||||||
static int
|
static int
|
||||||
acpi_video_bus_get_devices(struct acpi_video_bus *video,
|
acpi_video_bus_get_devices(struct acpi_video_bus *video,
|
||||||
struct acpi_device *device)
|
struct acpi_device *device)
|
||||||
|
@ -250,7 +250,7 @@ static int __init acpi_backlight(char *str)
|
|||||||
ACPI_VIDEO_BACKLIGHT_FORCE_VENDOR;
|
ACPI_VIDEO_BACKLIGHT_FORCE_VENDOR;
|
||||||
if (!strcmp("video", str))
|
if (!strcmp("video", str))
|
||||||
acpi_video_support |=
|
acpi_video_support |=
|
||||||
ACPI_VIDEO_OUTPUT_SWITCHING_FORCE_VIDEO;
|
ACPI_VIDEO_BACKLIGHT_FORCE_VIDEO;
|
||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -1,12 +1,28 @@
|
|||||||
#ifndef __ACPI_VIDEO_H
|
#ifndef __ACPI_VIDEO_H
|
||||||
#define __ACPI_VIDEO_H
|
#define __ACPI_VIDEO_H
|
||||||
|
|
||||||
|
#define ACPI_VIDEO_DISPLAY_CRT 1
|
||||||
|
#define ACPI_VIDEO_DISPLAY_TV 2
|
||||||
|
#define ACPI_VIDEO_DISPLAY_DVI 3
|
||||||
|
#define ACPI_VIDEO_DISPLAY_LCD 4
|
||||||
|
|
||||||
|
#define ACPI_VIDEO_DISPLAY_LEGACY_MONITOR 0x0100
|
||||||
|
#define ACPI_VIDEO_DISPLAY_LEGACY_PANEL 0x0110
|
||||||
|
#define ACPI_VIDEO_DISPLAY_LEGACY_TV 0x0200
|
||||||
|
|
||||||
#if (defined CONFIG_ACPI_VIDEO || defined CONFIG_ACPI_VIDEO_MODULE)
|
#if (defined CONFIG_ACPI_VIDEO || defined CONFIG_ACPI_VIDEO_MODULE)
|
||||||
extern int acpi_video_register(void);
|
extern int acpi_video_register(void);
|
||||||
extern void acpi_video_unregister(void);
|
extern void acpi_video_unregister(void);
|
||||||
|
extern int acpi_video_get_edid(struct acpi_device *device, int type,
|
||||||
|
int device_id, void **edid);
|
||||||
#else
|
#else
|
||||||
static inline int acpi_video_register(void) { return 0; }
|
static inline int acpi_video_register(void) { return 0; }
|
||||||
static inline void acpi_video_unregister(void) { return; }
|
static inline void acpi_video_unregister(void) { return; }
|
||||||
|
static inline int acpi_video_get_edid(struct acpi_device *device, int type,
|
||||||
|
int device_id, void **edid)
|
||||||
|
{
|
||||||
|
return -ENODEV;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user