From: Rodrigo Vivi <rodrigo.vivi@intel.com>
To: Alexander Usyskin <alexander.usyskin@intel.com>
Cc: "Miquel Raynal" <miquel.raynal@bootlin.com>,
"Richard Weinberger" <richard@nod.at>,
"Vignesh Raghavendra" <vigneshr@ti.com>,
"Lucas De Marchi" <lucas.demarchi@intel.com>,
"Thomas Hellström" <thomas.hellstrom@linux.intel.com>,
"Maarten Lankhorst" <maarten.lankhorst@linux.intel.com>,
"Maxime Ripard" <mripard@kernel.org>,
"Thomas Zimmermann" <tzimmermann@suse.de>,
"David Airlie" <airlied@gmail.com>,
"Simona Vetter" <simona@ffwll.ch>,
"Jani Nikula" <jani.nikula@linux.intel.com>,
"Joonas Lahtinen" <joonas.lahtinen@linux.intel.com>,
"Tvrtko Ursulin" <tursulin@ursulin.net>,
"Oren Weil" <oren.jer.weil@intel.com>,
linux-mtd@lists.infradead.org, dri-devel@lists.freedesktop.org,
intel-gfx@lists.freedesktop.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH v2 08/10] drm/i915/nvm: add support for access mode
Date: Thu, 7 Nov 2024 16:41:22 -0500 [thread overview]
Message-ID: <Zy00AoxE0_8p5xCY@intel.com> (raw)
In-Reply-To: <20241107131356.2796969-9-alexander.usyskin@intel.com>
On Thu, Nov 07, 2024 at 03:13:54PM +0200, Alexander Usyskin wrote:
> Check NVM access mode from GSC FW status registers
> and overwrite access status read from SPI descriptor, if needed.
Reviewed-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
>
> Signed-off-by: Alexander Usyskin <alexander.usyskin@intel.com>
> ---
> drivers/gpu/drm/i915/intel_nvm.c | 25 ++++++++++++++++++++++++-
> 1 file changed, 24 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/gpu/drm/i915/intel_nvm.c b/drivers/gpu/drm/i915/intel_nvm.c
> index 214c4d47a9cd..cbd776e667ad 100644
> --- a/drivers/gpu/drm/i915/intel_nvm.c
> +++ b/drivers/gpu/drm/i915/intel_nvm.c
> @@ -10,6 +10,7 @@
> #include "intel_nvm.h"
>
> #define GEN12_GUNIT_NVM_SIZE 0x80
> +#define HECI_FW_STATUS_2_NVM_ACCESS_MODE BIT(3)
>
> static const struct intel_dg_nvm_region regions[INTEL_DG_NVM_REGIONS] = {
> [0] = { .name = "DESCRIPTOR", },
> @@ -22,6 +23,28 @@ static void i915_nvm_release_dev(struct device *dev)
> {
> }
>
> +static bool i915_nvm_writeable_override(struct drm_i915_private *i915)
> +{
> + resource_size_t base;
> + bool writeable_override;
> +
> + if (IS_DG1(i915)) {
> + base = DG1_GSC_HECI2_BASE;
> + } else if (IS_DG2(i915)) {
> + base = DG2_GSC_HECI2_BASE;
> + } else {
> + drm_err(&i915->drm, "Unknown platform\n");
> + return true;
> + }
> +
> + writeable_override =
> + !(intel_uncore_read(&i915->uncore, HECI_FWSTS(base, 2)) &
> + HECI_FW_STATUS_2_NVM_ACCESS_MODE);
> + if (writeable_override)
> + drm_info(&i915->drm, "NVM access overridden by jumper\n");
> + return writeable_override;
> +}
> +
> void intel_nvm_init(struct drm_i915_private *i915)
> {
> struct pci_dev *pdev = to_pci_dev(i915->drm.dev);
> @@ -43,7 +66,7 @@ void intel_nvm_init(struct drm_i915_private *i915)
>
> nvm = i915->nvm;
>
> - nvm->writeable_override = true;
> + nvm->writeable_override = i915_nvm_writeable_override(i915);
> nvm->bar.parent = &pdev->resource[0];
> nvm->bar.start = GEN12_GUNIT_NVM_BASE + pdev->resource[0].start;
> nvm->bar.end = nvm->bar.start + GEN12_GUNIT_NVM_SIZE - 1;
> --
> 2.43.0
>
WARNING: multiple messages have this Message-ID (diff)
From: Rodrigo Vivi <rodrigo.vivi@intel.com>
To: Alexander Usyskin <alexander.usyskin@intel.com>
Cc: "Miquel Raynal" <miquel.raynal@bootlin.com>,
"Richard Weinberger" <richard@nod.at>,
"Vignesh Raghavendra" <vigneshr@ti.com>,
"Lucas De Marchi" <lucas.demarchi@intel.com>,
"Thomas Hellström" <thomas.hellstrom@linux.intel.com>,
"Maarten Lankhorst" <maarten.lankhorst@linux.intel.com>,
"Maxime Ripard" <mripard@kernel.org>,
"Thomas Zimmermann" <tzimmermann@suse.de>,
"David Airlie" <airlied@gmail.com>,
"Simona Vetter" <simona@ffwll.ch>,
"Jani Nikula" <jani.nikula@linux.intel.com>,
"Joonas Lahtinen" <joonas.lahtinen@linux.intel.com>,
"Tvrtko Ursulin" <tursulin@ursulin.net>,
"Oren Weil" <oren.jer.weil@intel.com>,
linux-mtd@lists.infradead.org, dri-devel@lists.freedesktop.org,
intel-gfx@lists.freedesktop.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH v2 08/10] drm/i915/nvm: add support for access mode
Date: Thu, 7 Nov 2024 16:41:22 -0500 [thread overview]
Message-ID: <Zy00AoxE0_8p5xCY@intel.com> (raw)
In-Reply-To: <20241107131356.2796969-9-alexander.usyskin@intel.com>
On Thu, Nov 07, 2024 at 03:13:54PM +0200, Alexander Usyskin wrote:
> Check NVM access mode from GSC FW status registers
> and overwrite access status read from SPI descriptor, if needed.
Reviewed-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
>
> Signed-off-by: Alexander Usyskin <alexander.usyskin@intel.com>
> ---
> drivers/gpu/drm/i915/intel_nvm.c | 25 ++++++++++++++++++++++++-
> 1 file changed, 24 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/gpu/drm/i915/intel_nvm.c b/drivers/gpu/drm/i915/intel_nvm.c
> index 214c4d47a9cd..cbd776e667ad 100644
> --- a/drivers/gpu/drm/i915/intel_nvm.c
> +++ b/drivers/gpu/drm/i915/intel_nvm.c
> @@ -10,6 +10,7 @@
> #include "intel_nvm.h"
>
> #define GEN12_GUNIT_NVM_SIZE 0x80
> +#define HECI_FW_STATUS_2_NVM_ACCESS_MODE BIT(3)
>
> static const struct intel_dg_nvm_region regions[INTEL_DG_NVM_REGIONS] = {
> [0] = { .name = "DESCRIPTOR", },
> @@ -22,6 +23,28 @@ static void i915_nvm_release_dev(struct device *dev)
> {
> }
>
> +static bool i915_nvm_writeable_override(struct drm_i915_private *i915)
> +{
> + resource_size_t base;
> + bool writeable_override;
> +
> + if (IS_DG1(i915)) {
> + base = DG1_GSC_HECI2_BASE;
> + } else if (IS_DG2(i915)) {
> + base = DG2_GSC_HECI2_BASE;
> + } else {
> + drm_err(&i915->drm, "Unknown platform\n");
> + return true;
> + }
> +
> + writeable_override =
> + !(intel_uncore_read(&i915->uncore, HECI_FWSTS(base, 2)) &
> + HECI_FW_STATUS_2_NVM_ACCESS_MODE);
> + if (writeable_override)
> + drm_info(&i915->drm, "NVM access overridden by jumper\n");
> + return writeable_override;
> +}
> +
> void intel_nvm_init(struct drm_i915_private *i915)
> {
> struct pci_dev *pdev = to_pci_dev(i915->drm.dev);
> @@ -43,7 +66,7 @@ void intel_nvm_init(struct drm_i915_private *i915)
>
> nvm = i915->nvm;
>
> - nvm->writeable_override = true;
> + nvm->writeable_override = i915_nvm_writeable_override(i915);
> nvm->bar.parent = &pdev->resource[0];
> nvm->bar.start = GEN12_GUNIT_NVM_BASE + pdev->resource[0].start;
> nvm->bar.end = nvm->bar.start + GEN12_GUNIT_NVM_SIZE - 1;
> --
> 2.43.0
>
______________________________________________________
Linux MTD discussion mailing list
http://lists.infradead.org/mailman/listinfo/linux-mtd/
next prev parent reply other threads:[~2024-11-07 21:41 UTC|newest]
Thread overview: 33+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-11-07 13:13 [PATCH v2 00/10] mtd: add driver for Intel discrete graphics Alexander Usyskin
2024-11-07 13:13 ` Alexander Usyskin
2024-11-07 13:13 ` [PATCH v2 01/10] mtd: add driver for intel graphics non-volatile memory device Alexander Usyskin
2024-11-07 13:13 ` Alexander Usyskin
2024-11-07 13:13 ` [PATCH v2 02/10] mtd: intel-dg: implement region enumeration Alexander Usyskin
2024-11-07 13:13 ` Alexander Usyskin
2024-11-07 13:13 ` [PATCH v2 03/10] mtd: intel-dg: implement access functions Alexander Usyskin
2024-11-07 13:13 ` Alexander Usyskin
2024-11-07 13:13 ` [PATCH v2 04/10] mtd: intel-dg: register with mtd Alexander Usyskin
2024-11-07 13:13 ` Alexander Usyskin
2024-11-07 13:13 ` [PATCH v2 05/10] mtd: intel-dg: align 64bit read and write Alexander Usyskin
2024-11-07 13:13 ` Alexander Usyskin
2024-11-07 13:13 ` [PATCH v2 06/10] mtd: intel-dg: wake card on operations Alexander Usyskin
2024-11-07 13:13 ` Alexander Usyskin
2024-11-07 13:13 ` [PATCH v2 07/10] drm/i915/nvm: add nvm device for discrete graphics Alexander Usyskin
2024-11-07 13:13 ` Alexander Usyskin
2024-11-07 21:40 ` Rodrigo Vivi
2024-11-07 21:40 ` Rodrigo Vivi
2024-11-07 13:13 ` [PATCH v2 08/10] drm/i915/nvm: add support for access mode Alexander Usyskin
2024-11-07 13:13 ` Alexander Usyskin
2024-11-07 21:41 ` Rodrigo Vivi [this message]
2024-11-07 21:41 ` Rodrigo Vivi
2024-11-07 13:13 ` [PATCH v2 09/10] drm/xe/nvm: add on-die non-volatile memory device Alexander Usyskin
2024-11-07 13:13 ` Alexander Usyskin
2024-11-07 13:13 ` [PATCH v2 10/10] drm/xe/nvm: add support for access mode Alexander Usyskin
2024-11-07 13:13 ` Alexander Usyskin
2024-11-07 21:38 ` Rodrigo Vivi
2024-11-07 21:38 ` Rodrigo Vivi
2024-11-07 13:55 ` ✗ Fi.CI.CHECKPATCH: warning for mtd: add driver for Intel discrete graphics (rev2) Patchwork
2024-11-07 13:55 ` ✗ Fi.CI.SPARSE: " Patchwork
2024-11-07 14:15 ` ✗ Fi.CI.BAT: failure " Patchwork
2024-11-11 19:59 ` [PATCH v2 00/10] mtd: add driver for Intel discrete graphics Miquel Raynal
2024-11-11 19:59 ` Miquel Raynal
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=Zy00AoxE0_8p5xCY@intel.com \
--to=rodrigo.vivi@intel.com \
--cc=airlied@gmail.com \
--cc=alexander.usyskin@intel.com \
--cc=dri-devel@lists.freedesktop.org \
--cc=intel-gfx@lists.freedesktop.org \
--cc=jani.nikula@linux.intel.com \
--cc=joonas.lahtinen@linux.intel.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mtd@lists.infradead.org \
--cc=lucas.demarchi@intel.com \
--cc=maarten.lankhorst@linux.intel.com \
--cc=miquel.raynal@bootlin.com \
--cc=mripard@kernel.org \
--cc=oren.jer.weil@intel.com \
--cc=richard@nod.at \
--cc=simona@ffwll.ch \
--cc=thomas.hellstrom@linux.intel.com \
--cc=tursulin@ursulin.net \
--cc=tzimmermann@suse.de \
--cc=vigneshr@ti.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.