From nobody Sat May 11 12:55:23 2024 Delivered-To: importer2@patchew.org Received-SPF: pass (zohomail.com: domain of vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; envelope-from=linux-kernel-owner@vger.kernel.org; helo=vger.kernel.org; Authentication-Results: mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; arc=pass (i=1dmarc=pass fromdomain=televic.com); dmarc=pass(p=quarantine dis=none) header.from=televic.com ARC-Seal: i=2; a=rsa-sha256; t=1622634959; cv=pass; d=zohomail.com; s=zohoarc; b=aWatdIbIj3FIjqobINPniNxQtRzwb9haVPfRV7fJaQ3oADvVQKd2HdyiXpNvRT1ID6cwfrZPrklrq3NLp4Zvq2rumRa6/DY2MfHS15MNkaqGWd6ESlr/gRWkJDEMFS2LT616yTkntAd+0P40/JBDJYNkItBnwhzKP5ujpxUja7s= ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1622634959; h=Content-Type:Cc:Date:From:In-Reply-To:List-Id:MIME-Version:Message-ID:References:Subject:To; bh=iBt1hWbklCNLGZGqQnvYcVuvtaN/sPsIJRNvbDIx37I=; b=bJnuz4GzR161QejuKpv+AXPmTeuHJF/xMhckB1jCR0xatBa9RtTEitoVL0OKR85C6qtVWNC9WZW4MMwK9w4kczC3fUzt4gWvbSnxnx5TvbELmt/9NpUKdhhG2/eoyxW8rZ9JEttVVCisaqjlEw05CvNIce3AEXBFlY4QyNh5o2U= ARC-Authentication-Results: i=2; mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; arc=pass (i=1dmarc=pass fromdomain=televic.com); dmarc=pass header.from= (p=quarantine dis=none) header.from= Return-Path: Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mx.zohomail.com with SMTP id 1622634959303987.9185059554082; Wed, 2 Jun 2021 04:55:59 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230134AbhFBL5k (ORCPT ); Wed, 2 Jun 2021 07:57:40 -0400 Received: from mail-eopbgr70115.outbound.protection.outlook.com ([40.107.7.115]:41590 "EHLO EUR04-HE1-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S229586AbhFBL5i (ORCPT ); Wed, 2 Jun 2021 07:57:38 -0400 Received: from PR3PR07MB8049.eurprd07.prod.outlook.com (2603:10a6:102:14c::21) by PR3PR07MB6988.eurprd07.prod.outlook.com (2603:10a6:102:73::13) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4195.12; Wed, 2 Jun 2021 11:55:52 +0000 Received: from PR3PR07MB8049.eurprd07.prod.outlook.com ([fe80::395a:cb81:11c7:f958]) by PR3PR07MB8049.eurprd07.prod.outlook.com ([fe80::395a:cb81:11c7:f958%4]) with mapi id 15.20.4195.015; Wed, 2 Jun 2021 11:55:52 +0000 Received: from localhost.localdomain (2a02:1811:b71a:2e00:dd9:9421:9245:2349) by AM0PR02CA0198.eurprd02.prod.outlook.com (2603:10a6:20b:28e::35) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256) id 15.20.4173.22 via Frontend Transport; Wed, 2 Jun 2021 11:55:52 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=cjAbiP02n+DWDs0/+vb6ua79qsXJVVKGatkDppeo4dpAza9REFjMMbKzhgGxDCEoOelqfsLowVEM+mNGdXHJ/ho5K3n9jjhLh53iG5sfF5xUikbUfw58GiEtbTRmK2CmsoYh6V6yUhU6V/pexLQOFWy6XstQz6LjvX0a+FonO4GO08IH6UvAWDuFBDYxT6toOGW+hTtePKEC7WL2zicLhha1gESmRvLAv2ioP15utoaEZrtZAXKNycI3KUEQZZ8Nv8EYpnYmIxv0wiJDDa8u/GEyowl/AGCm/S+QtEaquHDQMSv5BtUrLL6/EjFr52Z9JF/uxjsP6C9U2Ij833DBKw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=iBt1hWbklCNLGZGqQnvYcVuvtaN/sPsIJRNvbDIx37I=; b=Cl4tQfTQtRaJfBYk3G3tNhS98Nn+l52dDjzsGT6D9xY5DPg5xbGFYQ1oeN+Rb9RX3nMJyl7bNEiEWSbC3+pABOKu5Db7KLgaHwvqep4H66WBWqshn2Z6zsgBiIA5sAu/rD6wQweW00Czq1pLFQIQiaZMfVC0/g+uItkV+DfSObrXzsZEATAD24o1XNLCu01YvXdokjuOarofh6XnTWJUi3UHeAhbzXzLJJ+x+1DMs6rvLDKh392JphcrSXgnAyM9nGBsiVw3nJxo+IGGqVVPVAId0VIVTk2hZQ7lxxVlMWLv9j22MnosrBgNTgs9CQLRALnnmhPSZdqtjuvs/3C4Bw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=televic.com; dmarc=pass action=none header.from=televic.com; dkim=pass header.d=televic.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=televic.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=iBt1hWbklCNLGZGqQnvYcVuvtaN/sPsIJRNvbDIx37I=; b=NImQ6qAkdaohYGfb1r+N6aIc9ddOpRT28Lyptwr4XoIPnKYRIaU9tSrFrRX3RBn8rW6uxuYRVyt4uvSh2wNOLMQx7RMuINhk4UbSooevgmIIRwRWzN9rSuWSM/mX4TfYqXc8IhBz+BwEUTDKhDtpzbH3hYycd6NrEsb+ZnBLcmg= Authentication-Results: televic.com; dkim=none (message not signed) header.d=none;televic.com; dmarc=none action=none header.from=televic.com; From: Pieter Cardoen Cc: Pieter Cardoen , Russell King , Shawn Guo , Sascha Hauer , Pengutronix Kernel Team , Fabio Estevam , NXP Linux Team , Oleksij Rempel , Robert Karszniewicz , Stefan Riedmueller , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH] ARM: imx: mach-imx6ul: support ptp and rmii clock from pad Date: Wed, 2 Jun 2021 13:55:32 +0200 Message-Id: <1622634933-4098-1-git-send-email-p.cardoen@televic.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1622621468-17013-1-git-send-email-p.cardoen@televic.com> References: <1622621468-17013-1-git-send-email-p.cardoen@televic.com> X-Originating-IP: [2a02:1811:b71a:2e00:dd9:9421:9245:2349] X-ClientProxiedBy: AM0PR02CA0198.eurprd02.prod.outlook.com (2603:10a6:20b:28e::35) To PR3PR07MB8049.eurprd07.prod.outlook.com (2603:10a6:102:14c::21) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 68d09ba6-b948-436c-dc63-08d925bd5f23 X-MS-TrafficTypeDiagnostic: PR3PR07MB6988: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:962; X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: yI1mh/eMkPskM4odyJBYqviDOfvqjIelSH99t5LJzYMKkvYIYMlE9+SdoJfzVhgLGwQeWoynLM0vpdsAtUY2JdPMIZ5kz/ftX28ooxIh8D1DHdTSFUxSllwfvK8VVabYtaZ50FzOCm4gm8btWLALqWuMDd34CBXmd3tgsKYem7aLZJsJBuLm7x0yZm9A1r2kvPugzrKqqMrJGE8YJwbeMGiGTu+ZsKBVjE4C1EXt9DmuuLXKZYKkEUOAT1GBUzv+k6hhxoCdLEiTpNHUbWhB1JOSu6gPryF19XUQNcUKarU056hldefqzwjCC5kOK3KkTDvcnkDhDPgeeuLzOdpYGaDvhnl2tHojOtptHUHPDBhoVyO7MtCf6oJE3CUklh7zLuGNpg7FDlhStUa+6rjMWbgyiP9eDrNGEQhbfxynjch0yAWQkk3WNG/zEcmiXd8YYHtW3Zj/wi9WYTDJW3qM/AOxL8pqSxtZWbFGBpjjRDUhfHTYiZnfdY2iNRzNMiH0SgMr8/0mQu+CmO14kIo768KJTH0ELImt9yDiOZbRQVUH252AWW65gKyvQKlIgS5+O2Xa7vnRvDFmGc6rIPMKyY0ZaK0WLcXXrIh+qrTkjhNgZ3FyztNFU9WLZpYRaptKSzzf1PhSwCHtcyl3W3UR5TAlK6ubEt5OOcETPlHuzG0= X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PR3PR07MB8049.eurprd07.prod.outlook.com;PTR:;CAT:NONE;SFS:(4636009)(346002)(376002)(136003)(396003)(39840400004)(366004)(16526019)(4326008)(38100700002)(109986005)(6666004)(5660300002)(8936002)(186003)(54906003)(316002)(6506007)(36756003)(86362001)(6486002)(2906002)(83380400001)(2616005)(6512007)(66556008)(478600001)(66946007)(8676002)(66476007)(52116002)(7416002)(69590400013)(266003);DIR:OUT;SFP:1102; X-MS-Exchange-AntiSpam-MessageData: =?us-ascii?Q?jLhaKtLmuwBCDeUt2EzZL/K+SJ9dT0udbWAuyOYWk8pznYh44ZiUYKvzXMpk?= =?us-ascii?Q?cCAJ8p5CShd17AmPAtTZgiv3rJ29YzRsA2/QmCqPcaqnRzteWPV3BKURiK3S?= =?us-ascii?Q?grCpie4duU+omtW54sBFgDaWjBr1mzofV9Awnjn9H4EUviWibWzzAi6Zhbri?= =?us-ascii?Q?i8eKsve71g0zFJd2Qu5eDsj6DC2elYFn6BvmPD/6LJSdFKCAfZQykGLkx3rh?= =?us-ascii?Q?x1FnGa+NCSDSm9ZwZbmqZ5awNwE+YpV2rwG0o1PK5UmMegjGnE8bkzGrfXVP?= =?us-ascii?Q?zZuI2/3PXDZfIGh5eoc9aL39dFJhyb5fr38xGkcbfta5JqLiKr5otbdWnel5?= =?us-ascii?Q?m+UDS44SntDuwmf349iYCv7UGH9rL2z3zk5vByW5GnJeKxhPw+jgq6ays6Dl?= =?us-ascii?Q?9GNwk2WLGXfWd6oDIMH2KlUkHNf3m16d01AC/YeU/N9fsOeMsL3vj9d8NWdl?= =?us-ascii?Q?t+wqbRhnrzYsfUFrICoAg3S0MC+wACqshO97cEaZLQeZOgHZ3D9/OLgjoL93?= =?us-ascii?Q?BNZVM/cxDn9kB9mK3WQf6JBLKcRwFby2aqeJc1c79ucNCjEAt6MM3K1PsyA4?= =?us-ascii?Q?OsVSPxB9CuvSsJlO3JwqWvqyW6jJaneaMcH5d+L9ylkLe2ozVAx4NjNzOazF?= =?us-ascii?Q?KCNEpv4hlgjMXJSwv1NGGYWYnpU3EvwaLhi95f4pMg41ggo7I4EBIndSsqEj?= =?us-ascii?Q?AqQa8B5LmKd+1u083y/jvtAYZOVDTFbyNQgmH/ajW84QVZEovHe8y2LC7WEL?= =?us-ascii?Q?sqTdyHSssdSSQqNSglEd8t195f/PbKza2Eyox1qRP4dUEqto+6iSE3Fb6BFI?= =?us-ascii?Q?1GrvfXkCX3COBEE0xV2rAgh1oFCjhAQvLz+NHpFK4bD0/7YlNAnRHduya1co?= =?us-ascii?Q?HMphpcuTW2Lg5Bxt54/6aCpZEqqFPCXWVQIAzKG9xMhbgK8R8dqIUVDu+pfQ?= =?us-ascii?Q?EdTN7PCTeflRXXiZ4nqQgXai+y931HbAZjVKUhC8hvAxkbXknRjS5oF70qDB?= =?us-ascii?Q?bN9T7EOMt/DE3L2eqX2CIfPraY032BSdvG1k+e6OHDrnMfJkS45gEGnW94wa?= =?us-ascii?Q?ifgGLO5yKl86HlHjUhtuz7oU/RXpLKv1/4XYViM2kNGbvRSiLuCz9hEfsoq2?= =?us-ascii?Q?prO3WNdE0j5A2hF1DCihTAI8jmHz0Ztzj/EBa3Y08u/o2DtXxQVUyhvEN0iM?= =?us-ascii?Q?bIhOWvtoeyJQRXMANT0WMVPikYShKfPcQv5NsvPN9IqYo+ijuJog7u6nxClG?= =?us-ascii?Q?aAuXaxiW4joj1rvVnSEIU90fCtjfTTXSeXI4+I3hM3uI6zQOVXlKA27ZtmOL?= =?us-ascii?Q?qtoatLhn5kJe8CphLWFQovaGJjNt+GlreLHmT4wNStVzUjhDN3ZVYLh2n4oO?= =?us-ascii?Q?oUxwTRXCx9hR4P5LOHvOwe9CqVaw?= X-OriginatorOrg: televic.com X-MS-Exchange-CrossTenant-Network-Message-Id: 68d09ba6-b948-436c-dc63-08d925bd5f23 X-MS-Exchange-CrossTenant-AuthSource: PR3PR07MB8049.eurprd07.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 02 Jun 2021 11:55:52.6630 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 68a8593e-d1fc-4a6a-b782-1bdcb0633231 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: YCBzX1XIqqKV4/21M0hmBzSzQ/Obo6ZpPJdpB5XIRDsKbTyJhIwdHIRpsU/V/c64/1D0HHImxt3g4xrqC8Ncug== X-MS-Exchange-Transport-CrossTenantHeadersStamped: PR3PR07MB6988 To: unlisted-recipients:; (no To-header on input) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-ZohoMail-DKIM: pass (identity @televic.com) Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" On imx6ul, the ENET RMII and PTP clock can come from either internal ANATOP/CCM or external clock source through pad ENET1_TX_CLK. But in case of the external clock source, bit IOMUXC_GPR1[21] needs to be cleared. The patch adds the support for systems that use an external clock source and distinguishes above two cases by checking if the PTP clock specified in device tree is the one coming from the internal ANATOP/CCM. Signed-off-by: Pieter Cardoen --- arch/arm/mach-imx/mach-imx6ul.c | 44 +++++++++++++++++++++++++++++++++++++= +--- 1 file changed, 41 insertions(+), 3 deletions(-) diff --git a/arch/arm/mach-imx/mach-imx6ul.c b/arch/arm/mach-imx/mach-imx6u= l.c index 35e8120..70d82cf 100644 --- a/arch/arm/mach-imx/mach-imx6ul.c +++ b/arch/arm/mach-imx/mach-imx6ul.c @@ -2,6 +2,7 @@ /* * Copyright (C) 2015 Freescale Semiconductor, Inc. */ +#include #include #include #include @@ -18,14 +19,51 @@ =20 static void __init imx6ul_enet_clk_init(void) { + struct device_node *np; + struct clk *ptp_clk; + struct clk *enet_ref; struct regmap *gpr; + u32 clksel; =20 + np =3D of_find_compatible_node(NULL, NULL, "fsl,imx6ul-fec"); + if (!np) { + pr_warn("%s: failed to find fec node\n", __func__); + return; + } + + ptp_clk =3D of_clk_get(np, 2); + if (IS_ERR(ptp_clk)) { + pr_warn("%s: failed to get ptp clock\n", __func__); + goto put_node; + } + + enet_ref =3D clk_get_sys(NULL, "enet_ref"); + if (IS_ERR(enet_ref)) { + pr_warn("%s: failed to get enet clock\n", __func__); + goto put_ptp_clk; + } + + /* + * If enet_ref from ANATOP/CCM is the PTP clock source, we need to + * set bit IOMUXC_GPR1[21]. Or the PTP clock must be from pad + * (external OSC), and we need to clear the bit. + */ + clksel =3D clk_is_match(ptp_clk, enet_ref) ? + IMX6Q_GPR1_ENET_CLK_SEL_ANATOP : + IMX6Q_GPR1_ENET_CLK_SEL_PAD; gpr =3D syscon_regmap_lookup_by_compatible("fsl,imx6ul-iomuxc-gpr"); if (!IS_ERR(gpr)) - regmap_update_bits(gpr, IOMUXC_GPR1, IMX6UL_GPR1_ENET_CLK_DIR, - IMX6UL_GPR1_ENET_CLK_OUTPUT); + regmap_update_bits(gpr, IOMUXC_GPR1, + IMX6Q_GPR1_ENET_CLK_SEL_MASK, + clksel); else - pr_err("failed to find fsl,imx6ul-iomux-gpr regmap\n"); + pr_err("failed to find fsl,imx6ul-iomuxc-gpr regmap\n"); + + clk_put(enet_ref); +put_ptp_clk: + clk_put(ptp_clk); +put_node: + of_node_put(np); } =20 static inline void imx6ul_enet_init(void) --=20 2.7.4