Received: by 2002:a05:7412:b795:b0:e2:908c:2ebd with SMTP id iv21csp470736rdb; Thu, 2 Nov 2023 08:46:29 -0700 (PDT) X-Google-Smtp-Source: AGHT+IGQpSBnqMt/KwATIMIKKDP+Pqf9lHQ/fAJZtktdmCaW7eqtwMW79CjysxKY78xSUiuID+Qi X-Received: by 2002:a17:902:f305:b0:1c4:44a0:5c03 with SMTP id c5-20020a170902f30500b001c444a05c03mr14090385ple.9.1698939989167; Thu, 02 Nov 2023 08:46:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1698939989; cv=none; d=google.com; s=arc-20160816; b=nHGlkkw7bF3G3PtRs75VpXTwK8Tc0VKB/rx4BNGEMZ7y2RZCFapjBbbMFk/ULUlqxa 6X/5rB9HRiVoRn0WJzwVywFNDmt8OsSXM++FhSzM0w4Qjb96IgqxeKaLzAQlv0ZBYBs3 7nskWvsiR1HCd0eg0PmQNyeIXt+PGGLEnSAMEYKqDkKKvXd8K8Pgo6dXagSQinLMV1rY ZoYc7TtaEYLxaVBUPJU0tkpaJUorZ6e+aJlF8skDvuFQdibNx91zb3mSWZa2wflnP5Ck 6enofFq2CfIoMRRxiWo7uSGR1gsrRUXpx2aHlPVEhvpkC32D21FKMJ4CyC1dhuCWiZ3l e0pw== 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 :message-id:date:subject:cc:to:from; bh=4HbYwZeCF0DF1kdrZf/KDfIzFv3XURfMXEeVDIoqGwg=; fh=J4St9tMjBInT3r1VVHSF1O7f2qS3KxSaZBHCVggmRHk=; b=Bsq7ax1bwYDG/m81dYHp+M1TNT2NQ80PjpM8ENAS2Y9Yr5DeqQ+ma2vIe912i74zim 98o9EhOIBPTMA2oDnwv7708dJIjZuF/nsuAI0Xwhl7xFJeSuJDrd0BN3glNydHbzIvV8 DlhxoDdDyKcyT87TT3eGrJM2iGuDQFH4dZBq2htUyxmceViOMYJ4BwQXCO0vgzgpXg1G FZXS6ZMtsvQ4ww5pGH/YFeYSdMAs3YMVGiyxnk2Qu1JSt5dKw1qcCoyh4ud9W+AQuWGt LcMac+DDHP5QdhFxFYVcptkkmGmRMTkqotMuNdVWlaAieIRvuu48b7rICdckuH8jgXu+ K3ww== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:7 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from snail.vger.email (snail.vger.email. [2620:137:e000::3:7]) by mx.google.com with ESMTPS id s12-20020a170903200c00b001c3b5a1336esi60821pla.329.2023.11.02.08.46.28 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 02 Nov 2023 08:46:29 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:7 as permitted sender) client-ip=2620:137:e000::3:7; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:7 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by snail.vger.email (Postfix) with ESMTP id B5DAF80D31E0; Thu, 2 Nov 2023 08:46:03 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at snail.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1376872AbjKBPpw (ORCPT + 99 others); Thu, 2 Nov 2023 11:45:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48418 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1376857AbjKBPpr (ORCPT ); Thu, 2 Nov 2023 11:45:47 -0400 Received: from rtits2.realtek.com.tw (rtits2.realtek.com [211.75.126.72]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7907E186; Thu, 2 Nov 2023 08:45:42 -0700 (PDT) X-SpamFilter-By: ArmorX SpamTrap 5.78 with qID 3A2FjCdL53125129, This message is accepted by code: ctloc85258 Received: from mail.realtek.com (rtexh36505.realtek.com.tw[172.21.6.25]) by rtits2.realtek.com.tw (8.15.2/2.95/5.92) with ESMTPS id 3A2FjCdL53125129 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 2 Nov 2023 23:45:12 +0800 Received: from RTEXMBS04.realtek.com.tw (172.21.6.97) by RTEXH36505.realtek.com.tw (172.21.6.25) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.32; Thu, 2 Nov 2023 23:45:13 +0800 Received: from RTDOMAIN (172.21.210.160) by RTEXMBS04.realtek.com.tw (172.21.6.97) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.7; Thu, 2 Nov 2023 23:45:12 +0800 From: Justin Lai To: CC: , , , , , , , , Justin Lai Subject: [PATCH net-next v10 00/13] Add Realtek automotive PCIe driver Date: Thu, 2 Nov 2023 23:44:52 +0800 Message-ID: <20231102154505.940783-1-justinlai0215@realtek.com> X-Mailer: git-send-email 2.34.1 MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [172.21.210.160] X-ClientProxiedBy: RTEXH36505.realtek.com.tw (172.21.6.25) To RTEXMBS04.realtek.com.tw (172.21.6.97) X-KSE-ServerInfo: RTEXMBS04.realtek.com.tw, 9 X-KSE-AntiSpam-Interceptor-Info: license violation X-KSE-Antivirus-Attachment-Filter-Interceptor-Info: license violation X-KSE-ServerInfo: RTEXH36505.realtek.com.tw, 9 X-KSE-AntiSpam-Interceptor-Info: fallback X-KSE-Antivirus-Interceptor-Info: fallback X-KSE-AntiSpam-Interceptor-Info: fallback X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham 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 X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (snail.vger.email [0.0.0.0]); Thu, 02 Nov 2023 08:46:03 -0700 (PDT) This series includes adding realtek automotive ethernet driver and adding rtase ethernet driver entry in MAINTAINERS file. This ethernet device driver for the PCIe interface of Realtek Automotive Ethernet Switch,applicable to RTL9054, RTL9068, RTL9072, RTL9075, RTL9068, RTL9071. v1 -> v2: - Remove redundent debug message. - Modify coding rule. - Remove other function codes not related to netdev. v2 -> v3: - Remove SR-IOV function - We will add the SR-IOV function together when uploading the vf driver in the future. - Remove other unnecessary code and macro. v3 -> v4: - Remove function prototype - Our driver does not use recursion, so we have reordered the code and removed the function prototypes. - Define macro precisely - Improve macro code readability to make the source code cleaner. v4 -> v5: - Modify ethtool function - Remove some unnecessary code. - Don't use inline function - Let the compiler decide. v5 -> v6: - Some old macro definitions have been removed and replaced with the lastest usage. - Replace s32 with int to ensure consistency. - Clearly point out the objects of the service and remove unnecessary struct. v6 -> v7: - Split this driver into multiple patches. - Reorganize this driver code and remove redundant code to make this driver more concise. v7 -> v8: - Add the function to calculate time mitigation and the function to calculate packet number mitigation. Users can use these two functions to calculate the reg value that needs to be set for the mitigation value they want to set. - This device is usually used in automotive embedded systems. The page pool api will use more memory in receiving packets and requires more verification, so we currently do not plan to use it in this patch. v8 -> v9: - Declare functions that are not extern as static functions and increase the size of the character array named name in the rtase_int_vector struct to correct the build warning noticed by the kernel test robot. v9 -> v10: - Currently we change to use the page pool api. However, when we allocate more than one page to an rx buffer, it will cause system errors in some cases. Therefore, we set the rx buffer to fixed size with 3776 (PAGE_SIZE - SKB_DATA_ALIGN(sizeof(skb_shared_info) )), and the maximum value of mtu is set to 3754(rx buffer size - VLAN_ETH_HLEN - ETH_FCS_LEN). - When ndo_tx_timeout is called, it will dump some device information, which can be used for debugging. - When the mtu is greater than 1500, the device supports checksums but not TSO. - Fix compiler warnning. Justin Lai (13): net:ethernet:realtek:rtase: Add pci table supported in this module net:ethernet:realtek:rtase: Implement the .ndo_open function net:ethernet:realtek:rtase: Implement the rtase_down function net:ethernet:realtek:rtase: Implement the interrupt routine and rtase_poll net:ethernet:realtek:rtase: Implement hardware configuration function net:ethernet:realtek:rtase: Implement .ndo_start_xmit function net:ethernet:realtek:rtase: Implement a function to receive packets net:ethernet:realtek:rtase: Implement net_device_ops net:ethernet:realtek:rtase: Implement pci_driver suspend and resume function net:ethernet:realtek:rtase: Implement ethtool function net:ethernet:realtek:rtase: Add a Makefile in the rtase folder net:ethernet:realtek: Update the Makefile and Kconfig in the realtek folder MAINTAINERS: Add the rtase ethernet driver entry MAINTAINERS | 7 + drivers/net/ethernet/realtek/Kconfig | 17 + drivers/net/ethernet/realtek/Makefile | 1 + drivers/net/ethernet/realtek/rtase/Makefile | 10 + drivers/net/ethernet/realtek/rtase/rtase.h | 353 +++ .../net/ethernet/realtek/rtase/rtase_main.c | 2541 +++++++++++++++++ 6 files changed, 2929 insertions(+) create mode 100644 drivers/net/ethernet/realtek/rtase/Makefile create mode 100644 drivers/net/ethernet/realtek/rtase/rtase.h create mode 100644 drivers/net/ethernet/realtek/rtase/rtase_main.c -- 2.34.1