* [PATCH v3 0/5] drm/dp: Implement CRC debugfs API @ 2017-01-06 14:30 Tomeu Vizoso 2017-01-06 14:30 ` [PATCH v3 5/5] drm/rockchip: " Tomeu Vizoso 0 siblings, 1 reply; 4+ messages in thread From: Tomeu Vizoso @ 2017-01-06 14:30 UTC (permalink / raw) To: linux-arm-kernel Hi, this series builds up on the API for exposing captured CRCs through debugfs. It adds new DP helpers for starting and stopping CRC capture and gets the Rockchip driver to use it. Also had to add a connector backpointer to the drm_dp_aux struct so we could wait for the right vblank and store the CRCs afterwards, I will be glad to hear about better alternatives. With these patches, tests in IGT such as kms_pipe_crc_basic and kms_plane do pass on RK3288. Thanks, Tomeu Tomeu Vizoso (5): drm/dp: add connector backpointer to drm_dp_aux drm/bridge: analogix_dp: set connector to drm_dp_aux drm/dp: add helpers for capture of frame CRCs drm/bridge: analogix_dp: add helpers for capture of frame CRCs drm/rockchip: Implement CRC debugfs API drivers/gpu/drm/bridge/analogix/analogix_dp_core.c | 34 ++++-- drivers/gpu/drm/drm_dp_helper.c | 118 +++++++++++++++++++++ drivers/gpu/drm/rockchip/rockchip_drm_vop.c | 48 +++++++++ include/drm/bridge/analogix_dp.h | 3 + include/drm/drm_dp_helper.h | 9 ++ 5 files changed, 204 insertions(+), 8 deletions(-) -- 2.9.3 ^ permalink raw reply [flat|nested] 4+ messages in thread
* [PATCH v3 5/5] drm/rockchip: Implement CRC debugfs API 2017-01-06 14:30 [PATCH v3 0/5] drm/dp: Implement CRC debugfs API Tomeu Vizoso @ 2017-01-06 14:30 ` Tomeu Vizoso 2017-01-06 15:56 ` Sean Paul 0 siblings, 1 reply; 4+ messages in thread From: Tomeu Vizoso @ 2017-01-06 14:30 UTC (permalink / raw) To: linux-arm-kernel Implement the .set_crc_source() callback and call the DP helpers accordingly to start and stop CRC capture. This is only done if this CRTC is currently using the eDP connector. v3: Remove superfluous check on rockchip_crtc_state->output_type Signed-off-by: Tomeu Vizoso <tomeu.vizoso@collabora.com> --- drivers/gpu/drm/rockchip/rockchip_drm_vop.c | 48 +++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) diff --git a/drivers/gpu/drm/rockchip/rockchip_drm_vop.c b/drivers/gpu/drm/rockchip/rockchip_drm_vop.c index fb5f001f51c3..5e19bef6d5b4 100644 --- a/drivers/gpu/drm/rockchip/rockchip_drm_vop.c +++ b/drivers/gpu/drm/rockchip/rockchip_drm_vop.c @@ -19,6 +19,7 @@ #include <drm/drm_crtc_helper.h> #include <drm/drm_flip_work.h> #include <drm/drm_plane_helper.h> +#include <drm/bridge/analogix_dp.h> #include <linux/kernel.h> #include <linux/module.h> @@ -1105,6 +1106,52 @@ static void vop_crtc_destroy_state(struct drm_crtc *crtc, kfree(s); } +static struct drm_connector *vop_get_edp_connector(struct vop *vop) +{ + struct drm_crtc *crtc = &vop->crtc; + struct drm_connector *connector; + + mutex_lock(&crtc->dev->mode_config.mutex); + drm_for_each_connector(connector, crtc->dev) + if (connector->connector_type == DRM_MODE_CONNECTOR_eDP) { + mutex_unlock(&crtc->dev->mode_config.mutex); + return connector; + } + mutex_unlock(&crtc->dev->mode_config.mutex); + + return NULL; +} + +static int vop_crtc_set_crc_source(struct drm_crtc *crtc, + const char *source_name, size_t *values_cnt) +{ + struct vop *vop = to_vop(crtc); + struct rockchip_crtc_state *s = to_rockchip_crtc_state(crtc->state); + struct drm_connector *connector; + int ret; + + connector = vop_get_edp_connector(vop); + if (!connector) + return -EINVAL; + + *values_cnt = 3; + + if (source_name && + strcmp(source_name, "auto") == 0) { + + if (s->output_type != DRM_MODE_CONNECTOR_eDP) + return -EINVAL; + + ret = analogix_dp_start_crc(connector); + } else if (!source_name) + + ret = analogix_dp_stop_crc(connector); + else + ret = -EINVAL; + + return ret; +} + static const struct drm_crtc_funcs vop_crtc_funcs = { .set_config = drm_atomic_helper_set_config, .page_flip = drm_atomic_helper_page_flip, @@ -1112,6 +1159,7 @@ static const struct drm_crtc_funcs vop_crtc_funcs = { .reset = vop_crtc_reset, .atomic_duplicate_state = vop_crtc_duplicate_state, .atomic_destroy_state = vop_crtc_destroy_state, + .set_crc_source = vop_crtc_set_crc_source, }; static void vop_fb_unref_worker(struct drm_flip_work *work, void *val) -- 2.9.3 ^ permalink raw reply related [flat|nested] 4+ messages in thread
* [PATCH v3 5/5] drm/rockchip: Implement CRC debugfs API 2017-01-06 14:30 ` [PATCH v3 5/5] drm/rockchip: " Tomeu Vizoso @ 2017-01-06 15:56 ` Sean Paul 2017-01-09 13:25 ` Tomeu Vizoso 0 siblings, 1 reply; 4+ messages in thread From: Sean Paul @ 2017-01-06 15:56 UTC (permalink / raw) To: linux-arm-kernel On Fri, Jan 6, 2017 at 9:30 AM, Tomeu Vizoso <tomeu.vizoso@collabora.com> wrote: > Implement the .set_crc_source() callback and call the DP helpers > accordingly to start and stop CRC capture. > > This is only done if this CRTC is currently using the eDP connector. > > v3: Remove superfluous check on rockchip_crtc_state->output_type > > Signed-off-by: Tomeu Vizoso <tomeu.vizoso@collabora.com> > --- > > drivers/gpu/drm/rockchip/rockchip_drm_vop.c | 48 +++++++++++++++++++++++++++++ > 1 file changed, 48 insertions(+) > > diff --git a/drivers/gpu/drm/rockchip/rockchip_drm_vop.c b/drivers/gpu/drm/rockchip/rockchip_drm_vop.c > index fb5f001f51c3..5e19bef6d5b4 100644 > --- a/drivers/gpu/drm/rockchip/rockchip_drm_vop.c > +++ b/drivers/gpu/drm/rockchip/rockchip_drm_vop.c > @@ -19,6 +19,7 @@ > #include <drm/drm_crtc_helper.h> > #include <drm/drm_flip_work.h> > #include <drm/drm_plane_helper.h> > +#include <drm/bridge/analogix_dp.h> > > #include <linux/kernel.h> > #include <linux/module.h> > @@ -1105,6 +1106,52 @@ static void vop_crtc_destroy_state(struct drm_crtc *crtc, > kfree(s); > } > > +static struct drm_connector *vop_get_edp_connector(struct vop *vop) > +{ > + struct drm_crtc *crtc = &vop->crtc; > + struct drm_connector *connector; > + > + mutex_lock(&crtc->dev->mode_config.mutex); > + drm_for_each_connector(connector, crtc->dev) > + if (connector->connector_type == DRM_MODE_CONNECTOR_eDP) { > + mutex_unlock(&crtc->dev->mode_config.mutex); > + return connector; > + } > + mutex_unlock(&crtc->dev->mode_config.mutex); > + > + return NULL; > +} > + > +static int vop_crtc_set_crc_source(struct drm_crtc *crtc, > + const char *source_name, size_t *values_cnt) > +{ > + struct vop *vop = to_vop(crtc); > + struct rockchip_crtc_state *s = to_rockchip_crtc_state(crtc->state); > + struct drm_connector *connector; > + int ret; > + > + connector = vop_get_edp_connector(vop); > + if (!connector) > + return -EINVAL; > + > + *values_cnt = 3; > + > + if (source_name && > + strcmp(source_name, "auto") == 0) { > + > + if (s->output_type != DRM_MODE_CONNECTOR_eDP) > + return -EINVAL; > + > + ret = analogix_dp_start_crc(connector); To pick up my thoughts from 1/5, you could do the following instead: analogix_dp_start_crc(drm_crtc_index(crtc)); > + } else if (!source_name) > + > + ret = analogix_dp_stop_crc(connector); > + else > + ret = -EINVAL; > + > + return ret; > +} > + > static const struct drm_crtc_funcs vop_crtc_funcs = { > .set_config = drm_atomic_helper_set_config, > .page_flip = drm_atomic_helper_page_flip, > @@ -1112,6 +1159,7 @@ static const struct drm_crtc_funcs vop_crtc_funcs = { > .reset = vop_crtc_reset, > .atomic_duplicate_state = vop_crtc_duplicate_state, > .atomic_destroy_state = vop_crtc_destroy_state, > + .set_crc_source = vop_crtc_set_crc_source, > }; > > static void vop_fb_unref_worker(struct drm_flip_work *work, void *val) > -- > 2.9.3 > > > _______________________________________________ > linux-arm-kernel mailing list > linux-arm-kernel at lists.infradead.org > http://lists.infradead.org/mailman/listinfo/linux-arm-kernel -- Sean Paul, Software Engineer, Google / Chromium OS ^ permalink raw reply [flat|nested] 4+ messages in thread
* [PATCH v3 5/5] drm/rockchip: Implement CRC debugfs API 2017-01-06 15:56 ` Sean Paul @ 2017-01-09 13:25 ` Tomeu Vizoso 0 siblings, 0 replies; 4+ messages in thread From: Tomeu Vizoso @ 2017-01-09 13:25 UTC (permalink / raw) To: linux-arm-kernel On 6 January 2017 at 16:56, Sean Paul <seanpaul@chromium.org> wrote: > On Fri, Jan 6, 2017 at 9:30 AM, Tomeu Vizoso <tomeu.vizoso@collabora.com> wrote: >> Implement the .set_crc_source() callback and call the DP helpers >> accordingly to start and stop CRC capture. >> >> This is only done if this CRTC is currently using the eDP connector. >> >> v3: Remove superfluous check on rockchip_crtc_state->output_type >> >> Signed-off-by: Tomeu Vizoso <tomeu.vizoso@collabora.com> >> --- >> >> drivers/gpu/drm/rockchip/rockchip_drm_vop.c | 48 +++++++++++++++++++++++++++++ >> 1 file changed, 48 insertions(+) >> >> diff --git a/drivers/gpu/drm/rockchip/rockchip_drm_vop.c b/drivers/gpu/drm/rockchip/rockchip_drm_vop.c >> index fb5f001f51c3..5e19bef6d5b4 100644 >> --- a/drivers/gpu/drm/rockchip/rockchip_drm_vop.c >> +++ b/drivers/gpu/drm/rockchip/rockchip_drm_vop.c >> @@ -19,6 +19,7 @@ >> #include <drm/drm_crtc_helper.h> >> #include <drm/drm_flip_work.h> >> #include <drm/drm_plane_helper.h> >> +#include <drm/bridge/analogix_dp.h> >> >> #include <linux/kernel.h> >> #include <linux/module.h> >> @@ -1105,6 +1106,52 @@ static void vop_crtc_destroy_state(struct drm_crtc *crtc, >> kfree(s); >> } >> >> +static struct drm_connector *vop_get_edp_connector(struct vop *vop) >> +{ >> + struct drm_crtc *crtc = &vop->crtc; >> + struct drm_connector *connector; >> + >> + mutex_lock(&crtc->dev->mode_config.mutex); >> + drm_for_each_connector(connector, crtc->dev) >> + if (connector->connector_type == DRM_MODE_CONNECTOR_eDP) { >> + mutex_unlock(&crtc->dev->mode_config.mutex); >> + return connector; >> + } >> + mutex_unlock(&crtc->dev->mode_config.mutex); >> + >> + return NULL; >> +} >> + >> +static int vop_crtc_set_crc_source(struct drm_crtc *crtc, >> + const char *source_name, size_t *values_cnt) >> +{ >> + struct vop *vop = to_vop(crtc); >> + struct rockchip_crtc_state *s = to_rockchip_crtc_state(crtc->state); >> + struct drm_connector *connector; >> + int ret; >> + >> + connector = vop_get_edp_connector(vop); >> + if (!connector) >> + return -EINVAL; >> + >> + *values_cnt = 3; >> + >> + if (source_name && >> + strcmp(source_name, "auto") == 0) { >> + >> + if (s->output_type != DRM_MODE_CONNECTOR_eDP) >> + return -EINVAL; >> + >> + ret = analogix_dp_start_crc(connector); > > To pick up my thoughts from 1/5, you could do the following instead: > > analogix_dp_start_crc(drm_crtc_index(crtc)); Well, I still need the dpaux to access the dpcd, so that would have to be: analogix_dp_start_crc(connector, drm_crtc_index(crtc)); Regards, Tomeu >> + } else if (!source_name) >> + >> + ret = analogix_dp_stop_crc(connector); >> + else >> + ret = -EINVAL; >> + >> + return ret; >> +} >> + >> static const struct drm_crtc_funcs vop_crtc_funcs = { >> .set_config = drm_atomic_helper_set_config, >> .page_flip = drm_atomic_helper_page_flip, >> @@ -1112,6 +1159,7 @@ static const struct drm_crtc_funcs vop_crtc_funcs = { >> .reset = vop_crtc_reset, >> .atomic_duplicate_state = vop_crtc_duplicate_state, >> .atomic_destroy_state = vop_crtc_destroy_state, >> + .set_crc_source = vop_crtc_set_crc_source, >> }; >> >> static void vop_fb_unref_worker(struct drm_flip_work *work, void *val) >> -- >> 2.9.3 >> >> >> _______________________________________________ >> linux-arm-kernel mailing list >> linux-arm-kernel at lists.infradead.org >> http://lists.infradead.org/mailman/listinfo/linux-arm-kernel > > > > -- > Sean Paul, Software Engineer, Google / Chromium OS ^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2017-01-09 13:25 UTC | newest] Thread overview: 4+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2017-01-06 14:30 [PATCH v3 0/5] drm/dp: Implement CRC debugfs API Tomeu Vizoso 2017-01-06 14:30 ` [PATCH v3 5/5] drm/rockchip: " Tomeu Vizoso 2017-01-06 15:56 ` Sean Paul 2017-01-09 13:25 ` Tomeu Vizoso
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).