Received: by 2002:a05:6a10:144:0:0:0:0 with SMTP id 4csp267308pxw; Fri, 8 Apr 2022 07:08:07 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzNNddb3kM9EsNV2MBAfGpy7gzVz81Q6yq7o63cx1idDUXkGC8ez5IyjoyeW4E3cYWmcC8/ X-Received: by 2002:aa7:d047:0:b0:41d:57cf:d588 with SMTP id n7-20020aa7d047000000b0041d57cfd588mr1368246edo.172.1649426887679; Fri, 08 Apr 2022 07:08:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1649426887; cv=none; d=google.com; s=arc-20160816; b=UCibfAT9psj03v3UdxSV5rdTTuD6mueAgovmIea7j85eRdy/o+rhwaUpF565n2+o9A jxkdQtKNz9WrpMpCn1Avt+qEPr+MxHYw9sF2ijHaS5/Xs24WzpzoGwWvIPjeT4b6lVWF ZBtI7A3YW1ImOFSp5hWYNKEIMtZQ+ZDk9X6xvRxER3OzdwoGiKBGiayLaGqOb531hqYF IsUG17qlSYboV/BkgeiaKHq5pFe7Az+ILwISjl3uabNTzBdSITgs02+2V6O9jBEfXZPO Rf5dHY7kd8CXNcWxy+KI7flAbXSHQ1jmA14cPSJ3bJy67kcGp3B6D6+q4FjEOoW9TI3+ IFWQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=wQ32oIqx14rnvXLxjvE2i+RnWC98UtztZC7z3pVQWG0=; b=RWu+sUoSq+JJk51fWS/0C657aRtvLH3XXCNONLWYOdmmb0dnWYOyUPCSeNoYEO7dnM KY2U21PYx/YR7RCgEyPeWoQwztMd/GUHkUbSWmbiXYi9KDwS42MkpDWxxBn+PDO+fXvL 6sqP6XvDWlS9kwQthyOCfZrLupt64g0OMtbIF+8OXPGEiFaID1pI4hQw4tOSRb/N5q/Y yZrcg0O61DiblvoSSeg2BlCdwDlxF7DK/mGfH+ngcOTEklP7pz2Sp6xwevrDdBhMk9yK s3MZamKkXdaZjtWSezaBbRXH0JjnR9fq1Bg93DIQZoTV5i0aLKJF08u2+C/e2O5UZ7JD 4Bcg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=AbFjIX8h; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id h26-20020a170906591a00b006e748e41ce3si1047735ejq.385.2022.04.08.07.07.10; Fri, 08 Apr 2022 07:08:07 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=AbFjIX8h; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 S234782AbiDHK5f (ORCPT + 99 others); Fri, 8 Apr 2022 06:57:35 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36454 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234800AbiDHK5b (ORCPT ); Fri, 8 Apr 2022 06:57:31 -0400 Received: from mail-qt1-x835.google.com (mail-qt1-x835.google.com [IPv6:2607:f8b0:4864:20::835]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1DE9B62A3A for ; Fri, 8 Apr 2022 03:55:27 -0700 (PDT) Received: by mail-qt1-x835.google.com with SMTP id s11so10345152qtc.3 for ; Fri, 08 Apr 2022 03:55:27 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=wQ32oIqx14rnvXLxjvE2i+RnWC98UtztZC7z3pVQWG0=; b=AbFjIX8hslk9QQUB7VIg/V2V9rNvdg+6M+CE8a3dm7OqpujpJZgeWTTERV3NVZMCC3 JgtmGdfdY7epLJRAqh70xZxPIL//GGVMhn8Rx7sVDtBPl/KS+rUKXdPG3W1a7CWlTho4 QbZA3oN8ua1KAeSACKN7V1zUDC0cDHbTWe3W4MGYWaxScO1Bhl1DlU0mYo0v6CiBz/+r kqH9q640xPC3VWzF4Gk7PDTHxwxhYkLBEfIBz1xv49ZsmsjxHPrAjwRN3cRIiT7K7Kwe th54qu+Wfdzv7o//SgeK3weD25KwAUJzSJVr8Oeo3zy+Z76swvOkwMTjnFo4eROTsiXn i81A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=wQ32oIqx14rnvXLxjvE2i+RnWC98UtztZC7z3pVQWG0=; b=chfAMO/WXOKkMtxrvxAc+fV9yMe48lUP6ApAIGs2lt1sT/RWvE4ZkbVu4N/I+/c4uZ BcAxijnRgI+T587s/W1wKTAdcHUeLTl8UzA7nhb1mINVaKEdtXBCy36JPRO0SPebbvKR zD9VcR7UHFJNXXMM3l6u3DkSHHE/oWM9bIWrSt0EnCxa6Ps3zukVdC9rY/pn2yUn6tMg 1HNb/M6cGGDYjCVnnQD/ZDODYTD9KNfJVhySVlWYuxCIsX7UEmxhvdAsCl/Q3SIew885 RfpgrLSvNeUqZaAT/RnQUIeJ8IbSywq+pQjwXqbRR/pWMKOC7QOKL+t2H+KXykfCtvby 8sUg== X-Gm-Message-State: AOAM531ppIygJUyWF4dCUTfmFRNTu6Rc8VSQum3asoedlifHQcBkKsyk qIou+xO6haU/c4OP/g0Pdc5aWh87b9nC4DdLwsY= X-Received: by 2002:ac8:588c:0:b0:2e1:ee12:3473 with SMTP id t12-20020ac8588c000000b002e1ee123473mr15545900qta.455.1649415326229; Fri, 08 Apr 2022 03:55:26 -0700 (PDT) MIME-Version: 1.0 References: <20220407125839.1479249-1-alexander.usyskin@intel.com> <20220407125839.1479249-21-alexander.usyskin@intel.com> In-Reply-To: <20220407125839.1479249-21-alexander.usyskin@intel.com> From: Matthew Auld Date: Fri, 8 Apr 2022 11:54:59 +0100 Message-ID: Subject: Re: [Intel-gfx] [PATCH 20/20] drm/i915/gsc: allocate extended operational memory in LMEM To: Alexander Usyskin Cc: Greg Kroah-Hartman , Jani Nikula , Joonas Lahtinen , Rodrigo Vivi , David Airlie , Daniel Vetter , Tvrtko Ursulin , Alan Previn , Intel Graphics Development , kernel list , Tomas Winkler , Vitaly Lubart Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 7 Apr 2022 at 14:00, Alexander Usyskin wrote: > > From: Tomas Winkler > > GSC requires more operational memory than available on chip. > Reserve 4M of LMEM for GSC operation. The memory is provided to the > GSC as struct resource to the auxiliary data of the child device. > > Signed-off-by: Tomas Winkler > Signed-off-by: Daniele Ceraolo Spurio > Cc: Alan Previn > --- > drivers/gpu/drm/i915/gt/intel_gsc.c | 92 ++++++++++++++++++++++++++--- > drivers/gpu/drm/i915/gt/intel_gsc.h | 3 + > 2 files changed, 88 insertions(+), 7 deletions(-) > > diff --git a/drivers/gpu/drm/i915/gt/intel_gsc.c b/drivers/gpu/drm/i915/gt/intel_gsc.c > index bfc307e49bf9..4d87519d5773 100644 > --- a/drivers/gpu/drm/i915/gt/intel_gsc.c > +++ b/drivers/gpu/drm/i915/gt/intel_gsc.c > @@ -7,6 +7,7 @@ > #include > #include "i915_drv.h" > #include "i915_reg.h" > +#include "gem/i915_gem_region.h" > #include "gt/intel_gsc.h" > #include "gt/intel_gt.h" > > @@ -36,12 +37,68 @@ static int gsc_irq_init(int irq) > return irq_set_chip_data(irq, NULL); > } > > +static int > +gsc_ext_om_alloc(struct intel_gsc *gsc, struct intel_gsc_intf *intf, size_t size) > +{ > + struct intel_gt *gt = gsc_to_gt(gsc); > + struct drm_i915_gem_object *obj; > + void *vaddr; > + int err; > + > + obj = i915_gem_object_create_lmem(gt->i915, size, I915_BO_ALLOC_CONTIGUOUS); > + if (IS_ERR(obj)) { > + drm_err(>->i915->drm, "Failed to allocate gsc memory\n"); > + return PTR_ERR(obj); > + } > + > + err = i915_gem_object_pin_pages_unlocked(obj); > + if (err) { > + drm_err(>->i915->drm, "Failed to pin pages for gsc memory\n"); > + goto out_put; > + } > + > + vaddr = i915_gem_object_pin_map_unlocked(obj, i915_coherent_map_type(gt->i915, obj, true)); > + if (IS_ERR(vaddr)) { > + err = PTR_ERR(vaddr); > + drm_err(>->i915->drm, "Failed to map gsc memory\n"); > + goto out_unpin; > + } > + > + memset(vaddr, 0, obj->base.size); We should be able to pass I915_BO_ALLOC_CPU_CLEAR to create_lmem, which should do something like this for us, when later calling pin_pages or similar. > + > + i915_gem_object_unpin_map(obj); > + > + intf->gem_obj = obj; > + > + return 0; > + > +out_unpin: > + i915_gem_object_unpin_pages(obj); > +out_put: > + i915_gem_object_put(obj); > + return err; > +} > + > +static void gsc_ext_om_destroy(struct intel_gsc_intf *intf) > +{ > + struct drm_i915_gem_object *obj = fetch_and_zero(&intf->gem_obj); > + > + if (!obj) > + return; > + > + if (i915_gem_object_has_pinned_pages(obj)) > + i915_gem_object_unpin_pages(obj); > + > + i915_gem_object_put(obj); > +} > + > struct gsc_def { > const char *name; > unsigned long bar; > size_t bar_size; > bool use_polling; > bool slow_fw; > + size_t lmem_size; > }; > > /* gsc resources and definitions (HECI1 and HECI2) */ > @@ -74,6 +131,7 @@ static const struct gsc_def gsc_def_dg2[] = { > .name = "mei-gsc", > .bar = DG2_GSC_HECI1_BASE, > .bar_size = GSC_BAR_LENGTH, > + .lmem_size = SZ_4M, > }, > { > .name = "mei-gscfi", > @@ -90,26 +148,33 @@ static void gsc_release_dev(struct device *dev) > kfree(adev); > } > > -static void gsc_destroy_one(struct intel_gsc_intf *intf) > +static void gsc_destroy_one(struct drm_i915_private *i915, > + struct intel_gsc *gsc, unsigned int intf_id) > { > + struct intel_gsc_intf *intf = &gsc->intf[intf_id]; > + > if (intf->adev) { > auxiliary_device_delete(&intf->adev->aux_dev); > auxiliary_device_uninit(&intf->adev->aux_dev); > intf->adev = NULL; > } > + > if (intf->irq >= 0) > irq_free_desc(intf->irq); > intf->irq = -1; > + > + gsc_ext_om_destroy(intf); > } > > static void gsc_init_one(struct drm_i915_private *i915, > - struct intel_gsc_intf *intf, > - unsigned int intf_id) > + struct intel_gsc *gsc, > + unsigned int intf_id) > { > struct pci_dev *pdev = to_pci_dev(i915->drm.dev); > struct mei_aux_device *adev; > struct auxiliary_device *aux_dev; > const struct gsc_def *def; > + struct intel_gsc_intf *intf = &gsc->intf[intf_id]; > int ret; > > intf->irq = -1; > @@ -141,7 +206,7 @@ static void gsc_init_one(struct drm_i915_private *i915, > intf->irq = irq_alloc_desc(0); > if (intf->irq < 0) { > drm_err(&i915->drm, "gsc irq error %d\n", intf->irq); > - return; > + goto fail; > } > > ret = gsc_irq_init(intf->irq); > @@ -155,6 +220,19 @@ static void gsc_init_one(struct drm_i915_private *i915, > if (!adev) > goto fail; > > + if (def->lmem_size) { > + dev_dbg(&pdev->dev, "setting up GSC lmem\n"); > + > + if (gsc_ext_om_alloc(gsc, intf, def->lmem_size)) { > + dev_err(&pdev->dev, "setting up gsc extended operational memory failed\n"); > + kfree(adev); > + goto fail; > + } > + > + adev->ext_op_mem.start = i915_gem_object_get_dma_address(intf->gem_obj, 0); > + adev->ext_op_mem.end = adev->ext_op_mem.start + def->lmem_size; > + } > + > adev->irq = intf->irq; > adev->bar.parent = &pdev->resource[0]; > adev->bar.start = def->bar + pdev->resource[0].start; > @@ -188,7 +266,7 @@ static void gsc_init_one(struct drm_i915_private *i915, > > return; > fail: > - gsc_destroy_one(intf); > + gsc_destroy_one(i915, gsc, intf->id); > } > > static void gsc_irq_handler(struct intel_gt *gt, unsigned int intf_id) > @@ -229,7 +307,7 @@ void intel_gsc_init(struct intel_gsc *gsc, struct drm_i915_private *i915) > return; > > for (i = 0; i < INTEL_GSC_NUM_INTERFACES; i++) > - gsc_init_one(i915, &gsc->intf[i], i); > + gsc_init_one(i915, gsc, i); > } > > void intel_gsc_fini(struct intel_gsc *gsc) > @@ -241,5 +319,5 @@ void intel_gsc_fini(struct intel_gsc *gsc) > return; > > for (i = 0; i < INTEL_GSC_NUM_INTERFACES; i++) > - gsc_destroy_one(&gsc->intf[i]); > + gsc_destroy_one(gt->i915, gsc, i); > } > diff --git a/drivers/gpu/drm/i915/gt/intel_gsc.h b/drivers/gpu/drm/i915/gt/intel_gsc.h > index 68582f912b21..fcac1775e9c3 100644 > --- a/drivers/gpu/drm/i915/gt/intel_gsc.h > +++ b/drivers/gpu/drm/i915/gt/intel_gsc.h > @@ -20,11 +20,14 @@ struct mei_aux_device; > > /** > * struct intel_gsc - graphics security controller > + * > + * @gem_obj: scratch memory GSC operations > * @intf : gsc interface > */ > struct intel_gsc { > struct intel_gsc_intf { > struct mei_aux_device *adev; > + struct drm_i915_gem_object *gem_obj; > int irq; > unsigned int id; > } intf[INTEL_GSC_NUM_INTERFACES]; > -- > 2.32.0 >