Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp7008337ybi; Thu, 13 Jun 2019 08:05:05 -0700 (PDT) X-Google-Smtp-Source: APXvYqyYskcCgQP7uHaj7J+MoPRNHQwJ735WhaAvuMx3Kyofwl1SsiwMx3cmliZjnnPwX4gAjgiM X-Received: by 2002:a62:ce07:: with SMTP id y7mr64621885pfg.12.1560438305842; Thu, 13 Jun 2019 08:05:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1560438305; cv=none; d=google.com; s=arc-20160816; b=HqezSJrQ4onR0r2ZcA+Xcco9ugV6bKdR8gj0genGP4evPSnx7cztwPynUqZ+ZMeLfc 6wZycrsYchovC60fDN1ju5/iwenyhLwgzCEbtc8oP/95qCg2lDxP77SVViHACcn9jv3h vQCMtS7dzWhTeYwgTX4CADHsqglZvroUlLbPk0PvlnOVI5SuLpOOI/wyQSIaomQkyd4P 71kp97WlIcBt7ZnlebXF2a+126lG3embt9NQUVizyspTIVxM0r7SH3muOqcHq/nCD8FH IaJ2kgZe+CJ8tqY4eNc+vFnGp5HjiXKnmTxZS9QUWXN5ysirYhtDIRS4Sj7F9/Wi4Xd9 5PJw== 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-transfer-encoding:content-disposition:mime-version :references:mail-followup-to:message-id:subject:cc:to:from:date :dkim-signature; bh=oVRvqGAJLCqtggjxP8ZfAYvArrXiZbY8dJkI7Luwcsc=; b=TtNcf/bkZeal9qYBkwSG8yDhHOapcJcUHr765mbm/wtxo03l6JvvQeq66FMCu1Mffc UD4FzRPBZy8jr7ob3JPKcQ7lzhxKRCQQSemedOOkZYPcsSmV89Lj+qGdmRyaDlgTv2Nt 93jDt9rzl4LsFDiGUlAtbDLlLSVd5sw3RS+PFHxdYgovjhxQDb2/THU75hM+xVpt1y9K 2JFZK3yrr+6ogey0Bqp+GigEcxaqTRkzI4IbQR62qQeFiYnnCxr2ZawmkMclNNmST1KZ MrtLhMBUcjoJzhaGwVRDfy2RBLdj9MO/DkTn65zjn+pBacM9tHVkO1nThi5ei2bjNvdN Kumg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@ffwll.ch header.s=google header.b="i3Cb/pxt"; 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 k1si50980pgh.69.2019.06.13.08.04.48; Thu, 13 Jun 2019 08:05:05 -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="i3Cb/pxt"; 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 S1733166AbfFMPCS (ORCPT + 99 others); Thu, 13 Jun 2019 11:02:18 -0400 Received: from mail-ed1-f66.google.com ([209.85.208.66]:45230 "EHLO mail-ed1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732518AbfFMOaO (ORCPT ); Thu, 13 Jun 2019 10:30:14 -0400 Received: by mail-ed1-f66.google.com with SMTP id a14so29650639edv.12 for ; Thu, 13 Jun 2019 07:30:12 -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 :content-transfer-encoding:in-reply-to:user-agent; bh=oVRvqGAJLCqtggjxP8ZfAYvArrXiZbY8dJkI7Luwcsc=; b=i3Cb/pxtaFuJB59OOds7nZfbeZKTr03wdxZIiBVwGz7ICL9yEAP7mnHGW1iBJ4KQ3N fr0f6RNoe5b9dXHTySrlYpYQfCwpSiwD6eUhZQRlqzq0EJGjtssgL/E1VOg8usGtXPKm AiEZxfzO/JzzksLBIKfaLTkriITluSuxwFnWo= 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 :content-transfer-encoding:in-reply-to:user-agent; bh=oVRvqGAJLCqtggjxP8ZfAYvArrXiZbY8dJkI7Luwcsc=; b=nx82rgOiSQK4JlHRGMnQ4E6w9NfKDw0c1n9Y+ZfWh6HKFSlQ/hgXtnZ0wfpFshhQ2t XWxCZqs/LmulYE0QxF3l1UCQgG29VkCB4TQbKm+nmaGiJASLITSeK4v8mCAoqssnRGbU 7fXrMa9v4sjwHIB1HY78mHDliauseGWISspdd+Vl8SId+XeIE64mJ27ghXGjMs8gzdms FxQc+N9h2vTrDvDPcS+hXF1kPp2AegFMAoryu8+Vp64igULCNvKheaqnA15NMzfY1xOJ i48FFRWAyueMMRBYFG+dM++4KYDkfc4uwkw3AK/njSnB/kBf488Y7D+AnVN0anOjY0hE BMhg== X-Gm-Message-State: APjAAAUFaKpIfxx4RZL3tFY4V0YPTlPco+k95WZnEP1R4AhKUDCkFOZL BwuhGW/i98fmODnM5f7bxCw4oQ== X-Received: by 2002:a17:906:9149:: with SMTP id y9mr16298345ejw.98.1560436211357; Thu, 13 Jun 2019 07:30:11 -0700 (PDT) Received: from phenom.ffwll.local ([2a02:168:569e:0:3106:d637:d723:e855]) by smtp.gmail.com with ESMTPSA id v6sm923205eds.23.2019.06.13.07.30.09 (version=TLS1_3 cipher=AEAD-AES256-GCM-SHA384 bits=256/256); Thu, 13 Jun 2019 07:30:10 -0700 (PDT) Date: Thu, 13 Jun 2019 16:30:08 +0200 From: Daniel Vetter To: Liviu Dudau Cc: "james qian wang (Arm Technology China)" , "Lowry Li (Arm Technology China)" , "maarten.lankhorst@linux.intel.com" , "seanpaul@chromium.org" , "airlied@linux.ie" , Brian Starkey , Ayan Halder , "Jonathan Chai (Arm Technology China)" , "linux-kernel@vger.kernel.org" , "dri-devel@lists.freedesktop.org" , "Julien Yin (Arm Technology China)" , nd Subject: Re: [PATCH v2 2/2] drm/komeda: Adds komeda_kms_drop_master Message-ID: <20190613143008.GO23020@phenom.ffwll.local> Mail-Followup-To: Liviu Dudau , "james qian wang (Arm Technology China)" , "Lowry Li (Arm Technology China)" , "maarten.lankhorst@linux.intel.com" , "seanpaul@chromium.org" , "airlied@linux.ie" , Brian Starkey , Ayan Halder , "Jonathan Chai (Arm Technology China)" , "linux-kernel@vger.kernel.org" , "dri-devel@lists.freedesktop.org" , "Julien Yin (Arm Technology China)" , nd References: <1560251589-31827-1-git-send-email-lowry.li@arm.com> <1560251589-31827-3-git-send-email-lowry.li@arm.com> <20190611123038.GC2458@phenom.ffwll.local> <20190612022617.GA8595@james-ThinkStation-P300> <20190613081727.GE23020@phenom.ffwll.local> <20190613082813.GM4173@e110455-lin.cambridge.arm.com> <20190613090814.GJ23020@phenom.ffwll.local> <20190613132436.GN4173@e110455-lin.cambridge.arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <20190613132436.GN4173@e110455-lin.cambridge.arm.com> X-Operating-System: Linux phenom 4.19.0-5-amd64 User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Jun 13, 2019 at 02:24:37PM +0100, Liviu Dudau wrote: > On Thu, Jun 13, 2019 at 11:08:14AM +0200, Daniel Vetter wrote: > > On Thu, Jun 13, 2019 at 09:28:13AM +0100, Liviu Dudau wrote: > > > On Thu, Jun 13, 2019 at 10:17:27AM +0200, Daniel Vetter wrote: > > > > On Wed, Jun 12, 2019 at 02:26:24AM +0000, james qian wang (Arm Technology China) wrote: > > > > > On Tue, Jun 11, 2019 at 02:30:38PM +0200, Daniel Vetter wrote: > > > > > > On Tue, Jun 11, 2019 at 11:13:45AM +0000, Lowry Li (Arm Technology China) wrote: > > > > > > > From: "Lowry Li (Arm Technology China)" > > > > > > > > > > > > > > The komeda internal resources (pipelines) are shared between crtcs, > > > > > > > and resources release by disable_crtc. This commit is working for once > > > > > > > user forgot disabling crtc like app quit abnomally, and then the > > > > > > > resources can not be used by another crtc. Adds drop_master to > > > > > > > shutdown the device and make sure all the komeda resources have been > > > > > > > released and can be used for the next usage. > > > > > > > > > > > > > > Signed-off-by: Lowry Li (Arm Technology China) > > > > > > > --- > > > > > > > drivers/gpu/drm/arm/display/komeda/komeda_kms.c | 13 +++++++++++++ > > > > > > > 1 file changed, 13 insertions(+) > > > > > > > > > > > > > > diff --git a/drivers/gpu/drm/arm/display/komeda/komeda_kms.c b/drivers/gpu/drm/arm/display/komeda/komeda_kms.c > > > > > > > index 8543860..647bce5 100644 > > > > > > > --- a/drivers/gpu/drm/arm/display/komeda/komeda_kms.c > > > > > > > +++ b/drivers/gpu/drm/arm/display/komeda/komeda_kms.c > > > > > > > @@ -54,11 +54,24 @@ static irqreturn_t komeda_kms_irq_handler(int irq, void *data) > > > > > > > return status; > > > > > > > } > > > > > > > > > > > > > > +/* Komeda internal resources (pipelines) are shared between crtcs, and resources > > > > > > > + * are released by disable_crtc. But if user forget disabling crtc like app quit > > > > > > > + * abnormally, the resources can not be used by another crtc. > > > > > > > + * Use drop_master to shutdown the device and make sure all the komeda resources > > > > > > > + * have been released, and can be used for the next usage. > > > > > > > + */ > > > > > > > > > > > > No. If we want this, we need to implement this across drivers, not with > > > > > > per-vendor hacks. > > > > > > > > > > > > The kerneldoc should have been a solid hint: "Only used by vmwgfx." > > > > > > -Daniel > > > > > > > > > > Hi Daniel: > > > > > This drop_master is really what we want, can we update the doc and > > > > > add komeda as a user of this hacks like "used by vmwfgx and komeda", > > > > > or maybe directly promote this per-vendor hacks as an optional chip > > > > > function ? > > > > > > > > Still no, because it would mean different behaviour for arm/komeda > > > > compared to everyone else. And we really don't want this, because this > > > > would completely break flicker-less vt-switching. > > > > > > > > Currently the only fallback for this case is the lastclose handler, which > > > > atm just restores fbcon/fbdev. If you want to change/extend that to work > > > > without fbdev, then that's the place to do the change. And across _all_ > > > > drm kms drivers, so that we have consistent behaviour. > > > > > > Slightly unrelated, just thinking of a solution and wanted confirmation/double > > > checking: can a CRTC be instantiated without any planes (or without a primary > > > plane)? > > > > Without a primary plane maybe not so recommended, because it would break > > all the legacy userspace. Might even result in some oopses, not sure we > > check for crtc->primary != NULL. > > > > I'm not sure what you mean about instantiating it without any plane at > > all. That would be rather useless. > > Agree, and I think I have one way of solving the scenario Lowry and James are > trying to cover. Basically, komeda has 2 pipelines that are exposed as 2 crtcs. > However, layers (planes in DRM) can be associated with any of the pipelines and > it is possible to have a DRM master open up crtc0 and enable all possible planes, > which would leave crtc1 with no available layer to use (but technically still visible to > userspace, as it has been drm_crtc_init-ed. James and Lowry are trying to give > another master a chance of enabling crtc1 if previous master drops the > ownership of crtc0 without disabling it. So one solution I'm thinking of is to > tie one of the layers/planes to crtc1 regardless if that pipeline is enabled or > not. > > Alternatively, we need a more generic solution for re-allocating resources > between CRTCs that might be enabled at different times. Ideas on how userspace > should handle it first are welcome as well. Uh, you can't have more than one active master. And that other master needs to clean up the mess left behind by the previous one. Generally that means disabling all the planes, like e.g. fbdev emulation does (but there's a lot more we should probably clean up, current code is kinda just good enough). If you want multiple concurrent masters on the same hw, then you need drm leases, and there you can limit the leases to however many planes you think they need. -Daniel > > Best regards, > Liviu > > > -Daniel > > > > > > > > Best regards, > > > Liviu > > > > > > > > > > > kms is a cross-vendor api, vendor hacks are very, very much not cool. > > > > -Daniel > > > > > > > > > > > > > > James > > > > > > > > > > > > +static void komeda_kms_drop_master(struct drm_device *dev, > > > > > > > + struct drm_file *file_priv) > > > > > > > +{ > > > > > > > +drm_atomic_helper_shutdown(dev); > > > > > > > +} > > > > > > > + > > > > > > > static struct drm_driver komeda_kms_driver = { > > > > > > > .driver_features = DRIVER_GEM | DRIVER_MODESET | DRIVER_ATOMIC | > > > > > > > DRIVER_PRIME | DRIVER_HAVE_IRQ, > > > > > > > .lastclose= drm_fb_helper_lastclose, > > > > > > > .irq_handler= komeda_kms_irq_handler, > > > > > > > +.master_drop= komeda_kms_drop_master, > > > > > > > .gem_free_object_unlocked= drm_gem_cma_free_object, > > > > > > > .gem_vm_ops= &drm_gem_cma_vm_ops, > > > > > > > .dumb_create= komeda_gem_cma_dumb_create, > > > > > > > -- > > > > > > > 1.9.1 > > > > > > > > > > > > > > _______________________________________________ > > > > > > > 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 > > > > > IMPORTANT NOTICE: The contents of this email and any attachments are confidential and may also be privileged. If you are not the intended recipient, please notify the sender immediately and do not disclose the contents to any other person, use it for any purpose, or store or copy the information in any medium. Thank you. > > > > > _______________________________________________ > > > > > 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 > > > > > > -- > > > ==================== > > > | I would like to | > > > | fix the world, | > > > | but they're not | > > > | giving me the | > > > \ source code! / > > > --------------- > > > ¯\_(ツ)_/¯ > > > _______________________________________________ > > > 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 > > -- > ==================== > | I would like to | > | fix the world, | > | but they're not | > | giving me the | > \ source code! / > --------------- > ¯\_(ツ)_/¯ > _______________________________________________ > 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