Received: by 2002:ab2:6991:0:b0:1f7:f6c3:9cb1 with SMTP id v17csp468629lqo; Wed, 8 May 2024 05:40:45 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCVSfsf9mDuPNGpDl/G8vw2tmLJHn7KnWAt065A6KOZ7AWtoNFy01iWzUsS0KWVJV37D+WfZ+eZ5xk0kOdLHjYDVpNiuLYbwKlJ8wb94Ag== X-Google-Smtp-Source: AGHT+IEDirxDrXjW+Yfyzn2lDEXuQSEs4J4civ2Q1WOkh5IzonQl8FOd6A7DPc6w0yLTrMUVirDp X-Received: by 2002:ac8:7e92:0:b0:43a:3502:8446 with SMTP id d75a77b69052e-43d8f7c6408mr86467111cf.28.1715172044878; Wed, 08 May 2024 05:40:44 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1715172044; cv=pass; d=google.com; s=arc-20160816; b=JmmPdWFKnckORTwSEnWzPCPPiFjR17zZJDOyk/IQD9gWnRHxLxMclywkVxPHo+y30q uYKRV87AkG+l+jeXXFTHEoAK8DJTDvX1I1rsGDoDfugdnLx1jS1Jf+1/0hD7m4jIbHFf EzDydS2RHfr6iZ0bt1g9muv2WiqO2BUXrZ7uoOaqheLSb7I4h0SBP3sF5mdptqtbLWa2 XyvSpYYYfQGEbuHch257n79nvEmAoRDHUFECJZEARYJN7hdF3XwO+GlQhBDsCrGb284/ kq2cbhdv8nOpl599yX+On3ez+kwLVnopz+5OH3dbDd0tJKfqDmAxuFq0yoskYEwfbmpO 0UlA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:message-id:date:subject:cc:to :from; bh=aQsdawHgqz4AQpWCJCTvOe0C8FB1iJjZLH4xzOn+i3c=; fh=dvR/tTWg2OfrU+TdVNug7ZowrURi76OJYRbHXzqKj5w=; b=TFWa9CxxlF+j1uw2ke+SZH9SDysJf9EdI5ZeZT0W3VjIMiphur5JIrTDFj6WkDtPEF j2XMh863eJkQyGpHI6riKVEoKHBRmxjoncalGyjNCZZLKzUAsjBsmseRkFyA4e7BjTLM 8SCUx+7V8bCOj6jEbJQ9vwi68Sd3W4p0sFtLVL1oS17dGPWmpzodzKKCbGoJyQTDbow4 Ro9D/9UBbjPfqTEL/q/tJFDULfHysFw4+91QDBlI08vOAL9415GHQqY1nmwzW+SbxKCh Nzzu3KfAD01P4G3iC5APZFHJ5Q8qrpQAbl66lMUmtc6Mbkodn0wc1phykRXTJxd3VpiU UNxQ==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; arc=pass (i=1 spf=pass spfdomain=realtek.com); spf=pass (google.com: domain of linux-kernel+bounces-173230-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-173230-linux.lists.archive=gmail.com@vger.kernel.org" Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [147.75.199.223]) by mx.google.com with ESMTPS id c2-20020ac87d82000000b004313889961dsi13746257qtd.557.2024.05.08.05.40.44 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 08 May 2024 05:40:44 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-173230-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) client-ip=147.75.199.223; Authentication-Results: mx.google.com; arc=pass (i=1 spf=pass spfdomain=realtek.com); spf=pass (google.com: domain of linux-kernel+bounces-173230-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-173230-linux.lists.archive=gmail.com@vger.kernel.org" Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id 89F491C21D00 for ; Wed, 8 May 2024 12:40:44 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 8F0CB54BED; Wed, 8 May 2024 12:40:35 +0000 (UTC) Received: from rtits2.realtek.com.tw (rtits2.realtek.com [211.75.126.72]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 21D6B43ACA; Wed, 8 May 2024 12:40:31 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=211.75.126.72 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1715172035; cv=none; b=ZH1syLLpRY5JVDhpz5vN5jR1oyfgMAkYSADXgzDg9EAJ+hLrpn0xRebNaUmHplrYB6lEzVFU0OO0B2lSGZBeVU5TXAWpT6jlltFoofsi8O25BOKI9kZdZKazSqm0dOQgqt0eg1qlX2swZ6cjAEJyniIfrQgxPiNYGOMVl3yNRJE= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1715172035; c=relaxed/simple; bh=4xlPiApvLSWf+1n3R2aI2Emt3M+fAvUv2Q2gwKr0vtY=; h=From:To:CC:Subject:Date:Message-ID:MIME-Version:Content-Type; b=IHi/93HXZHJ5TotTW8Tql4kEbbU/GCRhDjtRcz6R9UPo82r11+sXpFT8U5U7wQcyqbx3N1hXz8IUluVh1y5WhXpO7FxiXwpZY2vMM8DpsbiFbuoe8/M+y5H76b//cKAia9Fi7e+gurdyzGjcsPfFSERX48fL8Yp9jXs4cOGxx1E= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=realtek.com; spf=pass smtp.mailfrom=realtek.com; arc=none smtp.client-ip=211.75.126.72 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=realtek.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=realtek.com X-SpamFilter-By: ArmorX SpamTrap 5.78 with qID 448CdwGsB464588, This message is accepted by code: ctloc85258 Received: from mail.realtek.com (rtexh36506.realtek.com.tw[172.21.6.27]) by rtits2.realtek.com.tw (8.15.2/2.95/5.92) with ESMTPS id 448CdwGsB464588 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Wed, 8 May 2024 20:39:58 +0800 Received: from RTEXMBS04.realtek.com.tw (172.21.6.97) by RTEXH36506.realtek.com.tw (172.21.6.27) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.1.2507.35; Wed, 8 May 2024 20:39:58 +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_256_GCM_SHA384) id 15.1.2507.35; Wed, 8 May 2024 20:39:57 +0800 From: Justin Lai To: CC: , , , , , , , , , , Justin Lai Subject: [PATCH net-next v18 00/13] Add Realtek automotive PCIe driver Date: Wed, 8 May 2024 20:39:32 +0800 Message-ID: <20240508123945.201524-1-justinlai0215@realtek.com> X-Mailer: git-send-email 2.34.1 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-ClientProxiedBy: RTEXH36505.realtek.com.tw (172.21.6.25) To RTEXMBS04.realtek.com.tw (172.21.6.97) 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. v10 -> v11: - Added error handling of rtase_init_ring(). - Modify the error related to asymmetric pause in rtase_get_settings. - Fix compiler error. v11 -> v12: - Use pm_sleep_ptr and related macros. - Remove multicast filter limit. - Remove VLAN support and CBS offload functions. - Remove redundent code. - Fix compiler warnning. v12 -> v13: - Fixed the compiler warning of unuse rtase_suspend() and rtase_resume() when there is no define CONFIG_PM_SLEEP. v13 -> v14: - Remove unuse include. - call eth_hw_addr_random() to generate random MAC and set device flag - use pci_enable_msix_exact() instead of pci_enable_msix_range() - If dev->dma_mask is non-NULL, dma_set_mask_and_coherent with a 64-bit mask will never fail, so remove the part that determines the 32-bit mask. - set dev->pcpu_stat_type before register_netdev() and core will allocate stats - call NAPI instance at the right location v14 -> v15: - In rtase_open, when the request interrupt fails, all request interrupts are freed. - When calling netif_device_detach, there is no need to call netif_stop_queue. - Call netif_tx_disable() instead of stop_queue(), it takes the tx lock so there is no need to worry about the packets being transmitted. - In rtase_tx_handler, napi budget is no longer used, but a customized tx budget is used. - Use the start / stop macros from include/net/netdev_queues.h. - Remove redundent code. v15 -> v16: - Re-upload v15 patch set v16 -> v17: - Prefix the names of some rtase-specific macros, structs, and enums. - Fix the abnormal problem when returning page_pool resources. v17 -> v18: - Limit the width of each line to 80 colums. - Use reverse xmas tree order. - Modify the error handling of rtase_alloc_msix and rtase_alloc_interrupt. Justin Lai (13): rtase: Add pci table supported in this module rtase: Implement the .ndo_open function rtase: Implement the rtase_down function rtase: Implement the interrupt routine and rtase_poll rtase: Implement hardware configuration function rtase: Implement .ndo_start_xmit function rtase: Implement a function to receive packets rtase: Implement net_device_ops rtase: Implement pci_driver suspend and resume function rtase: Implement ethtool function rtase: Add a Makefile in the rtase folder realtek: Update the Makefile and Kconfig in the realtek folder MAINTAINERS: Add the rtase ethernet driver entry MAINTAINERS | 7 + drivers/net/ethernet/realtek/Kconfig | 19 + drivers/net/ethernet/realtek/Makefile | 1 + drivers/net/ethernet/realtek/rtase/Makefile | 10 + drivers/net/ethernet/realtek/rtase/rtase.h | 326 +++ .../net/ethernet/realtek/rtase/rtase_main.c | 2363 +++++++++++++++++ 6 files changed, 2726 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