Received: by 10.213.65.68 with SMTP id h4csp733994imn; Wed, 4 Apr 2018 06:26:34 -0700 (PDT) X-Google-Smtp-Source: AIpwx4+Cue8x85n9FYnpc1QHdgWH55Haq0CFtOdXnwdDdzdxJPop0ktTUQm0UXY3jxQmhMsnWK65 X-Received: by 10.101.90.203 with SMTP id d11mr11887272pgt.20.1522848394597; Wed, 04 Apr 2018 06:26:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522848394; cv=none; d=google.com; s=arc-20160816; b=m+WrL+IrRREVaOR4q7YPF6bR0QZIyPUdII2LFM25YnwX5PoOpv+HyOTvHZto4v2YJz Rc6pGuRI50PIKOwdQHGEcQ7uUsWksaHIL6X2+j659J8wXJj1AsY96OoynXTgYlpauLwU NmxASvNuL3V3BYN2lyECNGQa1iY/gZLn2ZxzK45LjuYjLG1e/w2Q9uw3H5pX6e41IKCF OnvbmwBfEiQoEpYUZqg1UUtM7k5vhYolI1Ly719IE8GC9UeP9MehowXhvXbAJfe797An JrOVX7zDKSx2UmgvFePF1rIf8IVtoG93nbPUUqdcEurA+djy3PH6MnLbFAMRmI/DMvOT 0RJw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:subject:message-id:date:from :references:in-reply-to:mime-version:dkim-signature :arc-authentication-results; bh=9vnN2K71vrMxV5uPzkaR+GPfWGtLGNmYmH3/Qfv3ppw=; b=eisFFVPIRwNwgxg/CPHMAxs3i8thqQnlCBooPocFOfberp95jTngrUFIcgXxnHRM1E NIE9JvfjS1adZACVxc+0i5BJoNJd5AvgmKaKExeT3UJ3TpSZYVbrOtVkMCVoQVP1l9x4 gv7fpk1+zjwIS0SjwWSK2HumtJMtU3O/3fv3TsWkrraAaLhKJF39fsWtLIzJQTXiCvIu CfEROB2KmhVIleqvBuaTHPwuAYR8Xc6xKF6rg6fAsDEHjgB7hOeJEUp12hPysXm291eJ LBTLNVElJDrltGDpkSy2m1wW4TrhO3DajozXVoyHV2KcjPQn6A/rL+TUNsI23+Eah5q7 Il9g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=upAv1utZ; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id s9-v6si4495613plp.18.2018.04.04.06.26.20; Wed, 04 Apr 2018 06:26:34 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=upAv1utZ; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751350AbeDDNY1 (ORCPT + 99 others); Wed, 4 Apr 2018 09:24:27 -0400 Received: from mail-io0-f171.google.com ([209.85.223.171]:36030 "EHLO mail-io0-f171.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750915AbeDDNYZ (ORCPT ); Wed, 4 Apr 2018 09:24:25 -0400 Received: by mail-io0-f171.google.com with SMTP id o4so26341455iod.3; Wed, 04 Apr 2018 06:24:25 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:in-reply-to:references:from:date:message-id:subject:to; bh=9vnN2K71vrMxV5uPzkaR+GPfWGtLGNmYmH3/Qfv3ppw=; b=upAv1utZn/+eIbUo2o5m9gKmoZ14Ui8TUlHclROjmyyKseteQICRUQYaVHxFT2YrsQ RjzGQv5r+TUW4PJ4mV9ZZN1Q7n/Bp86PoCLT/xrEj6/D1yHLrPaiaZruOKYCSvISq+BK bno722Ka9Gr6W8HeZkL1wsXqeZ4695rjlCCm5NzLpjtU/IepvwFfGL2Vmri+7JlUWFEy LmMjgbioEzBGiT5NBvWsQuEI27uXyGyBl0lfV2719yuzio9i1jpIhx0NjylAZ4PxneFN ST7WFhllSNAx4rGaxXxa3rR+jVR87KYizJ/GVH93wlLZOOJaf5CSeFbtUgiC1R+SiYfJ myBg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to; bh=9vnN2K71vrMxV5uPzkaR+GPfWGtLGNmYmH3/Qfv3ppw=; b=NROXHKYbxGq/q6AYGAGwOEQOYx8ZoNkn8qYLepEjlxiIJuZDEwDo1tXii8B3UpcEOr /whjC3+5DPFLNDj0c/bl4cBodO2r8anKBmyc7zlFVsOpKYJ/KQP5Rp/wgW/z+iPAfuBe oBcUDp3EbUYs+pjEmURppE+oRYAzlzhQqCWiTP6s9E4GA+66xJbErevQX6u+5ERpipsR o8xrEl0mkvIUUdJ1f9eezzNdFFkWNvVQrtq0RX5aLvhOSBK/d/8SPgwVJo/fR/rhhtYB SZ1DvnIm55+16OPij2GaY7y6N+PFz7edYr42++FB+RlbAWv7pM1bzOPSw6HJnTAAin+R uNtg== X-Gm-Message-State: AElRT7HamFu41Tk73KD/SqjTbF5dDoztNfARBxkPa3N5Vx2e7TJ/q/O8 JZZVFYUz9ac8yFrLYoSWV0knTHXoQJvRgaIeEh8= X-Received: by 10.107.15.144 with SMTP id 16mr17316527iop.108.1522848264331; Wed, 04 Apr 2018 06:24:24 -0700 (PDT) MIME-Version: 1.0 Received: by 10.213.85.204 with HTTP; Wed, 4 Apr 2018 06:24:23 -0700 (PDT) In-Reply-To: <20180404121617.GK3881@phenom.ffwll.local> References: <20180403224225.26776-1-robdclark@gmail.com> <307adb15-412a-1fe2-f116-27fe5b4a657d@shipmail.org> <20180404084320.GA3881@phenom.ffwll.local> <20180404095604.GD3881@phenom.ffwll.local> <20180404121617.GK3881@phenom.ffwll.local> From: Rob Clark Date: Wed, 4 Apr 2018 09:24:23 -0400 Message-ID: Subject: Re: [RFC] drm/atomic+msm: add helper to implement legacy dirtyfb To: Rob Clark , Thomas Hellstrom , =?UTF-8?Q?Noralf_Tr=C3=B8nnes?= , dri-devel , freedreno , linux-arm-msm , =?UTF-8?B?VmlsbGUgU3lyasOkbMOk?= , Lukasz Spintzyk , Deepak Singh Rawat , Gustavo Padovan , Maarten Lankhorst , Sean Paul , David Airlie , Linux Kernel Mailing List Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Apr 4, 2018 at 8:16 AM, Daniel Vetter wrote: > On Wed, Apr 04, 2018 at 07:40:32AM -0400, Rob Clark wrote: >> On Wed, Apr 4, 2018 at 5:56 AM, Daniel Vetter wrote: >> > On Wed, Apr 04, 2018 at 11:10:08AM +0200, Thomas Hellstrom wrote: >> >> On 04/04/2018 10:43 AM, Daniel Vetter wrote: >> >> > On Wed, Apr 04, 2018 at 10:22:21AM +0200, Thomas Hellstrom wrote: >> >> > > Hi, >> >> > > >> >> > > On 04/04/2018 08:58 AM, Daniel Vetter wrote: >> >> > > > On Wed, Apr 4, 2018 at 12:42 AM, Rob Clark wrote: >> >> > > > > Add an atomic helper to implement dirtyfb support. This is needed to >> >> > > > > support DSI command-mode panels with x11 userspace (ie. when we can't >> >> > > > > rely on pageflips to trigger a flush to the panel). >> >> > > > > >> >> > > > > To signal to the driver that the async atomic update needs to >> >> > > > > synchronize with fences, even though the fb didn't change, the >> >> > > > > drm_atomic_state::dirty flag is added. >> >> > > > > >> >> > > > > Signed-off-by: Rob Clark >> >> > > > > --- >> >> > > > > Background: there are a number of different folks working on getting >> >> > > > > upstream kernel working on various different phones/tablets with qcom >> >> > > > > SoC's.. many of them have command mode panels, so we kind of need a >> >> > > > > way to support the legacy dirtyfb ioctl for x11 support. >> >> > > > > >> >> > > > > I know there is work on a proprer non-legacy atomic property for >> >> > > > > userspace to communicate dirty-rect(s) to the kernel, so this can >> >> > > > > be improved from triggering a full-frame flush once that is in >> >> > > > > place. But we kinda needa a stop-gap solution. >> >> > > > > >> >> > > > > I had considered an in-driver solution for this, but things get a >> >> > > > > bit tricky if userspace ands up combining dirtyfb ioctls with page- >> >> > > > > flips, because we need to synchronize setting various CTL.FLUSH bits >> >> > > > > with setting the CTL.START bit. (ie. really all we need to do for >> >> > > > > cmd mode panels is bang CTL.START, but is this ends up racing with >> >> > > > > pageflips setting FLUSH bits, then bad things.) The easiest soln >> >> > > > > is to wrap this up as an atomic commit and rely on the worker to >> >> > > > > serialize things. Hence adding an atomic dirtyfb helper. >> >> > > > > >> >> > > > > I guess at least the helper, with some small addition to translate >> >> > > > > and pass-thru the dirty rect(s) is useful to the final atomic dirty- >> >> > > > > rect property solution. Depending on how far off that is, a stop- >> >> > > > > gap solution could be useful. >> >> > > > Adding Noralf, who iirc already posted the full dirty helpers already somewhere. >> >> > > > -Daniel >> >> > > I've asked Deepak to RFC the core changes suggested for the full dirty blob >> >> > > on dri-devel. It builds on DisplayLink's suggestion, with a simple helper to >> >> > > get to the desired coordinates. >> >> > > >> >> > > One thing to perhaps discuss is how we would like to fit this with >> >> > > front-buffer rendering and the dirty ioctl. In the page-flip context, the >> >> > > dirty rects, like egl's swapbuffer_with_damage is a hint to restrict the >> >> > > damage region that can be fully ignored by the driver, new content is >> >> > > indicated by a new framebuffer. >> >> > > >> >> > > We could do the same for frontbuffer rendering: Either set a dirty flag like >> >> > > you do here, or provide a content_age state member. Since we clear the dirty >> >> > > flag on state copies, I guess that would be sufficient. The blob rectangles >> >> > > would then become a hint to restrict the damage region. >> >> > I'm not entirely following here - I thought for frontbuffer rendering the >> >> > dirty rects have always just been a hint, and that the driver was always >> >> > free to re-upload the entire buffer to the screen. >> >> > >> >> > And through a helper like Rob's proposing here (and have floated around in >> >> > different versions already) we'd essentially map a frontbuffer dirtyfb >> >> > call to a fake flip with dirty rect. Manual upload drivers already need to >> >> > upload the entire screen if they get a flip, since some userspace uses >> >> > that to flush out frontbuffer rendering (instead of calling dirtyfb). >> >> > >> >> > So from that pov the new dirty flag is kinda not necessary imo. >> >> > >> >> > > Another approach would be to have the presence of dirty rects without >> >> > > framebuffer change to indicate frontbuffer rendering. >> >> > > >> >> > > I think I like the first approach best, although it may be tempting for >> >> > > user-space apps to just set the dirty bit instead of providing the full >> >> > > damage region. >> >> > Or I'm not following you here, because I don't quite see the difference >> >> > between dirtyfb and a flip. >> >> > -Daniel >> >> >> >> OK, let me rephrase: >> >> >> >> From the driver's point-of-view, in the atomic world, new content and the >> >> need for manual upload is indicated by a change in fb attached to the plane. >> >> >> >> With Rob's patch here, (correct me if I'm wrong) in addition new content and >> >> the need for manual upload is identified by the dirty flag, (since the fb >> >> stays the same and the driver thus never identifies a page-flip). >> > >> > Hm, I'm not entirely sure Rob's approach is correct. Imo a pageflip >> > (atomic or not) should result in the entire buffer getting uploaded. The >> > dirty flag is kinda redundant, a flip with the same buffer works the same >> > way as a dirtyfb with the entire buffer as the dirty rectangle. >> >> Userspace could do a pageflip, but (with buffer-age extension) only >> re-render part of the frame. So there is a use-case for full frame >> pageflip with hints about what region(s) changed since previous frame. >> >> (Of course userspace could screw that up and get different results on >> "command" vs "video" style display.. in that case, it gets to keep >> both pieces) > > I'm not against dirty on flips with the same buffer as an optimization. > Disagreement here is around whether a flip to the same buffer means: > a) nothing changed, upload nothing > b) entire buffer might have changed > > I'm proposing we standardize on b) (with maybe the exception of legacy > cursor ioctls because those are special) and add the dirty rects as an > option to optimize this more. ok, I can agree w/ flip to same buffer, if FB_ID is in the incoming property list.. I just want a way to differentiate that from "plane got added to new state for unrelated reasons".. so new_fb != old_fb isn't a good test for "should we synchronize", but new plane state isn't either. Keeping the dirty flag (or sequence count or whatever mechanism) to indicate that an FB_ID that happened to be the same fb was part of what userspace passed in would do the trick. BR, -R > Either way you'd always have to follow the implicit fence (which is what > your msm hunk seems to be doing, but only for dirtyfb). > -Daniel > >> >> BR, >> -R >> >> >> >> In both these situations, clip rects can provide a hint to restrict the >> >> dirty region. >> >> >> >> Now I was thinking about the preferred way for user-space to communicate >> >> front buffer rendering through the atomic ioctl: >> >> >> >> 1) Expose a dirty (or content_age property) >> >> 2) Attach a clip-rect blob property. >> >> 3) Fake a page-flip by ping-ponging two frame-buffers pointing to the same >> >> underlying buffer object. >> >> >> >> Are you saying that people are already using 3) and we should keep using >> >> that? >> > >> > I'm saying they're using 3b), flip the same buffer wrapped in the same >> > drm_framebuffer, and expect it to work. >> > >> > The only advantage dirtyfb has is that it allows you to supply the >> > optimized upload rectangles, but at the cost of a funny api (it's working >> > on the fb, not the plane/crtc you want to upload) and lack of drm_event to >> > confirm when exactly you uploaded your stuff. But imo they should be the >> > same underlying operation. >> > >> > Also note that atomic helpers don't optimize out plane flips for same >> > buffers. We only optimize out some of the waiting, in a failed attempt at >> > making cursors stall less, but that's not fixed with the async plane >> > update stuff. And we can obviously optimize out the prepare/cleanup hooks, >> > because the buffer should be pinned already. >> > >> > So imo for a quick fix I think we need: >> > 1) Fix drivers (or at least msm) to upload buffers for manual upload on >> > all flips (well, all screen updates). Probably should do the fence waiting >> > unconditionally too (and handle cursors with the new async stuff). >> > 2) Tiny helper that remaps a dirtyfb call into a nonblocking atomic >> > commit, which currently means we're throwing the dirty rect optimization >> > into the wind. But that could easily be added to the drm_plane_state, >> > without exposing it to userspace as a property just yet. >> > >> > Cheers, Daniel >> > -- >> > Daniel Vetter >> > Software Engineer, Intel Corporation >> > http://blog.ffwll.ch >> _______________________________________________ >> dri-devel mailing list >> dri-devel@lists.freedesktop.org >> https://lists.freedesktop.org/mailman/listinfo/dri-devel > > -- > Daniel Vetter > Software Engineer, Intel Corporation > http://blog.ffwll.ch