Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp203677ybi; Tue, 16 Jul 2019 19:09:56 -0700 (PDT) X-Google-Smtp-Source: APXvYqxxKJmZzAI13NeEUTD5UOHoEbJczAZaZ/Wqu4PkdKhXtS4eOaVKlehu6hzqMq7YGuqnMv7c X-Received: by 2002:a63:e901:: with SMTP id i1mr21878116pgh.451.1563329395799; Tue, 16 Jul 2019 19:09:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1563329395; cv=none; d=google.com; s=arc-20160816; b=a4+tkaHfTmSFGzIjhP3oDyxfyuxVQNX3oC0XBkxarZTddNJOrcFCQPUnK+JlR8P5Rg ZQi1bOA15if8onHuzjU7VktQYyQGifhMOxUOMgl1PwMmogR2/p3QTx2tLMvBrnrFs/ze hmYZ6qIhqBeMlTVEEcptGeQjPQRbdpdRGiuv8bzdYqipC4QwHkZFJ2v4TKA1TrCd2He0 HtTqbb/ohSwfdVSIKIlqvYmZwNZbeAMY3oIVqG+5R+KB5Hh46rr/XRBiDUZSLiA05Vrz LRoWCV881cPkjjWTf/1UGMydS0khnLXjja0Imqv5Qm0kLq9MUwTSCYP7SK7WrlwiTvr5 kv/w== 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:message-id:subject:to :from:date:dkim-signature; bh=IP2uVEPbIAzpGypWmMwZYQMjWgXBZrIwHeY5kTSzUnI=; b=KlXd9fXZHAVWCc2+Q9LGrFpiKT9FSISSWW3Rb9m4K25KO9ey5YlLEII8KtZo76EiMo ggj8sb39C10oXTUA4vOU3TGc+euxuRX5a1tj3/ipBiNrVctH69EYr2aJIXVe1te5SNWw 4laJCvHUjhmxOjDZL6r3IZsQ+qpelUjcYxJeMVU4/iUhgHOIn7oYDP+mGtp2bpkz9vOG YZ/4dPzF+MO4IIPeMABJ4j9xxxxTieuJ/Dra4Jk1XXlRVxmhcOGX+UEA5TMwj+Hnv5yA VmOzVSZU75pr61ZJLWQ3LJG3asrpbMZNNyaZVdNsNUZKqom8+5qyx0xDrLXuyCBNZZpE nJ6Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=QduOLZsr; 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 v2si20251476pjy.48.2019.07.16.19.09.38; Tue, 16 Jul 2019 19:09:55 -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=QduOLZsr; 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 S1727416AbfGQCHm (ORCPT + 99 others); Tue, 16 Jul 2019 22:07:42 -0400 Received: from mail-qk1-f193.google.com ([209.85.222.193]:40566 "EHLO mail-qk1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725892AbfGQCHm (ORCPT ); Tue, 16 Jul 2019 22:07:42 -0400 Received: by mail-qk1-f193.google.com with SMTP id s145so16249908qke.7 for ; Tue, 16 Jul 2019 19:07:42 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=date:from:to:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=IP2uVEPbIAzpGypWmMwZYQMjWgXBZrIwHeY5kTSzUnI=; b=QduOLZsrNp0z6hne15BBhmgcbZc0yNFvihobCtsn7/Tlf9116Wd1UfbQP3H1pGpbUv /2gml2kbhUt5y2KOplxKzcXdUGs2MJA7/cykVzJBm5oaYeHrNtFh3fbom6OxYu892o7z GokTxnEUcwZuwdpmR8dssn4IBq+bIheL97qADs4G1UUvCnq7yasCRdvRSU5DHk1MP1W8 nWysr2BRTlJnb9wzAb+U1FkBGltEahmJVCaiBZqLfyfDvu+cmEIQx1H4H1m0o5TvU1LB WN6O6d9AbTiFhjxc+61dg4Unl/XA/xu1s7kcKBnRFpLt76LuGlLNdsX0Tetzg8TM/mwi /BuQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=IP2uVEPbIAzpGypWmMwZYQMjWgXBZrIwHeY5kTSzUnI=; b=hYYPOcwrFc0T/zsHvjIj2yPE1w9AT+mXEwVqhFi8Bh43pwvjZIjDsxQejRVGCsy7Kb WjdICsAJJsx4v2JWMSbUMWB9FDuLapCVDd0W5EumF80bkHbp05gYuG5BW+WRkMpwnw0m vQG3NEBaajrl9PoC4eo+cnJDCRIBxrL5y2J8DOeORCu9/ul8j6WXhLKL1/vl6JqmKA8Q RWqM/sTTf9Hf1hCQu8+DMSFckAlEDh43ebMxDXUjdfGrhg7HT6trc+a/2zUqC4Xrs2Ii kGAPZyAUWfCZMSZZorxCsVQlAKdliDnT5DkOKqCe0KRa5B567krTEIsME3XpScLWtEzz hflw== X-Gm-Message-State: APjAAAXm9QQ0MnauvFUFod/tRq4ZjaMd5joj+2OFNG9caDqA6ng5PqmR LS7f3/PfFWMUvSwgh7kJzq3CBufQ1fQ= X-Received: by 2002:a05:620a:142e:: with SMTP id k14mr24078298qkj.336.1563329261678; Tue, 16 Jul 2019 19:07:41 -0700 (PDT) Received: from smtp.gmail.com ([187.121.151.22]) by smtp.gmail.com with ESMTPSA id z18sm10659315qka.12.2019.07.16.19.07.39 (version=TLS1_3 cipher=AEAD-AES256-GCM-SHA384 bits=256/256); Tue, 16 Jul 2019 19:07:41 -0700 (PDT) Date: Tue, 16 Jul 2019 23:07:37 -0300 From: Rodrigo Siqueira To: Haneen Mohammed , David Airlie , Simon Ser , Oleg Vasilev , dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH V3] drm/vkms: Add support for vkms work without vblank Message-ID: <20190717020737.z2mu64s3lfyt7pl7@smtp.gmail.com> References: <20190710015514.42anrmx3r2ijaomz@smtp.gmail.com> <20190710164036.GZ15868@phenom.ffwll.local> <20190712025718.wdlafaujpxhpupj7@smtp.gmail.com> <20190716090345.GX15868@phenom.ffwll.local> MIME-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha512; protocol="application/pgp-signature"; boundary="wy4ejomefpiiq7cz" Content-Disposition: inline In-Reply-To: <20190716090345.GX15868@phenom.ffwll.local> User-Agent: NeoMutt/20180716 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --wy4ejomefpiiq7cz Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On 07/16, Daniel Vetter wrote: > On Thu, Jul 11, 2019 at 11:57:18PM -0300, Rodrigo Siqueira wrote: > > On 07/10, Daniel Vetter wrote: > > > On Tue, Jul 09, 2019 at 10:55:14PM -0300, Rodrigo Siqueira wrote: > > > > Currently, vkms only work with enabled VBlank. This patch adds anot= her > > > > operation model that allows vkms to work without VBlank support. In= this > > > > scenario, vblank signaling is faked by calling drm_send_vblank_even= t() > > > > in vkms_crtc_atomic_flush(); this approach works due to the > > > > drm_vblank_get() =3D=3D 0 checking. > > > >=20 > > > > Changes since V2: > > > > - Rebase > > > >=20 > > > > Changes since V1: > > > > Daniel Vetter: > > > > - Change module parameter name from disablevblank to virtual_hw > > > > - Improve parameter description > > > > - Improve commit message > > > >=20 > > > > Signed-off-by: Rodrigo Siqueira > > > > --- > > > > drivers/gpu/drm/vkms/vkms_crtc.c | 10 ++++++++++ > > > > drivers/gpu/drm/vkms/vkms_drv.c | 13 +++++++++++-- > > > > drivers/gpu/drm/vkms/vkms_drv.h | 2 ++ > > > > 3 files changed, 23 insertions(+), 2 deletions(-) > > > >=20 > > > > diff --git a/drivers/gpu/drm/vkms/vkms_crtc.c b/drivers/gpu/drm/vkm= s/vkms_crtc.c > > > > index 49a8ec2cb1c1..a0c75b8c4335 100644 > > > > --- a/drivers/gpu/drm/vkms/vkms_crtc.c > > > > +++ b/drivers/gpu/drm/vkms/vkms_crtc.c > > > > @@ -207,12 +207,22 @@ static int vkms_crtc_atomic_check(struct drm_= crtc *crtc, > > > > static void vkms_crtc_atomic_enable(struct drm_crtc *crtc, > > > > struct drm_crtc_state *old_state) > > > > { > > > > + struct vkms_output *vkms_out =3D drm_crtc_to_vkms_output(crtc); > > > > + > > > > + if (vkms_out->disable_vblank) > > > > + return; > > > > + > > > > drm_crtc_vblank_on(crtc); > > > > } > > > > =20 > > > > static void vkms_crtc_atomic_disable(struct drm_crtc *crtc, > > > > struct drm_crtc_state *old_state) > > > > { > > > > + struct vkms_output *vkms_out =3D drm_crtc_to_vkms_output(crtc); > > > > + > > > > + if (vkms_out->disable_vblank) > > > > + return; > > > > + > > > > drm_crtc_vblank_off(crtc); > > > > } > > > > =20 > > > > diff --git a/drivers/gpu/drm/vkms/vkms_drv.c b/drivers/gpu/drm/vkms= /vkms_drv.c > > > > index 152d7de24a76..542a002ef9d5 100644 > > > > --- a/drivers/gpu/drm/vkms/vkms_drv.c > > > > +++ b/drivers/gpu/drm/vkms/vkms_drv.c > > > > @@ -34,6 +34,11 @@ bool enable_writeback; > > > > module_param_named(enable_writeback, enable_writeback, bool, 0444); > > > > MODULE_PARM_DESC(enable_writeback, "Enable/Disable writeback conne= ctor"); > > > > =20 > > > > +bool virtual_hw; > > >=20 > > > Can be static, you only use this in vkms_drv.c. > > >=20 > > > > +module_param_named(virtual_hw, virtual_hw, bool, 0444); > > > > +MODULE_PARM_DESC(virtual_hw, > > > > + "Enable virtual hardware mode (disables vblanks and immediately= completes flips)"); > > > > + > > > > static const struct file_operations vkms_driver_fops =3D { > > > > .owner =3D THIS_MODULE, > > > > .open =3D drm_open, > > > > @@ -154,9 +159,13 @@ static int __init vkms_init(void) > > > > if (ret) > > > > goto out_unregister; > > > > =20 > > > > - vkms_device->drm.irq_enabled =3D true; > > > > + vkms_device->output.disable_vblank =3D virtual_hw; > > > > + vkms_device->drm.irq_enabled =3D !virtual_hw; > > > > + > > > > + if (virtual_hw) > > > > + DRM_INFO("Virtual hardware mode enabled"); > > > > =20 > > > > - ret =3D drm_vblank_init(&vkms_device->drm, 1); > > > > + ret =3D (virtual_hw) ? 0 : drm_vblank_init(&vkms_device->drm, 1); > > > > if (ret) { > > > > DRM_ERROR("Failed to vblank\n"); > > > > goto out_fini; > > > > diff --git a/drivers/gpu/drm/vkms/vkms_drv.h b/drivers/gpu/drm/vkms= /vkms_drv.h > > > > index 9ff2cd4ebf81..256e5e65c947 100644 > > > > --- a/drivers/gpu/drm/vkms/vkms_drv.h > > > > +++ b/drivers/gpu/drm/vkms/vkms_drv.h > > > > @@ -21,6 +21,7 @@ > > > > =20 > > > > extern bool enable_cursor; > > > > extern bool enable_writeback; > > > > +extern bool virtual_hw; > > > > =20 > > > > struct vkms_composer { > > > > struct drm_framebuffer fb; > > > > @@ -69,6 +70,7 @@ struct vkms_output { > > > > struct drm_connector connector; > > > > struct drm_writeback_connector wb_connector; > > > > struct hrtimer vblank_hrtimer; > > > > + bool disable_vblank; > > > > ktime_t period_ns; > > > > struct drm_pending_vblank_event *event; > > > > /* ordered wq for composer_work */ > > >=20 > > > I'm kinda wondering how this works at all ... does writeback/crc still > > > work if you set virtual mode? Writeback since this seems based on the > > > writeback series ... > >=20 > > Hi, > >=20 > > I tested this patch with kms_flip with the "drm/drm_vblank: Change > > EINVAL by the correct errno" patch [1]. However, you=E2=80=99re right a= bout the > > writeback/crc tests, they does not pass because this patch disables > > vblank which in turn does not invoke "vkms_vblank_simulate()". > >=20 > > In this sense, I=E2=80=99m a little bit confused about how should I han= dle this > > issue. If I correctly understood, without vblank support we have to > > trigger vkms_composer_worker() when the userspace invoke > > drmModePageFlip(), am I right? If so, an approach could add page_flip() > > callback to vkms and invoke vkms_composer_worker(); however, the > > documentation says that page_flip is a legacy entry point. Do you have a > > suggestion? >=20 > We need this in atomic, for everyone. So instead of launching a vblank and > letting the vblank simulation kick off the crc/writeback work, > atomic_flush needs to also kick of the crc/vblank work. And make sure that > we feed the same vblank frame count values to the generated vblank even as > to the crc work (or maybe those are hardcoded to 0 for vblank-less, not > sure). > -Daniel Just for checking if I correctly understood... the idea is reworking vkms_vblank_simulate() a little bit in order to decouple the kick of crc/writeback to atomic_flush(). Right? =20 > >=20 > > 1. https://patchwork.freedesktop.org/patch/314399/?series=3D50697&rev= =3D7 > >=20 > > Thanks > > =20 > > > btw if you send out patches that need other patches, point at that ot= her > > > series in the cover letter or patch. Gets confusing fast otherwise. > > > -Daniel > > > --=20 > > > Daniel Vetter > > > Software Engineer, Intel Corporation > > > http://blog.ffwll.ch > >=20 > > --=20 > > Rodrigo Siqueira > > https://siqueira.tech >=20 >=20 >=20 > > _______________________________________________ > > dri-devel mailing list > > dri-devel@lists.freedesktop.org > > https://lists.freedesktop.org/mailman/listinfo/dri-devel >=20 >=20 > --=20 > Daniel Vetter > Software Engineer, Intel Corporation > http://blog.ffwll.ch --=20 Rodrigo Siqueira https://siqueira.tech --wy4ejomefpiiq7cz Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iQIzBAEBCgAdFiEE4tZ+ii1mjMCMQbfkWJzP/comvP8FAl0ugugACgkQWJzP/com vP/+aA/9EP5Fdxa15qHv0znCbXQ1doJyn/FqSXV5T4w3fTgRZM8+GIEvS6xHEN1J sswU8lpuPzAmoFnwXhNY503JENCAMVp50sr1OQIJPwGja1jLAYqpGedKUKLrXMwm QTX7EjaQWNysRy4oy22XFTga2ozCAMWOhlGOjLyij+3nzZ4kWJKajpvMoy5NeL3U SiFlEFQ34uEv5/rKqGyMZRQOojdW1T2ityHdzscJf0eGC+FS5AQtBHev9O6tTPQd QTiQXPL4SE7a79dEuDSWCp2F/F2Lfy0p+8f2Q0kbJrfxNhTouifhRVJAZZQTXfcJ JWjBKjXUpkCuy2LGdxZmpt3dTLtawys4KtyJCRL3HU/dWJ1pEUDpIrvNzUdTFdHt 6qlB1dn6aoUp8XhNt3s6BTV99/021KxZR+lLhL6+tWxIg4/pdn+SpZnCkxC2eloP VjuH+DCgWc5wtZAFOaCq+7qeebqYmfIjIDzeeim6TLoAaNx4zz75Zjpz4zDifxtK 46eSygog5AHoqKtYWN31wJQOWeDZtwf1I2/Kio2VgJEdICKGv9I/7aRgab+2pvj1 3FWalEoKnaDm8kRVHJVw8/NZrL6ui0rwMjm/VUBgRjGOvBXxarVbtGXQjDuwEdrN hnqtY3ynwYQsyIbc+7IVwrSwNiWKQJsM31TlBP5mzUBWmwitCpk= =Rsi1 -----END PGP SIGNATURE----- --wy4ejomefpiiq7cz--