From patchwork Sat Mar 15 15:43:41 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christian Marangi X-Patchwork-Id: 14018113 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 B7EDEC28B28 for ; Sat, 15 Mar 2025 15:48:17 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Transfer-Encoding: MIME-Version:References:In-Reply-To:Message-ID:Date:Subject:To:From:Reply-To: Cc:Content-Type:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=okDifKvdAt9bOzQUyi7HcNUDD0Vs7iNNXK17iMvuX8c=; b=cvADnJIjGsOEatPF3pSocrRY65 d/N8lD79U92o7blAmP0wKzLy4wF/WakI+F6SETyC8ChQBin0Q1UK7U9rfjMoZN9erQZWSg5rxM/2K kzyVk2uv6FwtcxWBgEM0DMY7/UGOSv7pvTok7DxG1PHwqBV6hxgTi6uvcLv/7ciKmPLqFozwHKEvs RGsbAQet02azMjOdYj9QmuKsp+ZxckLS2Obh3OEixwazs6iwBt85YieY0V4GODmsRb4VeLT416TL9 OvyWMRQXr70Xd/Q6d2WCUlfRDWMdkQbRV1Mki/lE/lLJ7R5Hi4s1kuso5FYLMlF3zrRXapjz7pt/Y Aej4vNTA==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1ttTk9-0000000GXlu-2ggm; Sat, 15 Mar 2025 15:48:09 +0000 Received: from mail-wr1-x431.google.com ([2a00:1450:4864:20::431]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1ttTgp-0000000GX03-1QlH; Sat, 15 Mar 2025 15:44:44 +0000 Received: by mail-wr1-x431.google.com with SMTP id ffacd0b85a97d-390cf7458f5so2553429f8f.2; Sat, 15 Mar 2025 08:44:42 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1742053481; x=1742658281; darn=lists.infradead.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=okDifKvdAt9bOzQUyi7HcNUDD0Vs7iNNXK17iMvuX8c=; b=mg7bWDL79Nu80JznaYY1zl3yivEqB696yk8n1vxar+nT0f/4HI6RQ2kdRETQY/2uNb 5CuNpU0nyQwpb11MHI5Lb4MS/jvTu2z6owCxZ+BeXPocr8iORDku00uTO8D5OwwXLkSp Cou51U5plShWPahUAMPvzDET3r5M1PHTp7rfdCTQz7qUI46ztWd6HtMn9KXzBzsk9uhu OI7XP+G7PO1nEbzpzfVyMW9h86SDxXwI6AEnGdlfmskxxfCrR8OYjf9+k6hdhImz7Xd3 2WbLwlrJ0GzB8cfPMNrvnr1DwyOf65GaIMcNl4L549KZ03ogiCloBBVry4fcixe4SeBu zhUg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1742053481; x=1742658281; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=okDifKvdAt9bOzQUyi7HcNUDD0Vs7iNNXK17iMvuX8c=; b=nMU0hTMQ1SRk44slQZ9tUF0/UVRViDJTwbz8d8N5YElJV4bdWlT86msLEGLnDVmFe8 Vm1cfOG6K8LxJy5TZD1r+0Lm+vP4eUneF/gtC3ipAP3GbUXUdkdtbK0qm5STAe8ZvsWv fnMnZ1NaAR66esJOFYhEmXwcQ56PaajgTTrlDgVMOM96d7r6wQOQHfUEN+S+SSWllUfC ce/lxnV8bUYuaDRKPRUnrqjLV4M7VtlpqElR2hGBSltxdjnnTxyp0xqDBm9qsMIXFZ3J PyC0SlWlrO3es9eoFLE4pap9/pzhggLVqr+MyTevEVZDhCtUsDnHQlGmQAxSAND1keDI UgPw== X-Forwarded-Encrypted: i=1; AJvYcCUJRS4uj9pMwDQa7dtRTAjw0oJ6mvSmfyv8/y6SsaIyqJGdMuzXi84fuJy35/tvUIsAzIBh6ZQS3b4a4R9u4JOy@lists.infradead.org, AJvYcCWbf5wCUTsu1ceXcs/SEbRQ2MrNkpNRo4ovoWFKHYqQw7fZlaL6kY7RTolz9GkJyc9Yiy+iUibUPTr5j95jELY=@lists.infradead.org X-Gm-Message-State: AOJu0YyAtz022hgsxRTus5NsIPl1RLgl49fCl0wcXHOvdJfC+YXFXpTq sgKdBsdZUdJfFL/wEFoOe2nVmnshwz0UjaoYfmOmO3VzMo4DeAVT X-Gm-Gg: ASbGncsQr+54TMi+u8LtednfswrDXySsRhp/KHaw5PSUcXfN/b7jguFdV+sr62vyFIA 2uJdIOkNujU70ku3dLgE0yjXje6O8M4bnPIol05yr3DmpIsmMa3jlkX08bwlOfiOi2eAl5GIqN1 tLMxEbHSMMdFtBw0g/yTPCnhW4WTU01BRgrjpLNkFjEhN9qKSODUIsPOLWV1i+UlvJLmwHvBtxZ ZZLoJtrmiIRDy/xvwS1zzkqYvzgguGceYl86pHVJKC/8xQhYMPOFMJ4K9cDuMgcS4CpA0nonBHr t0TK12ydZZaD31D4tTU+H5PLyLrBagx4XDXq5/z7UazEFqgPX9ifb0KA8aZYfeYm/jTw7aFi5pb VBlVhRNOhDBlM/Q== X-Google-Smtp-Source: AGHT+IH0OLRKrXpJrRaoJd0L3/pG0iIlC1HdRZdErik/X4m/88HEG/SGXSmlbLE3Y1ZZpFL0dkO6yQ== X-Received: by 2002:a05:6000:1567:b0:391:2f2f:828 with SMTP id ffacd0b85a97d-3971ee443f8mr9152016f8f.29.1742053481230; Sat, 15 Mar 2025 08:44:41 -0700 (PDT) Received: from localhost.localdomain (93-34-90-129.ip49.fastwebnet.it. [93.34.90.129]) by smtp.googlemail.com with ESMTPSA id 5b1f17b1804b1-43d1fe0636dsm53464195e9.11.2025.03.15.08.44.40 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 15 Mar 2025 08:44:40 -0700 (PDT) From: Christian Marangi To: Christian Marangi , Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Andrew Lunn , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Vladimir Oltean , Srinivas Kandagatla , Heiner Kallweit , Russell King , Maxime Chevallier , Matthias Brugger , AngeloGioacchino Del Regno , linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, upstream@airoha.com Subject: [net-next PATCH v13 01/14] dt-bindings: nvmem: Document support for Airoha AN8855 Switch EFUSE Date: Sat, 15 Mar 2025 16:43:41 +0100 Message-ID: <20250315154407.26304-2-ansuelsmth@gmail.com> X-Mailer: git-send-email 2.48.1 In-Reply-To: <20250315154407.26304-1-ansuelsmth@gmail.com> References: <20250315154407.26304-1-ansuelsmth@gmail.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250315_084443_378071_39D2D941 X-CRM114-Status: GOOD ( 15.27 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Document support for Airoha AN8855 Switch EFUSE used to calibrate internal PHYs and store additional configuration info. Signed-off-by: Christian Marangi Reviewed-by: Rob Herring (Arm) --- .../bindings/nvmem/airoha,an8855-efuse.yaml | 123 ++++++++++++++++++ MAINTAINERS | 8 ++ 2 files changed, 131 insertions(+) create mode 100644 Documentation/devicetree/bindings/nvmem/airoha,an8855-efuse.yaml diff --git a/Documentation/devicetree/bindings/nvmem/airoha,an8855-efuse.yaml b/Documentation/devicetree/bindings/nvmem/airoha,an8855-efuse.yaml new file mode 100644 index 000000000000..9802d9ea2176 --- /dev/null +++ b/Documentation/devicetree/bindings/nvmem/airoha,an8855-efuse.yaml @@ -0,0 +1,123 @@ +# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/nvmem/airoha,an8855-efuse.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: Airoha AN8855 Switch EFUSE + +maintainers: + - Christian Marangi + +description: + Airoha AN8855 EFUSE used to calibrate internal PHYs and store additional + configuration info. + +$ref: nvmem.yaml# + +properties: + compatible: + const: airoha,an8855-efuse + + '#nvmem-cell-cells': + const: 0 + +required: + - compatible + - '#nvmem-cell-cells' + +unevaluatedProperties: false + +examples: + - | + efuse { + compatible = "airoha,an8855-efuse"; + + #nvmem-cell-cells = <0>; + + nvmem-layout { + compatible = "fixed-layout"; + #address-cells = <1>; + #size-cells = <1>; + + shift_sel_port0_tx_a: shift-sel-port0-tx-a@c { + reg = <0xc 0x4>; + }; + + shift_sel_port0_tx_b: shift-sel-port0-tx-b@10 { + reg = <0x10 0x4>; + }; + + shift_sel_port0_tx_c: shift-sel-port0-tx-c@14 { + reg = <0x14 0x4>; + }; + + shift_sel_port0_tx_d: shift-sel-port0-tx-d@18 { + reg = <0x18 0x4>; + }; + + shift_sel_port1_tx_a: shift-sel-port1-tx-a@1c { + reg = <0x1c 0x4>; + }; + + shift_sel_port1_tx_b: shift-sel-port1-tx-b@20 { + reg = <0x20 0x4>; + }; + + shift_sel_port1_tx_c: shift-sel-port1-tx-c@24 { + reg = <0x24 0x4>; + }; + + shift_sel_port1_tx_d: shift-sel-port1-tx-d@28 { + reg = <0x28 0x4>; + }; + + shift_sel_port2_tx_a: shift-sel-port2-tx-a@2c { + reg = <0x2c 0x4>; + }; + + shift_sel_port2_tx_b: shift-sel-port2-tx-b@30 { + reg = <0x30 0x4>; + }; + + shift_sel_port2_tx_c: shift-sel-port2-tx-c@34 { + reg = <0x34 0x4>; + }; + + shift_sel_port2_tx_d: shift-sel-port2-tx-d@38 { + reg = <0x38 0x4>; + }; + + shift_sel_port3_tx_a: shift-sel-port3-tx-a@4c { + reg = <0x4c 0x4>; + }; + + shift_sel_port3_tx_b: shift-sel-port3-tx-b@50 { + reg = <0x50 0x4>; + }; + + shift_sel_port3_tx_c: shift-sel-port3-tx-c@54 { + reg = <0x54 0x4>; + }; + + shift_sel_port3_tx_d: shift-sel-port3-tx-d@58 { + reg = <0x58 0x4>; + }; + + shift_sel_port4_tx_a: shift-sel-port4-tx-a@5c { + reg = <0x5c 0x4>; + }; + + shift_sel_port4_tx_b: shift-sel-port4-tx-b@60 { + reg = <0x60 0x4>; + }; + + shift_sel_port4_tx_c: shift-sel-port4-tx-c@64 { + reg = <0x64 0x4>; + }; + + shift_sel_port4_tx_d: shift-sel-port4-tx-d@68 { + reg = <0x68 0x4>; + }; + }; + }; diff --git a/MAINTAINERS b/MAINTAINERS index ffbcd072fb14..576fa7eb7b55 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -719,6 +719,14 @@ S: Supported F: fs/aio.c F: include/linux/*aio*.h +AIROHA DSA DRIVER +M: Christian Marangi +L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers) +L: linux-mediatek@lists.infradead.org (moderated for non-subscribers) +L: netdev@vger.kernel.org +S: Maintained +F: Documentation/devicetree/bindings/nvmem/airoha,an8855-efuse.yaml + AIROHA ETHERNET DRIVER M: Lorenzo Bianconi L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers) From patchwork Sat Mar 15 15:43:42 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christian Marangi X-Patchwork-Id: 14018114 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 8B85FC28B2F for ; Sat, 15 Mar 2025 15:50:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Transfer-Encoding: MIME-Version:References:In-Reply-To:Message-ID:Date:Subject:To:From:Reply-To: Cc:Content-Type:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=qe3n3ZQ5LVdeF6eehOPJZ7TfJ6ssfs/dDpnWYl0JxU0=; b=1NBMhZTLPX8Qs6xxsNyJdInMmj h03/d5FDvjD1NQmJnR9sTuT9HnFauh8AC1s81GROpcMJmxO1ejxuWTKjFFP3L5UW9iDlUbpdtaMdE 7g0nCPES9N8wl4z25+PBXV52RPXqJbI+q5Q2lrJuinnV1MUuCyIEE0tpWKBrTkdlP7AKdtvrlDNCB lAJWBRm8fDK/0W77W0VIbiK666wVmKhx7UzRTqEoZZ4IZSozGqrkaRwOBOWGQ+4eCzn2yUdGJCnzA j1N8UrdNGlKdyQyMz4roCiWu9fxUXKd6rMj5MyWHYmkveYHDXoPtUUqnGw85vnao/Ia89jPxMrziH ATYMDsfw==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1ttTln-0000000GY30-2jvk; Sat, 15 Mar 2025 15:49:51 +0000 Received: from mail-wm1-x32f.google.com ([2a00:1450:4864:20::32f]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1ttTgr-0000000GX14-39J3; Sat, 15 Mar 2025 15:44:47 +0000 Received: by mail-wm1-x32f.google.com with SMTP id 5b1f17b1804b1-43cfa7e7f54so3681385e9.1; Sat, 15 Mar 2025 08:44:45 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1742053484; x=1742658284; darn=lists.infradead.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=qe3n3ZQ5LVdeF6eehOPJZ7TfJ6ssfs/dDpnWYl0JxU0=; b=OJKX5nN8FPCykU+080jd8FnSXf71ax0F74Xl3D9CNq6A/BApSg/tXdyJoRjxXBZQVp t331SXcl16hB0HvaMMBAqF8m+lJI+/0/lIEvyGwugCbKeyhzxXIJy2hOm9WaoD5IAMNr NxFwG+Tu3P/YgVDfWKsWZ2iLMTLw7+cuilP/bJ9Oz16LaB8L5pP/YyL2eL7pldXl+epa tiAjmIfVTG6003Ppt10z2MCp/MRHw1TcIioHWrOTOZePdDC+6XziPi2ZArGW/lL4yGxK 0y/i2cA79GjJ1FcHV5jRxYcwY+7Uu37ZfQ+SJPWJHCLA1CIqzAa5z6e5/xE/kATgFyNd 21CA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1742053484; x=1742658284; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=qe3n3ZQ5LVdeF6eehOPJZ7TfJ6ssfs/dDpnWYl0JxU0=; b=T8mJ9BuUQUIPU7fHH1rw/rGBZx+iIXuLDTZT+zqmKt370eK1ClyuBfs4tt8g7v7tY9 nDUoBDQ1p48RTCyRsVtAgKzd3kQVW+Hkgk42RChxQF/MIDKDucv5NXxF4gqEGwcKmlPJ 1RQb6yCFGLcFrYmrSis9rVTcAWBR5CUEgVUzB0qfBiYHubcwg44AQwQy+PMggJLEiISX 0yz9lVc8S+E2I1sA2VSxUVyXybBZPThi0FVhEFyUJ2T20mI59zuxGLdaT9znAqfumidB djHzyJQ5MzLkfh/OrDs3teh+3ledl58HYNDRk4kQoHoXGyU/R8TCta3Hm0q0BHRmbntG 4cYA== X-Forwarded-Encrypted: i=1; AJvYcCUQslVC2Kgewo869XxLH5Dzs18wq/uYv3yt1vOQvwpfi8y7XzDN6Qh6u4sungIYGp0Za5l9kPgT8lNYWFeLpBg=@lists.infradead.org, AJvYcCW6J66AWsNcyINj/Mn8eIwRPo3pYtggCQn6pVpCULAIS63RJnwXP9UYJkD86k+M8s5rsvbRDrhLNwD19LbQUXjY@lists.infradead.org X-Gm-Message-State: AOJu0YzSe2g0SND8ZftXaDWAxvc8f6O3yQgT1jClLFk+CQVOiykgBts6 P7LnfCAibBKpDrEjEDVOpfO4beRcAlbjyo2edo28jsScZ7Fkg0EI X-Gm-Gg: ASbGnctCOoSFT9sPlH20hNa8+0XQMjSYxJdpULn+NyrapTVKWu3xtcSDssrB0/XSSMQ vDjVko8XKtHL6sHYMrnmbH9u5C8KU8yqCdWuLTC6I9x0rasM/dq1XNjkb93nph45UxjHTVbLE5Y 36vsxHGMvRYr/0yjAeOi+qH58+4UTtnE4YQAMJk4e1Uo1NbnJU54rx82pUTcRGj8idwG6lVzzVF Ms5gBposMRUTkPa4pe6ChIG49rksq6C6QBaPX4fGqv63qb17SKkZu8h1ekITmGdmAY16DNrWRBg OP77yxhaLTfxgQnelBtsSu+Uys14l70j1FXxbxeJh0LeQWYI0zZ3K+symFI15xeZI+Luupr6o6c aNih5qzPJS470jHpD3oK6jite X-Google-Smtp-Source: AGHT+IGTFgETv3X0OQn9kvlEZkX9uQ97Mv1FK3vI4v+6bp7/gfuNtt5DkcoUjwWXNpHFChDijAtH+w== X-Received: by 2002:a05:600c:3b87:b0:43b:ca8c:fca3 with SMTP id 5b1f17b1804b1-43d1f235e79mr82196265e9.11.1742053482562; Sat, 15 Mar 2025 08:44:42 -0700 (PDT) Received: from localhost.localdomain (93-34-90-129.ip49.fastwebnet.it. [93.34.90.129]) by smtp.googlemail.com with ESMTPSA id 5b1f17b1804b1-43d1fe0636dsm53464195e9.11.2025.03.15.08.44.41 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 15 Mar 2025 08:44:42 -0700 (PDT) From: Christian Marangi To: Christian Marangi , Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Andrew Lunn , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Vladimir Oltean , Srinivas Kandagatla , Heiner Kallweit , Russell King , Maxime Chevallier , Matthias Brugger , AngeloGioacchino Del Regno , linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, upstream@airoha.com Subject: [net-next PATCH v13 02/14] dt-bindings: net: Document support for Airoha AN8855 Switch Virtual MDIO Date: Sat, 15 Mar 2025 16:43:42 +0100 Message-ID: <20250315154407.26304-3-ansuelsmth@gmail.com> X-Mailer: git-send-email 2.48.1 In-Reply-To: <20250315154407.26304-1-ansuelsmth@gmail.com> References: <20250315154407.26304-1-ansuelsmth@gmail.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250315_084445_840295_FB7C6251 X-CRM114-Status: GOOD ( 17.47 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Document support for Airoha AN8855 Virtual MDIO Passtrough. This is needed as AN8855 require special handling as the same address on the MDIO bus is shared for both Switch and PHY and special handling for the page configuration is needed to switch accessing to Switch address space or PHY. Signed-off-by: Christian Marangi Reviewed-by: Rob Herring (Arm) --- .../bindings/net/airoha,an8855-mdio.yaml | 56 +++++++++++++++++++ MAINTAINERS | 1 + 2 files changed, 57 insertions(+) create mode 100644 Documentation/devicetree/bindings/net/airoha,an8855-mdio.yaml diff --git a/Documentation/devicetree/bindings/net/airoha,an8855-mdio.yaml b/Documentation/devicetree/bindings/net/airoha,an8855-mdio.yaml new file mode 100644 index 000000000000..3078277bf478 --- /dev/null +++ b/Documentation/devicetree/bindings/net/airoha,an8855-mdio.yaml @@ -0,0 +1,56 @@ +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/net/airoha,an8855-mdio.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: Airoha AN8855 MDIO Passtrough + +maintainers: + - Christian Marangi + +description: + Airoha AN8855 Virtual MDIO Passtrough. This is needed as AN8855 + require special handling as the same address on the MDIO bus is + shared for both Switch and PHY and special handling for the page + configuration is needed to switch accessing to Switch address space + or PHY. + +$ref: /schemas/net/mdio.yaml# + +properties: + compatible: + const: airoha,an8855-mdio + +required: + - compatible + +unevaluatedProperties: false + +examples: + - | + mdio { + compatible = "airoha,an8855-mdio"; + #address-cells = <1>; + #size-cells = <0>; + + internal_phy1: phy@1 { + reg = <1>; + }; + + internal_phy2: phy@2 { + reg = <2>; + }; + + internal_phy3: phy@3 { + reg = <3>; + }; + + internal_phy4: phy@4 { + reg = <4>; + }; + + internal_phy5: phy@5 { + reg = <5>; + }; + }; diff --git a/MAINTAINERS b/MAINTAINERS index 576fa7eb7b55..1e8055b5e162 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -725,6 +725,7 @@ L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers) L: linux-mediatek@lists.infradead.org (moderated for non-subscribers) L: netdev@vger.kernel.org S: Maintained +F: Documentation/devicetree/bindings/net/airoha,an8855-mdio.yaml F: Documentation/devicetree/bindings/nvmem/airoha,an8855-efuse.yaml AIROHA ETHERNET DRIVER From patchwork Sat Mar 15 15:43:43 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christian Marangi X-Patchwork-Id: 14018123 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 346C5C28B2F for ; Sat, 15 Mar 2025 15:51:51 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Transfer-Encoding: MIME-Version:References:In-Reply-To:Message-ID:Date:Subject:To:From:Reply-To: Cc:Content-Type:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=qKzguv5FZbUbvmSzUVMgTGlbeTysJjbKI0MLUuKQXJY=; b=XphEEKvcdacXUqCBvEPvJz40dO Jy2JuRdIR7C8lB4mGpG3cA4eQuwg3sx7oUsBYkgH6UFJ9pVAqgvDA4fCUUe16ASPrH7PJMq9tkeZf 5RB9DgaByvk8jTtYlJ+n5cKIgwy38nHXf8K2ZfV9mf9r80ccxgcRxWjmZgheXdCJShn+zZpdfAphR m0rVQlgJoEfzpXIHEjS1AwhwpAilb4F44VnGbpLU7onV4QYmo2Xz2KB0KiMxi9QKr0zNnfVMq3qAU y8QJDIW8icIyJwBdsiddHUZa5bfrZXSEOYPvHe4N2v363hAPRYloqbE3uknq7dTOQquNkMUf9/oMz 3YEpns/w==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1ttTnZ-0000000GYLB-300b; Sat, 15 Mar 2025 15:51:41 +0000 Received: from mail-wr1-x432.google.com ([2a00:1450:4864:20::432]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1ttTgr-0000000GX0x-3cA2; Sat, 15 Mar 2025 15:44:47 +0000 Received: by mail-wr1-x432.google.com with SMTP id ffacd0b85a97d-3913d129c1aso2422125f8f.0; Sat, 15 Mar 2025 08:44:45 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1742053484; x=1742658284; darn=lists.infradead.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=qKzguv5FZbUbvmSzUVMgTGlbeTysJjbKI0MLUuKQXJY=; b=GvyAbAHGO+n2OCTMD136TfD4rO+ELbM25fxszZZdhvzxRYgarc73NpgkY1eDSGoLtw SfTxdTw8BJWsr+JqnO+N0V7MCtf7b+tSjlSC7Pek0lYa+Dbyodew44nAZxe3CZWpkEpJ JQT95miGsTXaBxBscWGfvdrQ/2Xv20w+o1KexF6I6Z/X7WTY43gW3ziOZjb9NSm/Ygst sJDg1RKQtAm1ON9W1cCV0LT9K9pg5cvUEZ4Yp5oE7cFu3o+3Ztubni6SJb5SQk6F5yOM bcOD4ur4WYzqnxDByP3fNyOOyq1DvWQJK8zaxSqOCRFvhXmemFaToi/sjBwYBjS6Dji9 W+OA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1742053484; x=1742658284; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=qKzguv5FZbUbvmSzUVMgTGlbeTysJjbKI0MLUuKQXJY=; b=uYCC6XkfD4D8dLDGtZRJMMfOjpwj8OluuVfMUEp+aJEBMeo/5E5Tx+xw9bvzYRMdcY Cv4Vifq6oqRENTi8+Qu11sTanvISF2pCYTHD3OLA+Ka8KeizGRyn+j3AN2qrieC4nOxA ihr9/WY7vi//luM/kcPVY+kxPJPwQeO9EGvmLzCAHKpLyUvlggxvIBiDvvVVsFrJKE1R 1dHsEVFfsaJHpw+9CrF4KvztVtdiUoK9O5OSNeU1sw+DXG0No3u+6dn433xZaQp0dmfJ fbEYQK3SxElDMTsF/SRmGlrvLbqILVePxnLwkfmONjGwY1HehMOHnaNumyh7LIYmY4Ge JVZw== X-Forwarded-Encrypted: i=1; AJvYcCVkZp+p1kXFQxuj3P6f8nFc+3FemW8fLgtMXYEg1BkoYqgoaVRunNgF4qZqESNPAm4vLB6z5i78ZprhnsMUsNbD@lists.infradead.org, AJvYcCXKK6DM6dSZS/HAWiCWRjj18QfzAceNSnkMwO3ednq+/KFO5nPHwZN3WlCe9jA+oErOwJT65fxrTBQs8SzbLzU=@lists.infradead.org X-Gm-Message-State: AOJu0Yx2gJbvW0fEnbT/b4FwbD0Ooz3CfhaHfKwBJmT4pEgBbms4WNi8 CA0hPDBdWgppi35KsNWMwowzLFvOxUc3m6nUIrYL9ffgLIF64vnp X-Gm-Gg: ASbGncu0B/oGTPXuSkbhndh1vadTTWb7eq00TCrSw6IrHqJR55pvRbArnTzxMwPuiF9 dYosr2q6o2JFrjCR84TiWtpasLR01UCI/ueVgghL2FOpRU2i5DHTvYdm2DJmofPbEdS96hxJIG7 Up4+azaTNfDSjk6bEG7Gd4kxLgQYOi/LDbmdYj2KEDyZA1823to0wvHhjSUa4/iQWUFK5Va0pm5 ehq+GiCks5huad/NpkfXY4xpceJyS4VEirpK1yNmsj9jQ+KNciK/2svR6dWNFKSnU61aMGvC7pZ xK2jTNiZ8o+AXi2YEV8GvVjGiE6gBudRxXmcgbBsOiaky2gKSQpKTjePDI+oVUX0wYTlSisP4/f gZMLCC0wKXZEuHzpjSxVS87f6 X-Google-Smtp-Source: AGHT+IE49+rfPRWkhQnonyxaadm1sq1c5PFRzPYaCltbYtN0FqVKUN0uyr5WSerVe16ioqfKocwosw== X-Received: by 2002:a05:6000:1869:b0:38d:df15:2770 with SMTP id ffacd0b85a97d-395b4231bacmr12639946f8f.0.1742053483995; Sat, 15 Mar 2025 08:44:43 -0700 (PDT) Received: from localhost.localdomain (93-34-90-129.ip49.fastwebnet.it. [93.34.90.129]) by smtp.googlemail.com with ESMTPSA id 5b1f17b1804b1-43d1fe0636dsm53464195e9.11.2025.03.15.08.44.42 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 15 Mar 2025 08:44:43 -0700 (PDT) From: Christian Marangi To: Christian Marangi , Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Andrew Lunn , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Vladimir Oltean , Srinivas Kandagatla , Heiner Kallweit , Russell King , Maxime Chevallier , Matthias Brugger , AngeloGioacchino Del Regno , linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, upstream@airoha.com Subject: [net-next PATCH v13 03/14] dt-bindings: net: dsa: Document support for Airoha AN8855 DSA Switch Date: Sat, 15 Mar 2025 16:43:43 +0100 Message-ID: <20250315154407.26304-4-ansuelsmth@gmail.com> X-Mailer: git-send-email 2.48.1 In-Reply-To: <20250315154407.26304-1-ansuelsmth@gmail.com> References: <20250315154407.26304-1-ansuelsmth@gmail.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250315_084445_899777_9AA34110 X-CRM114-Status: GOOD ( 16.04 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Document support for Airoha AN8855 5-port Gigabit Switch. It does expose the 5 Internal PHYs on the MDIO bus and each port can access the Switch register space by configurting the PHY page. Signed-off-by: Christian Marangi --- .../net/dsa/airoha,an8855-switch.yaml | 86 +++++++++++++++++++ MAINTAINERS | 1 + 2 files changed, 87 insertions(+) create mode 100644 Documentation/devicetree/bindings/net/dsa/airoha,an8855-switch.yaml diff --git a/Documentation/devicetree/bindings/net/dsa/airoha,an8855-switch.yaml b/Documentation/devicetree/bindings/net/dsa/airoha,an8855-switch.yaml new file mode 100644 index 000000000000..fbb9219fadae --- /dev/null +++ b/Documentation/devicetree/bindings/net/dsa/airoha,an8855-switch.yaml @@ -0,0 +1,86 @@ +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/net/dsa/airoha,an8855-switch.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: Airoha AN8855 Gigabit Switch + +maintainers: + - Christian Marangi + +description: > + Airoha AN8855 is a 5-port Gigabit Switch. + + It does expose the 5 Internal PHYs on the MDIO bus and each port + can access the Switch register space by configurting the PHY page. + +$ref: dsa.yaml#/$defs/ethernet-ports + +properties: + compatible: + const: airoha,an8855-switch + +required: + - compatible + +unevaluatedProperties: false + +examples: + - | + ethernet-switch { + compatible = "airoha,an8855-switch"; + + ports { + #address-cells = <1>; + #size-cells = <0>; + + port@0 { + reg = <0>; + label = "lan1"; + phy-mode = "internal"; + phy-handle = <&internal_phy1>; + }; + + port@1 { + reg = <1>; + label = "lan2"; + phy-mode = "internal"; + phy-handle = <&internal_phy2>; + }; + + port@2 { + reg = <2>; + label = "lan3"; + phy-mode = "internal"; + phy-handle = <&internal_phy3>; + }; + + port@3 { + reg = <3>; + label = "lan4"; + phy-mode = "internal"; + phy-handle = <&internal_phy4>; + }; + + port@4 { + reg = <4>; + label = "wan"; + phy-mode = "internal"; + phy-handle = <&internal_phy5>; + }; + + port@5 { + reg = <5>; + label = "cpu"; + ethernet = <&gmac0>; + phy-mode = "2500base-x"; + + fixed-link { + speed = <2500>; + full-duplex; + pause; + }; + }; + }; + }; diff --git a/MAINTAINERS b/MAINTAINERS index 1e8055b5e162..696ad8465ea8 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -726,6 +726,7 @@ L: linux-mediatek@lists.infradead.org (moderated for non-subscribers) L: netdev@vger.kernel.org S: Maintained F: Documentation/devicetree/bindings/net/airoha,an8855-mdio.yaml +F: Documentation/devicetree/bindings/net/dsa/airoha,an8855-switch.yaml F: Documentation/devicetree/bindings/nvmem/airoha,an8855-efuse.yaml AIROHA ETHERNET DRIVER From patchwork Sat Mar 15 15:43:44 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christian Marangi X-Patchwork-Id: 14018124 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 9F803C28B2F for ; Sat, 15 Mar 2025 15:53:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Transfer-Encoding: MIME-Version:References:In-Reply-To:Message-ID:Date:Subject:To:From:Reply-To: Cc:Content-Type:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=UOSxaiCNgkguMhmOsgtIM1pXf1qRsgQMSyGwNzCSHvc=; b=ZYUJPQeE9Bgttx31CNo9Itk/XI om5CA3JJIb8zMWPUpeVGP0R4Qm9h9cQVcywPCPc8HnJB9SsatzDv/zAe7y/vEHTEfXetMhnUFlX6b 5uhhj6OueBOM/+NsfF1k8y3STtCWFHw1zsYtmxywRKPdFHPqP5+gTEodmEwtn+Y5pH6fLIhTxNo/I x9V3rgKLF97wTI6sJJRknctIU6dWJN31C3hVD4z+2lltzblstN+yJa8WomR4q15fzrPYwd84w2203 /DAIsmASZDfmtC2g0xGNoMD2X2UFsLX8EKgyN8iBsTXwWtHpVX2UMnpbCLqKlEGE3Uk7U15b6Z97o gHOxNO9w==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1ttTpC-0000000GYTi-4BhQ; Sat, 15 Mar 2025 15:53:23 +0000 Received: from mail-wm1-x330.google.com ([2a00:1450:4864:20::330]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1ttTgt-0000000GX1a-0pjd; Sat, 15 Mar 2025 15:44:48 +0000 Received: by mail-wm1-x330.google.com with SMTP id 5b1f17b1804b1-43cec5cd73bso4045155e9.3; Sat, 15 Mar 2025 08:44:46 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1742053485; x=1742658285; darn=lists.infradead.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=UOSxaiCNgkguMhmOsgtIM1pXf1qRsgQMSyGwNzCSHvc=; b=CVXxFDZfDs7dUsOu0qpHKI9tTr1NtgYcEDwWGiXkw20faXL2oCaFWSGCWQWkyXbBO4 WlFY6vZNoVo3gvtQ1I6Purc+MekCO+GhWCfJZxiZ+heF4URZIhCc1Uj+GTMKxMOIqu2x 6t9B9xs98Ge8rXyXKRKhFWXxPd7mjxHzpjYmMrcGvVveYFo7aXw44GdnsyR831zd/NFg im2QBrHvcZ4wWJF+N74WmFaETjNj6d71knnNogaP7zJHSkUwDsNoPn4ZrLoYccLIc57w zx/t36EUVzAaxYtwWg35emhrYYUyo+y0me+YDXOHolyUE7CBelQdIm7M/a66PEGO4Qup 1XcQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1742053485; x=1742658285; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=UOSxaiCNgkguMhmOsgtIM1pXf1qRsgQMSyGwNzCSHvc=; b=FKdl5rzgXVIGQJzjkMyZliQ2JTwdGOjIuKAS8ZUsYyopZm7Ag/6kNh7eNtESzzcNbr dllP4PgHdLR5QRjskDXYnqquH6fMH5jJS1ECvoxb36rfZZ/XAq8fSnmQ0dR5pfS3WIGj NuUyX3E8QQSdPOmlveG/HwBjQY7N/hHZ193FKn7+nDFOy07SEucRzFsU4QgDe56pSVn1 yhR0sZuXwiIq0pGegb3X+YxaJCrCwKeeN3mWi2YEA3r5QxdvgGou6Rfay/b1bWKqX3Ky Qr31uqgVIeIU7ehtM1pcAL00SGKmZI86VcBO0+9VZuKeCirJskji1cmFbA4Y21fsNAoE zwWg== X-Forwarded-Encrypted: i=1; AJvYcCWOMjN4o8yd8AXJ8hkpPYAv09w4r7WICwnCR7aQtDIhvje5TwXIvkpmpl6surujLcKfQSo4kE+IQtrj57/mQoE=@lists.infradead.org, AJvYcCWWDmpsY598KOeRNAD9Jmkj+RtSRgX2lUfzSysomKITGQKEWar/TjcQCSRP1qUzFLSwVwddORFQZjleCqkIXUf9@lists.infradead.org X-Gm-Message-State: AOJu0YwTpVFpwbartQ3Fmtt4aGS4mnghIzfMVxEZ6OG/jSlBU06glZhs 1pTv6O4gSQp8fyKv8yFmyWvH7ZGG1XSKdbg2UTTgW+0j948bYf49 X-Gm-Gg: ASbGncv6xC7esM35hDR/mDwlQW8mvGTx8h64vcYGOEU35ZmMaZ3aEuGAq3IXwJ60Owu MklyN3J/C120QLXCYDl2lYf6pZE9p0zm1PGQq15Ddc30OeoG/MpYPxbZhFoNcX4tAGJRzPlSw9I eWpwrs6Eay2yKKPxz8nRILG9YrUwb2wEiNtn8c2LP1dWQTMBYeuNAIRvYyPblLym93gQxO+xOyr 4Cf1tDoe6X66Xs5FXabdK5hCJZae8whdrDl2lvEDDf6bd8YLUN8TAKNjqzuOHQxlmdTnC3d2/Qp oy6ZFknfK7eJdpABl7wTYkiTyzKD27ghQRQsLzY6GqqDMuAp/oxt0IwCB2wNK85lHA/7lsAbh8v ymH/eIaQ7e6q+XA== X-Google-Smtp-Source: AGHT+IGsWcjc1hDGEO8cxnzByykp8hNWR+gBAlcKe4nhtYmqVcy+n+X4aKOrFdK8VFw4PIbyBeMzjQ== X-Received: by 2002:a05:600c:4f0d:b0:43d:42b:e186 with SMTP id 5b1f17b1804b1-43d1ec71e13mr74675115e9.8.1742053485345; Sat, 15 Mar 2025 08:44:45 -0700 (PDT) Received: from localhost.localdomain (93-34-90-129.ip49.fastwebnet.it. [93.34.90.129]) by smtp.googlemail.com with ESMTPSA id 5b1f17b1804b1-43d1fe0636dsm53464195e9.11.2025.03.15.08.44.44 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 15 Mar 2025 08:44:45 -0700 (PDT) From: Christian Marangi To: Christian Marangi , Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Andrew Lunn , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Vladimir Oltean , Srinivas Kandagatla , Heiner Kallweit , Russell King , Maxime Chevallier , Matthias Brugger , AngeloGioacchino Del Regno , linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, upstream@airoha.com Subject: [net-next PATCH v13 04/14] dt-bindings: net: Document support for AN8855 Switch Internal PHY Date: Sat, 15 Mar 2025 16:43:44 +0100 Message-ID: <20250315154407.26304-5-ansuelsmth@gmail.com> X-Mailer: git-send-email 2.48.1 In-Reply-To: <20250315154407.26304-1-ansuelsmth@gmail.com> References: <20250315154407.26304-1-ansuelsmth@gmail.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250315_084447_248800_227EF404 X-CRM114-Status: GOOD ( 17.73 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Document support for AN8855 Switch Internal PHY. Airoha AN8855 is a 5-port Gigabit Switch that expose the Internal PHYs on the MDIO bus. Each PHY might need to be calibrated to correctly work with the use of the eFUSE provided by the Switch SoC. This can be enabled by defining in the PHY node the NVMEM cell properties. Signed-off-by: Christian Marangi --- .../bindings/net/airoha,an8855-phy.yaml | 83 +++++++++++++++++++ MAINTAINERS | 1 + 2 files changed, 84 insertions(+) create mode 100644 Documentation/devicetree/bindings/net/airoha,an8855-phy.yaml diff --git a/Documentation/devicetree/bindings/net/airoha,an8855-phy.yaml b/Documentation/devicetree/bindings/net/airoha,an8855-phy.yaml new file mode 100644 index 000000000000..d2f86116badf --- /dev/null +++ b/Documentation/devicetree/bindings/net/airoha,an8855-phy.yaml @@ -0,0 +1,83 @@ +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/net/airoha,an8855-phy.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: Airoha AN8855 Switch Internal PHY + +maintainers: + - Christian Marangi + +description: > + Airoha AN8855 is a 5-port Gigabit Switch that expose the Internal + PHYs on the MDIO bus. + + Each PHY might need to be calibrated to correctly work with the + use of the eFUSE provided by the Switch SoC. + +allOf: + - $ref: ethernet-phy.yaml# + +select: + properties: + compatible: + contains: + enum: + - ethernet-phy-idc0ff.0410 + required: + - compatible + +properties: + reg: + maxItems: 1 + + nvmem-cells: + items: + - description: phandle to SoC eFUSE tx_a + - description: phandle to SoC eFUSE tx_b + - description: phandle to SoC eFUSE tx_c + - description: phandle to SoC eFUSE tx_d + + nvmem-cell-names: + items: + - const: tx_a + - const: tx_b + - const: tx_c + - const: tx_d + +required: + - compatible + - reg + +dependentRequired: + nvmem-cells: [ nvmem-cell-names ] + +unevaluatedProperties: false + +examples: + - | + mdio { + #address-cells = <1>; + #size-cells = <0>; + + ethernet-phy@1 { + compatible = "ethernet-phy-idc0ff.0410", + "ethernet-phy-ieee802.3-c45"; + + reg = <1>; + }; + + ethernet-phy@2 { + compatible = "ethernet-phy-idc0ff.0410", + "ethernet-phy-ieee802.3-c45"; + + reg = <2>; + + nvmem-cells = <&shift_sel_port0_tx_a>, + <&shift_sel_port0_tx_b>, + <&shift_sel_port0_tx_c>, + <&shift_sel_port0_tx_d>; + nvmem-cell-names = "tx_a", "tx_b", "tx_c", "tx_d"; + }; + }; diff --git a/MAINTAINERS b/MAINTAINERS index 696ad8465ea8..45f4bb8deb0d 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -726,6 +726,7 @@ L: linux-mediatek@lists.infradead.org (moderated for non-subscribers) L: netdev@vger.kernel.org S: Maintained F: Documentation/devicetree/bindings/net/airoha,an8855-mdio.yaml +F: Documentation/devicetree/bindings/net/airoha,an8855-phy.yaml F: Documentation/devicetree/bindings/net/dsa/airoha,an8855-switch.yaml F: Documentation/devicetree/bindings/nvmem/airoha,an8855-efuse.yaml From patchwork Sat Mar 15 15:43:45 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christian Marangi X-Patchwork-Id: 14018125 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 47E97C28B28 for ; Sat, 15 Mar 2025 15:55:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Transfer-Encoding: MIME-Version:References:In-Reply-To:Message-ID:Date:Subject:To:From:Reply-To: Cc:Content-Type:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=A2bomu0aDGtFs04nywYlMbipXyb3n9cPvymFIMABLx4=; b=LpzQr+Hf+9dYS1YP+FOQRvs1Zs ZxlVPJfoXfFIaS78Rnb6id8zvdN3KLlV8FjoJa+5OLmKh474BiPOyiAmZuW87tquiy1d4cX5AlQ4q 9cOjrtVJb/f+CdVBaoWiVDNDKIQEq+n918qPV5+hxBHxkDKeFMGdTNVIsK5O0fjtYlVhSPjGiW8qt Nk2uQpsWfnBz0F/z6QAx0rHKUTZndSmiKWCLwJ4mtb6zrk0zOjow8dqUx2ZuoIhyMGaI0Cnss6vy3 4OnftFHXMdLTDNWfcBY+8kCOk27GCiEZ3fAbTaIqO4hLzgYg6viesq5lttiZpH1y7OZnma+TnZn2F 12eXtmxg==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1ttTqr-0000000GYaF-08nO; Sat, 15 Mar 2025 15:55:05 +0000 Received: from mail-wm1-x332.google.com ([2a00:1450:4864:20::332]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1ttTgu-0000000GX26-33hg; Sat, 15 Mar 2025 15:44:50 +0000 Received: by mail-wm1-x332.google.com with SMTP id 5b1f17b1804b1-43cf628cb14so3652955e9.1; Sat, 15 Mar 2025 08:44:48 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1742053487; x=1742658287; darn=lists.infradead.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=A2bomu0aDGtFs04nywYlMbipXyb3n9cPvymFIMABLx4=; b=atF5mY/DQr3jql3f6tW/2tWp/APE081iZr+p+/kma1wO8MNlc8LY3WRHqon6Fhil8F qe4b3OQUUd+/y1Qu1HY92To9mq05RG1tnvV7MPA+jkDcNKOpSeNF4kn3RsssXvcRGUxc PBuA04j5Ff9UKhAI1dNmdRlwPx11SyMLlzOmy7EkLR8/Gt6FEywUcGQxVOy5oti3ePTC rDKwFlJmWmovMH6Iw09XNpVOUgIb1aEtIQu8d9iSgCvtNCS0/rF0uhow/SYeScFzNvS9 DujoEPkoKcCoOIgjw0PFWBaY6Pxidxy7Ost1FKUcV+xEm3nnOmQn7Lg/F7pJijQxM/Lb 2YEA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1742053487; x=1742658287; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=A2bomu0aDGtFs04nywYlMbipXyb3n9cPvymFIMABLx4=; b=i7T6cj48nHbdfr11mbC2t0W2WO6hYm8pROrVJxk1qZHmfiQNkdRqX4Nad3Ss6/JOLP vYuWlU//Ydf/308kVuNK/7M5gOLBKy2R4rO8Zl0j3lSheEaI7TCSHdijSOaguOU80MAt 4Sc02H5rv0degcs9ssMlyzirNJAjeIOaFeVG0FtqrwApTZWnU+JdXX8ZRGtxe3m8jq5U sZR0GQhBUNeS/gxcbM7qvc9kZQ10w7fJgUotlc1WhJf4yTLXqS+qwIZAgPOCzcD5Fnia zdXxYumaQqUFeIhsMd1cwUa0fnfClIbnoBDYbR2tqVUcwH2zgRSeOf0F3RAaaew6tuDT Pcjw== X-Forwarded-Encrypted: i=1; AJvYcCX75S2HCzB4YUNiwvWEVeVINUgKGJHLBcWXJTS7Ek/dr6gz1Xkti5VaOatYOe5h+m0LerymuBJWhj2KhRqdJJA=@lists.infradead.org, AJvYcCXrYQkDvZeu/5mRmgAs5HnpxlGg5boQYsyj8HqmT0MnYkKkwJ4XAWh0VrstczOEcY14ZaqV2jzOqYxkPAUX8Cmq@lists.infradead.org X-Gm-Message-State: AOJu0Yx+aaGe26tTW+dv6D3AulZg/5VQkRkwhdAxA/Earhw7WXnOTAH9 cxumYg7+43824Dp4XK3V1FJrtY+G4bOMpGL2T4iyv4+aUgwJAtlQ X-Gm-Gg: ASbGncvaTce6UR9k47F9JYTGTG/pbcbFydmBYHft+6TuzAycOfVfdaCfi389ZFsqhg/ KnivGTV7D7FVAZkN7w4hV9vvxqCs98BIQQVsK7dMBRjxS9roYmKJrQbvuceqoXsk4RwsIfuX4UT AF++vJHpj0zR/jt/hXMXZFtDounVwC9/U+4/3uVZ3lYWXEyjH3SZxDZROtKI6RGj06qk2ET4Pjl WZOol3vNDF95PFQ+vmyyQUzI5m+ew+kKIVYhg8vLJ/VO5tL7EcAuR4tocU1/x+egi35Fg6AvI6G ATG90kGV2iPq7ws0CgIv7fS1hBmQaJ25gCIvbNNBweZx7Qr9fHEQXEKblETcFCdU+9LRslbmtkk ij0HAC8kcA5nyfg== X-Google-Smtp-Source: AGHT+IEhCyUiyhg64g12SU6KmHgYBMBD6ll/U35SvERkYFCfc0O2UiPMXs8V+ySvepc/0dICSdJ4SQ== X-Received: by 2002:a05:600c:1c9d:b0:43d:186d:a4bf with SMTP id 5b1f17b1804b1-43d1f120201mr78301655e9.0.1742053486688; Sat, 15 Mar 2025 08:44:46 -0700 (PDT) Received: from localhost.localdomain (93-34-90-129.ip49.fastwebnet.it. [93.34.90.129]) by smtp.googlemail.com with ESMTPSA id 5b1f17b1804b1-43d1fe0636dsm53464195e9.11.2025.03.15.08.44.45 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 15 Mar 2025 08:44:46 -0700 (PDT) From: Christian Marangi To: Christian Marangi , Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Andrew Lunn , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Vladimir Oltean , Srinivas Kandagatla , Heiner Kallweit , Russell King , Maxime Chevallier , Matthias Brugger , AngeloGioacchino Del Regno , linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, upstream@airoha.com Subject: [net-next PATCH v13 05/14] dt-bindings: mfd: Document support for Airoha AN8855 Switch SoC Date: Sat, 15 Mar 2025 16:43:45 +0100 Message-ID: <20250315154407.26304-6-ansuelsmth@gmail.com> X-Mailer: git-send-email 2.48.1 In-Reply-To: <20250315154407.26304-1-ansuelsmth@gmail.com> References: <20250315154407.26304-1-ansuelsmth@gmail.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250315_084448_766961_2141FDD6 X-CRM114-Status: GOOD ( 17.01 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Document support for Airoha AN8855 Switch SoC. This SoC expose various peripherals like an Ethernet Switch, a NVMEM provider and Ethernet PHYs. It does also support i2c and timers but those are not currently supported/used. Signed-off-by: Christian Marangi --- .../bindings/mfd/airoha,an8855.yaml | 182 ++++++++++++++++++ MAINTAINERS | 1 + 2 files changed, 183 insertions(+) create mode 100644 Documentation/devicetree/bindings/mfd/airoha,an8855.yaml diff --git a/Documentation/devicetree/bindings/mfd/airoha,an8855.yaml b/Documentation/devicetree/bindings/mfd/airoha,an8855.yaml new file mode 100644 index 000000000000..a59a23056b3a --- /dev/null +++ b/Documentation/devicetree/bindings/mfd/airoha,an8855.yaml @@ -0,0 +1,182 @@ +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/mfd/airoha,an8855.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: Airoha AN8855 Switch SoC + +maintainers: + - Christian Marangi + +description: > + Airoha AN8855 Switch is a SoC that expose various peripherals like an + Ethernet Switch, a NVMEM provider and Ethernet PHYs. + + It does also support i2c and timers but those are not currently + supported/used. + +properties: + compatible: + const: airoha,an8855 + + reg: + maxItems: 1 + + reset-gpios: true + + efuse: + type: object + $ref: /schemas/nvmem/airoha,an8855-efuse.yaml + description: + EFUSE exposed by the Airoha AN8855 Switch. This child node definition + should follow the bindings specified in + Documentation/devicetree/bindings/nvmem/airoha,an8855-efuse.yaml + + ethernet-switch: + type: object + $ref: /schemas/net/dsa/airoha,an8855-switch.yaml + description: + Switch exposed by the Airoha AN8855 Switch. This child node definition + should follow the bindings specified in + Documentation/devicetree/bindings/net/dsa/airoha,an8855-switch.yaml + + mdio: + type: object + $ref: /schemas/net/airoha,an8855-mdio.yaml + description: + MDIO exposed by the Airoha AN8855 Switch. This child node definition + should follow the bindings specified in + Documentation/devicetree/bindings/net/airoha,an8855-mdio.yaml + +required: + - compatible + - reg + +additionalProperties: false + +examples: + - | + #include + + mdio { + #address-cells = <1>; + #size-cells = <0>; + + soc@1 { + compatible = "airoha,an8855"; + reg = <1>; + + reset-gpios = <&pio 39 0>; + + efuse { + compatible = "airoha,an8855-efuse"; + + #nvmem-cell-cells = <0>; + + nvmem-layout { + compatible = "fixed-layout"; + #address-cells = <1>; + #size-cells = <1>; + + shift_sel_port0_tx_a: shift-sel-port0-tx-a@c { + reg = <0xc 0x4>; + }; + + shift_sel_port0_tx_b: shift-sel-port0-tx-b@10 { + reg = <0x10 0x4>; + }; + + shift_sel_port0_tx_c: shift-sel-port0-tx-c@14 { + reg = <0x14 0x4>; + }; + + shift_sel_port0_tx_d: shift-sel-port0-tx-d@18 { + reg = <0x18 0x4>; + }; + + shift_sel_port1_tx_a: shift-sel-port1-tx-a@1c { + reg = <0x1c 0x4>; + }; + + shift_sel_port1_tx_b: shift-sel-port1-tx-b@20 { + reg = <0x20 0x4>; + }; + + shift_sel_port1_tx_c: shift-sel-port1-tx-c@24 { + reg = <0x24 0x4>; + }; + + shift_sel_port1_tx_d: shift-sel-port1-tx-d@28 { + reg = <0x28 0x4>; + }; + }; + }; + + ethernet-switch { + compatible = "airoha,an8855-switch"; + + ports { + #address-cells = <1>; + #size-cells = <0>; + + port@0 { + reg = <0>; + label = "lan1"; + phy-mode = "internal"; + phy-handle = <&internal_phy1>; + }; + + port@1 { + reg = <1>; + label = "lan2"; + phy-mode = "internal"; + phy-handle = <&internal_phy2>; + }; + + port@5 { + reg = <5>; + label = "cpu"; + ethernet = <&gmac0>; + phy-mode = "2500base-x"; + + fixed-link { + speed = <2500>; + full-duplex; + pause; + }; + }; + }; + }; + + mdio { + compatible = "airoha,an8855-mdio"; + #address-cells = <1>; + #size-cells = <0>; + + internal_phy1: phy@1 { + compatible = "ethernet-phy-idc0ff.0410", + "ethernet-phy-ieee802.3-c45"; + reg = <1>; + + nvmem-cells = <&shift_sel_port0_tx_a>, + <&shift_sel_port0_tx_b>, + <&shift_sel_port0_tx_c>, + <&shift_sel_port0_tx_d>; + nvmem-cell-names = "tx_a", "tx_b", "tx_c", "tx_d"; + }; + + internal_phy2: phy@2 { + compatible = "ethernet-phy-idc0ff.0410", + "ethernet-phy-ieee802.3-c45"; + reg = <2>; + + nvmem-cells = <&shift_sel_port1_tx_a>, + <&shift_sel_port1_tx_b>, + <&shift_sel_port1_tx_c>, + <&shift_sel_port1_tx_d>; + nvmem-cell-names = "tx_a", "tx_b", "tx_c", "tx_d"; + }; + }; + }; + }; diff --git a/MAINTAINERS b/MAINTAINERS index 45f4bb8deb0d..65709e47adc7 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -725,6 +725,7 @@ L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers) L: linux-mediatek@lists.infradead.org (moderated for non-subscribers) L: netdev@vger.kernel.org S: Maintained +F: Documentation/devicetree/bindings/mfd/airoha,an8855.yaml F: Documentation/devicetree/bindings/net/airoha,an8855-mdio.yaml F: Documentation/devicetree/bindings/net/airoha,an8855-phy.yaml F: Documentation/devicetree/bindings/net/dsa/airoha,an8855-switch.yaml From patchwork Sat Mar 15 15:43:46 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christian Marangi X-Patchwork-Id: 14018129 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 DA4E0C28B28 for ; Sat, 15 Mar 2025 15:56:55 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Transfer-Encoding: MIME-Version:References:In-Reply-To:Message-ID:Date:Subject:To:From:Reply-To: Cc:Content-Type:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=NEeHqPbidnUgfl04t+LLdBVbgy41Di7XU1dGgXeGDSo=; b=u8XfjIRqQowu9/ZYvakMxmrjn7 080CTl7OKVqlmgYmiS1sDwV8NJNIpTO4yXOlLqWsmAeWYUkq9TNAIKucg02mfgHxNA2lJXjKEaEER JFW3KZyxdxkbiQYu0Idd3Z+lxji+SnQaKTXPcw52Q+D8/8r108Qq1082sl53fjXgc7X4Vzkt0zD8E F2ZG/EvI6NTAu9YMl4mvfalf62T6IABXxmJEd2t3ncleeN9kfos5r4/E+Qaos79CPehpUIjIj/zmi QXpR6bC2wedk9o1oLAeZmTC1smvrsVqh97sM5wKPpAMLPrjFqkLki7wVVARWDvjNPcTgpL8Z7lKlv reb/l20A==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1ttTsV-0000000GYlM-0fVc; Sat, 15 Mar 2025 15:56:47 +0000 Received: from mail-wm1-x32b.google.com ([2a00:1450:4864:20::32b]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1ttTgv-0000000GX2L-40SD; Sat, 15 Mar 2025 15:44:51 +0000 Received: by mail-wm1-x32b.google.com with SMTP id 5b1f17b1804b1-43cef035a3bso4605565e9.1; Sat, 15 Mar 2025 08:44:49 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1742053488; x=1742658288; darn=lists.infradead.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=NEeHqPbidnUgfl04t+LLdBVbgy41Di7XU1dGgXeGDSo=; b=ILagMfU/BEXwPwROO383ki3QkiqN0aO40zDUrOng3bpESbJMCJB4vWzeMtPGtItjdi 4/dyN0Kwra5xbZAnJE+SROSUb9ScfF84jDYH7YB/tZntZhU8TT/OVaI5K4P7iQc+KXFN mfbbUNVk2lcsVbULGJrpBc5zdRz6Con6zXw89npYSiMSUx5xc35KSIw5RQ1M5oNGTnaM hXwL4h7FUfH9JsGhoNQ8zMS4g7IWyylqxW1j3TA/r9cfUDwu9XpOtvh9D1mbzQsxK7uT v8+8WpOK1MYPyXKmcf+5dbhKbWnexaIe0mIhy4o1FGm2DIhTBgUCEpzrK1sKYAWSACUX R1Jw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1742053488; x=1742658288; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=NEeHqPbidnUgfl04t+LLdBVbgy41Di7XU1dGgXeGDSo=; b=HP8GoCcaQZw/HFMd/1Yw4R9lgmKYodjYxawx3IaTCwgq2MuKUIrQgARuiQgEtxbkSX OmKjDapr8ZOYaif9H9ZgU9Cu/33fDKPT8XUw51+diKgah+Svkqd0EmUfyghOdKl9WmCm ex+uPEEPG039HvfdZc6MEOgRmB0z3V8hy/8ZJBNoRwTwbMaLSV0s+z+exeXvyUm4yokX XxlyYbu+QYkfpTFnhCLfWI3kUMyVC/ykgvyLmqDI+UPbMkWGnlJ0M/jMQtx0VHsy9GKv wKQA+eb9UEF8JFBFnSvQGLHG9yv0lm0pC6Ajwv9zPOwUqvr90kV/RLaZR4fiMRjLIckL GYzg== X-Forwarded-Encrypted: i=1; AJvYcCXBMXK+KrCn+T5tU4GtZR3xjRVOch2JtYhWYGXaVa3ZGmX3udzCKYfGvpXMDe2AeX/2U7ENWWjFRC4oIdWx/iI=@lists.infradead.org, AJvYcCXRQVIZKwJchq0QMCX5CizNA5dh0ftK3RBqvOk6Bbkmhv7jcIOcpCd+dA0R9g8bDzqdaGWKA+U+9rzuyzUsjtyw@lists.infradead.org X-Gm-Message-State: AOJu0YxTWot4cTaes5xqUcuXJr/nBKKAQudwhxxbcigaLOFLTTA11hCj b4+ZTmqYnQaNnNFVSVYdj9CYkvTvqEu7cAqEBOwYXi7HVudQTTp4 X-Gm-Gg: ASbGncvItGHc7i6Pn0Q37d79sRRCNThsQtbPcLCJlD8i3NTQ9lUJ9HLtyLrGA1ImRMi suNdsi1/IyeCAooS8eZInRl2tN+dgFiHNEdzjPaxeBAtzboMa66KXqQA3ovpyeh5IVX2Y1yZ/zJ E4FOOWjiSUuXeiSzRb7uN1gD7gt4sRlz00R05EjodP/XuAfwoJjobMed+PnOBkNunDU++yBtSsd ASNqB6/Q00IIAAKEElwbrnuEnQ6Kc6A3B064Yhu6OvbtGXNJdRwMplRM+fo+lKN65ldYO+T6VrL ThcmSPdJtj9QxzJ8YR8B5eOQpMsfbqI4daNkTi2n0XdnBtn4B8YkU4vmvF+LOx+moDlDHHxhUBO 0+q1OArC0acgSMA== X-Google-Smtp-Source: AGHT+IGir5EjbBHxfMQYrp8pkd06ZMtYDcN3X2GtiQlfMspqlPbumHAhw6bjrr+M4eP0wyzj84nKQg== X-Received: by 2002:a05:600c:4fd3:b0:43d:8ea:8d80 with SMTP id 5b1f17b1804b1-43d1ec9071amr88893115e9.5.1742053488011; Sat, 15 Mar 2025 08:44:48 -0700 (PDT) Received: from localhost.localdomain (93-34-90-129.ip49.fastwebnet.it. [93.34.90.129]) by smtp.googlemail.com with ESMTPSA id 5b1f17b1804b1-43d1fe0636dsm53464195e9.11.2025.03.15.08.44.46 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 15 Mar 2025 08:44:47 -0700 (PDT) From: Christian Marangi To: Christian Marangi , Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Andrew Lunn , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Vladimir Oltean , Srinivas Kandagatla , Heiner Kallweit , Russell King , Maxime Chevallier , Matthias Brugger , AngeloGioacchino Del Regno , linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, upstream@airoha.com Subject: [net-next PATCH v13 06/14] net: mdio: regmap: prepare support for multiple valid addr Date: Sat, 15 Mar 2025 16:43:46 +0100 Message-ID: <20250315154407.26304-7-ansuelsmth@gmail.com> X-Mailer: git-send-email 2.48.1 In-Reply-To: <20250315154407.26304-1-ansuelsmth@gmail.com> References: <20250315154407.26304-1-ansuelsmth@gmail.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250315_084450_008218_DECBED7D X-CRM114-Status: GOOD ( 15.17 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Rework the valid_addr and convert it to a mask in preparation for mdio regmap to support multiple valid addr in the case the regmap can support it. Signed-off-by: Christian Marangi --- drivers/net/mdio/mdio-regmap.c | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/drivers/net/mdio/mdio-regmap.c b/drivers/net/mdio/mdio-regmap.c index 8a742a8d6387..810ba0a736f0 100644 --- a/drivers/net/mdio/mdio-regmap.c +++ b/drivers/net/mdio/mdio-regmap.c @@ -19,7 +19,7 @@ struct mdio_regmap_priv { struct regmap *regmap; - u8 valid_addr; + u32 valid_addr_mask; }; static int mdio_regmap_read_c22(struct mii_bus *bus, int addr, int regnum) @@ -28,7 +28,7 @@ static int mdio_regmap_read_c22(struct mii_bus *bus, int addr, int regnum) unsigned int val; int ret; - if (ctx->valid_addr != addr) + if (!(ctx->valid_addr_mask & BIT(addr))) return -ENODEV; ret = regmap_read(ctx->regmap, regnum, &val); @@ -43,7 +43,7 @@ static int mdio_regmap_write_c22(struct mii_bus *bus, int addr, int regnum, { struct mdio_regmap_priv *ctx = bus->priv; - if (ctx->valid_addr != addr) + if (!(ctx->valid_addr_mask & BIT(addr))) return -ENODEV; return regmap_write(ctx->regmap, regnum, val); @@ -65,7 +65,7 @@ struct mii_bus *devm_mdio_regmap_register(struct device *dev, mr = mii->priv; mr->regmap = config->regmap; - mr->valid_addr = config->valid_addr; + mr->valid_addr_mask = BIT(config->valid_addr); mii->name = DRV_NAME; strscpy(mii->id, config->name, MII_BUS_ID_SIZE); @@ -74,7 +74,7 @@ struct mii_bus *devm_mdio_regmap_register(struct device *dev, mii->write = mdio_regmap_write_c22; if (config->autoscan) - mii->phy_mask = ~BIT(config->valid_addr); + mii->phy_mask = ~mr->valid_addr_mask; else mii->phy_mask = ~0; From patchwork Sat Mar 15 15:43:47 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christian Marangi X-Patchwork-Id: 14018130 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 B9A95C28B2F for ; Sat, 15 Mar 2025 15:58:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Transfer-Encoding: MIME-Version:References:In-Reply-To:Message-ID:Date:Subject:To:From:Reply-To: Cc:Content-Type:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=B/n2TjI2M2VtBMHZFJp0/mcf13FR0dQEfPH18lq5S60=; b=KSp6oO9hBr4DfXk15rCKWsF+jm fdaqMogCBbOEgnpT242hs1wYdh56RNTsAKuY5/TYtOdFFiwlCL2YLtQw5MdIjXjDo9ddaCDotc5I+ uDnwwmJSGG5h3xLn2yufz09Jyv/xwmyVtaWncbwG+HHBe7LWy93k1BcWWKBMoCjMVGPnaCgQVIbbE C/gGNeITmtm6wMboe6q75OWDwsz6MIOqg8deC8jvWLseSn1yRMSoh/VlMq+CkILoFlKPbKdlTmAUp R4B/cpqEfv8TcMfbkqb9yrfo1tZ9HdBOt3W67xJ2n9+kX/VSCz9u3XYGux2WBPmMi5tARLISjdtQS jd2AXxWQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1ttTu8-0000000GYsv-38fX; Sat, 15 Mar 2025 15:58:28 +0000 Received: from mail-wr1-x42f.google.com ([2a00:1450:4864:20::42f]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1ttTgx-0000000GX2k-1AWX; Sat, 15 Mar 2025 15:44:52 +0000 Received: by mail-wr1-x42f.google.com with SMTP id ffacd0b85a97d-390e3b3d3f4so1806531f8f.2; Sat, 15 Mar 2025 08:44:50 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1742053489; x=1742658289; darn=lists.infradead.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=B/n2TjI2M2VtBMHZFJp0/mcf13FR0dQEfPH18lq5S60=; b=hQPdayeElt5qFgJ7ycqKO6n7j+6SPns6+7GDZ9Du4gUw9EUwxWCW3Aves2NeKSpE6s V/M4br4vpyZWXLsuIABAmKeIEb1i4bgIHzqNwlELiZsDeqySmRgZ0eudCXEOWF2Js+Xj xAAKEWTcmZuyfMO/7cUKRk4OIl8938azd191imPpAh/cGnvVhaNf0Vd1fdDeJmKMWjug bNAN37D9ZqUtJMz4fKLxiB4fnx0D9Nzi3bxlEYwoNaCY5cSI/ERYB9Hb6jtS+ZfIqllp 1GM1Z6EFLRBEkGcnB+ih/Kw0WCDew4vnc9zXMdxMYkQl0aBHcpYF7RnKGKN125xN3Urj ktag== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1742053489; x=1742658289; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=B/n2TjI2M2VtBMHZFJp0/mcf13FR0dQEfPH18lq5S60=; b=NGWWAE6ORPeSJK+qk8IMno2tUlGyRmsIrRUBLnik5AbzNB5qERaGB8udH2bgFyIiMO RyNNX3F4n2hwepNC6fGjlagMwFVOGlsKmPblnvn8DTwlGubydXKfno2Bre5CGZOygNd5 PXVxTQ9ZjR5mZsYes8JjSvpUCmQcFX7yRNX/jxTBlcQBYUkkBV84jYdfOH2xpksLhyMQ 1wASn7Cc/x3HdMamhUIGHXhZsHASLl/ZlyFxXOt/CkKyxAi9NgHNo10mkEaPjAIMo3NA Y+g21LaNblrnHf802C1yIFih3YxBcO/vMgk/R2O/hxhHhz7SUyzZc0sSrEC+2yOYmH6i 2xEg== X-Forwarded-Encrypted: i=1; AJvYcCUNB7yIQ19eOEJLhHPMB3f/luVDkXTRB1/jZ6i715Nx6A+ubps/47JBwMLciL8kDnRKdgEK5Ou8LrGqkjHvQPM=@lists.infradead.org, AJvYcCXiQaU/vnJ8zHGAr7Twl07bvv66411HGEq3Fivv1TW+h9k8NS4e5OaGgc1gzxv8v+91OLhFyV7rNq4a1IZa2DlJ@lists.infradead.org X-Gm-Message-State: AOJu0Yxz/sd1JM+1eu5rQPcCISzcJekccpoDIbhYEt1GB8LXQmel0sB9 dzKhhRrYO0AUNDqEoUBP+qkAqHZQPsdOr/Zj7fL6QkrC16ygVEoI X-Gm-Gg: ASbGnctxDb+KTtlpAMu6jFwKRj+q3RO5ZqHwVNXEJCZAYFhZeTLkx7oxCwgrIKivqkU nxPLIPA0xLBekVDdHwM/4uYhhwzlKF7+kiB2LmGZlgbDCcu+/X4jsRPqN5NQzo893rSPc3IdILu spsVh5kVR9fdSMj0SvAacqW01JCgWXwRoyD0WDRqug7zqP6t+zaeluJN8liT6u3Q3a9iNFrnjlz S7qse3K/ngm8+g2pqcEAnllaRVx2PPEEfatGOVY35piknbniL7OKtFOVYiI7P05MSi+zOC1N3ei 9ZVEhg36DmOLmysdjqGQxcMJgYkH7LebRB6Bnt9EiSp/BpCczyrLaliu3VTerVWqw/ZIU+OGVxZ XAdgC9BxWXFHVng== X-Google-Smtp-Source: AGHT+IFfi4s8YK/7ZOy1tENtskKAFtjhxc2HmKBHt4o16W7ijUbFjzkhItG3iYRAjb22D/PG7p8FBg== X-Received: by 2002:a05:6000:1564:b0:38f:28a1:501e with SMTP id ffacd0b85a97d-3971d03df3dmr8216932f8f.8.1742053489365; Sat, 15 Mar 2025 08:44:49 -0700 (PDT) Received: from localhost.localdomain (93-34-90-129.ip49.fastwebnet.it. [93.34.90.129]) by smtp.googlemail.com with ESMTPSA id 5b1f17b1804b1-43d1fe0636dsm53464195e9.11.2025.03.15.08.44.48 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 15 Mar 2025 08:44:49 -0700 (PDT) From: Christian Marangi To: Christian Marangi , Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Andrew Lunn , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Vladimir Oltean , Srinivas Kandagatla , Heiner Kallweit , Russell King , Maxime Chevallier , Matthias Brugger , AngeloGioacchino Del Regno , linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, upstream@airoha.com Subject: [net-next PATCH v13 07/14] net: mdio: regmap: add support for C45 read/write Date: Sat, 15 Mar 2025 16:43:47 +0100 Message-ID: <20250315154407.26304-8-ansuelsmth@gmail.com> X-Mailer: git-send-email 2.48.1 In-Reply-To: <20250315154407.26304-1-ansuelsmth@gmail.com> References: <20250315154407.26304-1-ansuelsmth@gmail.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250315_084451_365457_096F3F01 X-CRM114-Status: GOOD ( 24.28 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Add support for C45 read/write for mdio regmap. This can be done by enabling the support_encoded_addr bool in mdio regmap config and by using the new API devm_mdio_regmap_init to init a regmap. To support C45, additional info needs to be appended to the regmap address passed to regmap OPs. The logic applied to the regmap address value: - First the regnum value (20, 16) - Second the devnum value (25, 21) - A bit to signal if it's C45 (26) devm_mdio_regmap_init MUST be used to register a regmap for this to correctly handle internally the encode/decode of the address. Drivers needs to define a mdio_regmap_init_config where an optional regmap name can be defined and MUST define C22 OPs (mdio_read/write). To support C45 operation also C45 OPs (mdio_read/write_c45). The regmap from devm_mdio_regmap_init will internally decode the encoded regmap address and extract the various info (addr, devnum if C45 and regnum). It will then call the related OP and pass the extracted values to the function. Example for a C45 read operation: - With an encoded address with C45 bit enabled, it will call the .mdio_read_c45 and addr, devnum and regnum will be passed. .mdio_read_c45 will then return the val and val will be stored in the regmap_read pointer and will return 0. If .mdio_read_c45 returns any error, then the regmap_read will return such error. With support_encoded_addr enabled, also C22 will encode the address in the regmap address and .mdio_read/write will called accordingly similar to C45 operation. Signed-off-by: Christian Marangi --- drivers/net/mdio/mdio-regmap.c | 170 +++++++++++++++++++++++++++++-- include/linux/mdio/mdio-regmap.h | 14 +++ 2 files changed, 176 insertions(+), 8 deletions(-) diff --git a/drivers/net/mdio/mdio-regmap.c b/drivers/net/mdio/mdio-regmap.c index 810ba0a736f0..f263e4ae2477 100644 --- a/drivers/net/mdio/mdio-regmap.c +++ b/drivers/net/mdio/mdio-regmap.c @@ -15,22 +15,72 @@ #include #include +#define MDIO_REGMAP_C45 BIT(26) +#define MDIO_REGMAP_ADDR GENMASK(25, 21) +#define MDIO_REGMAP_DEVNUM GENMASK(20, 16) +#define MDIO_REGMAP_REGNUM GENMASK(15, 0) + #define DRV_NAME "mdio-regmap" struct mdio_regmap_priv { + void *ctx; + + const struct mdio_regmap_init_config *config; +}; + +struct mdio_regmap_mii_priv { struct regmap *regmap; u32 valid_addr_mask; + bool encode_addr; }; -static int mdio_regmap_read_c22(struct mii_bus *bus, int addr, int regnum) +static int mdio_regmap_mii_read_c22(struct mii_bus *bus, int addr, int regnum) +{ + struct mdio_regmap_mii_priv *ctx = bus->priv; + unsigned int val; + int ret; + + if (!(ctx->valid_addr_mask & BIT(addr))) + return -ENODEV; + + if (ctx->encode_addr) + regnum |= FIELD_PREP(MDIO_REGMAP_ADDR, addr); + + ret = regmap_read(ctx->regmap, regnum, &val); + if (ret < 0) + return ret; + + return val; +} + +static int mdio_regmap_mii_write_c22(struct mii_bus *bus, int addr, int regnum, + u16 val) { - struct mdio_regmap_priv *ctx = bus->priv; + struct mdio_regmap_mii_priv *ctx = bus->priv; + + if (!(ctx->valid_addr_mask & BIT(addr))) + return -ENODEV; + + if (ctx->encode_addr) + regnum |= FIELD_PREP(MDIO_REGMAP_ADDR, addr); + + return regmap_write(ctx->regmap, regnum, val); +} + +static int mdio_regmap_mii_read_c45(struct mii_bus *bus, int addr, int devnum, + int regnum) +{ + struct mdio_regmap_mii_priv *ctx = bus->priv; unsigned int val; int ret; if (!(ctx->valid_addr_mask & BIT(addr))) return -ENODEV; + regnum |= MDIO_REGMAP_C45; + regnum |= FIELD_PREP(MDIO_REGMAP_ADDR, addr); + regnum |= FIELD_PREP(MDIO_REGMAP_DEVNUM, devnum); + ret = regmap_read(ctx->regmap, regnum, &val); if (ret < 0) return ret; @@ -38,21 +88,25 @@ static int mdio_regmap_read_c22(struct mii_bus *bus, int addr, int regnum) return val; } -static int mdio_regmap_write_c22(struct mii_bus *bus, int addr, int regnum, - u16 val) +static int mdio_regmap_mii_write_c45(struct mii_bus *bus, int addr, int devnum, + int regnum, u16 val) { - struct mdio_regmap_priv *ctx = bus->priv; + struct mdio_regmap_mii_priv *ctx = bus->priv; if (!(ctx->valid_addr_mask & BIT(addr))) return -ENODEV; + regnum |= MDIO_REGMAP_C45; + regnum |= FIELD_PREP(MDIO_REGMAP_ADDR, addr); + regnum |= FIELD_PREP(MDIO_REGMAP_DEVNUM, devnum); + return regmap_write(ctx->regmap, regnum, val); } struct mii_bus *devm_mdio_regmap_register(struct device *dev, const struct mdio_regmap_config *config) { - struct mdio_regmap_priv *mr; + struct mdio_regmap_mii_priv *mr; struct mii_bus *mii; int rc; @@ -66,12 +120,17 @@ struct mii_bus *devm_mdio_regmap_register(struct device *dev, mr = mii->priv; mr->regmap = config->regmap; mr->valid_addr_mask = BIT(config->valid_addr); + mr->encode_addr = config->support_encoded_addr; mii->name = DRV_NAME; strscpy(mii->id, config->name, MII_BUS_ID_SIZE); mii->parent = config->parent; - mii->read = mdio_regmap_read_c22; - mii->write = mdio_regmap_write_c22; + mii->read = mdio_regmap_mii_read_c22; + mii->write = mdio_regmap_mii_write_c22; + if (config->support_encoded_addr) { + mii->read_c45 = mdio_regmap_mii_read_c45; + mii->write_c45 = mdio_regmap_mii_write_c45; + } if (config->autoscan) mii->phy_mask = ~mr->valid_addr_mask; @@ -88,6 +147,101 @@ struct mii_bus *devm_mdio_regmap_register(struct device *dev, } EXPORT_SYMBOL_GPL(devm_mdio_regmap_register); +static int mdio_regmap_reg_read(void *context, unsigned int reg, unsigned int *val) +{ + const struct mdio_regmap_init_config *config; + struct mdio_regmap_priv *priv = context; + int addr, regnum; + int ret; + + config = priv->config; + + addr = FIELD_GET(MDIO_REGMAP_ADDR, reg); + regnum = FIELD_GET(MDIO_REGMAP_REGNUM, reg); + + if (reg & MDIO_REGMAP_C45) { + int devnum; + + if (!config->mdio_write_c45) + return -EOPNOTSUPP; + + devnum = FIELD_GET(MDIO_REGMAP_DEVNUM, reg); + ret = config->mdio_read_c45(priv->ctx, addr, devnum, regnum); + } else { + ret = config->mdio_read(priv->ctx, addr, regnum); + } + + if (ret < 0) + return ret; + + *val = ret; + return 0; +} + +static int mdio_regmap_reg_write(void *context, unsigned int reg, unsigned int val) +{ + const struct mdio_regmap_init_config *config; + struct mdio_regmap_priv *priv = context; + int addr, regnum; + + config = priv->config; + + addr = FIELD_GET(MDIO_REGMAP_ADDR, reg); + regnum = FIELD_GET(MDIO_REGMAP_REGNUM, reg); + + if (reg & MDIO_REGMAP_C45) { + int devnum; + + if (!config->mdio_write_c45) + return -EOPNOTSUPP; + + devnum = FIELD_GET(MDIO_REGMAP_DEVNUM, reg); + return config->mdio_write_c45(priv->ctx, addr, devnum, regnum, val); + } + + return config->mdio_write(priv->ctx, addr, regnum, val); +} + +static const struct regmap_config mdio_regmap_default_config = { + .reg_bits = 26, + .val_bits = 16, + .reg_stride = 1, + .max_register = MDIO_REGMAP_C45 | MDIO_REGMAP_ADDR | + MDIO_REGMAP_DEVNUM | MDIO_REGMAP_REGNUM, + .reg_read = mdio_regmap_reg_read, + .reg_write = mdio_regmap_reg_write, + /* Locking MUST be handled in mdio_write/read(_c45) */ + .disable_locking = true, +}; + +struct regmap *devm_mdio_regmap_init(struct device *dev, void *priv, + const struct mdio_regmap_init_config *config) +{ + struct mdio_regmap_priv *mdio_regmap_priv; + struct regmap_config regmap_config; + + /* Validate config */ + if (!config->mdio_read || !config->mdio_write) { + dev_err(dev, ".mdio_read and .mdio_write MUST be defined in config\n"); + return ERR_PTR(-EINVAL); + } + + mdio_regmap_priv = devm_kzalloc(dev, sizeof(*mdio_regmap_priv), + GFP_KERNEL); + if (!mdio_regmap_priv) + return ERR_PTR(-ENOMEM); + + memcpy(®map_config, &mdio_regmap_default_config, sizeof(regmap_config)); + regmap_config.name = config->name; + + mdio_regmap_priv->ctx = priv; + mdio_regmap_priv->config = config; + + return devm_regmap_init(dev, NULL, mdio_regmap_priv, + ®map_config); +} +EXPORT_SYMBOL_GPL(devm_mdio_regmap_init); + MODULE_DESCRIPTION("MDIO API over regmap"); MODULE_AUTHOR("Maxime Chevallier "); MODULE_LICENSE("GPL"); diff --git a/include/linux/mdio/mdio-regmap.h b/include/linux/mdio/mdio-regmap.h index 679d9069846b..504fa2046043 100644 --- a/include/linux/mdio/mdio-regmap.h +++ b/include/linux/mdio/mdio-regmap.h @@ -17,10 +17,24 @@ struct mdio_regmap_config { struct regmap *regmap; char name[MII_BUS_ID_SIZE]; u8 valid_addr; + /* devm_mdio_regmap_init is required with this enabled */ + bool support_encoded_addr; bool autoscan; }; struct mii_bus *devm_mdio_regmap_register(struct device *dev, const struct mdio_regmap_config *config); +struct mdio_regmap_init_config { + const char *name; + + int (*mdio_read)(void *ctx, int addr, int regnum); + int (*mdio_write)(void *ctx, int addr, int regnum, u16 val); + int (*mdio_read_c45)(void *ctx, int addr, int devnum, int regnum); + int (*mdio_write_c45)(void *ctx, int addr, int devnum, int regnum, u16 val); +}; + +struct regmap *devm_mdio_regmap_init(struct device *dev, void *priv, + const struct mdio_regmap_init_config *config); + #endif From patchwork Sat Mar 15 15:43:48 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christian Marangi X-Patchwork-Id: 14018131 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 5F604C28B28 for ; Sat, 15 Mar 2025 16:00:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Transfer-Encoding: MIME-Version:References:In-Reply-To:Message-ID:Date:Subject:To:From:Reply-To: Cc:Content-Type:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=i9cj1rDP/cubKfbE6LHAYD/iOcx4KqaxRMhogz7zaTE=; b=L8cIidEc40TJCc+NTlfwxSNfuJ KOxZexpT96MKMWLNM9GiE9covfiye2FSYB3+mFcfDYgmK8Nluz5gof9C9lhnRs0O86k7QCHK9/nQC r0TmShSFnmq5fBcf1wT851ZKMiT3oyxC+MoMQCIWt4ZroQvRcHQBuN0q2tDp4wxmiJjsvS2S1lRYV 6mX6kCRyb++FZHRi0aoIHKCf9oIDP6vSoWe/r+UrUdG1u0v/h1SejegZNG3O//BXlfNNBnz1mIgDW fkj4T4IaZfyw1WOMgrfuS9ZWWlFNlqqi97Y77mLuCWAd5h6WhpDiyfY/exgHXt+QtjOeNqNBErucY AVsRST9A==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1ttTvm-0000000GZ0G-3IZI; Sat, 15 Mar 2025 16:00:10 +0000 Received: from mail-wm1-x32c.google.com ([2a00:1450:4864:20::32c]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1ttTgy-0000000GX38-2gLB; Sat, 15 Mar 2025 15:44:53 +0000 Received: by mail-wm1-x32c.google.com with SMTP id 5b1f17b1804b1-43cfebc343dso4586045e9.2; Sat, 15 Mar 2025 08:44:52 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1742053491; x=1742658291; darn=lists.infradead.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=i9cj1rDP/cubKfbE6LHAYD/iOcx4KqaxRMhogz7zaTE=; b=Wl6akgg3r/6p2cHyUlLsibB/QHFLv+tHm7N8r8iw1KecjARlUAVLNdyBH4CtvgqAWB ODOSJahc9zUtqPcXG22Zh9b7W3lQQMPKsmoaC/LXgXtZO4zXSLKhIlsHl7kg6a62i60b Aaum8vHEvZaiCyLaBYe2NvHT807PmhlGNeY8jtKQ+hDcjg94DSatJnpEJMQi+Z58GTzp ig1z6cjgvtOZyd4TdstXP6uz4IhD5bAyvxOPrF4kwV0z/YLfXiFP0QcOHTmHYmpufDEY P+yECFsLdqpl9pl0CKiRV/hpLkw1RZFhjONU3JwNURRVSkVuiNSR0oHlrj3JAl6DBxd/ FVSw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1742053491; x=1742658291; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=i9cj1rDP/cubKfbE6LHAYD/iOcx4KqaxRMhogz7zaTE=; b=Vk3fN3GSa+N1Fsyvm05JKndwMzWTOAQcD/QWo1eXRYs1CgMpXENGCkspFxeEtZJlyK n661olwxNsa3f63bqU5QVXgJ9/PoV9QNgl3RsZehwMX2Yt227SJ+IdcQJgpBX73n1EBi teZPL9Xa7yw0lkXDnrAH6smn2+ZVgm6hBfL2uQas/sk8FikuSUIAqZ4kzOLiwtGBeGp0 gu7hbJZH2NBIG16LfmPGdvX52dtNuxYKDvlUF49GzxIHlxQEVR09+5a4Z5xh4EITH+Ru 4J+XpmuiUMeco5EG/cH726hQRude/GS2o6NF2oUn65MQxyQJnO9XCmCJe98dWSsktlVm vB9Q== X-Forwarded-Encrypted: i=1; AJvYcCV4ixnmxYH3ChIAYTxACbBxytXbX/YACVNdVJgNJ3DR0toHKDcp3E6fmZQmdYiFW5Qao5CgsANDJVTEFtLtxZo=@lists.infradead.org, AJvYcCVp8EyPfszifpwqXHTCQpwsxWKUPJMFUuGp+2IYRnZ/syWO5h1HDVqXkrZNZNacTst3FgMz9F3AQf0VFZOn5Wep@lists.infradead.org X-Gm-Message-State: AOJu0YyLjFaZM89BiY6ofZ3060w/RU3P2OgK1dr+sTJolx+nlTRkAaPF 7ciNmntVf+KahC7PrN+8bBUrFGOyYEDEXrZaWSkbURs/EcI3xMWn X-Gm-Gg: ASbGncuWvgUsbiOR+Fz2HP7bM0Edeq3NQkWnURdYFrBQSka8tW/FkCKWTOptGeDfhpA hIWua0hV4BBWWwFVwmGKApjW1HKxEhsNiBb6fl0iBVVLCHazv8GPVp2PuT87Rkkb2lSKTHgEKsT DwPnIEwV28wcKz5TiS6AJW4RkGFJEAtxtRBq7f8Ets8euPGo1ddqIz0q8tEqTGi+vLKYOs3gy4H IDj0GTFzXlzWnesVSchIjq4xG2c8Pi0XlnPugE39Ctr1PACjJ2j0ssRJf9LEYxEGKd296DyM90R a04ciz1j3wLyszUeawMNiKgRwTfbIztCi9U6MKYdqLiztCFRqP3QdB4tqObFRg4BEXPeZ4pIIzt 5OxhodGILWcrrGg== X-Google-Smtp-Source: AGHT+IEOhKkyCgm/ebHsk4V7WwKT8R78FhVt6pOGjtm8mBgSx5vzbp0xB3tzUWDN02MyZuAGCjf4jw== X-Received: by 2002:a05:600c:45cb:b0:43c:fcbc:9686 with SMTP id 5b1f17b1804b1-43d1ec66d39mr56598865e9.1.1742053490677; Sat, 15 Mar 2025 08:44:50 -0700 (PDT) Received: from localhost.localdomain (93-34-90-129.ip49.fastwebnet.it. [93.34.90.129]) by smtp.googlemail.com with ESMTPSA id 5b1f17b1804b1-43d1fe0636dsm53464195e9.11.2025.03.15.08.44.49 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 15 Mar 2025 08:44:50 -0700 (PDT) From: Christian Marangi To: Christian Marangi , Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Andrew Lunn , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Vladimir Oltean , Srinivas Kandagatla , Heiner Kallweit , Russell King , Maxime Chevallier , Matthias Brugger , AngeloGioacchino Del Regno , linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, upstream@airoha.com Subject: [net-next PATCH v13 08/14] net: mdio: regmap: add support for multiple valid addr Date: Sat, 15 Mar 2025 16:43:48 +0100 Message-ID: <20250315154407.26304-9-ansuelsmth@gmail.com> X-Mailer: git-send-email 2.48.1 In-Reply-To: <20250315154407.26304-1-ansuelsmth@gmail.com> References: <20250315154407.26304-1-ansuelsmth@gmail.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250315_084452_675196_F90EB556 X-CRM114-Status: GOOD ( 16.14 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Add support for multiple valid addr for mdio regmap. This can be done by defining the new valid_addr_mask value in the mdio regmap config. This makes use of the new implementation used by C45 to encode additional info in the regmap address to support multiple MDIO address. To actually use this, support_encoded_addr MUST be enabled and (indirectly) devm_mdio_regmap_init must be used to create the regmap. Signed-off-by: Christian Marangi --- drivers/net/mdio/mdio-regmap.c | 8 +++++++- include/linux/mdio/mdio-regmap.h | 1 + 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/drivers/net/mdio/mdio-regmap.c b/drivers/net/mdio/mdio-regmap.c index f263e4ae2477..ed0443eb039f 100644 --- a/drivers/net/mdio/mdio-regmap.c +++ b/drivers/net/mdio/mdio-regmap.c @@ -113,13 +113,19 @@ struct mii_bus *devm_mdio_regmap_register(struct device *dev, if (!config->parent) return ERR_PTR(-EINVAL); + if (config->valid_addr_mask && !config->support_encoded_addr) { + dev_err(dev, "encoded address support is required to support multiple MDIO address\n"); + return ERR_PTR(-EINVAL); + } + mii = devm_mdiobus_alloc_size(config->parent, sizeof(*mr)); if (!mii) return ERR_PTR(-ENOMEM); mr = mii->priv; mr->regmap = config->regmap; - mr->valid_addr_mask = BIT(config->valid_addr); + mr->valid_addr_mask = config->valid_addr_mask ? config->valid_addr_mask : + BIT(config->valid_addr); mr->encode_addr = config->support_encoded_addr; mii->name = DRV_NAME; diff --git a/include/linux/mdio/mdio-regmap.h b/include/linux/mdio/mdio-regmap.h index 504fa2046043..bb0e7dc9c0dc 100644 --- a/include/linux/mdio/mdio-regmap.h +++ b/include/linux/mdio/mdio-regmap.h @@ -17,6 +17,7 @@ struct mdio_regmap_config { struct regmap *regmap; char name[MII_BUS_ID_SIZE]; u8 valid_addr; + u32 valid_addr_mask; /* devm_mdio_regmap_init is required with this enabled */ bool support_encoded_addr; bool autoscan; From patchwork Sat Mar 15 15:43:49 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christian Marangi X-Patchwork-Id: 14018135 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 B6D7FC28B28 for ; Sat, 15 Mar 2025 16:02:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Transfer-Encoding: MIME-Version:References:In-Reply-To:Message-ID:Date:Subject:To:From:Reply-To: Cc:Content-Type:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=xHfS9Ayq+62ZEPKyiIIGlUUpg7PHKrYF5eIEp4kJv8I=; b=fUkjFy1WnOK1jzlcY0UbJOAve4 AUZZTgyRiU1kpuybr5U98TD5ENMHfxoiPB2qWOKioG0TVFCfnTsxr4c3FYtC8liHkia9nktaqZiQX StENGMG+2jLj16WjozE/l4YPkUrRqecKlttlt4bZuS+cGhJ2LPsj4N6R/kXzYWmB8R+T3JUWbNlcB dBnUPjTFPATjV4v/royeoOT7VyNv0mLHvW7JvLmnLxIAV2iNmGWQNy7tJt5zEY2i/r+sh0EW/c9a9 1LTFk2wzdG4xYBFVCbqW1obZkA07mYs2rD8l5Ev49UORkyZfwP3pEpXA+cjrkFW5UhlWalHZaJzZg 1/40GsAQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1ttTxP-0000000GZAu-3bZC; Sat, 15 Mar 2025 16:01:51 +0000 Received: from mail-wm1-x32a.google.com ([2a00:1450:4864:20::32a]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1ttTh1-0000000GX43-0hEC; Sat, 15 Mar 2025 15:44:56 +0000 Received: by mail-wm1-x32a.google.com with SMTP id 5b1f17b1804b1-43cfe574976so4052935e9.1; Sat, 15 Mar 2025 08:44:54 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1742053493; x=1742658293; darn=lists.infradead.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=xHfS9Ayq+62ZEPKyiIIGlUUpg7PHKrYF5eIEp4kJv8I=; b=HrKBvV32vgYWEYhpdh581GOP4CL36RPL7Fyiet57xaalxOo2th9MvqZX2ssEVwW2QC 6Od9LAOXBVwv8fbMmWvAEMAQVpyh81GvuVnd8q8vbAxntcwdnkPixIfym6nlP8M2Ns47 84zzkyVjAPYh++rN1HBcDVUW1+cmuTx7by5/e/E2Q8P6DDyRmQO5hWszkIi7M0STBxLu lFLi0hBZSwgwIeFz+K1/0pzL39pYGrdi4umngJxGM7fZMHrInmu4/Zb+pfwiCDMvgDxf BFZenYnsQMLwdC1qtz7A0nyGIiVZ8TMijrbYIFiIEVaD3MiRUXnyQEOUZjUs49f1y+Wj V7rg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1742053493; x=1742658293; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=xHfS9Ayq+62ZEPKyiIIGlUUpg7PHKrYF5eIEp4kJv8I=; b=D6LQ5y4Yv2vl18vcXCh7hF7WiNDneW6GOMbBL7w47y3zvSe6zt4L0GzPL2zzbXjIVF 7DAlfrEJbbiXxnKtCYB0ilyuq6zze5IfbeGw8o8CVjJjqdnitK6DRTt0HfWfcD4O/cp1 Ube4EiRA6NIOgPicjPjUDdwFTBHt/NKSIkzcZWmEko3y2cQ2/H2l+bCR8L04niFeo4bA 8dg1hGhCe6IlImK963cAZ2lpfqNvR4EThHMjrNe544cI5sPBzvYy3/KdgP3VY5TcaLru s36MBx8JWRqGpwv0HpZsKNi/Tzd4gpqkMT1NOTZITHBcSHSRi3T0sZQTsPgA1zyCGOTw vW/Q== X-Forwarded-Encrypted: i=1; AJvYcCVfw+sZeM1FVg0wTBK/6bZ17If5VdbLnpOOl8P5lI3sZcw8882lUiEp7yfjJcv3znXnWA8zWcd2J5RnCOk+k9Y=@lists.infradead.org, AJvYcCXHjSBzxM1iPhY/vas4cn0rwi71GDjSAePrhfejQkhiakSeljXa4MAVI8eLSnBatgUHp240jzD5zAzomK/C0Oc5@lists.infradead.org X-Gm-Message-State: AOJu0YwFx8+JbTCDJrwCLjA9MJK+VN28GX1aGQQVvxar5vH++zqVbEqQ zStGgsCYSrWhu+Oyg+PV3DB+ezhyeWfoF6WpMu7ompRABPeV0WDu X-Gm-Gg: ASbGncv5mqHyKdiFUywehpstdx9NxeFxPhYzeeKZghjVfbbvQjXuIwgUylmG4tpNqfZ tbdU1CKcDrEPeAfsu6clGDLtcE456TcXdPjmIPZ3jnIJeV+TVRq9k+SJzOXtxnhoBg4M9OYuYAf WOxko3wJi9NzgLv8xObyUHadwrAg2bJwr3/2X8nX5r/XGsHLRXIE7/11Adu/RAG44j4o8SWVvGL 4FJL2xLN5ErewgV/tlyOwxZZM5oqAjDNuekFKD/ycrOE/YfqWu/t6ojPVzpLsqJlCRNpMWR3S2h RuCkcVJxE9140VaPb0l1bn0EA1kXrTMtjvw4Y/uBbPkj5KeGxrSGmYpukPifmdM+N046ffz3LWM 0MQA48Dj5MmA5Uw== X-Google-Smtp-Source: AGHT+IGeR0GlB6V/S9Dn/s5gMh0ja71UFOJhw5HL2cIq3odbRefg3sGJoJMZ8zyrbhiVe+3weElnTg== X-Received: by 2002:a05:600c:1548:b0:43b:c95f:fd9 with SMTP id 5b1f17b1804b1-43d2a2ececcmr8971025e9.5.1742053493214; Sat, 15 Mar 2025 08:44:53 -0700 (PDT) Received: from localhost.localdomain (93-34-90-129.ip49.fastwebnet.it. [93.34.90.129]) by smtp.googlemail.com with ESMTPSA id 5b1f17b1804b1-43d1fe0636dsm53464195e9.11.2025.03.15.08.44.50 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 15 Mar 2025 08:44:52 -0700 (PDT) From: Christian Marangi To: Christian Marangi , Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Andrew Lunn , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Vladimir Oltean , Srinivas Kandagatla , Heiner Kallweit , Russell King , Maxime Chevallier , Matthias Brugger , AngeloGioacchino Del Regno , linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, upstream@airoha.com Subject: [net-next PATCH v13 09/14] net: mdio: regmap: add OF support Date: Sat, 15 Mar 2025 16:43:49 +0100 Message-ID: <20250315154407.26304-10-ansuelsmth@gmail.com> X-Mailer: git-send-email 2.48.1 In-Reply-To: <20250315154407.26304-1-ansuelsmth@gmail.com> References: <20250315154407.26304-1-ansuelsmth@gmail.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250315_084455_217988_A834A6FA X-CRM114-Status: GOOD ( 14.94 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Permit to pass a device tree node to mdio regmap config and use the OF variant of mdiobus_register. This is done to autoprobe PHY defined in device tree as the current mdiobus_register only permits probing PHY using the MDIO mask value. Previous implementation is not changed as of_mdiobus_register fallback to mdiobus_register if the passed device tree pointer is NULL. Signed-off-by: Christian Marangi --- drivers/net/mdio/mdio-regmap.c | 2 +- include/linux/mdio/mdio-regmap.h | 1 + 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/drivers/net/mdio/mdio-regmap.c b/drivers/net/mdio/mdio-regmap.c index ed0443eb039f..8e89068c844d 100644 --- a/drivers/net/mdio/mdio-regmap.c +++ b/drivers/net/mdio/mdio-regmap.c @@ -143,7 +143,7 @@ struct mii_bus *devm_mdio_regmap_register(struct device *dev, else mii->phy_mask = ~0; - rc = devm_mdiobus_register(dev, mii); + rc = devm_of_mdiobus_register(dev, mii, config->np); if (rc) { dev_err(config->parent, "Cannot register MDIO bus![%s] (%d)\n", mii->id, rc); return ERR_PTR(rc); diff --git a/include/linux/mdio/mdio-regmap.h b/include/linux/mdio/mdio-regmap.h index bb0e7dc9c0dc..228f12e90750 100644 --- a/include/linux/mdio/mdio-regmap.h +++ b/include/linux/mdio/mdio-regmap.h @@ -14,6 +14,7 @@ struct regmap; struct mdio_regmap_config { struct device *parent; + struct device_node *np; struct regmap *regmap; char name[MII_BUS_ID_SIZE]; u8 valid_addr; From patchwork Sat Mar 15 15:43:50 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christian Marangi X-Patchwork-Id: 14018136 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 4FFFFC28B28 for ; Sat, 15 Mar 2025 16:03:42 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Transfer-Encoding: MIME-Version:References:In-Reply-To:Message-ID:Date:Subject:To:From:Reply-To: Cc:Content-Type:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=DTToHn/Jz2ssF57ItcNgrn03e0Xd76NFNoRYFNTAyLc=; b=lTih65QRvL0Wh1doqEUQU5HKMG Mif2EcLmgRUnTZ7UswjFfpSqnW8To5eiva3pCvW9qbULsx0fBtwAvLV0LoEnQmn749h0kpUxaqpJs u2dCq5LHZ/ZlYpUg5R2dLpDHkFiNAEgQyYtI63Dl1eVC6HOJjty/EdGDw489qwp/hry2NpA5nnBnX IYjD7x9nKupXjwjH2AJp0PsKQMqwO4RjrTy3duuh1Jw1qs05FoWRkuSV/ISzwlf7ehass2vzl2eit O6HX9eNQcHLTYu7DhisXjQYfppxVHX4v4vu4k3zyl1QO6LuH96IXNZsr0+7P/vj1s5L8Z+kUeuYXc GMHWKZZA==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1ttTz4-0000000GZLZ-1TMg; Sat, 15 Mar 2025 16:03:34 +0000 Received: from mail-wm1-x336.google.com ([2a00:1450:4864:20::336]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1ttTh4-0000000GX52-2v2h; Sat, 15 Mar 2025 15:45:00 +0000 Received: by mail-wm1-x336.google.com with SMTP id 5b1f17b1804b1-43cfb6e9031so6195145e9.0; Sat, 15 Mar 2025 08:44:58 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1742053497; x=1742658297; darn=lists.infradead.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=DTToHn/Jz2ssF57ItcNgrn03e0Xd76NFNoRYFNTAyLc=; b=Hp0AKpMwMJJvqeUn+tGf/k8bnBI0Mk1fg7th5ysCiRKz4u4RMK262CHeBDduQ6XXp7 8E7yjOyukuqCQIQ/7gk1tKBYIW+6FAj351Qwrsyys0bKbngRG+/4dsmbcyzFSVGv4qgM WZ8MK1j3QwujfvQhb9aPSLSm24Deg6/t1fj0KzTUgS2WiOdhJ20lv+rQ7aB0kcOysUY5 zcjfjI86cd3/MosoEvR2c2dlp8cmewTyZ3cJMRUr1UgxITzaMmNVeoto/HK0XZaWwYhS y1iFZtxPiiN3VjhiQrtrBr0B2FZH0DZMP7xL4YpwKW4RukLhYQzGSwZl5cE/QpT4ByKt edjQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1742053497; x=1742658297; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=DTToHn/Jz2ssF57ItcNgrn03e0Xd76NFNoRYFNTAyLc=; b=MMYOHSIxBgc02VPs0P8Pd5xYjBJtJsDhN74KLXWqIF+0UE4PHdTSZaivBXuNoDLE46 4iqBffEhr/QX3AgE4i0WArGjcI3bjZlWsD8LAfcZ0rOPLUaPJmehptdSdYiyn87KnQsm 1pCbTWUw/2helMCey80rBLXUb6uhodOxTMRlpdbgUC0ccwU7y4++rcila1gvEEbPy23a BLC4kkLQOyQfVzW1914/6l7SLUKTucQk0B+pXXeQIWLP4fT4s6O559OjT5HOQn1QcVga ujtHPqQBwQ28a9SjnIdmUAg8prQDESmbOTkFjFuXn/tNo2Kf1vqu5jGaG3LFmsH/Cl2L FXmw== X-Forwarded-Encrypted: i=1; AJvYcCVWR57Nfb7106wRrry+a/b0fSLjEXummzhDjGQgHg3iZDq0qq2okQxvWqNkvfoxX2LVtY/KzGAnTDL530ZFepHZ@lists.infradead.org, AJvYcCX3tnZcps4B53h3MvEOLhJkQdtBIxQnELgXehShyTYTTePWBEAmzG6fIEjl5rtMW4my61JslOumt2yhMW5iwJA=@lists.infradead.org X-Gm-Message-State: AOJu0YyKv+7zE68KAKIeaa2usVOKTLEi6QzN0HXv5UBHEteLNmQ71P2e MylAuTeTykKW4ZCR9QWFOssh4eH4LQCZTW2lYFtEHZmpPG/Hcs6J X-Gm-Gg: ASbGncv307APo6jFeHbsWeFooKwjuFGm7kz2yRn0WZuRWCK8ySd0g3buvvPw00FOXCs mj84d9WejaQ7pDs+PYQ/YYeuetisUlEpSe4VPuoJfl78j7sXGi3IxHw17tNBYtOQWMmcUnIeKSH gLVYkv8EhGa2ZW8CTTjSFL/j/noCOeYmz5F1TK1ytR9AmrLUc5oIw4FzoREhrRv0COyHhRAGQKW GMpxSFRqv6MsVkcxrlakTR/G3wkfVSv6KxBG8NxuX3mzJ5o9T/1YZyJWIxyD8iJ1ppoV56SuBGt pcaNWGGS+v7uLo8WytpfHzgYlehJV2ENbfnqrLnIu17QQTg/BD6X3qIiivxvo+Oxb52Ntac3krV grjxlsLS/rq+0hA== X-Google-Smtp-Source: AGHT+IGrqpy4WIU256b61LOtzYs/Dq/7rOuFsh1ZZhATXezOmNCa/WUe8nySz//k1XLwIFwqoAq5Nw== X-Received: by 2002:a7b:c4c9:0:b0:43c:f969:13c0 with SMTP id 5b1f17b1804b1-43d23cb505fmr58242385e9.29.1742053495218; Sat, 15 Mar 2025 08:44:55 -0700 (PDT) Received: from localhost.localdomain (93-34-90-129.ip49.fastwebnet.it. [93.34.90.129]) by smtp.googlemail.com with ESMTPSA id 5b1f17b1804b1-43d1fe0636dsm53464195e9.11.2025.03.15.08.44.53 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 15 Mar 2025 08:44:54 -0700 (PDT) From: Christian Marangi To: Christian Marangi , Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Andrew Lunn , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Vladimir Oltean , Srinivas Kandagatla , Heiner Kallweit , Russell King , Maxime Chevallier , Matthias Brugger , AngeloGioacchino Del Regno , linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, upstream@airoha.com Subject: [net-next PATCH v13 10/14] mfd: an8855: Add support for Airoha AN8855 Switch MFD Date: Sat, 15 Mar 2025 16:43:50 +0100 Message-ID: <20250315154407.26304-11-ansuelsmth@gmail.com> X-Mailer: git-send-email 2.48.1 In-Reply-To: <20250315154407.26304-1-ansuelsmth@gmail.com> References: <20250315154407.26304-1-ansuelsmth@gmail.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250315_084458_747947_D77A8ACB X-CRM114-Status: GOOD ( 25.46 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Add support for Airoha AN8855 Switch MFD that provide support for a DSA switch and a NVMEM provider. Also provide support for a virtual MDIO passthrough as the PHYs address for the switch are shared with the switch address. Signed-off-by: Christian Marangi --- MAINTAINERS | 1 + drivers/mfd/Kconfig | 12 + drivers/mfd/Makefile | 1 + drivers/mfd/airoha-an8855.c | 429 ++++++++++++++++++++++++++++++++++++ 4 files changed, 443 insertions(+) create mode 100644 drivers/mfd/airoha-an8855.c diff --git a/MAINTAINERS b/MAINTAINERS index 65709e47adc7..aec293953382 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -730,6 +730,7 @@ F: Documentation/devicetree/bindings/net/airoha,an8855-mdio.yaml F: Documentation/devicetree/bindings/net/airoha,an8855-phy.yaml F: Documentation/devicetree/bindings/net/dsa/airoha,an8855-switch.yaml F: Documentation/devicetree/bindings/nvmem/airoha,an8855-efuse.yaml +F: drivers/mfd/airoha-an8855.c AIROHA ETHERNET DRIVER M: Lorenzo Bianconi diff --git a/drivers/mfd/Kconfig b/drivers/mfd/Kconfig index 6b0682af6e32..ebdced27e96a 100644 --- a/drivers/mfd/Kconfig +++ b/drivers/mfd/Kconfig @@ -53,6 +53,18 @@ config MFD_ALTERA_SYSMGR using regmap_mmio accesses for ARM32 parts and SMC calls to EL3 for ARM64 parts. +config MFD_AIROHA_AN8855 + tristate "Airoha AN8855 Switch Core" + select MFD_CORE + select MDIO_DEVICE + depends on NETDEVICES && OF + help + Support for the Airoha AN8855 Switch Core. This is an SoC + that provides various peripherals, to count, i2c, an Ethrnet + Switch, a CPU timer, GPIO, eFUSE. + + Currently it provides a DSA switch and a NVMEM provider. + config MFD_ACT8945A tristate "Active-semi ACT8945A" select MFD_CORE diff --git a/drivers/mfd/Makefile b/drivers/mfd/Makefile index 9220eaf7cf12..37677f65a981 100644 --- a/drivers/mfd/Makefile +++ b/drivers/mfd/Makefile @@ -8,6 +8,7 @@ obj-$(CONFIG_MFD_88PM860X) += 88pm860x.o obj-$(CONFIG_MFD_88PM800) += 88pm800.o 88pm80x.o obj-$(CONFIG_MFD_88PM805) += 88pm805.o 88pm80x.o obj-$(CONFIG_MFD_88PM886_PMIC) += 88pm886.o +obj-$(CONFIG_MFD_AIROHA_AN8855) += airoha-an8855.o obj-$(CONFIG_MFD_ACT8945A) += act8945a.o obj-$(CONFIG_MFD_SM501) += sm501.o obj-$(CONFIG_ARCH_BCM2835) += bcm2835-pm.o diff --git a/drivers/mfd/airoha-an8855.c b/drivers/mfd/airoha-an8855.c new file mode 100644 index 000000000000..fb2edf3132f9 --- /dev/null +++ b/drivers/mfd/airoha-an8855.c @@ -0,0 +1,429 @@ +// SPDX-License-Identifier: GPL-2.0+ +/* + * Core driver for Airoha AN8855 Switch + */ + +#include +#include +#include +#include +#include +#include +#include +#include + +/* Register for HW trap status */ +#define AN8855_HWTRAP 0x1000009c + +#define AN8855_CREV 0x10005000 +#define AN8855_ID 0x8855 + +#define AN8855_RG_GPHY_AFE_PWD 0x1028c840 + +/* MII Registers */ +#define AN8855_PHY_SELECT_PAGE 0x1f +#define AN8855_PHY_PAGE GENMASK(2, 0) +#define AN8855_PHY_PAGE_STANDARD FIELD_PREP_CONST(AN8855_PHY_PAGE, 0x0) +#define AN8855_PHY_PAGE_EXTENDED_1 FIELD_PREP_CONST(AN8855_PHY_PAGE, 0x1) +#define AN8855_PHY_PAGE_EXTENDED_4 FIELD_PREP_CONST(AN8855_PHY_PAGE, 0x4) + +/* MII Registers Page 4 */ +#define AN8855_PBUS_MODE 0x10 +#define AN8855_PBUS_MODE_ADDR_FIXED 0x0 +#define AN8855_PBUS_MODE_ADDR_INCR BIT(15) +#define AN8855_PBUS_WR_ADDR_HIGH 0x11 +#define AN8855_PBUS_WR_ADDR_LOW 0x12 +#define AN8855_PBUS_WR_DATA_HIGH 0x13 +#define AN8855_PBUS_WR_DATA_LOW 0x14 +#define AN8855_PBUS_RD_ADDR_HIGH 0x15 +#define AN8855_PBUS_RD_ADDR_LOW 0x16 +#define AN8855_PBUS_RD_DATA_HIGH 0x17 +#define AN8855_PBUS_RD_DATA_LOW 0x18 + +struct an8855_core_priv { + struct mii_bus *bus; + + unsigned int switch_addr; + u16 current_page; +}; + +static const struct mfd_cell an8855_core_childs[] = { + { + .name = "an8855-efuse", + .of_compatible = "airoha,an8855-efuse", + }, { + .name = "an8855-switch", + .of_compatible = "airoha,an8855-switch", + }, { + .name = "an8855-mdio", + .of_compatible = "airoha,an8855-mdio", + } +}; + +static int an8855_mii_set_page(struct an8855_core_priv *priv, u8 addr, + u8 page) __must_hold(&priv->bus->mdio_lock) +{ + struct mii_bus *bus = priv->bus; + int ret; + + ret = __mdiobus_write(bus, addr, AN8855_PHY_SELECT_PAGE, page); + if (ret) { + dev_err_ratelimited(&bus->dev, "failed to set mii page\n"); + return ret; + } + + /* Cache current page if next MII read/write is for Switch page */ + priv->current_page = page; + return 0; +} + +static int an8855_mii_read32(struct mii_bus *bus, u8 phy_id, u32 reg, + u32 *val) __must_hold(&bus->mdio_lock) +{ + int lo, hi, ret; + + ret = __mdiobus_write(bus, phy_id, AN8855_PBUS_MODE, + AN8855_PBUS_MODE_ADDR_FIXED); + if (ret) + goto err; + + ret = __mdiobus_write(bus, phy_id, AN8855_PBUS_RD_ADDR_HIGH, + upper_16_bits(reg)); + if (ret) + goto err; + + ret = __mdiobus_write(bus, phy_id, AN8855_PBUS_RD_ADDR_LOW, + lower_16_bits(reg)); + if (ret) + goto err; + + hi = __mdiobus_read(bus, phy_id, AN8855_PBUS_RD_DATA_HIGH); + if (hi < 0) { + ret = hi; + goto err; + } + + lo = __mdiobus_read(bus, phy_id, AN8855_PBUS_RD_DATA_LOW); + if (lo < 0) { + ret = lo; + goto err; + } + + *val = ((u16)hi << 16) | ((u16)lo & 0xffff); + + return 0; +err: + dev_err_ratelimited(&bus->dev, "failed to read register\n"); + return ret; +} + +static int an8855_regmap_read(void *ctx, uint32_t reg, uint32_t *val) +{ + struct an8855_core_priv *priv = ctx; + struct mii_bus *bus = priv->bus; + u16 addr = priv->switch_addr; + int ret; + + mutex_lock_nested(&bus->mdio_lock, MDIO_MUTEX_NESTED); + ret = an8855_mii_set_page(priv, addr, AN8855_PHY_PAGE_EXTENDED_4); + if (ret < 0) + goto exit; + + ret = an8855_mii_read32(bus, addr, reg, val); + +exit: + mutex_unlock(&bus->mdio_lock); + + return ret < 0 ? ret : 0; +} + +static int an8855_mii_write32(struct mii_bus *bus, u8 phy_id, u32 reg, + u32 val) __must_hold(&bus->mdio_lock) +{ + int ret; + + ret = __mdiobus_write(bus, phy_id, AN8855_PBUS_MODE, + AN8855_PBUS_MODE_ADDR_FIXED); + if (ret) + goto err; + + ret = __mdiobus_write(bus, phy_id, AN8855_PBUS_WR_ADDR_HIGH, + upper_16_bits(reg)); + if (ret) + goto err; + ret = __mdiobus_write(bus, phy_id, AN8855_PBUS_WR_ADDR_LOW, + lower_16_bits(reg)); + if (ret) + goto err; + + ret = __mdiobus_write(bus, phy_id, AN8855_PBUS_WR_DATA_HIGH, + upper_16_bits(val)); + if (ret) + goto err; + + ret = __mdiobus_write(bus, phy_id, AN8855_PBUS_WR_DATA_LOW, + lower_16_bits(val)); + if (ret) + goto err; + + return 0; +err: + dev_err_ratelimited(&bus->dev, + "failed to write an8855 register\n"); + return ret; +} + +static int an8855_regmap_write(void *ctx, uint32_t reg, uint32_t val) +{ + struct an8855_core_priv *priv = ctx; + struct mii_bus *bus = priv->bus; + u16 addr = priv->switch_addr; + int ret; + + mutex_lock_nested(&bus->mdio_lock, MDIO_MUTEX_NESTED); + ret = an8855_mii_set_page(priv, addr, AN8855_PHY_PAGE_EXTENDED_4); + if (ret) + goto exit; + + ret = an8855_mii_write32(bus, addr, reg, val); + +exit: + mutex_unlock(&bus->mdio_lock); + + return ret < 0 ? ret : 0; +} + +static int an8855_regmap_update_bits(void *ctx, uint32_t reg, uint32_t mask, + uint32_t write_val) +{ + struct an8855_core_priv *priv = ctx; + struct mii_bus *bus = priv->bus; + u16 addr = priv->switch_addr; + u32 val; + int ret; + + mutex_lock_nested(&bus->mdio_lock, MDIO_MUTEX_NESTED); + ret = an8855_mii_set_page(priv, addr, AN8855_PHY_PAGE_EXTENDED_4); + if (ret) + goto exit; + + ret = an8855_mii_read32(bus, addr, reg, &val); + if (ret < 0) + goto exit; + + val &= ~mask; + val |= write_val; + ret = an8855_mii_write32(bus, addr, reg, val); + +exit: + mutex_unlock(&bus->mdio_lock); + + return ret < 0 ? ret : 0; +} + +static const struct regmap_range an8855_readable_ranges[] = { + regmap_reg_range(0x10000000, 0x10000fff), /* SCU */ + regmap_reg_range(0x10001000, 0x10001fff), /* RBUS */ + regmap_reg_range(0x10002000, 0x10002fff), /* MCU */ + regmap_reg_range(0x10005000, 0x10005fff), /* SYS SCU */ + regmap_reg_range(0x10007000, 0x10007fff), /* I2C Slave */ + regmap_reg_range(0x10008000, 0x10008fff), /* I2C Master */ + regmap_reg_range(0x10009000, 0x10009fff), /* PDMA */ + regmap_reg_range(0x1000a100, 0x1000a2ff), /* General Purpose Timer */ + regmap_reg_range(0x1000a200, 0x1000a2ff), /* GPU timer */ + regmap_reg_range(0x1000a300, 0x1000a3ff), /* GPIO */ + regmap_reg_range(0x1000a400, 0x1000a5ff), /* EFUSE */ + regmap_reg_range(0x1000c000, 0x1000cfff), /* GDMP CSR */ + regmap_reg_range(0x10010000, 0x1001ffff), /* GDMP SRAM */ + regmap_reg_range(0x10200000, 0x10203fff), /* Switch - ARL Global */ + regmap_reg_range(0x10204000, 0x10207fff), /* Switch - BMU */ + regmap_reg_range(0x10208000, 0x1020bfff), /* Switch - ARL Port */ + regmap_reg_range(0x1020c000, 0x1020cfff), /* Switch - SCH */ + regmap_reg_range(0x10210000, 0x10213fff), /* Switch - MAC */ + regmap_reg_range(0x10214000, 0x10217fff), /* Switch - MIB */ + regmap_reg_range(0x10218000, 0x1021bfff), /* Switch - Port Control */ + regmap_reg_range(0x1021c000, 0x1021ffff), /* Switch - TOP */ + regmap_reg_range(0x10220000, 0x1022ffff), /* SerDes */ + regmap_reg_range(0x10286000, 0x10286fff), /* RG Batcher */ + regmap_reg_range(0x1028c000, 0x1028ffff), /* ETHER_SYS */ + regmap_reg_range(0x30000000, 0x37ffffff), /* I2C EEPROM */ + regmap_reg_range(0x38000000, 0x3fffffff), /* BOOT_ROM */ + regmap_reg_range(0xa0000000, 0xbfffffff), /* GPHY */ +}; + +static const struct regmap_access_table an8855_readable_table = { + .yes_ranges = an8855_readable_ranges, + .n_yes_ranges = ARRAY_SIZE(an8855_readable_ranges), +}; + +static const struct regmap_config an8855_regmap_config = { + .name = "switch", + .reg_bits = 32, + .val_bits = 32, + .reg_stride = 4, + .max_register = 0xbfffffff, + .reg_read = an8855_regmap_read, + .reg_write = an8855_regmap_write, + .reg_update_bits = an8855_regmap_update_bits, + .disable_locking = true, + .rd_table = &an8855_readable_table, +}; + +static int an855_regmap_phy_reset_page(struct an8855_core_priv *priv, + int phy) __must_hold(&priv->bus->mdio_lock) +{ + /* Check PHY page only for addr shared with switch */ + if (phy != priv->switch_addr) + return 0; + + /* Don't restore page if it's not set to Switch page */ + if (priv->current_page != FIELD_GET(AN8855_PHY_PAGE, + AN8855_PHY_PAGE_EXTENDED_4)) + return 0; + + /* + * Restore page to 0, PHY might change page right after but that + * will be ignored as it won't be a switch page. + */ + return an8855_mii_set_page(priv, phy, AN8855_PHY_PAGE_STANDARD); +} + +static int an8855_regmap_phy_read(void *ctx, int addr, int regnum) +{ + struct an8855_core_priv *priv = ctx; + struct mii_bus *bus = priv->bus; + int ret; + + mutex_lock_nested(&bus->mdio_lock, MDIO_MUTEX_NESTED); + ret = an855_regmap_phy_reset_page(priv, addr); + if (ret) + goto exit; + + ret = __mdiobus_read(priv->bus, addr, regnum); + +exit: + mutex_unlock(&bus->mdio_lock); + + return ret; +} + +static int an8855_regmap_phy_write(void *ctx, int addr, int regnum, u16 val) +{ + struct an8855_core_priv *priv = ctx; + struct mii_bus *bus = priv->bus; + int ret; + + mutex_lock_nested(&bus->mdio_lock, MDIO_MUTEX_NESTED); + ret = an855_regmap_phy_reset_page(priv, addr); + if (ret) + goto exit; + + ret = __mdiobus_write(priv->bus, addr, regnum, val); + +exit: + mutex_unlock(&bus->mdio_lock); + + return ret; +} + +static const struct mdio_regmap_init_config an8855_regmap_phy_config = { + .name = "phy", + .mdio_read = an8855_regmap_phy_read, + .mdio_write = an8855_regmap_phy_write, +}; + +static int an8855_read_switch_id(struct device *dev, struct regmap *regmap) +{ + u32 id; + int ret; + + ret = regmap_read(regmap, AN8855_CREV, &id); + if (ret) + return ret; + + if (id != AN8855_ID) { + dev_err(dev, "Detected Switch ID %x but %x was expected\n", + id, AN8855_ID); + return -ENODEV; + } + + return 0; +} + +static int an8855_core_probe(struct mdio_device *mdiodev) +{ + struct regmap *regmap, *regmap_phy; + struct device *dev = &mdiodev->dev; + struct an8855_core_priv *priv; + struct gpio_desc *reset_gpio; + u32 val; + int ret; + + priv = devm_kzalloc(dev, sizeof(*priv), GFP_KERNEL); + if (!priv) + return -ENOMEM; + + priv->bus = mdiodev->bus; + priv->switch_addr = mdiodev->addr; + /* No DMA for mdiobus, mute warning for DMA mask not set */ + dev->dma_mask = &dev->coherent_dma_mask; + + regmap = devm_regmap_init(dev, NULL, priv, &an8855_regmap_config); + if (IS_ERR(regmap)) + return dev_err_probe(dev, PTR_ERR(regmap), + "regmap initialization failed\n"); + + regmap_phy = devm_mdio_regmap_init(dev, priv, &an8855_regmap_phy_config); + if (IS_ERR(regmap_phy)) + return dev_err_probe(dev, PTR_ERR(regmap_phy), + "regmap phy initialization failed\n"); + + reset_gpio = devm_gpiod_get_optional(dev, "reset", GPIOD_OUT_LOW); + if (IS_ERR(reset_gpio)) + return PTR_ERR(reset_gpio); + + if (reset_gpio) { + usleep_range(100000, 150000); + gpiod_set_value_cansleep(reset_gpio, 0); + usleep_range(100000, 150000); + gpiod_set_value_cansleep(reset_gpio, 1); + + /* Poll HWTRAP reg to wait for Switch to fully Init */ + ret = regmap_read_poll_timeout(regmap, AN8855_HWTRAP, val, + val, 20, 200000); + if (ret) + return ret; + } + + ret = an8855_read_switch_id(dev, regmap); + if (ret) + return ret; + + /* Release global PHY power down */ + ret = regmap_write(regmap, AN8855_RG_GPHY_AFE_PWD, 0x0); + if (ret) + return ret; + + return devm_mfd_add_devices(dev, PLATFORM_DEVID_AUTO, an8855_core_childs, + ARRAY_SIZE(an8855_core_childs), NULL, 0, + NULL); +} + +static const struct of_device_id an8855_core_of_match[] = { + { .compatible = "airoha,an8855" }, + { /* sentinel */ } +}; +MODULE_DEVICE_TABLE(of, an8855_core_of_match); + +static struct mdio_driver an8855_core_driver = { + .probe = an8855_core_probe, + .mdiodrv.driver = { + .name = "an8855", + .of_match_table = an8855_core_of_match, + }, +}; +mdio_module_driver(an8855_core_driver); + +MODULE_AUTHOR("Christian Marangi "); +MODULE_DESCRIPTION("Driver for Airoha AN8855 MFD"); +MODULE_LICENSE("GPL"); From patchwork Sat Mar 15 15:43:51 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christian Marangi X-Patchwork-Id: 14018137 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 67644C28B28 for ; Sat, 15 Mar 2025 16:05:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Transfer-Encoding: MIME-Version:References:In-Reply-To:Message-ID:Date:Subject:To:From:Reply-To: Cc:Content-Type:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=o4y4aJLpRHg93RygCDV746A0LLkmeQjNEa/sOSVLGr8=; b=E4QSFat33QTWmBn2Z7BigwPyLP WFzI3awxh2G6g9AhMMp6XXlT1Q6vMZAxY8Fz0qk6VblsyAwCb8Ew6Kufp7YRRKWjo52S+0VrmFoLW AYJM8LtSrW9enKtQTih39ShhVNHct1j7Qlf8coz/O8cUk+O50eF4Jx4Rw1RIu5PpMZ1unleOgOaQy 1yrAlprakfD6xgQOrH7KrA73RhA3ZVutdelevdxLx32kb59jM+IMcuaO7PXg+kMesE1rWVycX1Tqt j/o9Qw5GnWjyI0ajoRyhpwbo4ySni7iB+pXEVB0F6lRsxKLgVL4IY9ZTEbh0A6gx5cyVIcHKcI/RY m3mm3slQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1ttU0i-0000000GZWx-1RUT; Sat, 15 Mar 2025 16:05:16 +0000 Received: from mail-wm1-x32e.google.com ([2a00:1450:4864:20::32e]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1ttTh5-0000000GX5Y-3YFu; Sat, 15 Mar 2025 15:45:01 +0000 Received: by mail-wm1-x32e.google.com with SMTP id 5b1f17b1804b1-43d0782d787so4706725e9.0; Sat, 15 Mar 2025 08:44:59 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1742053498; x=1742658298; darn=lists.infradead.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=o4y4aJLpRHg93RygCDV746A0LLkmeQjNEa/sOSVLGr8=; b=WsaIkHa1e1zDlhq1sho7cgy0SCGhQPPQXu3/e6GpiSP28FJOCFiO53jmagTK2Wkl/M YavKZiZkGwVyeq92rMvOu0o7Ch+Mc+YH+YCzmRs/5IqhH9GWogpwFD3FFybWBns3grjo +0nwxW2hhStBHhFWJgFtRy3Qnieo6W/S2XtiyrtcFaodfgwUIisN1jQNqxUga+dlePaN uc5qpeTl64Mf6lJ7N6MBaDR/Gttk05EPO2nFHNZVsCBQudiRGThbvrBQzjQig+DZ96WU 1jLvqiPjgQaK4Gi6AmbF2AWrLSQn2w+v4a0l2rJrwCPc5E03+wbxgq48HoTBtv4t/fA6 neKw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1742053498; x=1742658298; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=o4y4aJLpRHg93RygCDV746A0LLkmeQjNEa/sOSVLGr8=; b=BLfYD/YPpdELpRHsnhySt0fAo3/2Mkm99Z6NaFx8i7V//JeGl3jL1/wW5nNpCcOkee FFqXYbIDUMZKQbMeYkC2KpaT1y6dVowtz3yuwdzTRnR8RD5zgwaLxn+XVrJIt0Pygnb8 aVWwOsQzwD3CRj94JqshorXM3vkDupQwL2kC2wH8Jd4fJzBfJPc7uHa+u05w71GwjSff Dah86vPMHuBBkeGecFyGRDnQIFaN99eezAxOC5yF8sGVmlIx8kUaagweUtAcQ8G5GTa8 NS5tCEEbo1lXUat5EjomVTj9ip7Whji50RP9bXrWZRIk+WuYCJUDNAwaXljiX/Qy/JWd mz+g== X-Forwarded-Encrypted: i=1; AJvYcCUQxvU61Q/TpgrtQZNPdxRkWXOPvOtGVhh1dLkGzIZw1/n4JiouBg5KWGOxj3+DvgfUxRW3nyH+aLYS7j17qkA=@lists.infradead.org, AJvYcCUwMx8A9IBap+ZsVoT3mYerotIgv1yHvIGqfBzP8OgkikeXTQyJvxo0AM4cqsjxTGsGar/fbP5ZWcUsAF4//LhV@lists.infradead.org X-Gm-Message-State: AOJu0YzaFiIZtJLzs8j4xLfjYI3/gZfJgnvNxqWU9xcKtlGHPpLzeKGP bk9Z0c646dOPJ+VMSPogZLGc8ec/8yEqPtAI9UbCp/A7oCK4KBkO X-Gm-Gg: ASbGncuuKbUakD88BEyJk2u6QxJ66acVcpkUSDy1cM9k9EBcyKmYAivnVXuTMl7qZLz nzSv42l801iiplejT4/qNpoAW/K60lrKNdlk9H3zGgWkKJogoJb0jtGOEwvb8HaaE/GF2n2G4+J jzsHQYmns6NUiukIEMX9xaZ9qukrk9UGTLQc52oC/LGrLxCqlQdfmCx/Nx3VliDaletOYnJSGHS CusnNgvgy7HfZwukvsX8p4Ymewht2+Tb7SBXx+BDdk753Ydb07T2CSnErvTrN9BhcAx0yRWWeMK k/Q7t27frqXfoy6IWu2Nh4UDGOOzGxSKh3Aa47Q2KJsS+c39LVDx3zjeNGCHz2A5e39g4fNExNt tm+yw7aHS11IhYufoUVCCzPf/ X-Google-Smtp-Source: AGHT+IHdZpkFNBjA6COduNegwovJkZNCckMp9sNMex24ZFcOREOSr4DDptLMW0v+z79ptMTJ93Mulg== X-Received: by 2002:a05:600c:4f46:b0:43c:f6b0:e807 with SMTP id 5b1f17b1804b1-43d1ed0ea8dmr86614825e9.31.1742053497868; Sat, 15 Mar 2025 08:44:57 -0700 (PDT) Received: from localhost.localdomain (93-34-90-129.ip49.fastwebnet.it. [93.34.90.129]) by smtp.googlemail.com with ESMTPSA id 5b1f17b1804b1-43d1fe0636dsm53464195e9.11.2025.03.15.08.44.55 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 15 Mar 2025 08:44:56 -0700 (PDT) From: Christian Marangi To: Christian Marangi , Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Andrew Lunn , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Vladimir Oltean , Srinivas Kandagatla , Heiner Kallweit , Russell King , Maxime Chevallier , Matthias Brugger , AngeloGioacchino Del Regno , linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, upstream@airoha.com Subject: [net-next PATCH v13 11/14] net: mdio: Add Airoha AN8855 Switch MDIO Passtrough Date: Sat, 15 Mar 2025 16:43:51 +0100 Message-ID: <20250315154407.26304-12-ansuelsmth@gmail.com> X-Mailer: git-send-email 2.48.1 In-Reply-To: <20250315154407.26304-1-ansuelsmth@gmail.com> References: <20250315154407.26304-1-ansuelsmth@gmail.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250315_084459_884044_5512B945 X-CRM114-Status: GOOD ( 21.64 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Add Airoha AN8855 Switch driver to register a MDIO passtrough as switch address is shared with the internal PHYs and require additional page handling. This requires the upper Switch MFD to be probed and init to actually work. Signed-off-by: Christian Marangi --- MAINTAINERS | 1 + drivers/net/mdio/Kconfig | 10 +++++++ drivers/net/mdio/Makefile | 1 + drivers/net/mdio/mdio-an8855.c | 49 ++++++++++++++++++++++++++++++++++ 4 files changed, 61 insertions(+) create mode 100644 drivers/net/mdio/mdio-an8855.c diff --git a/MAINTAINERS b/MAINTAINERS index aec293953382..f4c8054d3980 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -731,6 +731,7 @@ F: Documentation/devicetree/bindings/net/airoha,an8855-phy.yaml F: Documentation/devicetree/bindings/net/dsa/airoha,an8855-switch.yaml F: Documentation/devicetree/bindings/nvmem/airoha,an8855-efuse.yaml F: drivers/mfd/airoha-an8855.c +F: drivers/net/mdio/mdio-an8855.c AIROHA ETHERNET DRIVER M: Lorenzo Bianconi diff --git a/drivers/net/mdio/Kconfig b/drivers/net/mdio/Kconfig index 4a7a303be2f7..e31a37064934 100644 --- a/drivers/net/mdio/Kconfig +++ b/drivers/net/mdio/Kconfig @@ -61,6 +61,16 @@ config MDIO_XGENE This module provides a driver for the MDIO busses found in the APM X-Gene SoC's. +config MDIO_AN8855 + tristate "Airoha AN8855 Switch MDIO bus controller" + depends on MFD_AIROHA_AN8855 + depends on OF_MDIO + select MDIO_REGMAP + help + This module provides a driver for the Airoha AN8855 Switch + that requires a MDIO passtrough as switch address is shared + with the internal PHYs and requires additional page handling. + config MDIO_ASPEED tristate "ASPEED MDIO bus controller" depends on ARCH_ASPEED || COMPILE_TEST diff --git a/drivers/net/mdio/Makefile b/drivers/net/mdio/Makefile index 1015f0db4531..546c4e55b475 100644 --- a/drivers/net/mdio/Makefile +++ b/drivers/net/mdio/Makefile @@ -5,6 +5,7 @@ obj-$(CONFIG_ACPI_MDIO) += acpi_mdio.o obj-$(CONFIG_FWNODE_MDIO) += fwnode_mdio.o obj-$(CONFIG_OF_MDIO) += of_mdio.o +obj-$(CONFIG_MDIO_AN8855) += mdio-an8855.o obj-$(CONFIG_MDIO_ASPEED) += mdio-aspeed.o obj-$(CONFIG_MDIO_BCM_IPROC) += mdio-bcm-iproc.o obj-$(CONFIG_MDIO_BCM_UNIMAC) += mdio-bcm-unimac.o diff --git a/drivers/net/mdio/mdio-an8855.c b/drivers/net/mdio/mdio-an8855.c new file mode 100644 index 000000000000..22d199942f1c --- /dev/null +++ b/drivers/net/mdio/mdio-an8855.c @@ -0,0 +1,49 @@ +// SPDX-License-Identifier: GPL-2.0+ +/* + * MDIO passthrough driver for Airoha AN8855 Switch + */ + +#include +#include +#include +#include + +static int an8855_mdio_probe(struct platform_device *pdev) +{ + struct mdio_regmap_config mrc = { }; + struct device *dev = &pdev->dev; + struct mii_bus *bus; + + mrc.regmap = dev_get_regmap(dev->parent, "phy"); + mrc.parent = dev; + mrc.valid_addr_mask = GENMASK(31, 0); + mrc.support_encoded_addr = true; + mrc.autoscan = true; + mrc.np = dev->of_node; + snprintf(mrc.name, MII_BUS_ID_SIZE, KBUILD_MODNAME); + + bus = devm_mdio_regmap_register(dev, &mrc); + if (IS_ERR(bus)) + return dev_err_probe(dev, PTR_ERR(bus), "failed to register MDIO bus\n"); + + return 0; +} + +static const struct of_device_id an8855_mdio_of_match[] = { + { .compatible = "airoha,an8855-mdio", }, + { /* sentinel */ } +}; +MODULE_DEVICE_TABLE(of, an8855_mdio_of_match); + +static struct platform_driver an8855_mdio_driver = { + .probe = an8855_mdio_probe, + .driver = { + .name = "an8855-mdio", + .of_match_table = an8855_mdio_of_match, + }, +}; +module_platform_driver(an8855_mdio_driver); + +MODULE_AUTHOR("Christian Marangi "); +MODULE_DESCRIPTION("Driver for AN8855 MDIO passthrough"); +MODULE_LICENSE("GPL"); From patchwork Sat Mar 15 15:43:52 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christian Marangi X-Patchwork-Id: 14018142 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 B57D3C28B28 for ; Sat, 15 Mar 2025 16:07:07 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Transfer-Encoding: MIME-Version:References:In-Reply-To:Message-ID:Date:Subject:To:From:Reply-To: Cc:Content-Type:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=MLADOhZLwHgDJvwkej1GksyyIBUmhIAfbT2mkxjXrtg=; b=GbKFLpcmzO55UrWXg6261LGTRT aCFQpxn5nT6xDUC1I0evrxO6JjmZXAQZR3FvXlA0QCBUplJw5vp73bffd1yxVVj6xCPzOXVOushFP Aa872lM1KMM3YpiQizSfIZE/BfcDQuCvlVygEAlsbMABn4KPtIZvQeGNc79T7OTVnFf7qNOL8DIQ3 Votym+86s58nF/xUQbco/aD9/TTF+bWJx/q7q85Z40zxxmNt+x7Tytrfdof/CyCHE/FY0wePUwNuq zkkAkit4RstIWK+ygfAAzxRLaiKU/KVtg8YtWXiTUREn8xk/+xzvoDRUOJfvP+OPoqtTZoOsvmtW+ HYt+hUNQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1ttU2M-0000000GZgo-3M8R; Sat, 15 Mar 2025 16:06:58 +0000 Received: from mail-wm1-x32f.google.com ([2a00:1450:4864:20::32f]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1ttTh7-0000000GX6i-2FaP; Sat, 15 Mar 2025 15:45:02 +0000 Received: by mail-wm1-x32f.google.com with SMTP id 5b1f17b1804b1-43d04dc73b7so7250005e9.3; Sat, 15 Mar 2025 08:45:01 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1742053500; x=1742658300; darn=lists.infradead.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=MLADOhZLwHgDJvwkej1GksyyIBUmhIAfbT2mkxjXrtg=; b=EYCWU8CwpirwQjIh/u5OygbQ2XK1wEt4V3VUObZBMdmxQiqXhmbd/OgKcYSM2//caJ 7sA3EvplkDAU2l4bmie7rtMlkxkxVwrTgU51N6MqdRP9u3t5oSfS0E0tXwAkfi/ONdpt CUO7eD9V3ytV4vhLHowi/qR1VMpUn6v4P9jX8bsU0NNy0+KagOXp/NYgE/lgbmzfEcH+ vqib1Q1rh+U5ELUWjkpgHC7kxXWPo7PROdD7AR9tka9b05AM7NBnUKXvOWkGpi7cCPGx HYgwbMvPhelRcrjhVqWMMPD+DtTB+FpNtiqoaZ1g5dhKhgz8cpql/hd1E+wD/xCs4okF +rag== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1742053500; x=1742658300; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=MLADOhZLwHgDJvwkej1GksyyIBUmhIAfbT2mkxjXrtg=; b=HKJDYazrMA8rzCBZ+QW0zKKUQKQR1URtn+YBC42AJBhIs91DRZKopC03xyh+k94uDl fv4NV9pjcWHwIKk3VUdnphPS0ykwByXrmonz+wxlMev2Irf8LtvHYv5u5ibca4Oo0Keo rhFf+lehxuUIK/xNLPoHsXkr8wgU5j991Mt0xbnN3xG5M7RkH6swJ6GX+XlMwxClW4P9 5SZqfnNe28paAPVlSGYlkUDyZXCJX1IRiXotUbPBc+L+bLp5V3B2hC5ILrnKtCJ0x6zD DLS1kquU28zmWkNEGlYusWnN+Ifth/QCetuvSouI6MqdmbMO7G41GazoEELh4ThIad+I 6c7g== X-Forwarded-Encrypted: i=1; AJvYcCVzVp3LpwcVGID5YOMkrzitnCB4LvJxqlCgDT9/7ZUD7JJkUNeG+zddgMYYaNeE0ySs3xPWYbeNqDaTc8/fmgo=@lists.infradead.org, AJvYcCVzYpjXZzd8BkzsFqo2zudyPudrC2kV5XfzE2fK7X3AwaghZB3516J8zspnskVfYBIzeBxvKmpLfIbgkAyHlQv0@lists.infradead.org X-Gm-Message-State: AOJu0Yw3DN7SZlKdZ+oAjP4rlszlo8aMpixpQYlm2dInaR6oytyYuRgu fDOnw3vwvBto2eFD9i1VQ46XEx/ONlacAfIGaTO7Zxl31BFFpdw4 X-Gm-Gg: ASbGncv1T/aRFfYysQqqTCzyl9r5jQKtvzLwT6lSqiKghoF+b7x0GCLiHxZD3USDM61 12K8fNdy5Cb1I++wnn7q4pEaQ/hcTA/seNW+pnLPjAzXI//958uZnwm550evR1pVhJMoFbGLt8I anZ0HlVP7SMW3MrRgbJYN1Hys+ZTL3uxnxeR71P5XTl3H3OpWtgpUnNjDH8CvaaZBsB6YRaYCYy PBK/4Iz4kP/HE9Mi5pVnQPDuxM1sQIcrSEYGDzNbPWONdDQQUx44qvJeHLRLou+ES6U2qPQFbQO T/CZ92tNmAgL9v4uWMIpqwzQg3QrA9W3eZjD1Ay5rst1/RgbYDeWMumOzcH6UpFoo7vhVox9A9X nTOpbEQ5nuLKcWA== X-Google-Smtp-Source: AGHT+IHw40EB6m3XbCZVxnXK0drFuLtBU4zju5WbN9CNTainjG2Tg6Im/75POmqbfCbDd2b7v424dg== X-Received: by 2002:a05:600c:358c:b0:43c:eeee:b713 with SMTP id 5b1f17b1804b1-43d1ecc31admr77024235e9.20.1742053499835; Sat, 15 Mar 2025 08:44:59 -0700 (PDT) Received: from localhost.localdomain (93-34-90-129.ip49.fastwebnet.it. [93.34.90.129]) by smtp.googlemail.com with ESMTPSA id 5b1f17b1804b1-43d1fe0636dsm53464195e9.11.2025.03.15.08.44.57 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 15 Mar 2025 08:44:58 -0700 (PDT) From: Christian Marangi To: Christian Marangi , Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Andrew Lunn , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Vladimir Oltean , Srinivas Kandagatla , Heiner Kallweit , Russell King , Maxime Chevallier , Matthias Brugger , AngeloGioacchino Del Regno , linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, upstream@airoha.com Subject: [net-next PATCH v13 12/14] nvmem: an8855: Add support for Airoha AN8855 Switch EFUSE Date: Sat, 15 Mar 2025 16:43:52 +0100 Message-ID: <20250315154407.26304-13-ansuelsmth@gmail.com> X-Mailer: git-send-email 2.48.1 In-Reply-To: <20250315154407.26304-1-ansuelsmth@gmail.com> References: <20250315154407.26304-1-ansuelsmth@gmail.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250315_084501_623241_27ABFECC X-CRM114-Status: GOOD ( 21.97 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Add support for Airoha AN8855 Switch EFUSE. These EFUSE might be used for calibration data for the internal switch PHYs. Signed-off-by: Christian Marangi --- MAINTAINERS | 1 + drivers/nvmem/Kconfig | 11 +++++++ drivers/nvmem/Makefile | 2 ++ drivers/nvmem/an8855-efuse.c | 63 ++++++++++++++++++++++++++++++++++++ 4 files changed, 77 insertions(+) create mode 100644 drivers/nvmem/an8855-efuse.c diff --git a/MAINTAINERS b/MAINTAINERS index f4c8054d3980..2cc8871186d5 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -732,6 +732,7 @@ F: Documentation/devicetree/bindings/net/dsa/airoha,an8855-switch.yaml F: Documentation/devicetree/bindings/nvmem/airoha,an8855-efuse.yaml F: drivers/mfd/airoha-an8855.c F: drivers/net/mdio/mdio-an8855.c +F: drivers/nvmem/an8855-efuse.c AIROHA ETHERNET DRIVER M: Lorenzo Bianconi diff --git a/drivers/nvmem/Kconfig b/drivers/nvmem/Kconfig index 8671b7c974b9..ca96c6ea685a 100644 --- a/drivers/nvmem/Kconfig +++ b/drivers/nvmem/Kconfig @@ -28,6 +28,17 @@ source "drivers/nvmem/layouts/Kconfig" # Devices +config NVMEM_AN8855_EFUSE + tristate "Airoha AN8855 eFuse support" + depends on MFD_AIROHA_AN8855 || COMPILE_TEST + help + Say y here to enable support for reading eFuses on Airoha AN8855 + Switch. These are e.g. used to store factory programmed + calibration data required for the PHY. + + This driver can also be built as a module. If so, the module will + be called nvmem-an8855-efuse. + config NVMEM_APPLE_EFUSES tristate "Apple eFuse support" depends on ARCH_APPLE || COMPILE_TEST diff --git a/drivers/nvmem/Makefile b/drivers/nvmem/Makefile index 5b77bbb6488b..c732132c0e45 100644 --- a/drivers/nvmem/Makefile +++ b/drivers/nvmem/Makefile @@ -10,6 +10,8 @@ nvmem_layouts-y := layouts.o obj-y += layouts/ # Devices +obj-$(CONFIG_NVMEM_AN8855_EFUSE) += nvmem-an8855-efuse.o +nvmem-an8855-efuse-y := an8855-efuse.o obj-$(CONFIG_NVMEM_APPLE_EFUSES) += nvmem-apple-efuses.o nvmem-apple-efuses-y := apple-efuses.o obj-$(CONFIG_NVMEM_BCM_OCOTP) += nvmem-bcm-ocotp.o diff --git a/drivers/nvmem/an8855-efuse.c b/drivers/nvmem/an8855-efuse.c new file mode 100644 index 000000000000..cd1564379098 --- /dev/null +++ b/drivers/nvmem/an8855-efuse.c @@ -0,0 +1,63 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * Airoha AN8855 Switch EFUSE Driver + */ + +#include +#include +#include +#include +#include + +#define AN8855_EFUSE_CELL 50 + +#define AN8855_EFUSE_DATA0 0x1000a500 +#define AN8855_EFUSE_R50O GENMASK(30, 24) + +static int an8855_efuse_read(void *context, unsigned int offset, + void *val, size_t bytes) +{ + struct regmap *regmap = context; + + return regmap_bulk_read(regmap, AN8855_EFUSE_DATA0 + offset, + val, bytes / sizeof(u32)); +} + +static int an8855_efuse_probe(struct platform_device *pdev) +{ + struct nvmem_config an8855_nvmem_config = { + .name = "an8855-efuse", + .size = AN8855_EFUSE_CELL * sizeof(u32), + .stride = sizeof(u32), + .word_size = sizeof(u32), + .reg_read = an8855_efuse_read, + }; + struct device *dev = &pdev->dev; + struct nvmem_device *nvmem; + + /* Assign NVMEM priv to MFD regmap */ + an8855_nvmem_config.priv = dev_get_regmap(dev->parent, "switch"); + an8855_nvmem_config.dev = dev; + nvmem = devm_nvmem_register(dev, &an8855_nvmem_config); + + return PTR_ERR_OR_ZERO(nvmem); +} + +static const struct of_device_id an8855_efuse_of_match[] = { + { .compatible = "airoha,an8855-efuse", }, + { /* sentinel */ } +}; +MODULE_DEVICE_TABLE(of, an8855_efuse_of_match); + +static struct platform_driver an8855_efuse_driver = { + .probe = an8855_efuse_probe, + .driver = { + .name = "an8855-efuse", + .of_match_table = an8855_efuse_of_match, + }, +}; +module_platform_driver(an8855_efuse_driver); + +MODULE_AUTHOR("Christian Marangi "); +MODULE_DESCRIPTION("Driver for AN8855 Switch EFUSE"); +MODULE_LICENSE("GPL"); From patchwork Sat Mar 15 15:43:54 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christian Marangi X-Patchwork-Id: 14018143 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 79243C28B28 for ; Sat, 15 Mar 2025 16:09:17 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Transfer-Encoding: MIME-Version:References:In-Reply-To:Message-ID:Date:Subject:To:From:Reply-To: Cc:Content-Type:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=26JJCmlDcdbfYCpzjJ343B/Vx1BEYMaxX+SKZPRwncE=; b=EW5E6mEs0KwVr4LycERemmgmHD lplCn6H7rM4ngx9tU5utsccJr2AX1palI/5R80YG0REKInEUEmBSWetFcDi7ZPHmcK4Bi9cjdZ+hx uRGqxFnE6452KaXFRTzO+hDjRqAj01Ixa8SNxugM/Vlyy80W3PurfBMIunxBmbA2it3NYbcyEhYLS N7LBCF2Dzj/l/AHG6AY1DEx5axQpzPfUv5ViVb9hHUdKzchc6B0SM4g7Ca+9eYu1TNBQ7tiU2/g0I Ta2llIkYFt0LQ3BdEiam8aUAyENTp442wo7A5P+CNcJOqzXB9OBKiOkvDSvgDiKQOFpDa2eLyl70K 21MmyOZQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1ttU4T-0000000GZtw-1iuc; Sat, 15 Mar 2025 16:09:09 +0000 Received: from mail-wm1-x32f.google.com ([2a00:1450:4864:20::32f]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1ttThA-0000000GX8L-1Dt5; Sat, 15 Mar 2025 15:45:05 +0000 Received: by mail-wm1-x32f.google.com with SMTP id 5b1f17b1804b1-43cfa7e7f54so3682245e9.1; Sat, 15 Mar 2025 08:45:04 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1742053503; x=1742658303; darn=lists.infradead.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=26JJCmlDcdbfYCpzjJ343B/Vx1BEYMaxX+SKZPRwncE=; b=kr8TZwcuJtwMBF1+Q6ZDabDjnsucnRtCFZxweGH2vtpb2MG+/c5N9SfPhmKqoJaVwS 0uNiC/9bs1QuQVwjQGOQIhED0xP+mw/vLxNitKouAK5Ujei5kv5eQtu9PZ9cTu4EUvcY fIl+Dj3U8H7Apt2RdMhTZguRverAQ3iZt/g3o19f5Cwubsgpf7oYN8e4lGBghW7EenVJ XhPRyfNa2zhXE28TOC/6OwcECCr3ERPGFyZE3DtHVvio9ghv6y4bBx0QLS4YqIJmzZhK Aw7eOq/gd/M0EhKCt9v9ynWuFX3y6P2fqeBqpBDk1gBw0Id/nO9b0HnYVEU1NP3/5GfN ByuA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1742053503; x=1742658303; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=26JJCmlDcdbfYCpzjJ343B/Vx1BEYMaxX+SKZPRwncE=; b=U22mRD4cMhm2l/BC8/jrfYpOUNZTKTBoXMGA+kZvNeoMGRo0z1IZbrDZ0oGzP2VBsT 3Rx7OeJItXCAdpMBFQgJ4XrOMr/pZA/paY1ykc2TEQPHUdBOz9k0nOHM9gcUvrQ5lIIj od9/SKECJkpYXkJF9uDL1d3hTKwZzL2uU4wNyQMK6goXZQ3w8TlVAJoiLsTTpIcThaWl AOtYxeEkQ3U2UnaWs8vMcHv1r4Uuvun+LFrZ1W0GYV0S5mpS79o12ExuXkVcR/V8bbJf oGINcZCxerLM8CzzqvRsAG3DcT+y+NU46b/f+GyG55UWHLetjL8cws2XnH87QAZYj+R4 i1FQ== X-Forwarded-Encrypted: i=1; AJvYcCWU1gfqHySsQ/3osnf1fBJg3BJRaWdojn1NDaBqqqS6fhyvmB57LCuU7NbZ2i1WyX+LuKecZq2PjKs7aeFPDcwg@lists.infradead.org, AJvYcCXbqidAzYQJnlOz7tFC4D0pQlHBD9EZsRHex4KkuqDly8dxZWY2d1Pc1zy4MP+6tLpCdbFCpBgrUlt69SsueZM=@lists.infradead.org X-Gm-Message-State: AOJu0Yx1bgIbdYq8onuwwqRy/FfyT1Ifo7s6Bmho6pdncBCr6+7n8D5C dmnhZfgvDjxzoo3b5a4wx7DItO+77XIJ+VkQxGGYH3+JTN8qg5Ee X-Gm-Gg: ASbGncsx1kvgbNTxkvhwybcUcN2RAC/k11gSSrY0BUbN+W355mut732eMeJzPyroi2f xYmqefUB+Wo7lVYrYV6W39rW+rhzcpXDqtIdesufxb1sU8mlr4wboBdSunNry14txT5VDAhglzS SwqyKJbevRUH2kncui526WBV14XFa5/j1nwM6FrMMw60tHxfrR2kXatUos/6qP2DYGoxzWegOOa PNu9rXdtaWGzL8T/Q8COJ40D+EZCpR2I24bGH2ptSvpznJIn+pTxDg7HeRVZyMx9nnnkQ+hdXnG XsSBiVYwAjhhqiA1lTlxXF5V9S9G0loSPKYzCp3FUmbYXOTNN7VMsMmW5IS7uRY/pjY+wHTHy+E qbJnqTDR3pSyOkw== X-Google-Smtp-Source: AGHT+IFmXsN8klX4GsDMXZh30znszwsLJ4cYBQtCjrSXHMtPD4sogoTlG8Lw8sNMVKOhx4PuKqFaOA== X-Received: by 2002:a05:600c:4ed2:b0:439:4b23:9e8e with SMTP id 5b1f17b1804b1-43d1f1d2bb6mr80487135e9.3.1742053502842; Sat, 15 Mar 2025 08:45:02 -0700 (PDT) Received: from localhost.localdomain (93-34-90-129.ip49.fastwebnet.it. [93.34.90.129]) by smtp.googlemail.com with ESMTPSA id 5b1f17b1804b1-43d1fe0636dsm53464195e9.11.2025.03.15.08.45.01 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 15 Mar 2025 08:45:02 -0700 (PDT) From: Christian Marangi To: Christian Marangi , Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Andrew Lunn , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Vladimir Oltean , Srinivas Kandagatla , Heiner Kallweit , Russell King , Maxime Chevallier , Matthias Brugger , AngeloGioacchino Del Regno , linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, upstream@airoha.com Subject: [net-next PATCH v13 14/14] net: phy: Add Airoha AN8855 Internal Switch Gigabit PHY Date: Sat, 15 Mar 2025 16:43:54 +0100 Message-ID: <20250315154407.26304-15-ansuelsmth@gmail.com> X-Mailer: git-send-email 2.48.1 In-Reply-To: <20250315154407.26304-1-ansuelsmth@gmail.com> References: <20250315154407.26304-1-ansuelsmth@gmail.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250315_084504_463730_29220D98 X-CRM114-Status: GOOD ( 23.79 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Add support for Airoha AN8855 Internal Switch Gigabit PHY. This is a simple PHY driver to configure and calibrate the PHY for the AN8855 Switch with the use of NVMEM cells. Signed-off-by: Christian Marangi --- MAINTAINERS | 1 + drivers/net/phy/Kconfig | 5 + drivers/net/phy/Makefile | 1 + drivers/net/phy/air_an8855.c | 261 +++++++++++++++++++++++++++++++++++ 4 files changed, 268 insertions(+) create mode 100644 drivers/net/phy/air_an8855.c diff --git a/MAINTAINERS b/MAINTAINERS index e285fa2702f5..41fb4d0d7fdb 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -734,6 +734,7 @@ F: drivers/mfd/airoha-an8855.c F: drivers/net/dsa/an8855.c F: drivers/net/dsa/an8855.h F: drivers/net/mdio/mdio-an8855.c +F: drivers/net/phy/air_an8855.c F: drivers/nvmem/an8855-efuse.c AIROHA ETHERNET DRIVER diff --git a/drivers/net/phy/Kconfig b/drivers/net/phy/Kconfig index d29f9f7fd2e1..e96f61b8eaba 100644 --- a/drivers/net/phy/Kconfig +++ b/drivers/net/phy/Kconfig @@ -79,6 +79,11 @@ config SFP comment "MII PHY device drivers" +config AIR_AN8855_PHY + tristate "Airoha AN8855 Internal Gigabit PHY" + help + Currently supports the internal Airoha AN8855 Switch PHY. + config AIR_EN8811H_PHY tristate "Airoha EN8811H 2.5 Gigabit PHY" help diff --git a/drivers/net/phy/Makefile b/drivers/net/phy/Makefile index 8f9ba5e8290d..d4f537ba006c 100644 --- a/drivers/net/phy/Makefile +++ b/drivers/net/phy/Makefile @@ -36,6 +36,7 @@ obj-y += $(sfp-obj-y) $(sfp-obj-m) obj-$(CONFIG_ADIN_PHY) += adin.o obj-$(CONFIG_ADIN1100_PHY) += adin1100.o +obj-$(CONFIG_AIR_AN8855_PHY) += air_an8855.o obj-$(CONFIG_AIR_EN8811H_PHY) += air_en8811h.o obj-$(CONFIG_AMD_PHY) += amd.o obj-$(CONFIG_AMCC_QT2025_PHY) += qt2025.o diff --git a/drivers/net/phy/air_an8855.c b/drivers/net/phy/air_an8855.c new file mode 100644 index 000000000000..a740dbaacf9a --- /dev/null +++ b/drivers/net/phy/air_an8855.c @@ -0,0 +1,261 @@ +// SPDX-License-Identifier: GPL-2.0+ +/* + * Copyright (C) 2024 Christian Marangi + */ + +#include +#include +#include +#include +#include + +#define AN8855_PHY_SELECT_PAGE 0x1f +#define AN8855_PHY_PAGE GENMASK(2, 0) +#define AN8855_PHY_PAGE_STANDARD FIELD_PREP_CONST(AN8855_PHY_PAGE, 0x0) +#define AN8855_PHY_PAGE_EXTENDED_1 FIELD_PREP_CONST(AN8855_PHY_PAGE, 0x1) + +/* MII Registers Page 1 */ +#define AN8855_PHY_EXT_REG_14 0x14 +#define AN8855_PHY_EN_DOWN_SHIFT BIT(4) + +/* R50 Calibration regs in MDIO_MMD_VEND1 */ +#define AN8855_PHY_R500HM_RSEL_TX_AB 0x174 +#define AN8855_PHY_R50OHM_RSEL_TX_A_EN BIT(15) +#define AN8855_PHY_R50OHM_RSEL_TX_A GENMASK(14, 8) +#define AN8855_PHY_R50OHM_RSEL_TX_B_EN BIT(7) +#define AN8855_PHY_R50OHM_RSEL_TX_B GENMASK(6, 0) +#define AN8855_PHY_R500HM_RSEL_TX_CD 0x175 +#define AN8855_PHY_R50OHM_RSEL_TX_C_EN BIT(15) +#define AN8855_PHY_R50OHM_RSEL_TX_C GENMASK(14, 8) +#define AN8855_PHY_R50OHM_RSEL_TX_D_EN BIT(7) +#define AN8855_PHY_R50OHM_RSEL_TX_D GENMASK(6, 0) + +#define AN8855_SWITCH_EFUSE_R50O GENMASK(30, 24) + +/* PHY TX PAIR DELAY SELECT Register */ +#define AN8855_PHY_TX_PAIR_DLY_SEL_GBE 0x013 +#define AN8855_PHY_CR_DA_TX_PAIR_DELKAY_SEL_A_GBE GENMASK(14, 12) +#define AN8855_PHY_CR_DA_TX_PAIR_DELKAY_SEL_B_GBE GENMASK(10, 8) +#define AN8855_PHY_CR_DA_TX_PAIR_DELKAY_SEL_C_GBE GENMASK(6, 4) +#define AN8855_PHY_CR_DA_TX_PAIR_DELKAY_SEL_D_GBE GENMASK(2, 0) +/* PHY ADC Register */ +#define AN8855_PHY_RXADC_CTRL 0x0d8 +#define AN8855_PHY_RG_AD_SAMNPLE_PHSEL_A BIT(12) +#define AN8855_PHY_RG_AD_SAMNPLE_PHSEL_B BIT(8) +#define AN8855_PHY_RG_AD_SAMNPLE_PHSEL_C BIT(4) +#define AN8855_PHY_RG_AD_SAMNPLE_PHSEL_D BIT(0) +#define AN8855_PHY_RXADC_REV_0 0x0d9 +#define AN8855_PHY_RG_AD_RESERVE0_A GENMASK(15, 8) +#define AN8855_PHY_RG_AD_RESERVE0_B GENMASK(7, 0) +#define AN8855_PHY_RXADC_REV_1 0x0da +#define AN8855_PHY_RG_AD_RESERVE0_C GENMASK(15, 8) +#define AN8855_PHY_RG_AD_RESERVE0_D GENMASK(7, 0) + +#define AN8855_PHY_ID 0xc0ff0410 + +struct air_an8855_priv { + bool needs_calibration; +}; + +static const u8 dsa_r50ohm_table[] = { + 127, 127, 127, 127, 127, 127, 127, 127, 127, 127, + 127, 127, 127, 127, 127, 127, 127, 126, 122, 117, + 112, 109, 104, 101, 97, 94, 90, 88, 84, 80, + 78, 74, 72, 68, 66, 64, 61, 58, 56, 53, + 51, 48, 47, 44, 42, 40, 38, 36, 34, 32, + 31, 28, 27, 24, 24, 22, 20, 18, 16, 16, + 14, 12, 11, 9 +}; + +static int en8855_get_r50ohm_val(struct device *dev, const char *calib_name, + u8 *dest) +{ + u32 shift_sel, val; + int ret; + int i; + + ret = nvmem_cell_read_u32(dev, calib_name, &val); + if (ret) + return ret; + + shift_sel = FIELD_GET(AN8855_SWITCH_EFUSE_R50O, val); + for (i = 0; i < ARRAY_SIZE(dsa_r50ohm_table); i++) + if (dsa_r50ohm_table[i] == shift_sel) + break; + + if (i < 8 || i >= ARRAY_SIZE(dsa_r50ohm_table)) + *dest = dsa_r50ohm_table[25]; + else + *dest = dsa_r50ohm_table[i - 8]; + + return 0; +} + +static int an8855_probe(struct phy_device *phydev) +{ + struct device *dev = &phydev->mdio.dev; + struct air_an8855_priv *priv; + + priv = devm_kzalloc(dev, sizeof(*priv), GFP_KERNEL); + if (!priv) + return -ENOMEM; + + priv->needs_calibration = of_property_present(dev->of_node, + "nvmem-cells"); + + phydev->priv = priv; + + return 0; +} + +static int an8855_get_downshift(struct phy_device *phydev, u8 *data) +{ + int val; + + val = phy_read_paged(phydev, AN8855_PHY_PAGE_EXTENDED_1, AN8855_PHY_EXT_REG_14); + if (val < 0) + return val; + + *data = val & AN8855_PHY_EN_DOWN_SHIFT ? DOWNSHIFT_DEV_DEFAULT_COUNT : + DOWNSHIFT_DEV_DISABLE; + + return 0; +} + +static int an8855_set_downshift(struct phy_device *phydev, u8 cnt) +{ + u16 ds = cnt != DOWNSHIFT_DEV_DISABLE ? AN8855_PHY_EN_DOWN_SHIFT : 0; + + return phy_modify_paged(phydev, AN8855_PHY_PAGE_EXTENDED_1, + AN8855_PHY_EXT_REG_14, AN8855_PHY_EN_DOWN_SHIFT, + ds); +} + +static int an8855_config_init(struct phy_device *phydev) +{ + struct air_an8855_priv *priv = phydev->priv; + struct device *dev = &phydev->mdio.dev; + int ret; + + /* Enable HW auto downshift */ + ret = an8855_set_downshift(phydev, DOWNSHIFT_DEV_DEFAULT_COUNT); + if (ret) + return ret; + + if (priv->needs_calibration) { + u8 calibration_data[4]; + + ret = en8855_get_r50ohm_val(dev, "tx_a", &calibration_data[0]); + if (ret) + return ret; + + ret = en8855_get_r50ohm_val(dev, "tx_b", &calibration_data[1]); + if (ret) + return ret; + + ret = en8855_get_r50ohm_val(dev, "tx_c", &calibration_data[2]); + if (ret) + return ret; + + ret = en8855_get_r50ohm_val(dev, "tx_d", &calibration_data[3]); + if (ret) + return ret; + + ret = phy_modify_mmd(phydev, MDIO_MMD_VEND1, AN8855_PHY_R500HM_RSEL_TX_AB, + AN8855_PHY_R50OHM_RSEL_TX_A | AN8855_PHY_R50OHM_RSEL_TX_B, + FIELD_PREP(AN8855_PHY_R50OHM_RSEL_TX_A, calibration_data[0]) | + FIELD_PREP(AN8855_PHY_R50OHM_RSEL_TX_B, calibration_data[1])); + if (ret) + return ret; + ret = phy_modify_mmd(phydev, MDIO_MMD_VEND1, AN8855_PHY_R500HM_RSEL_TX_CD, + AN8855_PHY_R50OHM_RSEL_TX_C | AN8855_PHY_R50OHM_RSEL_TX_D, + FIELD_PREP(AN8855_PHY_R50OHM_RSEL_TX_C, calibration_data[2]) | + FIELD_PREP(AN8855_PHY_R50OHM_RSEL_TX_D, calibration_data[3])); + if (ret) + return ret; + } + + /* Apply values to reduce signal noise */ + ret = phy_write_mmd(phydev, MDIO_MMD_VEND1, AN8855_PHY_TX_PAIR_DLY_SEL_GBE, + FIELD_PREP(AN8855_PHY_CR_DA_TX_PAIR_DELKAY_SEL_A_GBE, 0x4) | + FIELD_PREP(AN8855_PHY_CR_DA_TX_PAIR_DELKAY_SEL_C_GBE, 0x4)); + if (ret) + return ret; + ret = phy_write_mmd(phydev, MDIO_MMD_VEND1, AN8855_PHY_RXADC_CTRL, + AN8855_PHY_RG_AD_SAMNPLE_PHSEL_A | + AN8855_PHY_RG_AD_SAMNPLE_PHSEL_C); + if (ret) + return ret; + ret = phy_write_mmd(phydev, MDIO_MMD_VEND1, AN8855_PHY_RXADC_REV_0, + FIELD_PREP(AN8855_PHY_RG_AD_RESERVE0_A, 0x1)); + if (ret) + return ret; + ret = phy_write_mmd(phydev, MDIO_MMD_VEND1, AN8855_PHY_RXADC_REV_1, + FIELD_PREP(AN8855_PHY_RG_AD_RESERVE0_C, 0x1)); + if (ret) + return ret; + + return 0; +} + +static int an8855_get_tunable(struct phy_device *phydev, + struct ethtool_tunable *tuna, void *data) +{ + switch (tuna->id) { + case ETHTOOL_PHY_DOWNSHIFT: + return an8855_get_downshift(phydev, data); + default: + return -EOPNOTSUPP; + } +} + +static int an8855_set_tunable(struct phy_device *phydev, + struct ethtool_tunable *tuna, const void *data) +{ + switch (tuna->id) { + case ETHTOOL_PHY_DOWNSHIFT: + return an8855_set_downshift(phydev, *(const u8 *)data); + default: + return -EOPNOTSUPP; + } +} + +static int an8855_read_page(struct phy_device *phydev) +{ + return __phy_read(phydev, AN8855_PHY_SELECT_PAGE); +} + +static int an8855_write_page(struct phy_device *phydev, int page) +{ + return __phy_write(phydev, AN8855_PHY_SELECT_PAGE, page); +} + +static struct phy_driver an8855_driver[] = { +{ + PHY_ID_MATCH_EXACT(AN8855_PHY_ID), + .name = "Airoha AN8855 internal PHY", + /* PHY_GBIT_FEATURES */ + .flags = PHY_IS_INTERNAL, + .probe = an8855_probe, + .config_init = an8855_config_init, + .soft_reset = genphy_soft_reset, + .get_tunable = an8855_get_tunable, + .set_tunable = an8855_set_tunable, + .suspend = genphy_suspend, + .resume = genphy_resume, + .read_page = an8855_read_page, + .write_page = an8855_write_page, +}, }; + +module_phy_driver(an8855_driver); + +static struct mdio_device_id __maybe_unused an8855_tbl[] = { + { PHY_ID_MATCH_EXACT(AN8855_PHY_ID) }, + { } +}; + +MODULE_DEVICE_TABLE(mdio, an8855_tbl); + +MODULE_DESCRIPTION("Airoha AN8855 PHY driver"); +MODULE_AUTHOR("Christian Marangi "); +MODULE_LICENSE("GPL");