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 bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (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 709B3CD98CF for ; Fri, 12 Jun 2026 08:01:36 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version:Message-ID:Date:Subject:Cc :To:From:Reply-To:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:In-Reply-To:References: List-Owner; bh=lewf1Z1qFX56quEcsg9UmQq4789n1JtjSjV/Ufjnfbo=; b=WZL7p7+RnCEvOH BjgIH2Kl3aRXVYUU6pX9SQlnWFW08SQN7nPQRBPAH6FobqIIYyoxB8FFsPGUchcC1o9sf6edRqSOo QJHSkDkeBTTHP2aL/D67G5cA/OwKH9vCXzaxPWwnH1Ulaz9HeCWrkTulUNVaEumcXfkV2aqtk0URo Vr3SjatPQ2hGeM4hKxF+4676tczK6mOQIoviLQh1rQ8pzYAh/JDA4itu49adCZyIuKkwulwYY4evO nV1E2JmhqfCmZ8edhvUJWuvA6er8Te08kenRwz0esH71YFTvPvNSWQM0cDcJ6SxZ4OZTJyKRpZ7Tm yIJzr2XDtNpYVneMwaWA==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.99.1 #2 (Red Hat Linux)) id 1wXwpc-0000000AXBu-0r9Y; Fri, 12 Jun 2026 08:01:36 +0000 Received: from mgamail.intel.com ([192.198.163.15]) by bombadil.infradead.org with esmtps (Exim 4.99.1 #2 (Red Hat Linux)) id 1wXwpZ-0000000AX8Y-342p for linux-i3c@lists.infradead.org; Fri, 12 Jun 2026 08:01:35 +0000 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1781251294; x=1812787294; h=from:to:cc:subject:date:message-id:mime-version: content-transfer-encoding; bh=pvwSj2+sH7Rn37+lFRx+bP4U1caEPkCvYPv5x0EzYWE=; b=V6DhwOg/HHNHbMZPdAGiynlXLeOxAUAGPff3mIAc04+W00EQOn0DT/Ra cpNfGXFuenMaotyCyIeSmrJ5cF5O9KCA+nH0aLT7N6dHNr8p94VaIpBf7 EO+LYjPRM8pSqeoXElDA+pltk8ML2x6dKEDEh528dRqgXDdv3NVd8A5C+ pVFyWhsV680xonDXUJE7oluQVlly6jChNWC0i+9/nJ2a2v4Y0um1uWsWs QfEGq/kTq73ZuEnTqfIVV/cgRl3LRrWC88BsLPH3tX42gLW9VpoyJqFP6 iJdKCs0dSM8YaQqT0E3LhkpiHj3w4vEA2nDVQZ0FcTZ2gpRWAhMJzXLfV g==; X-CSE-ConnectionGUID: X1+42SaES/yNG6e+XJUzcQ== X-CSE-MsgGUID: vn5zP/qbRiSl1X8soKi0JA== X-IronPort-AV: E=McAfee;i="6800,10657,11813"; a="82186730" X-IronPort-AV: E=Sophos;i="6.24,200,1774335600"; d="scan'208";a="82186730" Received: from orviesa008.jf.intel.com ([10.64.159.148]) by fmvoesa109.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 12 Jun 2026 01:01:18 -0700 X-CSE-ConnectionGUID: /Zxye9UDRgO++dndNDK6gw== X-CSE-MsgGUID: 3X8CLNgYQ4KSfxI6iT7fnw== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.24,200,1774335600"; d="scan'208";a="246630330" Received: from vpanait-mobl.ger.corp.intel.com (HELO ahunter6-desk) ([10.245.245.41]) by orviesa008-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 12 Jun 2026 01:01:16 -0700 From: Adrian Hunter To: alexandre.belloni@bootlin.com Cc: Frank.Li@nxp.com, linux-i3c@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH V4 0/7] i3c: Fix IBI race, address handling, and reconcile DAA Date: Fri, 12 Jun 2026 11:01:00 +0300 Message-ID: <20260612080107.11606-1-adrian.hunter@intel.com> X-Mailer: git-send-email 2.51.0 MIME-Version: 1.0 Organization: Intel Finland Oy, Registered Address: c/o Alberga Business Park, 6 krs, Bertel Jungin Aukio 5, 02600 Espoo, Business Identity Code: 0357606 - 4, Domiciled in Helsinki X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.9.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20260612_010133_784781_324A29C1 X-CRM114-Status: GOOD ( 10.49 ) X-BeenThere: linux-i3c@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-i3c" Errors-To: linux-i3c-bounces+linux-i3c=archiver.kernel.org@lists.infradead.org Hi Note all patches have now been reviewed by Frank. Patches 1-2 fix a use-after-free race in the MIPI I3C HCI driver's IBI handling and make IBI teardown resilient to DISEC failures. Patches 3-7 fix address management issues in the I3C core and HCI driver that arise when Dynamic Address Assignment (DAA) does not complete cleanly, culminating in a reconciliation step that detects and resolves inconsistencies between assigned address slots and registered devices. Patches are based on top of: [PATCH V3 0/8] i3c: Hot-Join improvements and MIPI HCI Hot-Join support https://lore.kernel.org/linux-i3c/20260608054312.10604-1-adrian.hunter@intel.com which, in turn, applies on top of: [PATCH V5 00/17] i3c: mipi-i3c-hci: DMA abort, recovery and related improvements https://lore.kernel.org/linux-i3c/20260603090754.16252-1-adrian.hunter@intel.com Changes in V4: i3c: master: Prevent reuse of dynamic address on device add failure i3c: master: Reconcile dynamic addresses after DAA Add Frank's Rev'd-by Changes in V3: i3c: mipi-i3c-hci: Fix race in i3c_hci_addr_to_dev() i3c: mipi-i3c-hci: Ignore DISEC failures when disabling IBIs Add Frank's Rev'd-by i3c: master: Prevent reuse of dynamic address on device add failure Add note to commit message about Direct RSTDAA deprecation i3c: mipi-i3c-hci: Tolerate i3c_master_add_i3c_dev_locked() failures in DAA i3c: master: Make i3c_master_add_i3c_dev_locked() return void i3c: master: Move DAA API functions after i3c_master_add_i3c_dev_locked() Add Frank's Rev'd-by i3c: master: Reconcile dynamic addresses after DAA Add comment about the source of I3C_DEV_PROBE_* macro values. Also account for static_addr in i3c_master_reconcile_dyn_addrs() Changes in V2: i3c: mipi-i3c-hci: Fix race in i3c_hci_addr_to_dev() Factor out __i3c_hci_disable_ibi() to facilitate also clearing ibi_devs[dat_idx] upon IBI free, and update commit message accordingly. Demote a message in PIO and DMA IBI handling, and update commit message accordingly. i3c: mipi-i3c-hci: Ignore DISEC failures when disabling IBIs Re-base due to changes in previous patch. i3c: master: Prevent reuse of dynamic address on device add failure Fix 'if (IS_ERR(newdev)' error path. Be defensive and do not change the addr_slot_status if it is not free, and update commit message accordingly. Amend commit message to note removal of unnecesary 'if (!master)' check. Add Fixes tag. i3c: mipi-i3c-hci: Tolerate i3c_master_add_i3c_dev_locked() failures in DAA None i3c: master: Make i3c_master_add_i3c_dev_locked() return void Re-base due to changes in previous patches. i3c: master: Move DAA API functions after i3c_master_add_i3c_dev_locked() None i3c: master: Reconcile dynamic addresses after DAA Add bitmap.h include for bitmap_zero() etc. Re-base due to changes in previous patches. Adrian Hunter (7): i3c: mipi-i3c-hci: Fix race in i3c_hci_addr_to_dev() i3c: mipi-i3c-hci: Ignore DISEC failures when disabling IBIs i3c: master: Prevent reuse of dynamic address on device add failure i3c: mipi-i3c-hci: Tolerate i3c_master_add_i3c_dev_locked() failures in DAA i3c: master: Make i3c_master_add_i3c_dev_locked() return void i3c: master: Move DAA API functions after i3c_master_add_i3c_dev_locked() i3c: master: Reconcile dynamic addresses after DAA drivers/i3c/master.c | 279 ++++++++++++++++++++++--------- drivers/i3c/master/mipi-i3c-hci/cmd_v1.c | 4 +- drivers/i3c/master/mipi-i3c-hci/cmd_v2.c | 4 +- drivers/i3c/master/mipi-i3c-hci/core.c | 45 ++++- drivers/i3c/master/mipi-i3c-hci/dma.c | 7 +- drivers/i3c/master/mipi-i3c-hci/hci.h | 1 + drivers/i3c/master/mipi-i3c-hci/ibi.h | 13 +- drivers/i3c/master/mipi-i3c-hci/pio.c | 7 +- include/linux/i3c/master.h | 3 +- 9 files changed, 254 insertions(+), 109 deletions(-) Regards Adrian -- linux-i3c mailing list linux-i3c@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-i3c