From nobody Tue Apr 7 05:44:54 2026 Received: from mx0a-0031df01.pphosted.com (mx0a-0031df01.pphosted.com [205.220.168.131]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 3111E396D0D for ; Mon, 16 Mar 2026 13:20:14 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=205.220.168.131 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1773667215; cv=none; b=WXTebpe/7kJXgrFsqLpwyESTD3hDinApJ1t0fNd59syjdGAJL8wxfskIZ/pC81cdefZg9HBKZodZNwb+dgrWjl+GZ4bfy2knQCRkD+BnTHxYoCfD2bDauNQJ5F94LRkdWGFpnBLh53RUXRUvB3Y+luUI6VlrxTQTt+Njowei70o= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1773667215; c=relaxed/simple; bh=nA8U/iwRABvjNTx2JQEwhwxwRQjDOtrXw15Af+P3hFQ=; h=From:To:Cc:Subject:Date:Message-Id:In-Reply-To:References: MIME-Version; b=B9UD24QyUh6Pwn2cXWyrYfTlyT7k9GUmzKTx4yaqpcqPizWOVo45aU3qx7iAKF5ApCrmqdQ1FoOousF1jD1EaTHuDT2XFy34oZbYdTQk+Bicrl3B3tTy55z8R147HhWF8zCKUkin/w3XQjgbxZJb6om9hY7JaCyasTDnscvE4MI= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com; spf=pass smtp.mailfrom=oss.qualcomm.com; dkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com header.b=ahwkKhMW; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b=GHuJHQiA; arc=none smtp.client-ip=205.220.168.131 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=oss.qualcomm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com header.b="ahwkKhMW"; dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com header.b="GHuJHQiA" Received: from pps.filterd (m0279866.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.11/8.18.1.11) with ESMTP id 62GBlnBE3777541 for ; Mon, 16 Mar 2026 13:20:13 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=qualcomm.com; h= cc:content-transfer-encoding:date:from:in-reply-to:message-id :mime-version:references:subject:to; s=qcppdkim1; bh=50e4WqrX7UY a9bS7lYNGP5/8mA2vG+IzNq+mgjXtBT0=; b=ahwkKhMWx7WA9gJ3fd1zeEIECL/ V/2vfGCdx+6gqIRlfgHULvNNG1FnbAHau6RcqC55zCLC9AXPZmWRaRPFGF7/3s8h eit+5P4HihierCbx4lQtQsffGxMLOr4I8eg16B4LqyfEmHbaTIMYn1x4fgiBdlw8 XRVYWzv7fRR7aSgAQlI4VdNu/ikFMC1XLn/Bf23LxuVdOMNw7gOdGR4diQblHqSR jPgn0M6XXncCbeqITQI22IGNI+PdUInAeZLy0Rmmvbx8aaO9x03ZLe/HymgW4Jpn 4tAGoEpb4ZeLsOsAkUimfa6H3eqE4ajqzjQaQsUWbpqcQ2+DXllsJmWgAbg== Received: from mail-pj1-f71.google.com (mail-pj1-f71.google.com [209.85.216.71]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 4cw0y7wr90-1 (version=TLSv1.3 cipher=TLS_AES_128_GCM_SHA256 bits=128 verify=NOT) for ; Mon, 16 Mar 2026 13:20:13 +0000 (GMT) Received: by mail-pj1-f71.google.com with SMTP id 98e67ed59e1d1-35678f99c6eso3562656a91.1 for ; Mon, 16 Mar 2026 06:20:13 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oss.qualcomm.com; s=google; t=1773667213; x=1774272013; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=50e4WqrX7UYa9bS7lYNGP5/8mA2vG+IzNq+mgjXtBT0=; b=GHuJHQiA6Gl3VZX4G/GtW+mjtjFloKshplLwrhks4cSqBzOw21H3s8yzzO7zXaLGUv OXmAllBewxpzDFz9en/aem5oQpeABvIB6vleTZ71mrWkh8Zf3yFSClm4H4APumESfMu5 nDm4Gv7oprzjW+T2ma8vp/ecSwzfBzkX6+obUXR8i+EPNHV8g5NPB4Ey/mIit0bLgSjR 8CpoIrqx3MR3OOfQRCZ++dF6dOlSHFRLaiHPwaD7L2mO6OYRu8hhwW+JZShunleaP9cg m6HMhWoM1P7SFxpdE/RomjJl6zTJxYHGA2mUo6B7zLFnE+wtvtjuvPLrMpj4k7n/do+p 2WWQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1773667213; x=1774272013; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=50e4WqrX7UYa9bS7lYNGP5/8mA2vG+IzNq+mgjXtBT0=; b=FAkbqkl25xrhElKXRC/Re2MjDwHeqzPWc7yE4/Yf++KdVIKONwsum6KhRMh9dFgtpA VYuN9xlDnwih1ztLg8DSnW7dphyCn9ZB+X8aEp8C/a/ZGC62vGZhgg0zbbn7g5EjYnmc HzsIn7jPnU6Bvd8JaANSyS+btx14dd32zYCsyZlt1uQ5sHrWXFLHqyugsIsWmcAXPeg0 Ak9vKk7Aw7IXIcA4Zt4TmU1ZQ/7BY+w21GvgEWd9ks4LFoe7rdymQMkNmfpQDW3PZiSA smIIgLd430FuiNo1IKHrWiDHCC90TsAy2n9AeYNXrhWNc/9WyAf/8ifivtSWjyD0xGCi rRGQ== X-Forwarded-Encrypted: i=1; AJvYcCUSCYalBDLVi6eQxmXMap713Z006fMu3TA2OqfzMDCbhkNSeIJTpfP7UvvtBY8214WvQ8JhBUxaFDAubJg=@vger.kernel.org X-Gm-Message-State: AOJu0YzHXpfmb5bHFyzCwhSy/LQzJlPXk9BD/Mg8bRon9HvYcP3ncbN7 YJppvdGwf8ZgYwTXqeGMXBK10b22/eKKJ+5FeXYq00yf6lFnTaI6g3zW73x/5OdPKR8I6hVf+Rn Tj0MEjZ6XFv9F75jPJlX8kt1WLFDkNFxCGsHWr2Fsudk+7+GzJnAkuU8jlVqhazBU7t0= X-Gm-Gg: ATEYQzySPgyCNLXWtb8MuArk+Z3U+matxtUgj0MyzRuu5uAtMHWY+FVEdLaKwbuCZlZ Ej/GuwWK6ZxLOtoMhRLDYnnn45tbL+hdhNPjL0KhU6o3U/a/YseC6Nj13zUP39eeeFh+HticSC8 zlTlmPnhukGUWLhlaTAzCWilPMIMY7KNbD7dPaaCu3PudJc7DDxXngFB8bkun3DT4jmGXlsjDTy S8BZngqB/LSkmsoZ+QtW3s60dLCTOZpFPlQO5pjDm8V7/XIN2V4vYxl9DNVpQIKZoUsTSFHzvpy /9E0YN46SpiINxuAoGcA3kQAF65WLF+JihBd7jwWjhR2YoJ6ZqiHTa8bL9iqK8MIVSmI4dD6zjm jufUh+tLZhrXa8Ix7RNIbBo1h2O0ma1p7q727WCy9S7ezk3DihrU+t43Grw== X-Received: by 2002:a17:90b:3812:b0:35b:a960:62bb with SMTP id 98e67ed59e1d1-35ba960651fmr1013845a91.15.1773667212776; Mon, 16 Mar 2026 06:20:12 -0700 (PDT) X-Received: by 2002:a17:90b:3812:b0:35b:a960:62bb with SMTP id 98e67ed59e1d1-35ba960651fmr1013796a91.15.1773667212067; Mon, 16 Mar 2026 06:20:12 -0700 (PDT) Received: from hu-vdadhani-hyd.qualcomm.com ([202.46.23.25]) by smtp.gmail.com with ESMTPSA id 98e67ed59e1d1-35b9303eb9bsm5209648a91.8.2026.03.16.06.20.06 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 16 Mar 2026 06:20:11 -0700 (PDT) From: Viken Dadhaniya To: mkl@pengutronix.de, mani@kernel.org, thomas.kopp@microchip.com, mailhol@kernel.org, robh@kernel.org, krzk+dt@kernel.org, conor+dt@kernel.org, andersson@kernel.org, konradybcio@kernel.org, linux-can@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org Cc: mukesh.savaliya@oss.qualcomm.com, anup.kulkarni@oss.qualcomm.com, Viken Dadhaniya Subject: [PATCH v2 2/3] can: mcp251xfd: add support for XSTBYEN transceiver standby control Date: Mon, 16 Mar 2026 18:49:49 +0530 Message-Id: <20260316131950.859748-3-viken.dadhaniya@oss.qualcomm.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20260316131950.859748-1-viken.dadhaniya@oss.qualcomm.com> References: <20260316131950.859748-1-viken.dadhaniya@oss.qualcomm.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Proofpoint-GUID: 49l61j7LU9l0EPtEPn-oWar7T5KQPdpL X-Proofpoint-ORIG-GUID: 49l61j7LU9l0EPtEPn-oWar7T5KQPdpL X-Authority-Analysis: v=2.4 cv=D9xK6/Rj c=1 sm=1 tr=0 ts=69b8038d cx=c_pps a=UNFcQwm+pnOIJct1K4W+Mw==:117 a=ZePRamnt/+rB5gQjfz0u9A==:17 a=Yq5XynenixoA:10 a=s4-Qcg_JpJYA:10 a=VkNPw1HP01LnGYTKEx00:22 a=u7WPNUs3qKkmUXheDGA7:22 a=YMgV9FUhrdKAYTUUvYB2:22 a=EUspDBNiAAAA:8 a=8AlNlYzCCwYCxcDbmjsA:9 a=uKXjsCUrEbL0IQVhDsJ9:22 X-Proofpoint-Spam-Details-Enc: AW1haW4tMjYwMzE2MDEwMSBTYWx0ZWRfX+7EL20wqgz2f BYZvHYMR4YioSwosB9y80GeX+G+yOovv2E5nX+0OvsAD7jQ1SfoHm6lESFJVUdS3ycYlYNTa3r5 JMxH473LEPNvWEpmqWd+k4+C+PI4SgsRS87fabCQ9N6No/gQ5vx7L4hgJnzMvobYgCKLGd9j3i1 AvNyBWZ6H4+ZfF1BB0lJBOT+jtLwdUZXsA2B+eOzRzOfQSIU0UP+tPqg/r9Mm6t+kIpjXo2YL6z cjodUPoFHejJfEmrF9e9pDqVvrBZdE5J/ts7bbafZlH6BXeLBTK/tXE13TaPCSyKxMdpl1Glxld R2s6tDli9oFgNexospDzm2ucF1ZS6q88Rw8CCeT1fEIoFWNFl1yKKKTWhJBAf3n37fNZ7EyvEA7 nH8FkpwArDUtcZ+5UbfVLfdwqGza1IPR20sfcuI6vn0LigIKg/Lon5GTN4PD32uDRYTEwyw0LRB OWpM7Cp8oEeUA/8W1dg== X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1143,Hydra:6.1.51,FMLib:17.12.100.49 definitions=2026-03-16_04,2026-03-16_03,2025-10-01_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 malwarescore=0 impostorscore=0 lowpriorityscore=0 spamscore=0 suspectscore=0 clxscore=1015 bulkscore=0 priorityscore=1501 phishscore=0 adultscore=0 classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.22.0-2603050001 definitions=main-2603160101 Content-Type: text/plain; charset="utf-8" The MCP251xFD has a dedicated transceiver standby control function on the INT0/GPIO0/XSTBY pin, controlled by the XSTBYEN bit in IOCON. When enabled, the hardware automatically manages the transceiver standby state: the pin is driven low when the controller is active and high when it enters Sleep mode. Enable this feature when the 'microchip,xstbyen' device tree property is present. Signed-off-by: Viken Dadhaniya --- .../net/can/spi/mcp251xfd/mcp251xfd-core.c | 30 +++++++++++++++++++ drivers/net/can/spi/mcp251xfd/mcp251xfd.h | 1 + 2 files changed, 31 insertions(+) diff --git a/drivers/net/can/spi/mcp251xfd/mcp251xfd-core.c b/drivers/net/c= an/spi/mcp251xfd/mcp251xfd-core.c index 9c86df08c2c5..7a152acf4931 100644 --- a/drivers/net/can/spi/mcp251xfd/mcp251xfd-core.c +++ b/drivers/net/can/spi/mcp251xfd/mcp251xfd-core.c @@ -764,6 +764,29 @@ static void mcp251xfd_chip_stop(struct mcp251xfd_priv = *priv, mcp251xfd_chip_set_mode(priv, MCP251XFD_REG_CON_MODE_CONFIG); } =20 +static int mcp251xfd_chip_xstbyen_enable(const struct mcp251xfd_priv *priv) +{ + /* Configure the INT0/GPIO0/XSTBY pin as transceiver standby control: + * + * - XSTBYEN=3D1: route the pin to the transceiver standby function + * - TRIS0=3D0: set output direction; the reset default is 1 (input), + * which leaves the pin floating HIGH and keeps the + * transceiver in standby regardless of XSTBYEN + * - LAT0=3D0: drive pin LOW =3D> transceiver active (not in standby) + * + * All three bits are included in the mask; only XSTBYEN is set in + * val, so TRIS0 and LAT0 are cleared to 0 atomically. + * + * Once configured, the hardware automatically drives the pin HIGH + * on Sleep mode entry and LOW on Sleep mode exit. + */ + return regmap_update_bits(priv->map_reg, MCP251XFD_REG_IOCON, + MCP251XFD_REG_IOCON_XSTBYEN | + MCP251XFD_REG_IOCON_TRIS0 | + MCP251XFD_REG_IOCON_LAT0, + MCP251XFD_REG_IOCON_XSTBYEN); +} + static int mcp251xfd_chip_start(struct mcp251xfd_priv *priv) { int err; @@ -800,6 +823,12 @@ static int mcp251xfd_chip_start(struct mcp251xfd_priv = *priv) if (err) goto out_chip_stop; =20 + if (priv->xstbyen) { + err =3D mcp251xfd_chip_xstbyen_enable(priv); + if (err) + goto out_chip_stop; + } + return 0; =20 out_chip_stop: @@ -2271,6 +2300,7 @@ static int mcp251xfd_probe(struct spi_device *spi) priv->pll_enable =3D pll_enable; priv->reg_vdd =3D reg_vdd; priv->reg_xceiver =3D reg_xceiver; + priv->xstbyen =3D device_property_present(&spi->dev, "microchip,xstbyen"); priv->devtype_data =3D *(struct mcp251xfd_devtype_data *)spi_get_device_m= atch_data(spi); =20 /* Errata Reference: diff --git a/drivers/net/can/spi/mcp251xfd/mcp251xfd.h b/drivers/net/can/sp= i/mcp251xfd/mcp251xfd.h index 085d7101e595..d3f4704e2678 100644 --- a/drivers/net/can/spi/mcp251xfd/mcp251xfd.h +++ b/drivers/net/can/spi/mcp251xfd/mcp251xfd.h @@ -672,6 +672,7 @@ struct mcp251xfd_priv { struct gpio_desc *rx_int; struct clk *clk; bool pll_enable; + bool xstbyen; struct regulator *reg_vdd; struct regulator *reg_xceiver; =20 --=20 2.34.1