Ping. Just wanted to confirm if the patch is applied or anything still pending from my side ? Also I tried to subscribe as per instructions at https://lists.freedesktop.org/mailman/listinfo/dri-devel Sometime back, but still not able to receive messages from mailing list. Is there any other way to subscribe ? Regards, Devarsh > -----Original Message----- > From: Devarsh Thakkar <devarsh.thakkar@xxxxxxxxxx> > Sent: 15 November 2019 06:31 > To: dri-devel@xxxxxxxxxxxxxxxxxxxxx; ville.syrjala@xxxxxxxxxxxxxxx > Cc: Hyun Kwon <hyunk@xxxxxxxxxx>; vcu-team <vcu-team@xxxxxxxxxx>; > Ranganathan Sk <rsk@xxxxxxxxxx>; Dhaval Rajeshbhai Shah > <dshah@xxxxxxxxxx>; Satish Kumar Nagireddy <SATISHNA@xxxxxxxxxx>; > Varunkumar Allagadapa <VARUNKUM@xxxxxxxxxx>; Devarsh Thakkar > <DEVARSHT@xxxxxxxxxx> > Subject: [PATCH libdrm v4] modetest: Add support for setting mode having > floating vertical refresh rate > > For the scenario where user may require to modeset with a mode supporting > a fractional value for vertical refresh-rate, appropriate mode can be selected > by searching for mode having matching fractional vertical refresh rate using > below equation. > > vrefresh = (1000 * pixel clock) / (htotal * vtotal) Hz. > > We do this way since driver doesn't return float value of vrefresh as it use int > for vrefresh in struct drm_mode_info, but we can derive the actual value > using pixel clock, horizontal total size and vertical total size values. > > So for e.g. if user want to select mode having 59.94 Hz as refresh rate then > with this patch it be can done as shown in below command, given there is an > appropriate mode is available : > > modetest -M xlnx -s 39:1920x1080-59.94@BG24 -v > > NOTE: Above command was tested on xilinx DRM driver with DP monitor > which was supporting mode having 59.94 Hz refresh rate. > > V2: Update commit message > V3: Update with below changes as per review comments : > 1) Use epsilon for vrefresh comparison > 2) Use implicit type-casting wherever possible > V4: Keep patch version history on main commit message > > Signed-off-by: Devarsh Thakkar <devarsh.thakkar@xxxxxxxxxx> > Reviewed-by: Ville Syrjälä <ville.syrjala@xxxxxxxxxxxxxxx> > --- > tests/modetest/modetest.c | 20 ++++++++++++-------- > 1 file changed, 12 insertions(+), 8 deletions(-) > > diff --git a/tests/modetest/modetest.c b/tests/modetest/modetest.c index > e66be66..b4edfcb 100644 > --- a/tests/modetest/modetest.c > +++ b/tests/modetest/modetest.c > @@ -54,6 +54,7 @@ > #ifdef HAVE_SYS_SELECT_H > #include <sys/select.h> > #endif > +#include <math.h> > > #include "xf86drm.h" > #include "xf86drmMode.h" > @@ -795,7 +796,7 @@ struct pipe_arg { > uint32_t crtc_id; > char mode_str[64]; > char format_str[5]; > - unsigned int vrefresh; > + float vrefresh; > unsigned int fourcc; > drmModeModeInfo *mode; > struct crtc *crtc; > @@ -822,11 +823,12 @@ struct plane_arg { > > static drmModeModeInfo * > connector_find_mode(struct device *dev, uint32_t con_id, const char > *mode_str, > - const unsigned int vrefresh) > + const float vrefresh) > { > drmModeConnector *connector; > drmModeModeInfo *mode; > int i; > + float mode_vrefresh; > > connector = get_connector_by_id(dev, con_id); > if (!connector || !connector->count_modes) @@ -839,9 +841,11 > @@ connector_find_mode(struct device *dev, uint32_t con_id, const char > *mode_str, > * first mode that match with the name. Else, return > the mode that match > * the name and the specified vertical refresh > frequency. > */ > + mode_vrefresh = mode->clock * 1000.00 > + / (mode->htotal * mode->vtotal); > if (vrefresh == 0) > return mode; > - else if (mode->vrefresh == vrefresh) > + else if (fabs(mode_vrefresh - vrefresh) < 0.005) > return mode; > } > } > @@ -1393,8 +1397,8 @@ static void atomic_set_mode(struct device *dev, > struct pipe_arg *pipes, unsigned > if (pipe->mode == NULL) > continue; > > - printf("setting mode %s-%dHz on connectors ", > - pipe->mode_str, pipe->mode->vrefresh); > + printf("setting mode %s-%.2fHz on connectors ", > + pipe->mode_str, pipe->vrefresh); > for (j = 0; j < pipe->num_cons; ++j) { > printf("%s, ", pipe->cons[j]); > add_property(dev, pipe->con_ids[j], "CRTC_ID", pipe- > >crtc->crtc->crtc_id); @@ -1476,8 +1480,8 @@ static void set_mode(struct > device *dev, struct pipe_arg *pipes, unsigned int co > if (pipe->mode == NULL) > continue; > > - printf("setting mode %s-%dHz@%s on connectors ", > - pipe->mode_str, pipe->mode->vrefresh, pipe- > >format_str); > + printf("setting mode %s-%.2fHz@%s on connectors ", > + pipe->mode_str, pipe->vrefresh, pipe->format_str); > for (j = 0; j < pipe->num_cons; ++j) > printf("%s, ", pipe->cons[j]); > printf("crtc %d\n", pipe->crtc->crtc->crtc_id); @@ -1713,7 > +1717,7 @@ static int parse_connector(struct pipe_arg *pipe, const char > *arg) > pipe->mode_str[len] = '\0'; > > if (*p == '-') { > - pipe->vrefresh = strtoul(p + 1, &endp, 10); > + pipe->vrefresh = strtof(p + 1, &endp); > p = endp; > } > > -- > 2.7.4 _______________________________________________ dri-devel mailing list dri-devel@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/dri-devel