<html>
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  </head>
  <body text="#000000" bgcolor="#FFFFFF">
    <div class="gmail_quote">
      <blockquote type="cite">[SNIP]<br>
        <blockquote class="gmail_quote" style="margin:0 0 0
          .8ex;border-left:1px #ccc solid;padding-left:1ex">
          <div dir="ltr">
            <div class="gmail_extra">
              <div class="gmail_quote">
                <div>
                  <div class="h5">
                    <blockquote class="gmail_quote" style="margin:0 0 0
                      .8ex;border-left:1px #ccc solid;padding-left:1ex">
                      See a wait_queue is a callback mechanism anyway,
                      so you are wrapping a callback mechanism inside
                      another callback mechanism and that makes not
                      really much sense.<br>
                    </blockquote>
                    <div><br>
                    </div>
                  </div>
                </div>
                <div>Fair enough.  There is one little snag though:  We
                  need to wait on sync objects and fences at the same
                  time in order for WAIT_ANY | WAIT_FOR_SUBMIT to work. 
                  I see two options here:<br>
                  <br>
                </div>
                <div> 1) Convert dma-fence to use waitqueue instead of
                  its callback mechanism and add a wait_queue_any.  A
                  quick grep for dma_fence_add_callback says that this
                  would affect four drivers.<br>
                </div>
              </div>
            </div>
          </div>
        </blockquote>
        <div><br>
        </div>
        The more I think about it, the less sense using waitqueues
        makes.  The fundamental problem here is that the event we are
        waiting on is actually the concatenation of two events: submit
        and signal.  Since we are waiting on several of these pairs of
        concatenated events simultaneously, the only two options we have
        are to either combine them into one event (the proxy approach)
        or to implement a wait which is capable of handling both at the
        same time.  I don't see a way to do the latter with wait queues.<br>
      </blockquote>
      <br>
      <div>Agree completely.<br>
        <br>
        Essentially we would need to enable wait_event_* to wait for
        multiple events and then convert all the fence callback stuff to
        wait_event structures.<br>
        <br>
        But that is certainly outside the scope of this patchset, so
        feel free to go ahead with the approach of waiting manually (but
        please without the bugs).<br>
        <br>
        Well if you got a student/interim with free time that would
        certainly be a nice cleanup task to start on kernel work.<br>
        <br>
        Regards,<br>
        Christian.<br>
      </div>
    </div>
  </body>
</html>