Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp2965821iog; Mon, 20 Jun 2022 08:24:28 -0700 (PDT) X-Google-Smtp-Source: AGRyM1sdNFZkikAohHsw6oPG4M0QacQd04K1W2WfA5uKbBlnL9K+2V0922xkA/eg1ktk2rgWUWga X-Received: by 2002:a17:902:7042:b0:16a:2156:c325 with SMTP id h2-20020a170902704200b0016a2156c325mr6919124plt.166.1655738668523; Mon, 20 Jun 2022 08:24:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655738668; cv=none; d=google.com; s=arc-20160816; b=K9WVB8CcDKvf3VukXcphHTMxMN2gDx94WQZSd3x3L1thWC55A+nnaJbNbYGicA4Y5A emz9d4xQ4pPJL9lwpbfmYftDCDMOQvNefaQWd5g6MWEiO70b4KZHHAySxiEW3xp0EgVy bAD6Uen8UgLlfce+iKxJfAMGWcmgQolrQwGOgzPqzusej+aOw3fxZFonzbqaERheq4wQ 7FHzON1xLYuVCfELttLg6nZ6p9wPh+dO6fm7Dgw7Kn3X/j/Yd1eRQa3/tcTvuDodCoRw xIc36UTfOANuAxv+Pu0EoKisE9bIT3w3yRw0si/PNOkImmx7rLaS/ONz+xTnbU78L4fq 9b8A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=79HyXuMDzSUSAqm9LJDxm1QulLKFCMJuKULtDaG7pgg=; b=lm+FbSzSF7AhbZK8aw3L+StT1F0snaIKJ18H6Mw5eugJaqHpP7wSsqHUkoveQwsaD9 qyrx8wWQGQz91WSbcosMLUBffLyff8WyQ6PfNF+ugAIZoVq//jD35Qa6D0MfWzE1HpJg iscbE8go/8YQMxFauVaFjnOxr0wPUJnfzhjkef7tlwebJQHKSR8g3DfINBLnvFu9FmgN emlINeOLOKrEF4tVzzgb02R8hQ3pqYExFAnNCBrhqXXnb0DbP7oS3fKKr7ozpo2KZ3u4 hTz9+DF4OzRAHI7a3M1erDL0oCLd2t6BjFkL9hI5vHd2kpXR7w2emJ3jqzGjnI3JA8cQ h3bg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@semihalf.com header.s=google header.b=nFzaIAZu; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id 139-20020a630091000000b0040caec24b46si4651084pga.561.2022.06.20.08.24.14; Mon, 20 Jun 2022 08:24:28 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@semihalf.com header.s=google header.b=nFzaIAZu; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S243015AbiFTPOr (ORCPT + 99 others); Mon, 20 Jun 2022 11:14:47 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41076 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241872AbiFTPMX (ORCPT ); Mon, 20 Jun 2022 11:12:23 -0400 Received: from mail-lf1-x12f.google.com (mail-lf1-x12f.google.com [IPv6:2a00:1450:4864:20::12f]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 197761FA50 for ; Mon, 20 Jun 2022 08:03:00 -0700 (PDT) Received: by mail-lf1-x12f.google.com with SMTP id t25so17702927lfg.7 for ; Mon, 20 Jun 2022 08:03:00 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=semihalf.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=79HyXuMDzSUSAqm9LJDxm1QulLKFCMJuKULtDaG7pgg=; b=nFzaIAZullAM5QpV7lhiewLkjFv18wWs2j2rGdYzDLGAKqfmRPytd4UVWA0Sfl8EJ2 9d5m4M40GMi7QHDQ9TRwYn4Z9lkJNm2cUfefT8nA9Q/zGr4agzJ1BBbVQ9jKfFyEHmtx ePBznUBHD79+Z1j+mba+bqQTBIH2bJUV38tvJfn/nNjom4f3tYypl9LBWzsfCiDgjYX/ 7p1zgdkbcrzfnDn1XpWzPxkn1j/Z1oI0UWMzZtzVwFfMLXUWB6/cXOE5cCHUSYk0sgBk AWdAp5D8krh12xI1gZlvwuFmpn7/ZqcR8oTGJ9FEQf5A2tG5dpHH6vd84+ZI5slXizXb dcMg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=79HyXuMDzSUSAqm9LJDxm1QulLKFCMJuKULtDaG7pgg=; b=H2wvifn5BNkx5n547CrPDUiq/d4Nrpe4bq1E4T0WBYHhwE6KI6iYBjaCGatTwxqqHu BKQKJC8AvDrcceD7Bu6sFg8VXpxhald3QJD1oWi6sIg/ZPFF1n/r8mQC+ZM63sbcbUIe cH8b7ZVdIiQhTGM63XjQ0lT41qCCB8ZOMje/bVnrCnQUIEweo+8khrg9EXPI4HwHqP44 5JxPAqbXk0KyomVEUAGOG9t4cBtwzt3LwdbLv3tcnWWP31P4SBnNzasQFsoXNRqzVIdy TfSUd59lCH1+G7fBN4WsHQ7ixu7BYpo8e2pOLoOix6aKPSDuQTgqSIKN3dHUsQXIho9o J/MA== X-Gm-Message-State: AJIora+N3SxICshkwXENZHaXN55tK1Hw+X7sxDFf3kLd0tnNLwa7muMI JagxUQmZ0Yk2DiSTeJk7MmzhLZ67DGKbFg== X-Received: by 2002:a05:6512:3c87:b0:47f:70a0:b8f2 with SMTP id h7-20020a0565123c8700b0047f70a0b8f2mr2584155lfv.407.1655737378368; Mon, 20 Jun 2022 08:02:58 -0700 (PDT) Received: from gilgamesh.lab.semihalf.net ([83.142.187.85]) by smtp.gmail.com with ESMTPSA id e19-20020a05651236d300b0047f79f7758asm17564lfs.22.2022.06.20.08.02.57 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 20 Jun 2022 08:02:58 -0700 (PDT) From: Marcin Wojtas To: linux-kernel@vger.kernel.org, linux-acpi@vger.kernel.org, netdev@vger.kernel.org Cc: rafael@kernel.org, andriy.shevchenko@linux.intel.com, lenb@kernel.org, andrew@lunn.ch, vivien.didelot@gmail.com, f.fainelli@gmail.com, olteanv@gmail.com, davem@davemloft.net, edumazet@google.com, kuba@kernel.org, pabeni@redhat.com, linux@armlinux.org.uk, hkallweit1@gmail.com, gjb@semihalf.com, mw@semihalf.com, jaz@semihalf.com, tn@semihalf.com, Samer.El-Haj-Mahmoud@arm.com, upstream@semihalf.com Subject: [net-next: PATCH 12/12] net: dsa: mv88e6xxx: add ACPI support Date: Mon, 20 Jun 2022 17:02:25 +0200 Message-Id: <20220620150225.1307946-13-mw@semihalf.com> X-Mailer: git-send-email 2.29.0 In-Reply-To: <20220620150225.1307946-1-mw@semihalf.com> References: <20220620150225.1307946-1-mw@semihalf.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Previous patches dropped the strict dependency on the OF_* API in both generic DSA subsystem and the mv88e6xxx driver. As a result the ACPI support can be introduced by adding the necessary ID's in the acpi_match_table and a two minor required adjustments, i.e. different mdiobus registration and MDIO subnode name, so to conform ACPI namespace requirements [1]. [1] https://uefi.org/specs/ACPI/6.4/05_ACPI_Software_Programming_Model/ACPI_Software_Programming_Model.html#acpi-namespace Signed-off-by: Marcin Wojtas --- drivers/net/dsa/mv88e6xxx/chip.c | 25 ++++++++++++++++++-- 1 file changed, 23 insertions(+), 2 deletions(-) diff --git a/drivers/net/dsa/mv88e6xxx/chip.c b/drivers/net/dsa/mv88e6xxx/chip.c index 556defa4379d..a74e528184aa 100644 --- a/drivers/net/dsa/mv88e6xxx/chip.c +++ b/drivers/net/dsa/mv88e6xxx/chip.c @@ -10,6 +10,8 @@ * Vivien Didelot */ +#include +#include #include #include #include @@ -3913,7 +3915,10 @@ static int mv88e6xxx_mdio_register(struct mv88e6xxx_chip *chip, goto out; } - err = of_mdiobus_register(bus, np); + if (is_acpi_node(fwnode)) + err = acpi_mdiobus_register(bus, fwnode); + else + err = of_mdiobus_register(bus, np); if (err) { dev_err(chip->dev, "Cannot register MDIO bus (%d)\n", err); mv88e6xxx_g2_irq_mdio_free(chip, bus); @@ -3952,14 +3957,19 @@ static void mv88e6xxx_mdios_unregister(struct mv88e6xxx_chip *chip) static int mv88e6xxx_mdios_register(struct mv88e6xxx_chip *chip, struct fwnode_handle *fwnode) { + char mdio_node_name[] = "mdio"; struct fwnode_handle *child; int err; + /* Update subnode name if operating in the ACPI world. */ + if (is_acpi_node(fwnode)) + strncpy(mdio_node_name, "MDIO", ACPI_NAMESEG_SIZE); + /* Always register one mdio bus for the internal/default mdio * bus. This maybe represented in the device tree, but is * optional. */ - child = fwnode_get_named_child_node(fwnode, "mdio"); + child = fwnode_get_named_child_node(fwnode, mdio_node_name); err = mv88e6xxx_mdio_register(chip, child, false); fwnode_handle_put(child); if (err) @@ -7177,6 +7187,16 @@ static const struct of_device_id mv88e6xxx_of_match[] = { MODULE_DEVICE_TABLE(of, mv88e6xxx_of_match); +#ifdef CONFIG_ACPI +static const struct acpi_device_id sdhci_mv88e6xxx_acpi_ids[] = { + { .id = "MRVL0120", (kernel_ulong_t)&mv88e6xxx_table[MV88E6085]}, + { .id = "MRVL0121", (kernel_ulong_t)&mv88e6xxx_table[MV88E6190]}, + { .id = "MRVL0122", (kernel_ulong_t)&mv88e6xxx_table[MV88E6250]}, + {} +}; +MODULE_DEVICE_TABLE(acpi, sdhci_mv88e6xxx_acpi_ids); +#endif + static struct mdio_driver mv88e6xxx_driver = { .probe = mv88e6xxx_probe, .remove = mv88e6xxx_remove, @@ -7184,6 +7204,7 @@ static struct mdio_driver mv88e6xxx_driver = { .mdiodrv.driver = { .name = "mv88e6085", .of_match_table = mv88e6xxx_of_match, + .acpi_match_table = ACPI_PTR(sdhci_mv88e6xxx_acpi_ids), .pm = &mv88e6xxx_pm_ops, }, }; -- 2.29.0