<div dir="ltr">Hi<br><div><div class="gmail_extra"><br><div class="gmail_quote">On Fri, Nov 7, 2014 at 5:19 PM, Jonathon Jongsma <span dir="ltr"><<a href="mailto:jjongsma@redhat.com" target="_blank">jjongsma@redhat.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div class=""><div class="h5">On Thu, 2014-11-06 at 18:59 -0500, Marc-André Lureau wrote:<br>
><br>
> ----- Original Message -----<br>
> > When connector properties got changed, those changes were not being<br>
> > propagated to user-space. This pushes those chagnes up so that e.g. new<br>
> > suggested_x|y properties can be used to help lay out multiple displays<br>
> > properly. This code is based on similar code from the nouveau driver.<br>
> > ---<br>
> >  src/qxl_drmmode.c | 54<br>
> >  +++++++++++++++++++++++++++++++++++++++++++++++++++++-<br>
> >  1 file changed, 53 insertions(+), 1 deletion(-)<br>
> ><br>
> > diff --git a/src/qxl_drmmode.c b/src/qxl_drmmode.c<br>
> > index b7ea7d1..899eefd 100644<br>
> > --- a/src/qxl_drmmode.c<br>
> > +++ b/src/qxl_drmmode.c<br>
> > @@ -640,7 +640,59 @@ drmmode_output_set_property(xf86OutputPtr output, Atom<br>
> > property,<br>
> >  static Bool<br>
> >  drmmode_output_get_property(xf86OutputPtr output, Atom property)<br>
> >  {<br>
> > -    return TRUE;<br>
> > +    drmmode_output_private_ptr drmmode_output = output->driver_private;<br>
> > +    drmmode_ptr drmmode = drmmode_output->drmmode;<br>
> > +    uint32_t value;<br>
> > +    int err, i;<br>
> > +<br>
> > +    if (output->scrn->vtSema) {<br>
> > +   drmModeFreeConnector(drmmode_output->mode_output);<br>
> > +   drmmode_output->mode_output =<br>
> > +       drmModeGetConnector(drmmode->fd, drmmode_output->output_id);<br>
> > +    }<br>
> > +<br>
> > +    if (!drmmode_output->mode_output)<br>
> > +   return FALSE;<br>
><br>
> This line is different, is this a normal condition? If not, shouldn't be a warning?<br>
<br>
</div></div>This patch is based on the code here:<br>
<a href="http://cgit.freedesktop.org/nouveau/xf86-video-nouveau/tree/src/drmmode_display.c#n1086" target="_blank">http://cgit.freedesktop.org/nouveau/xf86-video-nouveau/tree/src/drmmode_display.c#n1086</a><br>
<br>
If that is not the latest version of the nouveau driver, let me know.<br></blockquote><div><br></div><div>Ok, I was looking at older code. It seems this check was added to "Clean up some errors on closing" on forced closed. Not sure this will be reached by QXL driver, but let say it's okay that way.. (I think I would still put a warning there)<br> <br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<span class=""><br>
><br>
> > +<br>
> > +    for (i = 0; i < drmmode_output->num_props; i++) {<br>
> > +   int n;<br>
> > +   drmmode_prop_ptr p = &drmmode_output->props[i];<br>
> > +   if (p->atoms[0] != property)<br>
> > +       continue;<br>
> > +<br>
> > +   for (n = 0; n < drmmode_output->mode_output->count_props; n++) {<br>
> > +       int id = drmmode_output->mode_output->props[n];<br>
> > +       if (id == p->mode_prop->prop_id) {<br>
> > +           value = drmmode_output->mode_output->prop_values[n];<br>
><br>
> and here, nouveau seems to use the p->index to access the value directly.<br>
<br>
<br>
</span>Right, the definition of drmmode_prop_rec in nouveau is slightly<br>
different than the one in qxl. In nouveau, the struct contains an index<br>
member, but doesn't in qxl. I thought about refactoring the qxl code to<br>
add an index to the property struct, but iterating the array to find the<br>
index didn't seem very expensive, so I didn't bother. If you think it's<br>
too expensive, I can go back and do it.<br>
<div class=""><div class="h5"><br></div></div></blockquote><div><br></div><div>If it's not too much to add, or you can leave a FIXME in the code I'd say.<br><br><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div class=""><div class="h5">
<br>
><br>
> > +           break;<br>
> > +       }<br>
> > +   }<br>
> > +<br>
> > +   if (p->mode_prop->flags & DRM_MODE_PROP_RANGE) {<br>
> > +       err = RRChangeOutputProperty(output->randr_output,<br>
> > +                                    property, XA_INTEGER, 32,<br>
> > +                                    PropModeReplace, 1, &value,<br>
> > +                                    FALSE, FALSE);<br>
> > +<br>
> > +       return !err;<br>
> > +   } else if (p->mode_prop->flags & DRM_MODE_PROP_ENUM) {<br>
> > +       int     j;<br>
> > +<br>
> > +       /* search for matching name string, then set its value down */<br>
> > +       for (j = 0; j < p->mode_prop->count_enums; j++) {<br>
> > +           if (p->mode_prop->enums[j].value == value)<br>
> > +               break;<br>
> > +       }<br>
> > +<br>
> > +       err = RRChangeOutputProperty(output->randr_output, property,<br>
> > +                                    XA_ATOM, 32, PropModeReplace, 1,<br>
> > +                                    &p->atoms[j+1], FALSE, FALSE);<br>
> > +<br>
> > +       return !err;<br>
> > +   }<br>
> > +    }<br>
> > +<br>
> > +    return FALSE;<br>
> >  }<br>
><br>
> looks ok otherwise<br>
><br>
> ><br>
> >  static const xf86OutputFuncsRec drmmode_output_funcs = {<br>
> > --<br>
> > 1.9.3<br>
> ><br>
> > _______________________________________________<br>
> > Spice-devel mailing list<br>
> > <a href="mailto:Spice-devel@lists.freedesktop.org">Spice-devel@lists.freedesktop.org</a><br>
> > <a href="http://lists.freedesktop.org/mailman/listinfo/spice-devel" target="_blank">http://lists.freedesktop.org/mailman/listinfo/spice-devel</a><br>
> ><br>
<br>
<br>
_______________________________________________<br>
Spice-devel mailing list<br>
<a href="mailto:Spice-devel@lists.freedesktop.org">Spice-devel@lists.freedesktop.org</a><br>
<a href="http://lists.freedesktop.org/mailman/listinfo/spice-devel" target="_blank">http://lists.freedesktop.org/mailman/listinfo/spice-devel</a><br>
</div></div></blockquote></div><br><br clear="all"><br>-- <br><div class="gmail_signature">Marc-André Lureau</div>
</div></div></div>