From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 82996C83F03 for ; Thu, 3 Jul 2025 19:26:46 +0000 (UTC) Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id 4A3C210E1C2; Thu, 3 Jul 2025 19:26:46 +0000 (UTC) Authentication-Results: gabe.freedesktop.org; dkim=pass (2048-bit key; unprotected) header.d=intel.com header.i=@intel.com header.b="POAMDLPg"; dkim-atps=neutral Received: from mgamail.intel.com (mgamail.intel.com [198.175.65.12]) by gabe.freedesktop.org (Postfix) with ESMTPS id 3124410E1C2; Thu, 3 Jul 2025 19:26:45 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1751570805; x=1783106805; h=from:to:cc:subject:date:message-id:mime-version: content-transfer-encoding; bh=9RTluMGj1g8RD7d0i52mXsmYAFSsoM546/tWGlFWYdE=; b=POAMDLPgZjIb6aihfl65Re186uOXUY4hKDJ8eg9w/VweHy3X0soqL4On Rn3ejJaiqR2WeABNFGfOigxWH5ukwWqdRkbt4881VXxc61M1jwADNUE9d +yOJ9OHvAHdzBXq247E6jSEWw35V4UHew58x63xvZgiZVtKjxfVue3Qvh Qeq9WMvsEnR2ZHGAMvdeF/6pJNrdapULWpkmbf73sriNWVYA7k+qvdglp SFeoB/beWwIMi0T0jP6VmGPDqivHAyUg2I3v5v3MdZXxzs/SF0h+uT67I O2+QGg7Du3K0hnaOC9ux/tnuZHxDNdhiCDX3Kz8q6p1D6ILtHCRRuNgW8 g==; X-CSE-ConnectionGUID: Mp+BFf55ROq3KalBbEZepw== X-CSE-MsgGUID: S4rX6qStQfS/pkRSDArT4Q== X-IronPort-AV: E=McAfee;i="6800,10657,11483"; a="65361986" X-IronPort-AV: E=Sophos;i="6.16,285,1744095600"; d="scan'208";a="65361986" Received: from orviesa001.jf.intel.com ([10.64.159.141]) by orvoesa104.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 03 Jul 2025 12:26:45 -0700 X-CSE-ConnectionGUID: 9Dn6TtZqR+ywhu72IhBjoA== X-CSE-MsgGUID: 5uWW33KBQ9SR0glKFo/YOA== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.16,285,1744095600"; d="scan'208";a="191624617" Received: from unknown (HELO bnilawar-desk2.iind.intel.com) ([10.190.239.41]) by smtpauth.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 03 Jul 2025 12:26:43 -0700 From: Badal Nilawar To: intel-xe@lists.freedesktop.org, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org Cc: anshuman.gupta@intel.com, rodrigo.vivi@intel.com, alexander.usyskin@intel.com, gregkh@linuxfoundation.org, daniele.ceraolospurio@intel.com Subject: [PATCH v6 00/10] Introducing firmware late binding Date: Fri, 4 Jul 2025 01:00:56 +0530 Message-Id: <20250703193106.954536-1-badal.nilawar@intel.com> X-Mailer: git-send-email 2.34.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-BeenThere: intel-xe@lists.freedesktop.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Intel Xe graphics driver List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: intel-xe-bounces@lists.freedesktop.org Sender: "Intel-xe" Introducing firmware late binding feature to enable firmware loading for the devices, such as the fan controller and voltage regulator, during the driver probe. Typically, firmware for these devices are part of IFWI flash image but can be replaced at probe after OEM tuning. v2: - Dropped voltage regulator specific code as binaries for it will not be available for upstreaming as of now. - Address review comments v3: - Dropped fwctl patch for now - Added new patch to extract binary version - Address v2 review comments v4: - Address v3 review comments v5: xe_kmd: - Dropped mutex is worker flush in unbind blocking component removal while fw download is in progress - Handled the fw load in all 3 scenarios (probe, system resume, rpm resume) by holding rpm wake ref in outer bounds of worker. mei: - Most of the review comments v6: - rebased - Disabled fw load upon error Alexander Usyskin (2): mei: bus: add mei_cldev_mtu interface mei: late_bind: add late binding component driver Badal Nilawar (8): drm/xe/xe_late_bind_fw: Introducing xe_late_bind_fw drm/xe/xe_late_bind_fw: Initialize late binding firmware drm/xe/xe_late_bind_fw: Load late binding firmware drm/xe/xe_late_bind_fw: Reload late binding fw in rpm resume drm/xe/xe_late_bind_fw: Reload late binding fw during system resume drm/xe/xe_late_bind_fw: Introduce debug fs node to disable late binding drm/xe/xe_late_bind_fw: Extract and print version info drm/xe/xe_late_bind_fw: Select INTEL_MEI_LATE_BIND for CI drivers/gpu/drm/xe/Kconfig | 1 + drivers/gpu/drm/xe/Makefile | 1 + drivers/gpu/drm/xe/xe_debugfs.c | 41 ++ drivers/gpu/drm/xe/xe_device.c | 5 + drivers/gpu/drm/xe/xe_device_types.h | 6 + drivers/gpu/drm/xe/xe_late_bind_fw.c | 461 ++++++++++++++++++++ drivers/gpu/drm/xe/xe_late_bind_fw.h | 17 + drivers/gpu/drm/xe/xe_late_bind_fw_types.h | 77 ++++ drivers/gpu/drm/xe/xe_pci.c | 2 + drivers/gpu/drm/xe/xe_pci_types.h | 1 + drivers/gpu/drm/xe/xe_pm.c | 8 + drivers/gpu/drm/xe/xe_uc_fw_abi.h | 66 +++ drivers/misc/mei/Kconfig | 1 + drivers/misc/mei/Makefile | 1 + drivers/misc/mei/bus.c | 13 + drivers/misc/mei/late_bind/Kconfig | 13 + drivers/misc/mei/late_bind/Makefile | 9 + drivers/misc/mei/late_bind/mei_late_bind.c | 272 ++++++++++++ include/drm/intel/i915_component.h | 1 + include/drm/intel/late_bind_mei_interface.h | 64 +++ include/linux/mei_cl_bus.h | 1 + 21 files changed, 1061 insertions(+) create mode 100644 drivers/gpu/drm/xe/xe_late_bind_fw.c create mode 100644 drivers/gpu/drm/xe/xe_late_bind_fw.h create mode 100644 drivers/gpu/drm/xe/xe_late_bind_fw_types.h create mode 100644 drivers/misc/mei/late_bind/Kconfig create mode 100644 drivers/misc/mei/late_bind/Makefile create mode 100644 drivers/misc/mei/late_bind/mei_late_bind.c create mode 100644 include/drm/intel/late_bind_mei_interface.h -- 2.34.1