From patchwork Thu Mar 11 20:11:16 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Robert Hancock X-Patchwork-Id: 398995 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-18.7 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER, INCLUDES_PATCH, MAILING_LIST_MULTI, MSGID_FROM_MTA_HEADER, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 9E9F9C433DB for ; Thu, 11 Mar 2021 20:12:33 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 5975964F91 for ; Thu, 11 Mar 2021 20:12:33 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229674AbhCKUMB (ORCPT ); Thu, 11 Mar 2021 15:12:01 -0500 Received: from mx0d-0054df01.pphosted.com ([67.231.150.19]:35430 "EHLO mx0d-0054df01.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229868AbhCKULx (ORCPT ); Thu, 11 Mar 2021 15:11:53 -0500 Received: from pps.filterd (m0209000.ppops.net [127.0.0.1]) by mx0c-0054df01.pphosted.com (8.16.0.43/8.16.0.43) with SMTP id 12BK2cx4031497; Thu, 11 Mar 2021 15:11:48 -0500 Received: from can01-qb1-obe.outbound.protection.outlook.com (mail-qb1can01lp2055.outbound.protection.outlook.com [104.47.60.55]) by mx0c-0054df01.pphosted.com with ESMTP id 375yymh7q7-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Thu, 11 Mar 2021 15:11:48 -0500 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=dh6CnM/3khZImAvS5daBy3hn5hiYCXV+zxzr5Ow2FyQxMyUhWsGcYR3UKkeAaRKx283IaQHTWfWPk6JPBqqYfszU26LkyzMu4vH0F3eHgXYj6BNoAeVG+nxuJC1VXzPeZKsYyj2WzZXhTMJWTO6vi2pdxktr8KxsMzgLQENJVYpBQtJsoxmiAu0L6v9bJp6Gz61mUSsu/TmQlH8NTA4npYlPT8t/nGXWRnJbfFj/8oHHB8VUEhiFQYzdZmziiMLbQjIryBQtu5XgxyKRx9iFC8tHMXyTurcVJxiSBEfCh1a/dHbYAJqVIT0TY1ZqayfLuA8t2JvvbvQeMNCiVr9AKA== 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=AzSrWy5AmBK0M57+siTXW/i56xWb17Xa7Z2fS8p3iig=; b=XUaKoM8a3IziqbC90RnYLFQK/spuiHb/po9RIVD1lHk3A7vrT8+mwLAQSSZ25CAJ3aO6c7NKHhp8N8nH+kUjovGcmDDvNa09RSvwAZMKqexlgV8x84QchWTL5eYTGvdWDsQp83UIAvRxHTSYsoNJyLhkKmxf5BUJpqv1AxCbeCUTCA5ZnlgaY6f/xxOS5AuculzDpbX82h9mWdOmRMp+KYm014329QaDMUxLobeBFdegN0ANBue0IvUz9ZgIhZyRM1vlmKHn5QBiIr+Zb7EMlkFa6xQVLArFGCPIGGSoMULdVt1pkgtCfc6OJNI47PUbUVlkkIicHJf8mMCgGRtRRw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=calian.com; dmarc=pass action=none header.from=calian.com; dkim=pass header.d=calian.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=calian.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=AzSrWy5AmBK0M57+siTXW/i56xWb17Xa7Z2fS8p3iig=; b=z25F2z/24jA1ru+AxruTLFBI6utbt2mc0Lzp+x/24qpLuPl/y1i8w7sGXl+qAErf22p3btbSYsu67C2wO7S5Ce53F0L+sCugMT6dNIwKbwJZehY2du/i4OYjX6X6EVH7IbZp39f6ExZFwZ/XNRcVeymaP8e5PZ0tbtmM6fBJ4j8= Authentication-Results: xilinx.com; dkim=none (message not signed) header.d=none; xilinx.com; dmarc=none action=none header.from=calian.com; Received: from YT1PR01MB3546.CANPRD01.PROD.OUTLOOK.COM (2603:10b6:b01:f::20) by YTBPR01MB3983.CANPRD01.PROD.OUTLOOK.COM (2603:10b6:b01:1d::24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3890.26; Thu, 11 Mar 2021 20:11:46 +0000 Received: from YT1PR01MB3546.CANPRD01.PROD.OUTLOOK.COM ([fe80::90d4:4d5b:b4c2:fdeb]) by YT1PR01MB3546.CANPRD01.PROD.OUTLOOK.COM ([fe80::90d4:4d5b:b4c2:fdeb%7]) with mapi id 15.20.3912.027; Thu, 11 Mar 2021 20:11:46 +0000 From: Robert Hancock To: radhey.shyam.pandey@xilinx.com, davem@davemloft.net, kuba@kernel.org Cc: netdev@vger.kernel.org, devicetree@vger.kernel.org, Robert Hancock Subject: [PATCH net-next 1/2] dt-bindings: net: xilinx_axienet: Document additional clocks Date: Thu, 11 Mar 2021 14:11:16 -0600 Message-Id: <20210311201117.3802311-2-robert.hancock@calian.com> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20210311201117.3802311-1-robert.hancock@calian.com> References: <20210311201117.3802311-1-robert.hancock@calian.com> X-Originating-IP: [204.83.154.189] X-ClientProxiedBy: CO2PR04CA0101.namprd04.prod.outlook.com (2603:10b6:104:6::27) To YT1PR01MB3546.CANPRD01.PROD.OUTLOOK.COM (2603:10b6:b01:f::20) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from localhost.localdomain (204.83.154.189) by CO2PR04CA0101.namprd04.prod.outlook.com (2603:10b6:104:6::27) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3912.17 via Frontend Transport; Thu, 11 Mar 2021 20:11:45 +0000 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 1ce61e29-b8b1-491e-b3ad-08d8e4c9e549 X-MS-TrafficTypeDiagnostic: YTBPR01MB3983: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:3513; X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: C3Tnx2bPl0pzLh1lVo1C4mqoBOLTN4WRCk75+yuXUppFUMnLjeZ6H0vINW4GGFrXMAUvTsDREWpvwwl7F01tnuoBEjdDVb2EzyyU5TYGJaRktDBI+kEusZtvtbR8dbICBOnEW2cbJseZw44TZgKCDFpSZ6BqwaN3bbYu6+gnhgFlgrmTBfFu409N5yaVJ4qYSWh7zbml4gwIvyQygCde8+KU2w/UFPa6/z3adRni9DM02plT2kp8KuScvRcE88xo3g2XwIgB2/Ukn6kuXJVkUeiRc0gmPQsRhLUVxhgiUZ8wL4BR3bJU1M2GBG8+NloXODTlVjxSxuFy5J9Ikpk8chEzVKtPu3Rep8AAGAxCF5REVTp9vxkCpiCpXsVYbNJ/wPjdxuvcRGnqHzV9QZSdEHNfIbuZ/YLUl2P7EhVie2h6hww2aBb9IKpz9ZHIM2l8iaUpYfwTrkDwHMchNmBqlFTuYktjIH+xwAVK8WtlVPNdQr5zqy3+5LgEEAoDdrXKhOHHIwVo53wtGtzTS6QSseEgZtvlOIhfL/NW1XT2iPS1LSitWxd7o8L/v7zbmQpUjT4YLptLo0TMajEDUA5KCw== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:YT1PR01MB3546.CANPRD01.PROD.OUTLOOK.COM; PTR:; CAT:NONE; SFS:(4636009)(39850400004)(136003)(366004)(396003)(346002)(376002)(69590400012)(2906002)(66476007)(52116002)(316002)(66556008)(44832011)(4326008)(6486002)(5660300002)(86362001)(66946007)(16526019)(6666004)(2616005)(6506007)(1076003)(83380400001)(186003)(26005)(6512007)(8676002)(107886003)(8936002)(36756003)(956004)(478600001); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData: dE4X1VJ2sUpBEGzXAaZks1k2gln8z7758CQNaN2+GXX3MTJ0tYUIgGxc8wb5WOtKI+TmqW6nVRrVwZQi9AClMCiXCkd1dNkd0xOBzZYm69VT/J+134vINFl8wsK51lkTHeFn+81xARF8jo8sHt8udXZioMhcSn/9USMt7vlrOxruUY51i1LqRTPiB7GNTJAXCSRsB5OBfYeVv8owj+I0/VvxXl6JRl4/dHkph/uNxoWHKlUd1ULQNJU9/j2LEm/jtRO3MP6Fm306yogSu06lMLfwnxppV5Vsd1Dpicce3W1JP3x79SgiOKV9XZ9z1/qYaFv5zu5FRsQ4jxPwiEcay2Sx7Me9lmKZplzAv6CS4JNZDIMLyAe+Hbgm5bwG7/rnRebW/s9Eel/ePYE6hYL80vexYJs3WYxWrM/WcKCpKdEzDCxHPlxQ0yedxkTPhBiOOHAuPYvpfiIqQKUW1Cf7DxYTaLkhsqS6or4iWp4COwmxlX2J/wjtkAF2M/4z4Jr0sd82q4NtH+O4Qk0RXROGrelqOwuAT9+oXSPBKZv8L2OLi9CmnELQG1Zmm85cyYBUnMebjMUN7DUVjGKVrgl0ZSUV6RLcEJxjlzEy7BpdR06+yKfp0SmTQC/WozbsvQptKMd2BviUeXeOoCPfr9ccFbGuimQClaamWtM4YuUlcSOfOiD0muHUEgbpy+JKU0q2u/oUxJXEGq/zvr+lTdUYDCun6uu24is7SFYGXBWtYzV8q5OLZUGwSKaTOqNHHTtrZeOYCPmX47nXPDdHozWyAL5CDYBN1Qcnta5/kFswvFq7XDGwQyx0Qe5FU2flrCz64uAllsjP8OLVqTQM3UgacVXX3HtUHJmI23/OUMWZc8c+bxZTl4e9voit2+LgIuPBZIX1VVKITkCrwTvqPGyARx/MqNQNsWu1g/f3akvQYmOhTAAyOt5fVmF7g9Goi8ftC6ufgGccTv+kNyvjbsZgqnRJTWqfxFI10250n9dKWZFejhAy+yu/Nv+z83ttNFv9YT+W8Ta7bFkcEerQIDxmci7w4aie+KvXEPdKrAVPmRWjYX+1w5w3pQDK84T3Hz2YfMG2mlLr3+N0zlZvVCOE/T3O2mdM3ABukGB1+zOWIElHLlmSo2EcLlT6W5D1zS5zv5cBckZksWUcvcsPNT/Cp0fL5rUJ7vVpUpPIKRjAVdI7+arPWp40TevdyurlgN1lTDZWTvP9mpVxuGWyeQeznl5Z4v+BtPs2Ac9a8ZRL9lG2qq/wd6oGRFqVFOoQDGyUrzUEF+r/5p5jBHK7aTn0ERIjXI76rNB2CIpLZX5xCc0AadWz+YXYqW7l0A+PFA/k X-OriginatorOrg: calian.com X-MS-Exchange-CrossTenant-Network-Message-Id: 1ce61e29-b8b1-491e-b3ad-08d8e4c9e549 X-MS-Exchange-CrossTenant-AuthSource: YT1PR01MB3546.CANPRD01.PROD.OUTLOOK.COM X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 11 Mar 2021 20:11:46.1186 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 23b57807-562f-49ad-92c4-3bb0f07a1fdf X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: CgEUE4j6BaiPkqGQlhYzxFW7B3YOLT/EUAmx/j3g1YzWls5qPkuEuY5guY6mmPlqiKZWMYqZ4OpaAyckAYKE96zH9oEYPj9lbNeM2Yr4AJs= X-MS-Exchange-Transport-CrossTenantHeadersStamped: YTBPR01MB3983 X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.369, 18.0.761 definitions=2021-03-11_08:2021-03-10,2021-03-11 signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 mlxscore=0 clxscore=1015 spamscore=0 suspectscore=0 phishscore=0 adultscore=0 lowpriorityscore=0 bulkscore=0 mlxlogscore=999 impostorscore=0 malwarescore=0 priorityscore=1501 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2009150000 definitions=main-2103110103 Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org Update DT bindings to describe all of the clocks that the axienet driver will now be able to make use of. Signed-off-by: Robert Hancock --- .../bindings/net/xilinx_axienet.txt | 23 ++++++++++++++----- 1 file changed, 17 insertions(+), 6 deletions(-) diff --git a/Documentation/devicetree/bindings/net/xilinx_axienet.txt b/Documentation/devicetree/bindings/net/xilinx_axienet.txt index 2cd452419ed0..1ee1c6c5fc66 100644 --- a/Documentation/devicetree/bindings/net/xilinx_axienet.txt +++ b/Documentation/devicetree/bindings/net/xilinx_axienet.txt @@ -42,11 +42,21 @@ Optional properties: support both 1000BaseX and SGMII modes. If set, the phy-mode should be set to match the mode selected on core reset (i.e. by the basex_or_sgmii core input line). -- clocks : AXI bus clock for the device. Refer to common clock bindings. - Used to calculate MDIO clock divisor. If not specified, it is - auto-detected from the CPU clock (but only on platforms where - this is possible). New device trees should specify this - the - auto detection is only for backward compatibility. +- clock-names: Tuple listing input clock names. Possible clocks: + s_axi_lite_clk: Clock for AXI register slave interface + axis_clk: AXI stream clock for DMA block + ref_clk: Ethernet reference clock + mgt_clk: MGT reference clock (used by internal PCS/PMA PHY) + + Note that if s_axi_lite_clk is not specified by name, the + first clock of any name is used for this. If that is also not + specified, the clock rate is auto-detected from the CPU clock + (but only on platforms where this is possible). New device + trees should specify all applicable clocks by name - the + fallbacks to an unnamed clock or to CPU clock are only for + backward compatibility. +- clocks: Phandles to input clocks matching clock-names. Refer to common + clock bindings. - axistream-connected: Reference to another node which contains the resources for the AXI DMA controller used by this device. If this is specified, the DMA-related resources from that @@ -62,7 +72,8 @@ Example: device_type = "network"; interrupt-parent = <µblaze_0_axi_intc>; interrupts = <2 0 1>; - clocks = <&axi_clk>; + clock-names = "s_axi_lite_clk", "axis_clk", "ref_clk", "mgt_clk"; + clocks = <&axi_clk>, <&axi_clk>, <&pl_enet_ref_clk>, <&mgt_clk>; phy-mode = "mii"; reg = <0x40c00000 0x40000 0x50c00000 0x40000>; xlnx,rxcsum = <0x2>; From patchwork Thu Mar 11 20:11:17 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Robert Hancock X-Patchwork-Id: 397742 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-18.7 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER, INCLUDES_PATCH, MAILING_LIST_MULTI, MSGID_FROM_MTA_HEADER, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 7DFBFC433E9 for ; Thu, 11 Mar 2021 20:12:33 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 3C17064D96 for ; Thu, 11 Mar 2021 20:12:33 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229809AbhCKUMC (ORCPT ); Thu, 11 Mar 2021 15:12:02 -0500 Received: from mx0d-0054df01.pphosted.com ([67.231.150.19]:52598 "EHLO mx0d-0054df01.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229900AbhCKULx (ORCPT ); Thu, 11 Mar 2021 15:11:53 -0500 Received: from pps.filterd (m0209000.ppops.net [127.0.0.1]) by mx0c-0054df01.pphosted.com (8.16.0.43/8.16.0.43) with SMTP id 12BK2cx5031497; Thu, 11 Mar 2021 15:11:49 -0500 Received: from can01-qb1-obe.outbound.protection.outlook.com (mail-qb1can01lp2055.outbound.protection.outlook.com [104.47.60.55]) by mx0c-0054df01.pphosted.com with ESMTP id 375yymh7q7-2 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Thu, 11 Mar 2021 15:11:48 -0500 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=A+bvSirp9S7Z2ybXUD0SPkmNE4asybQyf8bOXzfS7umX4BngIUNaJSisQiADG8SZHk43D5QAMt/Rl/962mncAlmM04UdEmZdaPM6mcA28Y5DALf4hcIzy0ZQs9YUGxOUke4uFYRCC+1OS1qkjy2czhnHDsa5K4ktej3KokvsObBXiA01hyY+Ux5ZJiJcOP/iOyHyNMKVQ2PX+BQgDfzoSUdluy3YlO7xpICN2D2l8xDfmOFWUWe7NIZdgojEV1BAbTlFUGCc8fS9zZTow+6yyI+AubVw0XRzvF1I5fKW+tQ8+uccukNBRBAMmBlGq6OjN294n73l5CIJsFIgzQAkWg== 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=7sp59zhl9kfnNJ2vSMXhsu/h1n7PmBzhLNrHkoxPJ3w=; b=XRciqBNMHJnkim5kuPujxzQlTeDO8ERTp3UhBlmulSWbUpUy+p78qkMXzHvI7bd3k+QcMCNrod0jN46hjjws4N2uxhWfNmLpiqwswOPxw20xihqf2/B0rGqmaYrDcqXQY1cFWj6P8EO2tv7fXCB7BnDqFdtAW3iYuNGjZWx0cPfxjvamQkoCarPGpQ3lq/1gFpTcpoTNsfLVQCmIVN+D+7GaN33NMZxhaP2sbQW7sR0ev94LaLN7KdMu/yv0RxDFiY75gV7VhhipDnDEZN1yThIEO3lHh0T4Gn7w5mQaPXdy7a7YLv4miCtEnBNIKHXwM/mHz7kuMQq6+VoEJptNwA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=calian.com; dmarc=pass action=none header.from=calian.com; dkim=pass header.d=calian.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=calian.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=7sp59zhl9kfnNJ2vSMXhsu/h1n7PmBzhLNrHkoxPJ3w=; b=w9t2slZlBnFfcorVwRB171hrFBxPCDll/IgdyXNDFo6bYkIzFh32rRh9UTNQdEpjPigr9VVlqjM8qIHUsOiWpp1I+cCw1dMoFqlQTW7CBSysJJYWqspsY5voDQ1zKjASw5QwuDnYIG2PYDts2j8wGbGU4KyvEfYkBS/tCftulF8= Authentication-Results: xilinx.com; dkim=none (message not signed) header.d=none; xilinx.com; dmarc=none action=none header.from=calian.com; Received: from YT1PR01MB3546.CANPRD01.PROD.OUTLOOK.COM (2603:10b6:b01:f::20) by YTBPR01MB3983.CANPRD01.PROD.OUTLOOK.COM (2603:10b6:b01:1d::24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3890.26; Thu, 11 Mar 2021 20:11:47 +0000 Received: from YT1PR01MB3546.CANPRD01.PROD.OUTLOOK.COM ([fe80::90d4:4d5b:b4c2:fdeb]) by YT1PR01MB3546.CANPRD01.PROD.OUTLOOK.COM ([fe80::90d4:4d5b:b4c2:fdeb%7]) with mapi id 15.20.3912.027; Thu, 11 Mar 2021 20:11:47 +0000 From: Robert Hancock To: radhey.shyam.pandey@xilinx.com, davem@davemloft.net, kuba@kernel.org Cc: netdev@vger.kernel.org, devicetree@vger.kernel.org, Robert Hancock Subject: [PATCH net-next 2/2] net: axienet: Enable more clocks Date: Thu, 11 Mar 2021 14:11:17 -0600 Message-Id: <20210311201117.3802311-3-robert.hancock@calian.com> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20210311201117.3802311-1-robert.hancock@calian.com> References: <20210311201117.3802311-1-robert.hancock@calian.com> X-Originating-IP: [204.83.154.189] X-ClientProxiedBy: CO2PR04CA0101.namprd04.prod.outlook.com (2603:10b6:104:6::27) To YT1PR01MB3546.CANPRD01.PROD.OUTLOOK.COM (2603:10b6:b01:f::20) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from localhost.localdomain (204.83.154.189) by CO2PR04CA0101.namprd04.prod.outlook.com (2603:10b6:104:6::27) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3912.17 via Frontend Transport; Thu, 11 Mar 2021 20:11:46 +0000 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 059b7fe0-65a0-467e-450a-08d8e4c9e620 X-MS-TrafficTypeDiagnostic: YTBPR01MB3983: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:8882; X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 3HobgBrk0S3uTpM4TOM5CW/Bc52tZHFarHRiGpLyT/4l/t8RTJZDjb3extIu6Q/AWBZi8LgRC7q8zEey/h9pnnhqhNS2Yk3jjj+i/NfsJfYJiBhnMw42q2wzcKgRCRYdKoS5ny49WxgpQ8qcRh86Fxc6i5Y5ZbcRO8a2OrLPDnZ12F/pGT1uxLXERiTDIaUJhQ3jbJt5sJaKffwSyXcEetBYM76fgJtwYqq2QTZG4jPzConrDX2wGO0lywL7vWepMwRfNEnb2yskqmFBVif1KHaUYNJb5gjYj1SJOuUBtm/M1k0IfnIrqBx9+/8RojyTjqjIoiyN5V03YWzgkGxDmpL0jJ7u+KxWXV7JHcm5wo5hJUiRIxH9F5cDQctHyAo9LXEZErRbKRxvPID7baKAk5ApP0+6bL/zQbjN9PL5kv/eHpnbIfGPs+9Z4MfVYvBQkOxMcguCJ6XDdPIrGY/WnvFB6ArpXkxQldOzlILyIdb8ebRywnU5XxHrT06CctTWHTA2XOD/PZLJ7rHdNL6Of69WduiqsTQKkapiuxT5a8YQXhQsxCQYm3AeDIpulKX6fMj8PBgjls7hsPhoPVl+BA== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:YT1PR01MB3546.CANPRD01.PROD.OUTLOOK.COM; PTR:; CAT:NONE; SFS:(4636009)(39850400004)(136003)(366004)(396003)(346002)(376002)(69590400012)(2906002)(66476007)(52116002)(316002)(66556008)(44832011)(4326008)(6486002)(5660300002)(86362001)(66946007)(16526019)(6666004)(2616005)(6506007)(1076003)(83380400001)(186003)(26005)(6512007)(8676002)(107886003)(8936002)(36756003)(956004)(478600001); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData: MIPGy0664Gxw/IOxuf+o5pZf62XnMFZi9GsRdaJiZrITKPx7CQo08WjA8aP7tFUwbgcshvPLmGJEgUeOrg4uizOcbYMQKMfCtjh5FJEZc/tex8H1yVDprFxeZjgfm6Y2z/RaXsU2uC1dgOGvwImwmhLcJPA1u9AvPxftWQ/Y/8TWxVdlXZ/VO3gCINb/AhvabVxHcFbmL+eTOiETMO2ZRxf21jKpiWCs3GoJAYuFffUwjv+Vmmm/Asfoo5jCDRCnifsLX+ZS9PfozHWbrxXjnbx06V1GWOuasXUN6fCJTu44Mkglg8ed6IkRqdSWj++4KbfKSlrdHzOm5ccSjkUeXshurKpdMFVx9wlwwN/Uzo47pZBTvC65t7veEeb3kAhW5oj8TIoz3HXa9c8ClBAQdCmEA7hv3BPQaKvWpUurvFnsZq797SFuoJJZRe70vS4fxjS4BQGBOG9A6LADKNQvLTbinWJMe/Niqhx31lsE2RPeZC0S84qocqEGTTxZLyu+Y4d5JZ+ydy5jYs9CMpAcd3HSNQvNa7cVsSndYn6RW2Qd70w3zSXl1cw355GPYA1Ev30hIFr3dBGleUqNtNvqyOWfnmk/WgmFsu7NeEoeeEYvNnokWcwkgzgwAKS5STYWq1l8r/e0n4Tq/wZT3HmxIOt/O/pGwi8/qa4GT20IpZ5gHG5w9ssbU1xek+bkUxQcelatvb3Jdzw5qsgQXOsTzVd1vwD2kagirEoDiovT3LG7LSgagxjpjNYrJTeXL59wsftwwHTcqLBGOudh1gwuua2CpRUIPTzWjZXSGd2OJ1LieQBq4t4+pRVoJq9eyVkvUQWjuH3e4nUiroALalA2JvqsXnh1oFnA0LitD1hEjIGmWe8GJ8yr5VrfAsbbYMPD7CsY1h9uW2G2YXIhL5zqCoeqBrtZKzPIi1Z476B7HLIWcRYIVHuJ4KfSh4/dDpGdO5D27PNSmPsg440sJTN98982CHCDIA9pmXNi8TXFniai39eQrxLonvcytHnC9UkPA9I90YnRe9FPm8XObRwdbN7RDgh9AUANx2PDNJ/zLcSx0YAVhQvNG9HOkS1DiEwcZa7t9vOoUPvXYk3t4Fh/uVTo5FVJmxq4niv8qbBeIUCZmcj0D7/NxieXnMrUs0lNNFqsLUR9eELOwpnhBrPqCFGnwnTFLogpH5rjScHZX++IwKQ6rc5N3fLxfWHZ6pNAL0LalneA36bhjypemDiTMp2hkRsRXfwpHldJNag187b4EISbx8vAC+6fXsNoWvwuP3V4OLGbP5M88t70kUpPgxoentKeIdpFj+CLDnduBzMsECNuAfXU/vsIDqyo7SkS X-OriginatorOrg: calian.com X-MS-Exchange-CrossTenant-Network-Message-Id: 059b7fe0-65a0-467e-450a-08d8e4c9e620 X-MS-Exchange-CrossTenant-AuthSource: YT1PR01MB3546.CANPRD01.PROD.OUTLOOK.COM X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 11 Mar 2021 20:11:47.4868 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 23b57807-562f-49ad-92c4-3bb0f07a1fdf X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: WgXh7hi2hvImrHqwVG5Szup5nm2pvnANRtcqFk/mRR6mpYQVviR/bSogOEMtN22WkRwCXakaDNwF36epsGN0qu+c/rAA/AuQzYzJqekqX9A= X-MS-Exchange-Transport-CrossTenantHeadersStamped: YTBPR01MB3983 X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.369, 18.0.761 definitions=2021-03-11_08:2021-03-10,2021-03-11 signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 mlxscore=0 clxscore=1015 spamscore=0 suspectscore=0 phishscore=0 adultscore=0 lowpriorityscore=0 bulkscore=0 mlxlogscore=999 impostorscore=0 malwarescore=0 priorityscore=1501 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2009150000 definitions=main-2103110103 Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org This driver was only enabling the first clock on the device, regardless of its name. However, this controller logic can have multiple clocks which should all be enabled. Add support for enabling additional clocks. The clock names used are matching those used in the Xilinx version of this driver as well as the Xilinx device tree generator, except for mgt_clk which is not present there. For backward compatibility, if no named clocks are present, the first clock present is used for determining the MDIO bus clock divider. Signed-off-by: Robert Hancock Reviewed-by: Radhey Shyam Pandey --- drivers/net/ethernet/xilinx/xilinx_axienet.h | 8 +++-- .../net/ethernet/xilinx/xilinx_axienet_main.c | 34 +++++++++++++++---- .../net/ethernet/xilinx/xilinx_axienet_mdio.c | 4 +-- 3 files changed, 35 insertions(+), 11 deletions(-) diff --git a/drivers/net/ethernet/xilinx/xilinx_axienet.h b/drivers/net/ethernet/xilinx/xilinx_axienet.h index 1e966a39967e..92f7cefb345e 100644 --- a/drivers/net/ethernet/xilinx/xilinx_axienet.h +++ b/drivers/net/ethernet/xilinx/xilinx_axienet.h @@ -376,6 +376,8 @@ struct axidma_bd { struct sk_buff *skb; } __aligned(XAXIDMA_BD_MINIMUM_ALIGNMENT); +#define XAE_NUM_MISC_CLOCKS 3 + /** * struct axienet_local - axienet private per device data * @ndev: Pointer for net_device to which it will be attached. @@ -385,7 +387,8 @@ struct axidma_bd { * @phylink_config: phylink configuration settings * @pcs_phy: Reference to PCS/PMA PHY if used * @switch_x_sgmii: Whether switchable 1000BaseX/SGMII mode is enabled in the core - * @clk: Clock for AXI bus + * @axi_clk: AXI bus clock + * @misc_clks: Other device clocks * @mii_bus: Pointer to MII bus structure * @mii_clk_div: MII bus clock divider value * @regs_start: Resource start for axienet device addresses @@ -434,7 +437,8 @@ struct axienet_local { bool switch_x_sgmii; - struct clk *clk; + struct clk *axi_clk; + struct clk_bulk_data misc_clks[XAE_NUM_MISC_CLOCKS]; struct mii_bus *mii_bus; u8 mii_clk_div; diff --git a/drivers/net/ethernet/xilinx/xilinx_axienet_main.c b/drivers/net/ethernet/xilinx/xilinx_axienet_main.c index 5d677db0aee5..9635101fbb88 100644 --- a/drivers/net/ethernet/xilinx/xilinx_axienet_main.c +++ b/drivers/net/ethernet/xilinx/xilinx_axienet_main.c @@ -1863,17 +1863,35 @@ static int axienet_probe(struct platform_device *pdev) lp->rx_bd_num = RX_BD_NUM_DEFAULT; lp->tx_bd_num = TX_BD_NUM_DEFAULT; - lp->clk = devm_clk_get_optional(&pdev->dev, NULL); - if (IS_ERR(lp->clk)) { - ret = PTR_ERR(lp->clk); + lp->axi_clk = devm_clk_get_optional(&pdev->dev, "s_axi_lite_clk"); + if (!lp->axi_clk) { + /* For backward compatibility, if named AXI clock is not present, + * treat the first clock specified as the AXI clock. + */ + lp->axi_clk = devm_clk_get_optional(&pdev->dev, NULL); + } + if (IS_ERR(lp->axi_clk)) { + ret = PTR_ERR(lp->axi_clk); goto free_netdev; } - ret = clk_prepare_enable(lp->clk); + ret = clk_prepare_enable(lp->axi_clk); if (ret) { - dev_err(&pdev->dev, "Unable to enable clock: %d\n", ret); + dev_err(&pdev->dev, "Unable to enable AXI clock: %d\n", ret); goto free_netdev; } + lp->misc_clks[0].id = "axis_clk"; + lp->misc_clks[1].id = "ref_clk"; + lp->misc_clks[2].id = "mgt_clk"; + + ret = devm_clk_bulk_get_optional(&pdev->dev, XAE_NUM_MISC_CLOCKS, lp->misc_clks); + if (ret) + goto cleanup_clk; + + ret = clk_bulk_prepare_enable(XAE_NUM_MISC_CLOCKS, lp->misc_clks); + if (ret) + goto cleanup_clk; + /* Map device registers */ ethres = platform_get_resource(pdev, IORESOURCE_MEM, 0); lp->regs = devm_ioremap_resource(&pdev->dev, ethres); @@ -2109,7 +2127,8 @@ static int axienet_probe(struct platform_device *pdev) of_node_put(lp->phy_node); cleanup_clk: - clk_disable_unprepare(lp->clk); + clk_bulk_disable_unprepare(XAE_NUM_MISC_CLOCKS, lp->misc_clks); + clk_disable_unprepare(lp->axi_clk); free_netdev: free_netdev(ndev); @@ -2132,7 +2151,8 @@ static int axienet_remove(struct platform_device *pdev) axienet_mdio_teardown(lp); - clk_disable_unprepare(lp->clk); + clk_bulk_disable_unprepare(XAE_NUM_MISC_CLOCKS, lp->misc_clks); + clk_disable_unprepare(lp->axi_clk); of_node_put(lp->phy_node); lp->phy_node = NULL; diff --git a/drivers/net/ethernet/xilinx/xilinx_axienet_mdio.c b/drivers/net/ethernet/xilinx/xilinx_axienet_mdio.c index 9c014cee34b2..48f544f6c999 100644 --- a/drivers/net/ethernet/xilinx/xilinx_axienet_mdio.c +++ b/drivers/net/ethernet/xilinx/xilinx_axienet_mdio.c @@ -159,8 +159,8 @@ int axienet_mdio_enable(struct axienet_local *lp) lp->mii_clk_div = 0; - if (lp->clk) { - host_clock = clk_get_rate(lp->clk); + if (lp->axi_clk) { + host_clock = clk_get_rate(lp->axi_clk); } else { struct device_node *np1;