Received: by 10.213.65.68 with SMTP id h4csp480573imn; Wed, 4 Apr 2018 01:45:34 -0700 (PDT) X-Google-Smtp-Source: AIpwx480rLLo/HwPSJsC5gIDWlzILhgJ8ttqICdyMOM/0AS2fBR1GruNXyZKkqqmzKA10HNgj6au X-Received: by 2002:a17:902:2862:: with SMTP id e89-v6mr17570852plb.348.1522831534624; Wed, 04 Apr 2018 01:45:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522831534; cv=none; d=google.com; s=arc-20160816; b=G6MFXgSTL4WZwxZasFI1Qz8IM03wb8OmBhHdcJy0seecuKVtYFc8vmTzvxDuWpHC6y 3b7zmi8FuAOpHKtlNHSlm1oE2I/T/3bLQN7LLUs3vkpXbaDeYcdH7xGsTlgIzVeAql9x TBjkMVWmpbHSgpJDSWVYNC42PyTx/i+K90dZOMecVaedNeDu69CjUTziGEoXCezM3HTv /IO45+D9wLMv60JQJ88bUEWReS+JsETV/vM/EPbV/+MaIxc1Q2+9MYLhu8d9tQvqS53j A7/EDg++NHFltDQ5dsCPuZbD59z3VQaF8n7dLKOP3zqLbXnJVIxy/6YjOblTRI9R9i3u wopA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:mail-followup-to :message-id:subject:cc:to:from:date:dkim-signature :arc-authentication-results; bh=E8xAiFigSE1tnhHEvJw1PLb3VpkaDrs+2dL0k/2nPuw=; b=KCcmj9KgwGQ7XxTwWVL4FVBpTnrgZ7fN+pdPntVfClgqH98kcGMjbteb+22GmTE2sd Hij2aDTu7EiH42yRhJAWQNwh/7ktqdZDTrWBCWCz5y5xAtr9M8EfTQGFAHj5wClT2ZTP dLDdNepLJoAzEb69AXP5kfELHlCUlh/e1DCJlKpoNkil9vcUhayf2lCV+Ki8ZaUqLU3C yjl5RGduJ1qL6g+Jgit+5HxAEIMdBNkO/1tynmu2ebKD19ZjXe6sxLYJRM8AQVMXxv8K pf5p8Mn3v3nWJ/rBXyHf9BPKrR3o12DugOSnLn/o7XFmr+spfD6uNglojfWHWY/7sYtx VZMg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@ffwll.ch header.s=google header.b=VVxAs88Q; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 64si3369217pgj.169.2018.04.04.01.45.20; Wed, 04 Apr 2018 01:45: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=fail header.i=@ffwll.ch header.s=google header.b=VVxAs88Q; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751392AbeDDIn1 (ORCPT + 99 others); Wed, 4 Apr 2018 04:43:27 -0400 Received: from mail-wm0-f44.google.com ([74.125.82.44]:35178 "EHLO mail-wm0-f44.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750995AbeDDInZ (ORCPT ); Wed, 4 Apr 2018 04:43:25 -0400 Received: by mail-wm0-f44.google.com with SMTP id r82so40530186wme.0 for ; Wed, 04 Apr 2018 01:43:24 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ffwll.ch; s=google; h=sender:date:from:to:cc:subject:message-id:mail-followup-to :references:mime-version:content-disposition:in-reply-to:user-agent; bh=E8xAiFigSE1tnhHEvJw1PLb3VpkaDrs+2dL0k/2nPuw=; b=VVxAs88QOo5wdymFE4HeurU/uaFGIYARY1kHYoIP4bgoQM7NAtz1Os2cogZsjDSAjH xAA16clIzjM8P5/FCgKhAyTlEH6mAYEGISUaKkac3ZwdcfAhkZJNHevOPHLmTbZ/FuKO tmaaMGVncalKgVjVqnSUaGdTUv819xxLOduaQ= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:date:from:to:cc:subject:message-id :mail-followup-to:references:mime-version:content-disposition :in-reply-to:user-agent; bh=E8xAiFigSE1tnhHEvJw1PLb3VpkaDrs+2dL0k/2nPuw=; b=JOMhGRmgFKfdm3JikNNsiATdMe3A1kYdosmZUVVmerHLG0fLE6IyK4xfxXisPZFLC9 a3755vFjMN+IhsLQQLYLMiTbAiY8NIYiDpsOYDdcA6DWXpIClHtjEG+xpCV5+c9UwtH1 LKjBIOaYYmXKvIru0vuFzQy+3rwfO7H8JBqov2UhKue8KTKZ8YIkxiKHCiVZiJCxMnQo HewFtRUHs5culnbVeUEq3z8H4vrmHsYevmfNHMf1q4BOQzrvp6mReWhoYrGHRLyWL4j9 XeRA9xuIf/M12HAa3FVmfubwAhtG5h6F/ffNsNF/UDkqkuamwRi7G1YlfBCs+lT2GGs+ 2Agg== X-Gm-Message-State: ALQs6tDi0K5cxCt717dtH8+roBo3N5eaSscY4mm/ijQmOH9647phpclf jpb9e6Jnjpjaq0ualWWYUUdZaw== X-Received: by 10.80.202.9 with SMTP id d9mr1995765edi.279.1522831404094; Wed, 04 Apr 2018 01:43:24 -0700 (PDT) Received: from phenom.ffwll.local (212-51-149-109.fiber7.init7.net. [212.51.149.109]) by smtp.gmail.com with ESMTPSA id l9sm2301910edk.9.2018.04.04.01.43.22 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Wed, 04 Apr 2018 01:43:23 -0700 (PDT) Date: Wed, 4 Apr 2018 10:43:20 +0200 From: Daniel Vetter To: Thomas Hellstrom Cc: Daniel Vetter , Rob Clark , Noralf =?iso-8859-1?Q?Tr=F8nnes?= , dri-devel , freedreno , linux-arm-msm , Ville =?iso-8859-1?Q?Syrj=E4l=E4?= , Lukasz Spintzyk , Deepak Singh Rawat , Gustavo Padovan , Maarten Lankhorst , Sean Paul , David Airlie , Linux Kernel Mailing List Subject: Re: [RFC] drm/atomic+msm: add helper to implement legacy dirtyfb Message-ID: <20180404084320.GA3881@phenom.ffwll.local> Mail-Followup-To: Thomas Hellstrom , Rob Clark , Noralf =?iso-8859-1?Q?Tr=F8nnes?= , dri-devel , freedreno , linux-arm-msm , Ville =?iso-8859-1?Q?Syrj=E4l=E4?= , Lukasz Spintzyk , Deepak Singh Rawat , Gustavo Padovan , Maarten Lankhorst , Sean Paul , David Airlie , Linux Kernel Mailing List References: <20180403224225.26776-1-robdclark@gmail.com> <307adb15-412a-1fe2-f116-27fe5b4a657d@shipmail.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <307adb15-412a-1fe2-f116-27fe5b4a657d@shipmail.org> X-Operating-System: Linux phenom 4.15.0-1-amd64 User-Agent: Mutt/1.9.4 (2018-02-28) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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 -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch