Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp1185779imm; Fri, 12 Oct 2018 13:19:38 -0700 (PDT) X-Google-Smtp-Source: ACcGV63FWFZtlixWBNIQBhMcI+xFxxSlpe0WRdlhpvrjySw8RslvV/BNGcg14H3G3xO9c9l6hduT X-Received: by 2002:a17:902:7b94:: with SMTP id w20-v6mr7245151pll.56.1539375578007; Fri, 12 Oct 2018 13:19:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539375577; cv=none; d=google.com; s=arc-20160816; b=zNqr2bmGz0ThDhQ8NunGDQ4WkzYcKOdUyAWEK2l2NkpIFTabVqz+FX/9mfGTSrrdUz ydCfL/8z3bcsEzHCTiEKkp+lC3fbDcpq2o03taAbtJsdhATJutyGMKbHiK8/My9zfERG fYJ7oGcTADNe0pXbyGiTDz/vn0mj/KdgN1Rs9kTQ99VvZYHLv9NoKuMvDNaT1yMGwYCE GH/bXdU8BjcGB6IrzCm6EuUrGO3gaYFGyHXmxKettNzumVg3avcjbafHnW9iHdIdGSWv 2xsRj+NRVAuWIs1fkOCI9ryARab0R5WgcDFNnIUKlXABafSZH9wCqr3OsK3/ifhAghVR sweQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:dkim-signature; bh=b6E8oXItaNH66wt3E4Y8dtew64zag+r7x73OQ+Bu6e8=; b=TP/Nzq+KvEreMMHeL0b+3snMq7ptfQsTMeZmYXK4rPaUwnhJZhcTTge/dazm9dtkdG 1NKaDngn/plbngcddk34P/C2fZcCQ59s2Hc1TejfqxH759IPBmVSAI83nryBC4A2kZS0 o/fF+iDELauWnB2Y0kZc1PfGofvTnRLUh8spbocTXukMKyDqvrBkAmxey9ELYbY5ZPbd CAeT6JLT+DG5vhaX2ELTLTKe1TqexiHnOzvPJoDpHzWSfDI2T4GGQXIcP5UI+mUTcB45 Hlv2u0nlrhxbEoFwjBTpsUUxh1XI6TIVdh5ILzm0jVhUZjeb0X0kAhBnLCBxo4WDN56o 5Vog== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=J2pB9MSO; 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=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v13-v6si2157666plo.182.2018.10.12.13.19.23; Fri, 12 Oct 2018 13:19:37 -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=@ti.com header.s=ti-com-17Q1 header.b=J2pB9MSO; 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=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727181AbeJMDvc (ORCPT + 99 others); Fri, 12 Oct 2018 23:51:32 -0400 Received: from fllv0016.ext.ti.com ([198.47.19.142]:56838 "EHLO fllv0016.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727071AbeJMDva (ORCPT ); Fri, 12 Oct 2018 23:51:30 -0400 Received: from dflxv15.itg.ti.com ([128.247.5.124]) by fllv0016.ext.ti.com (8.15.2/8.15.2) with ESMTP id w9CKHGLH122224; Fri, 12 Oct 2018 15:17:16 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1539375436; bh=b6E8oXItaNH66wt3E4Y8dtew64zag+r7x73OQ+Bu6e8=; h=From:To:CC:Subject:Date:In-Reply-To:References; b=J2pB9MSO5mt/FiR9UJ5R4a7KoAYNgGpeJYxW/FamKyQKGqfOd7NH6X35WzIIOTFPU sPeyFgAdVX+ZF3k8vyRbMP5SyKWGMZ4bjqtVF2VXEqiEas+t0r/PhAAU4GThH0UA5m vRj69WIdgaz/rukOLbfcZYlCTQXUSNAn3q23bZoc= Received: from DLEE104.ent.ti.com (dlee104.ent.ti.com [157.170.170.34]) by dflxv15.itg.ti.com (8.14.3/8.13.8) with ESMTP id w9CKHGcx011820; Fri, 12 Oct 2018 15:17:16 -0500 Received: from DLEE107.ent.ti.com (157.170.170.37) by DLEE104.ent.ti.com (157.170.170.34) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1466.3; Fri, 12 Oct 2018 15:17:16 -0500 Received: from dflp33.itg.ti.com (10.64.6.16) by DLEE107.ent.ti.com (157.170.170.37) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.1.1466.3 via Frontend Transport; Fri, 12 Oct 2018 15:17:16 -0500 Received: from uda0869644a.dhcp.ti.com (ileax41-snat.itg.ti.com [10.172.224.153]) by dflp33.itg.ti.com (8.14.3/8.13.8) with ESMTP id w9CKH7EZ000402; Fri, 12 Oct 2018 15:17:16 -0500 From: Benoit Parrot To: , , Laurent Pinchart , Daniel Vetter CC: Tomi Valkeinen , Peter Ujfalusi , Jyri Sarha , Benoit Parrot Subject: [Patch v4 5/8] drm/omap: Add global state as a private atomic object Date: Fri, 12 Oct 2018 15:17:00 -0500 Message-ID: <20181012201703.29065-6-bparrot@ti.com> X-Mailer: git-send-email 2.9.0 In-Reply-To: <20181012201703.29065-1-bparrot@ti.com> References: <20181012201703.29065-1-bparrot@ti.com> MIME-Version: 1.0 Content-Type: text/plain X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Global shared resources (like hw overlays) for omapdrm are implemented as a part of atomic state using the drm_private_obj infrastructure available in the atomic core. omap_global_state is introduced as a drm atomic private object. The two funcs omap_get_global_state() and omap_get_existing_global_state() are the two variants that will be used to access omap_global_state. Signed-off-by: Benoit Parrot --- drivers/gpu/drm/omapdrm/omap_drv.c | 97 +++++++++++++++++++++++++++++++++++++- drivers/gpu/drm/omapdrm/omap_drv.h | 23 +++++++++ 2 files changed, 119 insertions(+), 1 deletion(-) diff --git a/drivers/gpu/drm/omapdrm/omap_drv.c b/drivers/gpu/drm/omapdrm/omap_drv.c index 2921cc90f2d8..94658ec79c76 100644 --- a/drivers/gpu/drm/omapdrm/omap_drv.c +++ b/drivers/gpu/drm/omapdrm/omap_drv.c @@ -129,6 +129,94 @@ static const struct drm_mode_config_funcs omap_mode_config_funcs = { .atomic_commit = drm_atomic_helper_commit, }; +/* Global/shared object state funcs */ + +/* + * This is a helper that returns the private state currently in operation. + * Note that this would return the "old_state" if called in the atomic check + * path, and the "new_state" after the atomic swap has been done. + */ +struct omap_global_state * +omap_get_existing_global_state(struct omap_drm_private *priv) +{ + return to_omap_global_state(priv->glob_obj.state); +} + +/* + * This acquires the modeset lock set aside for global state, creates + * a new duplicated private object state. + */ +struct omap_global_state *__must_check +omap_get_global_state(struct drm_atomic_state *s) +{ + struct omap_drm_private *priv = s->dev->dev_private; + struct drm_private_state *priv_state; + int ret; + + if (!drm_modeset_is_locked(&priv->glob_obj_lock)) { + ret = drm_modeset_lock(&priv->glob_obj_lock, s->acquire_ctx); + if (ret) { + DBG("getting priv->glob_obj_lock (%p) failed %d", + &priv->glob_obj_lock, ret); + return ERR_PTR(ret); + } + } + + priv_state = drm_atomic_get_private_obj_state(s, &priv->glob_obj); + if (IS_ERR(priv_state)) + return ERR_CAST(priv_state); + + return to_omap_global_state(priv_state); +} + +static struct drm_private_state * +omap_global_duplicate_state(struct drm_private_obj *obj) +{ + struct omap_global_state *state; + + state = kmemdup(obj->state, sizeof(*state), GFP_KERNEL); + if (!state) + return NULL; + + __drm_atomic_helper_private_obj_duplicate_state(obj, &state->base); + + return &state->base; +} + +static void omap_global_destroy_state(struct drm_private_obj *obj, + struct drm_private_state *state) +{ + struct omap_global_state *omap_state = to_omap_global_state(state); + + kfree(omap_state); +} + +static const struct drm_private_state_funcs omap_global_state_funcs = { + .atomic_duplicate_state = omap_global_duplicate_state, + .atomic_destroy_state = omap_global_destroy_state, +}; + +static int omap_global_obj_init(struct omap_drm_private *priv) +{ + struct omap_global_state *state; + + drm_modeset_lock_init(&priv->glob_obj_lock); + + state = kzalloc(sizeof(*state), GFP_KERNEL); + if (!state) + return -ENOMEM; + + drm_atomic_private_obj_init(&priv->glob_obj, &state->base, + &omap_global_state_funcs); + return 0; +} + +static void omap_global_obj_fini(struct omap_drm_private *priv) +{ + drm_atomic_private_obj_fini(&priv->glob_obj); + drm_modeset_lock_fini(&priv->glob_obj_lock); +} + static void omap_disconnect_pipelines(struct drm_device *ddev) { struct omap_drm_private *priv = ddev->dev_private; @@ -569,10 +657,14 @@ static int omapdrm_init(struct omap_drm_private *priv, struct device *dev) omap_gem_init(ddev); - ret = omap_hwoverlays_init(priv); + ret = omap_global_obj_init(priv); if (ret) goto err_gem_deinit; + ret = omap_hwoverlays_init(priv); + if (ret) + goto err_free_priv_obj; + ret = omap_modeset_init(ddev); if (ret) { dev_err(priv->dev, "omap_modeset_init failed: ret=%d\n", ret); @@ -612,6 +704,8 @@ static int omapdrm_init(struct omap_drm_private *priv, struct device *dev) err_cleanup_modeset: drm_mode_config_cleanup(ddev); omap_drm_irq_uninstall(ddev); +err_free_priv_obj: + omap_global_obj_fini(priv); err_free_overlays: omap_hwoverlays_destroy(priv); err_gem_deinit: @@ -644,6 +738,7 @@ static void omapdrm_cleanup(struct omap_drm_private *priv) omap_drm_irq_uninstall(ddev); omap_gem_deinit(ddev); + omap_global_obj_fini(priv); omap_hwoverlays_destroy(priv); destroy_workqueue(priv->wq); diff --git a/drivers/gpu/drm/omapdrm/omap_drv.h b/drivers/gpu/drm/omapdrm/omap_drv.h index 929f04e7cc3b..f374dc100447 100644 --- a/drivers/gpu/drm/omapdrm/omap_drv.h +++ b/drivers/gpu/drm/omapdrm/omap_drv.h @@ -23,6 +23,7 @@ #include #include +#include #include #include #include @@ -54,6 +55,17 @@ struct omap_drm_pipeline { struct omap_dss_device *display; }; +/* + * Global private object state for tracking resources that are shared across + * multiple kms objects (planes/crtcs/etc). + */ +#define to_omap_global_state(x) container_of(x, struct omap_global_state, base) +struct omap_global_state { + struct drm_private_state base; + + struct drm_atomic_state *state; +}; + struct omap_drm_private { struct drm_device *ddev; struct device *dev; @@ -73,6 +85,13 @@ struct omap_drm_private { unsigned int num_ovls; struct omap_hw_overlay *overlays[8]; + /* + * Global private object state, Do not access directly, use + * omap_global_get_state() + */ + struct drm_modeset_lock glob_obj_lock; + struct drm_private_obj glob_obj; + struct drm_fb_helper *fbdev; struct workqueue_struct *wq; @@ -100,5 +119,9 @@ struct omap_drm_private { int omap_debugfs_init(struct drm_minor *minor); +struct omap_global_state *__must_check +omap_get_global_state(struct drm_atomic_state *s); +struct omap_global_state * +omap_get_existing_global_state(struct omap_drm_private *priv); #endif /* __OMAPDRM_DRV_H__ */ -- 2.9.0