Commit 329414c4 authored by Dave Airlie's avatar Dave Airlie

Merge tag 'topic/drm-misc-2015-02-25' of git://anongit.freedesktop.org/drm-intel into drm-next

misc atomic and dp macros

* tag 'topic/drm-misc-2015-02-25' of git://anongit.freedesktop.org/drm-intel:
  drm: Adding edp1.4 specific dpcd macros
  drm/atomic-helpers: make mode_set hooks optional
  drm/atomic-helper: Rename commmit_post/pre_planes
  drm/atomic: Rename drm_atomic_helper_commit_pre_planes() state argument
  drm: If available use atomic state in getcrtc ioctl
  drm: Add DRM_DEBUG_ATOMIC
  drm/atomic-helpers: Fix documentation typos and wrong copy&paste
  drm: Fix the CRTC_STEREO_DOUBLE_ONLY define to include stero modes
  drm: Fix drm_crtc_vblank_get() documentation
parents c517d838 e045d20b
...@@ -92,7 +92,7 @@ drm_atomic_state_alloc(struct drm_device *dev) ...@@ -92,7 +92,7 @@ drm_atomic_state_alloc(struct drm_device *dev)
state->dev = dev; state->dev = dev;
DRM_DEBUG_KMS("Allocate atomic state %p\n", state); DRM_DEBUG_ATOMIC("Allocate atomic state %p\n", state);
return state; return state;
fail: fail:
...@@ -122,7 +122,7 @@ void drm_atomic_state_clear(struct drm_atomic_state *state) ...@@ -122,7 +122,7 @@ void drm_atomic_state_clear(struct drm_atomic_state *state)
struct drm_mode_config *config = &dev->mode_config; struct drm_mode_config *config = &dev->mode_config;
int i; int i;
DRM_DEBUG_KMS("Clearing atomic state %p\n", state); DRM_DEBUG_ATOMIC("Clearing atomic state %p\n", state);
for (i = 0; i < state->num_connector; i++) { for (i = 0; i < state->num_connector; i++) {
struct drm_connector *connector = state->connectors[i]; struct drm_connector *connector = state->connectors[i];
...@@ -172,7 +172,7 @@ void drm_atomic_state_free(struct drm_atomic_state *state) ...@@ -172,7 +172,7 @@ void drm_atomic_state_free(struct drm_atomic_state *state)
{ {
drm_atomic_state_clear(state); drm_atomic_state_clear(state);
DRM_DEBUG_KMS("Freeing atomic state %p\n", state); DRM_DEBUG_ATOMIC("Freeing atomic state %p\n", state);
kfree_state(state); kfree_state(state);
} }
...@@ -217,7 +217,7 @@ drm_atomic_get_crtc_state(struct drm_atomic_state *state, ...@@ -217,7 +217,7 @@ drm_atomic_get_crtc_state(struct drm_atomic_state *state,
state->crtcs[index] = crtc; state->crtcs[index] = crtc;
crtc_state->state = state; crtc_state->state = state;
DRM_DEBUG_KMS("Added [CRTC:%d] %p state to %p\n", DRM_DEBUG_ATOMIC("Added [CRTC:%d] %p state to %p\n",
crtc->base.id, crtc_state, state); crtc->base.id, crtc_state, state);
return crtc_state; return crtc_state;
...@@ -293,7 +293,7 @@ static int drm_atomic_crtc_check(struct drm_crtc *crtc, ...@@ -293,7 +293,7 @@ static int drm_atomic_crtc_check(struct drm_crtc *crtc,
*/ */
if (state->active && !state->enable) { if (state->active && !state->enable) {
DRM_DEBUG_KMS("[CRTC:%d] active without enabled\n", DRM_DEBUG_ATOMIC("[CRTC:%d] active without enabled\n",
crtc->base.id); crtc->base.id);
return -EINVAL; return -EINVAL;
} }
...@@ -340,7 +340,7 @@ drm_atomic_get_plane_state(struct drm_atomic_state *state, ...@@ -340,7 +340,7 @@ drm_atomic_get_plane_state(struct drm_atomic_state *state,
state->planes[index] = plane; state->planes[index] = plane;
plane_state->state = state; plane_state->state = state;
DRM_DEBUG_KMS("Added [PLANE:%d] %p state to %p\n", DRM_DEBUG_ATOMIC("Added [PLANE:%d] %p state to %p\n",
plane->base.id, plane_state, state); plane->base.id, plane_state, state);
if (plane_state->crtc) { if (plane_state->crtc) {
...@@ -477,10 +477,10 @@ static int drm_atomic_plane_check(struct drm_plane *plane, ...@@ -477,10 +477,10 @@ static int drm_atomic_plane_check(struct drm_plane *plane,
/* either *both* CRTC and FB must be set, or neither */ /* either *both* CRTC and FB must be set, or neither */
if (WARN_ON(state->crtc && !state->fb)) { if (WARN_ON(state->crtc && !state->fb)) {
DRM_DEBUG_KMS("CRTC set but no FB\n"); DRM_DEBUG_ATOMIC("CRTC set but no FB\n");
return -EINVAL; return -EINVAL;
} else if (WARN_ON(state->fb && !state->crtc)) { } else if (WARN_ON(state->fb && !state->crtc)) {
DRM_DEBUG_KMS("FB set but no CRTC\n"); DRM_DEBUG_ATOMIC("FB set but no CRTC\n");
return -EINVAL; return -EINVAL;
} }
...@@ -490,7 +490,7 @@ static int drm_atomic_plane_check(struct drm_plane *plane, ...@@ -490,7 +490,7 @@ static int drm_atomic_plane_check(struct drm_plane *plane,
/* Check whether this plane is usable on this CRTC */ /* Check whether this plane is usable on this CRTC */
if (!(plane->possible_crtcs & drm_crtc_mask(state->crtc))) { if (!(plane->possible_crtcs & drm_crtc_mask(state->crtc))) {
DRM_DEBUG_KMS("Invalid crtc for plane\n"); DRM_DEBUG_ATOMIC("Invalid crtc for plane\n");
return -EINVAL; return -EINVAL;
} }
...@@ -499,7 +499,7 @@ static int drm_atomic_plane_check(struct drm_plane *plane, ...@@ -499,7 +499,7 @@ static int drm_atomic_plane_check(struct drm_plane *plane,
if (state->fb->pixel_format == plane->format_types[i]) if (state->fb->pixel_format == plane->format_types[i])
break; break;
if (i == plane->format_count) { if (i == plane->format_count) {
DRM_DEBUG_KMS("Invalid pixel format %s\n", DRM_DEBUG_ATOMIC("Invalid pixel format %s\n",
drm_get_format_name(state->fb->pixel_format)); drm_get_format_name(state->fb->pixel_format));
return -EINVAL; return -EINVAL;
} }
...@@ -509,7 +509,7 @@ static int drm_atomic_plane_check(struct drm_plane *plane, ...@@ -509,7 +509,7 @@ static int drm_atomic_plane_check(struct drm_plane *plane,
state->crtc_x > INT_MAX - (int32_t) state->crtc_w || state->crtc_x > INT_MAX - (int32_t) state->crtc_w ||
state->crtc_h > INT_MAX || state->crtc_h > INT_MAX ||
state->crtc_y > INT_MAX - (int32_t) state->crtc_h) { state->crtc_y > INT_MAX - (int32_t) state->crtc_h) {
DRM_DEBUG_KMS("Invalid CRTC coordinates %ux%u+%d+%d\n", DRM_DEBUG_ATOMIC("Invalid CRTC coordinates %ux%u+%d+%d\n",
state->crtc_w, state->crtc_h, state->crtc_w, state->crtc_h,
state->crtc_x, state->crtc_y); state->crtc_x, state->crtc_y);
return -ERANGE; return -ERANGE;
...@@ -523,7 +523,7 @@ static int drm_atomic_plane_check(struct drm_plane *plane, ...@@ -523,7 +523,7 @@ static int drm_atomic_plane_check(struct drm_plane *plane,
state->src_x > fb_width - state->src_w || state->src_x > fb_width - state->src_w ||
state->src_h > fb_height || state->src_h > fb_height ||
state->src_y > fb_height - state->src_h) { state->src_y > fb_height - state->src_h) {
DRM_DEBUG_KMS("Invalid source coordinates " DRM_DEBUG_ATOMIC("Invalid source coordinates "
"%u.%06ux%u.%06u+%u.%06u+%u.%06u\n", "%u.%06ux%u.%06u+%u.%06u+%u.%06u\n",
state->src_w >> 16, ((state->src_w & 0xffff) * 15625) >> 10, state->src_w >> 16, ((state->src_w & 0xffff) * 15625) >> 10,
state->src_h >> 16, ((state->src_h & 0xffff) * 15625) >> 10, state->src_h >> 16, ((state->src_h & 0xffff) * 15625) >> 10,
...@@ -575,7 +575,7 @@ drm_atomic_get_connector_state(struct drm_atomic_state *state, ...@@ -575,7 +575,7 @@ drm_atomic_get_connector_state(struct drm_atomic_state *state,
* at most the array is a bit too large. * at most the array is a bit too large.
*/ */
if (index >= state->num_connector) { if (index >= state->num_connector) {
DRM_DEBUG_KMS("Hot-added connector would overflow state array, restarting\n"); DRM_DEBUG_ATOMIC("Hot-added connector would overflow state array, restarting\n");
return ERR_PTR(-EAGAIN); return ERR_PTR(-EAGAIN);
} }
...@@ -590,7 +590,7 @@ drm_atomic_get_connector_state(struct drm_atomic_state *state, ...@@ -590,7 +590,7 @@ drm_atomic_get_connector_state(struct drm_atomic_state *state,
state->connectors[index] = connector; state->connectors[index] = connector;
connector_state->state = state; connector_state->state = state;
DRM_DEBUG_KMS("Added [CONNECTOR:%d] %p state to %p\n", DRM_DEBUG_ATOMIC("Added [CONNECTOR:%d] %p state to %p\n",
connector->base.id, connector_state, state); connector->base.id, connector_state, state);
if (connector_state->crtc) { if (connector_state->crtc) {
...@@ -752,10 +752,11 @@ drm_atomic_set_crtc_for_plane(struct drm_plane_state *plane_state, ...@@ -752,10 +752,11 @@ drm_atomic_set_crtc_for_plane(struct drm_plane_state *plane_state,
} }
if (crtc) if (crtc)
DRM_DEBUG_KMS("Link plane state %p to [CRTC:%d]\n", DRM_DEBUG_ATOMIC("Link plane state %p to [CRTC:%d]\n",
plane_state, crtc->base.id); plane_state, crtc->base.id);
else else
DRM_DEBUG_KMS("Link plane state %p to [NOCRTC]\n", plane_state); DRM_DEBUG_ATOMIC("Link plane state %p to [NOCRTC]\n",
plane_state);
return 0; return 0;
} }
...@@ -782,10 +783,11 @@ drm_atomic_set_fb_for_plane(struct drm_plane_state *plane_state, ...@@ -782,10 +783,11 @@ drm_atomic_set_fb_for_plane(struct drm_plane_state *plane_state,
plane_state->fb = fb; plane_state->fb = fb;
if (fb) if (fb)
DRM_DEBUG_KMS("Set [FB:%d] for plane state %p\n", DRM_DEBUG_ATOMIC("Set [FB:%d] for plane state %p\n",
fb->base.id, plane_state); fb->base.id, plane_state);
else else
DRM_DEBUG_KMS("Set [NOFB] for plane state %p\n", plane_state); DRM_DEBUG_ATOMIC("Set [NOFB] for plane state %p\n",
plane_state);
} }
EXPORT_SYMBOL(drm_atomic_set_fb_for_plane); EXPORT_SYMBOL(drm_atomic_set_fb_for_plane);
...@@ -818,10 +820,10 @@ drm_atomic_set_crtc_for_connector(struct drm_connector_state *conn_state, ...@@ -818,10 +820,10 @@ drm_atomic_set_crtc_for_connector(struct drm_connector_state *conn_state,
conn_state->crtc = crtc; conn_state->crtc = crtc;
if (crtc) if (crtc)
DRM_DEBUG_KMS("Link connector state %p to [CRTC:%d]\n", DRM_DEBUG_ATOMIC("Link connector state %p to [CRTC:%d]\n",
conn_state, crtc->base.id); conn_state, crtc->base.id);
else else
DRM_DEBUG_KMS("Link connector state %p to [NOCRTC]\n", DRM_DEBUG_ATOMIC("Link connector state %p to [NOCRTC]\n",
conn_state); conn_state);
return 0; return 0;
...@@ -858,7 +860,7 @@ drm_atomic_add_affected_connectors(struct drm_atomic_state *state, ...@@ -858,7 +860,7 @@ drm_atomic_add_affected_connectors(struct drm_atomic_state *state,
if (ret) if (ret)
return ret; return ret;
DRM_DEBUG_KMS("Adding all current connectors for [CRTC:%d] to %p\n", DRM_DEBUG_ATOMIC("Adding all current connectors for [CRTC:%d] to %p\n",
crtc->base.id, state); crtc->base.id, state);
/* /*
...@@ -901,7 +903,7 @@ drm_atomic_connectors_for_crtc(struct drm_atomic_state *state, ...@@ -901,7 +903,7 @@ drm_atomic_connectors_for_crtc(struct drm_atomic_state *state,
num_connected_connectors++; num_connected_connectors++;
} }
DRM_DEBUG_KMS("State %p has %i connectors for [CRTC:%d]\n", DRM_DEBUG_ATOMIC("State %p has %i connectors for [CRTC:%d]\n",
state, num_connected_connectors, crtc->base.id); state, num_connected_connectors, crtc->base.id);
return num_connected_connectors; return num_connected_connectors;
...@@ -953,7 +955,7 @@ int drm_atomic_check_only(struct drm_atomic_state *state) ...@@ -953,7 +955,7 @@ int drm_atomic_check_only(struct drm_atomic_state *state)
int ncrtcs = config->num_crtc; int ncrtcs = config->num_crtc;
int i, ret = 0; int i, ret = 0;
DRM_DEBUG_KMS("checking %p\n", state); DRM_DEBUG_ATOMIC("checking %p\n", state);
for (i = 0; i < nplanes; i++) { for (i = 0; i < nplanes; i++) {
struct drm_plane *plane = state->planes[i]; struct drm_plane *plane = state->planes[i];
...@@ -963,7 +965,7 @@ int drm_atomic_check_only(struct drm_atomic_state *state) ...@@ -963,7 +965,7 @@ int drm_atomic_check_only(struct drm_atomic_state *state)
ret = drm_atomic_plane_check(plane, state->plane_states[i]); ret = drm_atomic_plane_check(plane, state->plane_states[i]);
if (ret) { if (ret) {
DRM_DEBUG_KMS("[PLANE:%d] atomic core check failed\n", DRM_DEBUG_ATOMIC("[PLANE:%d] atomic core check failed\n",
plane->base.id); plane->base.id);
return ret; return ret;
} }
...@@ -977,7 +979,7 @@ int drm_atomic_check_only(struct drm_atomic_state *state) ...@@ -977,7 +979,7 @@ int drm_atomic_check_only(struct drm_atomic_state *state)
ret = drm_atomic_crtc_check(crtc, state->crtc_states[i]); ret = drm_atomic_crtc_check(crtc, state->crtc_states[i]);
if (ret) { if (ret) {
DRM_DEBUG_KMS("[CRTC:%d] atomic core check failed\n", DRM_DEBUG_ATOMIC("[CRTC:%d] atomic core check failed\n",
crtc->base.id); crtc->base.id);
return ret; return ret;
} }
...@@ -996,7 +998,7 @@ int drm_atomic_check_only(struct drm_atomic_state *state) ...@@ -996,7 +998,7 @@ int drm_atomic_check_only(struct drm_atomic_state *state)
if (crtc_state->mode_changed || if (crtc_state->mode_changed ||
crtc_state->active_changed) { crtc_state->active_changed) {
DRM_DEBUG_KMS("[CRTC:%d] requires full modeset\n", DRM_DEBUG_ATOMIC("[CRTC:%d] requires full modeset\n",
crtc->base.id); crtc->base.id);
return -EINVAL; return -EINVAL;
} }
...@@ -1032,7 +1034,7 @@ int drm_atomic_commit(struct drm_atomic_state *state) ...@@ -1032,7 +1034,7 @@ int drm_atomic_commit(struct drm_atomic_state *state)
if (ret) if (ret)
return ret; return ret;
DRM_DEBUG_KMS("commiting %p\n", state); DRM_DEBUG_ATOMIC("commiting %p\n", state);
return config->funcs->atomic_commit(state->dev, state, false); return config->funcs->atomic_commit(state->dev, state, false);
} }
...@@ -1063,7 +1065,7 @@ int drm_atomic_async_commit(struct drm_atomic_state *state) ...@@ -1063,7 +1065,7 @@ int drm_atomic_async_commit(struct drm_atomic_state *state)
if (ret) if (ret)
return ret; return ret;
DRM_DEBUG_KMS("commiting %p asynchronously\n", state); DRM_DEBUG_ATOMIC("commiting %p asynchronously\n", state);
return config->funcs->atomic_commit(state->dev, state, true); return config->funcs->atomic_commit(state->dev, state, true);
} }
......
This diff is collapsed.
...@@ -2009,22 +2009,33 @@ int drm_mode_getcrtc(struct drm_device *dev, ...@@ -2009,22 +2009,33 @@ int drm_mode_getcrtc(struct drm_device *dev,
return -ENOENT; return -ENOENT;
drm_modeset_lock_crtc(crtc, crtc->primary); drm_modeset_lock_crtc(crtc, crtc->primary);
crtc_resp->x = crtc->x;
crtc_resp->y = crtc->y;
crtc_resp->gamma_size = crtc->gamma_size; crtc_resp->gamma_size = crtc->gamma_size;
if (crtc->primary->fb) if (crtc->primary->fb)
crtc_resp->fb_id = crtc->primary->fb->base.id; crtc_resp->fb_id = crtc->primary->fb->base.id;
else else
crtc_resp->fb_id = 0; crtc_resp->fb_id = 0;
if (crtc->enabled) { if (crtc->state) {
crtc_resp->x = crtc->primary->state->src_x >> 16;
crtc_resp->y = crtc->primary->state->src_y >> 16;
if (crtc->state->enable) {
drm_crtc_convert_to_umode(&crtc_resp->mode, &crtc->state->mode);
crtc_resp->mode_valid = 1;
} else {
crtc_resp->mode_valid = 0;
}
} else {
crtc_resp->x = crtc->x;
crtc_resp->y = crtc->y;
if (crtc->enabled) {
drm_crtc_convert_to_umode(&crtc_resp->mode, &crtc->mode); drm_crtc_convert_to_umode(&crtc_resp->mode, &crtc->mode);
crtc_resp->mode_valid = 1; crtc_resp->mode_valid = 1;
} else { } else {
crtc_resp->mode_valid = 0; crtc_resp->mode_valid = 0;
} }
}
drm_modeset_unlock_crtc(crtc); drm_modeset_unlock_crtc(crtc);
return 0; return 0;
......
...@@ -1052,7 +1052,7 @@ EXPORT_SYMBOL(drm_vblank_get); ...@@ -1052,7 +1052,7 @@ EXPORT_SYMBOL(drm_vblank_get);
* Acquire a reference count on vblank events to avoid having them disabled * Acquire a reference count on vblank events to avoid having them disabled
* while in use. * while in use.
* *
* This is the native kms version of drm_vblank_off(). * This is the native kms version of drm_vblank_get().
* *
* Returns: * Returns:
* Zero on success, nonzero on failure. * Zero on success, nonzero on failure.
......
...@@ -134,9 +134,9 @@ int intel_atomic_commit(struct drm_device *dev, ...@@ -134,9 +134,9 @@ int intel_atomic_commit(struct drm_device *dev,
* FIXME: The proper sequence here will eventually be: * FIXME: The proper sequence here will eventually be:
* *
* drm_atomic_helper_swap_state(dev, state) * drm_atomic_helper_swap_state(dev, state)
* drm_atomic_helper_commit_pre_planes(dev, state); * drm_atomic_helper_commit_modeset_disables(dev, state);
* drm_atomic_helper_commit_planes(dev, state); * drm_atomic_helper_commit_planes(dev, state);
* drm_atomic_helper_commit_post_planes(dev, state); * drm_atomic_helper_commit_modeset_enables(dev, state);
* drm_atomic_helper_wait_for_vblanks(dev, state); * drm_atomic_helper_wait_for_vblanks(dev, state);
* drm_atomic_helper_cleanup_planes(dev, state); * drm_atomic_helper_cleanup_planes(dev, state);
* drm_atomic_state_free(state); * drm_atomic_state_free(state);
......
...@@ -96,11 +96,11 @@ static void complete_commit(struct msm_commit *c) ...@@ -96,11 +96,11 @@ static void complete_commit(struct msm_commit *c)
kms->funcs->prepare_commit(kms, state); kms->funcs->prepare_commit(kms, state);
drm_atomic_helper_commit_pre_planes(dev, state); drm_atomic_helper_commit_modeset_disables(dev, state);
drm_atomic_helper_commit_planes(dev, state); drm_atomic_helper_commit_planes(dev, state);
drm_atomic_helper_commit_post_planes(dev, state); drm_atomic_helper_commit_modeset_enables(dev, state);
/* NOTE: _wait_for_vblanks() only waits for vblank on /* NOTE: _wait_for_vblanks() only waits for vblank on
* enabled CRTCs. So we end up faulting when disabling * enabled CRTCs. So we end up faulting when disabling
......
...@@ -55,9 +55,9 @@ static void tegra_atomic_complete(struct tegra_drm *tegra, ...@@ -55,9 +55,9 @@ static void tegra_atomic_complete(struct tegra_drm *tegra,
* current layout. * current layout.
*/ */
drm_atomic_helper_commit_pre_planes(drm, state); drm_atomic_helper_commit_modeset_disables(drm, state);
drm_atomic_helper_commit_planes(drm, state); drm_atomic_helper_commit_planes(drm, state);
drm_atomic_helper_commit_post_planes(drm, state); drm_atomic_helper_commit_modeset_enables(drm, state);
drm_atomic_helper_wait_for_vblanks(drm, state); drm_atomic_helper_wait_for_vblanks(drm, state);
......
...@@ -104,6 +104,9 @@ struct dma_buf_attachment; ...@@ -104,6 +104,9 @@ struct dma_buf_attachment;
* PRIME: used in the prime code. * PRIME: used in the prime code.
* This is the category used by the DRM_DEBUG_PRIME() macro. * This is the category used by the DRM_DEBUG_PRIME() macro.
* *
* ATOMIC: used in the atomic code.
* This is the category used by the DRM_DEBUG_ATOMIC() macro.
*
* Enabling verbose debug messages is done through the drm.debug parameter, * Enabling verbose debug messages is done through the drm.debug parameter,
* each category being enabled by a bit. * each category being enabled by a bit.
* *
...@@ -121,6 +124,7 @@ struct dma_buf_attachment; ...@@ -121,6 +124,7 @@ struct dma_buf_attachment;
#define DRM_UT_DRIVER 0x02 #define DRM_UT_DRIVER 0x02
#define DRM_UT_KMS 0x04 #define DRM_UT_KMS 0x04
#define DRM_UT_PRIME 0x08 #define DRM_UT_PRIME 0x08
#define DRM_UT_ATOMIC 0x10
extern __printf(2, 3) extern __printf(2, 3)
void drm_ut_debug_printk(const char *function_name, void drm_ut_debug_printk(const char *function_name,
...@@ -207,6 +211,11 @@ void drm_err(const char *format, ...); ...@@ -207,6 +211,11 @@ void drm_err(const char *format, ...);
if (unlikely(drm_debug & DRM_UT_PRIME)) \ if (unlikely(drm_debug & DRM_UT_PRIME)) \
drm_ut_debug_printk(__func__, fmt, ##args); \ drm_ut_debug_printk(__func__, fmt, ##args); \
} while (0) } while (0)
#define DRM_DEBUG_ATOMIC(fmt, args...) \
do { \
if (unlikely(drm_debug & DRM_UT_ATOMIC)) \
drm_ut_debug_printk(__func__, fmt, ##args); \
} while (0)
/*@}*/ /*@}*/
......
...@@ -43,9 +43,9 @@ int drm_atomic_helper_commit(struct drm_device *dev, ...@@ -43,9 +43,9 @@ int drm_atomic_helper_commit(struct drm_device *dev,
void drm_atomic_helper_wait_for_vblanks(struct drm_device *dev, void drm_atomic_helper_wait_for_vblanks(struct drm_device *dev,
struct drm_atomic_state *old_state); struct drm_atomic_state *old_state);
void drm_atomic_helper_commit_pre_planes(struct drm_device *dev, void drm_atomic_helper_commit_modeset_disables(struct drm_device *dev,
struct drm_atomic_state *state); struct drm_atomic_state *state);
void drm_atomic_helper_commit_post_planes(struct drm_device *dev, void drm_atomic_helper_commit_modeset_enables(struct drm_device *dev,
struct drm_atomic_state *old_state); struct drm_atomic_state *old_state);
int drm_atomic_helper_prepare_planes(struct drm_device *dev, int drm_atomic_helper_prepare_planes(struct drm_device *dev,
......
...@@ -89,6 +89,7 @@ struct drm_crtc_helper_funcs { ...@@ -89,6 +89,7 @@ struct drm_crtc_helper_funcs {
int (*mode_set)(struct drm_crtc *crtc, struct drm_display_mode *mode, int (*mode_set)(struct drm_crtc *crtc, struct drm_display_mode *mode,
struct drm_display_mode *adjusted_mode, int x, int y, struct drm_display_mode *adjusted_mode, int x, int y,
struct drm_framebuffer *old_fb); struct drm_framebuffer *old_fb);
/* Actually set the mode for atomic helpers, optional */
void (*mode_set_nofb)(struct drm_crtc *crtc); void (*mode_set_nofb)(struct drm_crtc *crtc);
/* Move the crtc on the current fb to the given position *optional* */ /* Move the crtc on the current fb to the given position *optional* */
...@@ -119,7 +120,7 @@ struct drm_crtc_helper_funcs { ...@@ -119,7 +120,7 @@ struct drm_crtc_helper_funcs {
* @mode_fixup: try to fixup proposed mode for this connector * @mode_fixup: try to fixup proposed mode for this connector
* @prepare: part of the disable sequence, called before the CRTC modeset * @prepare: part of the disable sequence, called before the CRTC modeset
* @commit: called after the CRTC modeset * @commit: called after the CRTC modeset
* @mode_set: set this mode * @mode_set: set this mode, optional for atomic helpers
* @get_crtc: return CRTC that the encoder is currently attached to * @get_crtc: return CRTC that the encoder is currently attached to
* @detect: connection status detection * @detect: connection status detection
* @disable: disable encoder when not in use (overrides DPMS off) * @disable: disable encoder when not in use (overrides DPMS off)
......
...@@ -92,6 +92,9 @@ ...@@ -92,6 +92,9 @@
# define DP_MSA_TIMING_PAR_IGNORED (1 << 6) /* eDP */ # define DP_MSA_TIMING_PAR_IGNORED (1 << 6) /* eDP */
# define DP_OUI_SUPPORT (1 << 7) # define DP_OUI_SUPPORT (1 << 7)
#define DP_SUPPORTED_LINK_RATES 0x010 /*eDP 1.4*/
#define DP_MAX_SUPPORTED_RATES 0x8
#define DP_I2C_SPEED_CAP 0x00c /* DPI */ #define DP_I2C_SPEED_CAP 0x00c /* DPI */
# define DP_I2C_SPEED_1K 0x01 # define DP_I2C_SPEED_1K 0x01
# define DP_I2C_SPEED_5K 0x02 # define DP_I2C_SPEED_5K 0x02
...@@ -101,6 +104,7 @@ ...@@ -101,6 +104,7 @@
# define DP_I2C_SPEED_1M 0x20 # define DP_I2C_SPEED_1M 0x20
#define DP_EDP_CONFIGURATION_CAP 0x00d /* XXX 1.2? */ #define DP_EDP_CONFIGURATION_CAP 0x00d /* XXX 1.2? */
# define DP_DPCD_DISPLAY_CONTROL_CAPABLE (1 << 3) /* edp v1.2 or higher */
#define DP_TRAINING_AUX_RD_INTERVAL 0x00e /* XXX 1.2? */ #define DP_TRAINING_AUX_RD_INTERVAL 0x00e /* XXX 1.2? */
/* Multiple stream transport */ /* Multiple stream transport */
...@@ -221,6 +225,8 @@ ...@@ -221,6 +225,8 @@
# define DP_UP_REQ_EN (1 << 1) # define DP_UP_REQ_EN (1 << 1)
# define DP_UPSTREAM_IS_SRC (1 << 2) # define DP_UPSTREAM_IS_SRC (1 << 2)
#define DP_LINK_RATE_SET 0x115
#define DP_PSR_EN_CFG 0x170 /* XXX 1.2? */ #define DP_PSR_EN_CFG 0x170 /* XXX 1.2? */
# define DP_PSR_ENABLE (1 << 0) # define DP_PSR_ENABLE (1 << 0)
# define DP_PSR_MAIN_LINK_ACTIVE (1 << 1) # define DP_PSR_MAIN_LINK_ACTIVE (1 << 1)
...@@ -332,6 +338,8 @@ ...@@ -332,6 +338,8 @@
# define DP_SET_POWER_D3 0x2 # define DP_SET_POWER_D3 0x2
# define DP_SET_POWER_MASK 0x3 # define DP_SET_POWER_MASK 0x3
#define DP_EDP_DPCD_REV 0x700
#define DP_SIDEBAND_MSG_DOWN_REQ_BASE 0x1000 /* 1.2 MST */ #define DP_SIDEBAND_MSG_DOWN_REQ_BASE 0x1000 /* 1.2 MST */
#define DP_SIDEBAND_MSG_UP_REP_BASE 0x1200 /* 1.2 MST */ #define DP_SIDEBAND_MSG_UP_REP_BASE 0x1200 /* 1.2 MST */
#define DP_SIDEBAND_MSG_DOWN_REP_BASE 0x1400 /* 1.2 MST */ #define DP_SIDEBAND_MSG_DOWN_REP_BASE 0x1400 /* 1.2 MST */
......
...@@ -92,7 +92,7 @@ enum drm_mode_status { ...@@ -92,7 +92,7 @@ enum drm_mode_status {
#define CRTC_STEREO_DOUBLE (1 << 1) /* adjust timings for stereo modes */ #define CRTC_STEREO_DOUBLE (1 << 1) /* adjust timings for stereo modes */
#define CRTC_NO_DBLSCAN (1 << 2) /* don't adjust doublescan */ #define CRTC_NO_DBLSCAN (1 << 2) /* don't adjust doublescan */
#define CRTC_NO_VSCAN (1 << 3) /* don't adjust doublescan */ #define CRTC_NO_VSCAN (1 << 3) /* don't adjust doublescan */
#define CRTC_STEREO_DOUBLE_ONLY (CRTC_NO_DBLSCAN | CRTC_NO_VSCAN) #define CRTC_STEREO_DOUBLE_ONLY (CRTC_STEREO_DOUBLE | CRTC_NO_DBLSCAN | CRTC_NO_VSCAN)
#define DRM_MODE_FLAG_3D_MAX DRM_MODE_FLAG_3D_SIDE_BY_SIDE_HALF #define DRM_MODE_FLAG_3D_MAX DRM_MODE_FLAG_3D_SIDE_BY_SIDE_HALF
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment