From: Jani Nikula <jani.nikula@linux.intel.com>
To: Daniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>,
intel-gfx@lists.freedesktop.org
Cc: gregkh@linuxfoundation.org,
Daniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>,
Valentine Burley <valentine.burley@collabora.com>,
Rodrigo Vivi <rodrigo.vivi@intel.com>,
Alexander Usyskin <alexander.usyskin@intel.com>,
Alan Previn <alan.previn.teres.alexis@intel.com>
Subject: Re: [PATCH v3 2/2] drm/i915/pxp: Do not support PXP if CSME is not available
Date: Tue, 25 Nov 2025 12:28:32 +0200 [thread overview]
Message-ID: <aae6c3f4466e0f52e4f1f482c14dba68d8d04c0e@intel.com> (raw)
In-Reply-To: <20251114201431.1135031-6-daniele.ceraolospurio@intel.com>
On Fri, 14 Nov 2025, Daniele Ceraolo Spurio <daniele.ceraolospurio@intel.com> wrote:
> The PXP flow requires us to communicate with CSME, which we do via a
> mei component. Since the mei component binding is async and can take
> a bit to complete, we don't wait for it during i915 load. If userspace
> queries the state before the async binding is complete, we return an
> "init in progress" state, with the expectation that it will eventually
> transition to "init complete" if the CSME device is functional.
>
> Mesa CI is flashing a custom coreboot on their Chromebooks that hides
> the CSME device, which means that we never transition to the "init
> complete" state. While from an interface POV it is not incorrect to not
> end up in "init complete" if the CSME is missing, we can mitigate the
> impact of this by simply checking if the CSME device is available at
> all before attempting to initialize PXP.
>
> v2: rebase on updated mei patch.
> v3: rebase on exported pci id list.
>
> Reported-by: Valentine Burley <valentine.burley@collabora.com>
> Closes: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/14516
> Signed-off-by: Daniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>
> Cc: Rodrigo Vivi <rodrigo.vivi@intel.com>
> Cc: Alexander Usyskin <alexander.usyskin@intel.com>
> Cc: Alan Previn <alan.previn.teres.alexis@intel.com>
> ---
> drivers/gpu/drm/i915/pxp/intel_pxp.c | 25 +++++++++++++++++++++++++
> 1 file changed, 25 insertions(+)
>
> diff --git a/drivers/gpu/drm/i915/pxp/intel_pxp.c b/drivers/gpu/drm/i915/pxp/intel_pxp.c
> index 2860474ad2d0..26e7c5c26bac 100644
> --- a/drivers/gpu/drm/i915/pxp/intel_pxp.c
> +++ b/drivers/gpu/drm/i915/pxp/intel_pxp.c
> @@ -3,6 +3,7 @@
> * Copyright(c) 2020 Intel Corporation.
> */
>
> +#include <linux/mei_me.h>
> #include <linux/workqueue.h>
>
> #include <drm/drm_print.h>
> @@ -197,6 +198,15 @@ static struct intel_gt *find_gt_for_required_protected_content(struct drm_i915_p
> return NULL;
> }
>
> +static bool mei_device_available(void)
> +{
> +#if IS_ENABLED(CONFIG_INTEL_MEI_ME)
> + return pci_dev_present(mei_me_pci_tbl);
> +#else
> + return false;
> +#endif
> +}
> +
I think it's just ugly to have this in i915. IMO the function belongs in
mei.
BR,
Jani.
> int intel_pxp_init(struct drm_i915_private *i915)
> {
> struct intel_gt *gt;
> @@ -205,6 +215,21 @@ int intel_pxp_init(struct drm_i915_private *i915)
> if (intel_gt_is_wedged(to_gt(i915)))
> return -ENOTCONN;
>
> + /*
> + * iGPUs require CSME to be available to use PXP. Note that the
> + * availability of CSME might change after we check, but we only support
> + * PXP in the case where the CSME device is available from boot and
> + * stays that way. If CSME was not initially available and appears later
> + * we'll just continue without PXP, while if it was available and is
> + * then removed we'll catch it via the component unbind callback and
> + * handle it gracefully. Therefore, we don't require any locking around
> + * the state checking.
> + */
> + if (!IS_DGFX(i915) && !mei_device_available()) {
> + drm_dbg(&i915->drm, "skipping PXP init due to missing ME device\n");
> + return -ENODEV;
> + }
> +
> /*
> * NOTE: Get the ctrl_gt before checking intel_pxp_is_supported since
> * we still need it if PXP's backend tee transport is needed.
--
Jani Nikula, Intel
next prev parent reply other threads:[~2025-11-25 10:28 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-11-14 20:14 [PATCH v3 0/2] Check if CSME is available before initializing PXP Daniele Ceraolo Spurio
2025-11-14 20:14 ` [PATCH v3 1/2] mei: me: Export the PCI ID list Daniele Ceraolo Spurio
2025-11-25 10:26 ` Jani Nikula
2025-11-25 22:00 ` Daniele Ceraolo Spurio
2025-11-26 9:25 ` Jani Nikula
2025-11-14 20:14 ` [PATCH v3 2/2] drm/i915/pxp: Do not support PXP if CSME is not available Daniele Ceraolo Spurio
2025-11-25 10:28 ` Jani Nikula [this message]
2025-11-25 22:07 ` Daniele Ceraolo Spurio
2025-11-26 9:31 ` Jani Nikula
2025-11-26 22:24 ` Daniele Ceraolo Spurio
2025-11-15 13:13 ` ✗ i915.CI.Full: failure for Check if CSME is available before initializing PXP (rev3) Patchwork
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=aae6c3f4466e0f52e4f1f482c14dba68d8d04c0e@intel.com \
--to=jani.nikula@linux.intel.com \
--cc=alan.previn.teres.alexis@intel.com \
--cc=alexander.usyskin@intel.com \
--cc=daniele.ceraolospurio@intel.com \
--cc=gregkh@linuxfoundation.org \
--cc=intel-gfx@lists.freedesktop.org \
--cc=rodrigo.vivi@intel.com \
--cc=valentine.burley@collabora.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox