mirror of https://gitee.com/openkylin/linux.git
drm/i915: shuffle panel code
Somehow a few functions have been dropped in the middle of backlight code. Move them around. No functional changes. Signed-off-by: Jani Nikula <jani.nikula@intel.com> Reviewed-by: Jesse Barnes <jbarnes@virtuousgeek.org> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
This commit is contained in:
parent
9aa7250feb
commit
525997e00b
|
@ -42,6 +42,59 @@ intel_fixed_panel_mode(const struct drm_display_mode *fixed_mode,
|
||||||
drm_mode_set_crtcinfo(adjusted_mode, 0);
|
drm_mode_set_crtcinfo(adjusted_mode, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* intel_find_panel_downclock - find the reduced downclock for LVDS in EDID
|
||||||
|
* @dev: drm device
|
||||||
|
* @fixed_mode : panel native mode
|
||||||
|
* @connector: LVDS/eDP connector
|
||||||
|
*
|
||||||
|
* Return downclock_avail
|
||||||
|
* Find the reduced downclock for LVDS/eDP in EDID.
|
||||||
|
*/
|
||||||
|
struct drm_display_mode *
|
||||||
|
intel_find_panel_downclock(struct drm_device *dev,
|
||||||
|
struct drm_display_mode *fixed_mode,
|
||||||
|
struct drm_connector *connector)
|
||||||
|
{
|
||||||
|
struct drm_display_mode *scan, *tmp_mode;
|
||||||
|
int temp_downclock;
|
||||||
|
|
||||||
|
temp_downclock = fixed_mode->clock;
|
||||||
|
tmp_mode = NULL;
|
||||||
|
|
||||||
|
list_for_each_entry(scan, &connector->probed_modes, head) {
|
||||||
|
/*
|
||||||
|
* If one mode has the same resolution with the fixed_panel
|
||||||
|
* mode while they have the different refresh rate, it means
|
||||||
|
* that the reduced downclock is found. In such
|
||||||
|
* case we can set the different FPx0/1 to dynamically select
|
||||||
|
* between low and high frequency.
|
||||||
|
*/
|
||||||
|
if (scan->hdisplay == fixed_mode->hdisplay &&
|
||||||
|
scan->hsync_start == fixed_mode->hsync_start &&
|
||||||
|
scan->hsync_end == fixed_mode->hsync_end &&
|
||||||
|
scan->htotal == fixed_mode->htotal &&
|
||||||
|
scan->vdisplay == fixed_mode->vdisplay &&
|
||||||
|
scan->vsync_start == fixed_mode->vsync_start &&
|
||||||
|
scan->vsync_end == fixed_mode->vsync_end &&
|
||||||
|
scan->vtotal == fixed_mode->vtotal) {
|
||||||
|
if (scan->clock < temp_downclock) {
|
||||||
|
/*
|
||||||
|
* The downclock is already found. But we
|
||||||
|
* expect to find the lower downclock.
|
||||||
|
*/
|
||||||
|
temp_downclock = scan->clock;
|
||||||
|
tmp_mode = scan;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (temp_downclock < fixed_mode->clock)
|
||||||
|
return drm_mode_duplicate(dev, tmp_mode);
|
||||||
|
else
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
/* adjusted_mode has been preset to be the panel's fixed mode */
|
/* adjusted_mode has been preset to be the panel's fixed mode */
|
||||||
void
|
void
|
||||||
intel_pch_panel_fitting(struct intel_crtc *intel_crtc,
|
intel_pch_panel_fitting(struct intel_crtc *intel_crtc,
|
||||||
|
@ -323,6 +376,28 @@ void intel_gmch_panel_fitting(struct intel_crtc *intel_crtc,
|
||||||
pipe_config->gmch_pfit.lvds_border_bits = border;
|
pipe_config->gmch_pfit.lvds_border_bits = border;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
enum drm_connector_status
|
||||||
|
intel_panel_detect(struct drm_device *dev)
|
||||||
|
{
|
||||||
|
struct drm_i915_private *dev_priv = dev->dev_private;
|
||||||
|
|
||||||
|
/* Assume that the BIOS does not lie through the OpRegion... */
|
||||||
|
if (!i915.panel_ignore_lid && dev_priv->opregion.lid_state) {
|
||||||
|
return ioread32(dev_priv->opregion.lid_state) & 0x1 ?
|
||||||
|
connector_status_connected :
|
||||||
|
connector_status_disconnected;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (i915.panel_ignore_lid) {
|
||||||
|
case -2:
|
||||||
|
return connector_status_connected;
|
||||||
|
case -1:
|
||||||
|
return connector_status_disconnected;
|
||||||
|
default:
|
||||||
|
return connector_status_unknown;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static u32 intel_panel_compute_brightness(struct intel_connector *connector,
|
static u32 intel_panel_compute_brightness(struct intel_connector *connector,
|
||||||
u32 val)
|
u32 val)
|
||||||
{
|
{
|
||||||
|
@ -795,28 +870,6 @@ void intel_panel_enable_backlight(struct intel_connector *connector)
|
||||||
spin_unlock_irqrestore(&dev_priv->backlight_lock, flags);
|
spin_unlock_irqrestore(&dev_priv->backlight_lock, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
enum drm_connector_status
|
|
||||||
intel_panel_detect(struct drm_device *dev)
|
|
||||||
{
|
|
||||||
struct drm_i915_private *dev_priv = dev->dev_private;
|
|
||||||
|
|
||||||
/* Assume that the BIOS does not lie through the OpRegion... */
|
|
||||||
if (!i915.panel_ignore_lid && dev_priv->opregion.lid_state) {
|
|
||||||
return ioread32(dev_priv->opregion.lid_state) & 0x1 ?
|
|
||||||
connector_status_connected :
|
|
||||||
connector_status_disconnected;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (i915.panel_ignore_lid) {
|
|
||||||
case -2:
|
|
||||||
return connector_status_connected;
|
|
||||||
case -1:
|
|
||||||
return connector_status_disconnected;
|
|
||||||
default:
|
|
||||||
return connector_status_unknown;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#if IS_ENABLED(CONFIG_BACKLIGHT_CLASS_DEVICE)
|
#if IS_ENABLED(CONFIG_BACKLIGHT_CLASS_DEVICE)
|
||||||
static int intel_backlight_device_update_status(struct backlight_device *bd)
|
static int intel_backlight_device_update_status(struct backlight_device *bd)
|
||||||
{
|
{
|
||||||
|
@ -1103,59 +1156,6 @@ void intel_panel_destroy_backlight(struct drm_connector *connector)
|
||||||
intel_backlight_device_unregister(intel_connector);
|
intel_backlight_device_unregister(intel_connector);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* intel_find_panel_downclock - find the reduced downclock for LVDS in EDID
|
|
||||||
* @dev: drm device
|
|
||||||
* @fixed_mode : panel native mode
|
|
||||||
* @connector: LVDS/eDP connector
|
|
||||||
*
|
|
||||||
* Return downclock_avail
|
|
||||||
* Find the reduced downclock for LVDS/eDP in EDID.
|
|
||||||
*/
|
|
||||||
struct drm_display_mode *
|
|
||||||
intel_find_panel_downclock(struct drm_device *dev,
|
|
||||||
struct drm_display_mode *fixed_mode,
|
|
||||||
struct drm_connector *connector)
|
|
||||||
{
|
|
||||||
struct drm_display_mode *scan, *tmp_mode;
|
|
||||||
int temp_downclock;
|
|
||||||
|
|
||||||
temp_downclock = fixed_mode->clock;
|
|
||||||
tmp_mode = NULL;
|
|
||||||
|
|
||||||
list_for_each_entry(scan, &connector->probed_modes, head) {
|
|
||||||
/*
|
|
||||||
* If one mode has the same resolution with the fixed_panel
|
|
||||||
* mode while they have the different refresh rate, it means
|
|
||||||
* that the reduced downclock is found. In such
|
|
||||||
* case we can set the different FPx0/1 to dynamically select
|
|
||||||
* between low and high frequency.
|
|
||||||
*/
|
|
||||||
if (scan->hdisplay == fixed_mode->hdisplay &&
|
|
||||||
scan->hsync_start == fixed_mode->hsync_start &&
|
|
||||||
scan->hsync_end == fixed_mode->hsync_end &&
|
|
||||||
scan->htotal == fixed_mode->htotal &&
|
|
||||||
scan->vdisplay == fixed_mode->vdisplay &&
|
|
||||||
scan->vsync_start == fixed_mode->vsync_start &&
|
|
||||||
scan->vsync_end == fixed_mode->vsync_end &&
|
|
||||||
scan->vtotal == fixed_mode->vtotal) {
|
|
||||||
if (scan->clock < temp_downclock) {
|
|
||||||
/*
|
|
||||||
* The downclock is already found. But we
|
|
||||||
* expect to find the lower downclock.
|
|
||||||
*/
|
|
||||||
temp_downclock = scan->clock;
|
|
||||||
tmp_mode = scan;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (temp_downclock < fixed_mode->clock)
|
|
||||||
return drm_mode_duplicate(dev, tmp_mode);
|
|
||||||
else
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Set up chip specific backlight functions */
|
/* Set up chip specific backlight functions */
|
||||||
void intel_panel_init_backlight_funcs(struct drm_device *dev)
|
void intel_panel_init_backlight_funcs(struct drm_device *dev)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue