[PATCH v8 0/2] net: mhi: Add support to enable ethernet interface
From: Vivek Pernamitta <hidden>
Date: 2026-02-12 11:00:34
Also in:
linux-arm-msm, lkml
Add support to configure a new client as Ethernet type over MHI by setting "mhi_device_info.ethernet_if = true". Create a new Ethernet interface named eth%d. This complements existing NET driver support. Enable IP_SW1 (ch:48/49), IP_ETH0 (ch:50,51) and IP_ETH1 (ch:52, 53) channels over MHI for M-plane, NETCONF and S-plane interface for QDU100. M-plane: Implement DU M-Plane software for non-real-time O-RAN management between O-DU and O-RU using NETCONF/YANG and O-RAN WG4 M-Plane YANG models. Provide capability exchange, configuration management, performance monitoring, and fault management per O-RAN.WG4.TS.MP.0-R004-v18.00. YANG model based interface aligned with O-RAN WG4 M-Plane specifications over TCP between the OAM application on the host and the DU M-Plane software running on the X100 platform. Netconf: Use NETCONF protocol for configuration operations such as fetching, modifying, and deleting network device configurations. This interface is used for IETF Netconf communication, enabling a Netconf server on the ORU to interact with a Netconf client running on the host. S-plane: Support frequency and time synchronization between O-DUs and O-RUs using Synchronous Ethernet and IEEE 1588. Assume PTP transport over L2 Ethernet (ITU-T G.8275.1) for full timing support; allow PTP over UDP/IP (ITU-T G.8275.2) with reduced reliability, as per ORAN spec O-RAN.WG4.CUS.0-R003-v12.00. To support accurate phase and time synchronization between the host (L2) and device (L1-High), the system must exchange PTP messages as raw Layer-2 Ethernet frames, because the ITU-T G.8275.1 profile operates strictly over Ethernet multicast and not over IP networks. This means the device’s PTP stack can only send and receive PTP Announce, Sync, Follow-Up, and Delay messages in native Ethernet format, not as IPv4/IPv6 packets. However, the host and device communicate only through MHI/PCIe, which provides no native Ethernet interface. Therefore, the system must implement a virtual Ethernet interface over MHI on both sides. This virtual Layer-2 link enables true Ethernet-frame transport, ensuring the device’s PTP implementation remains fully compliant with the G.8275.1 Ethernet-based timing model. The actual link between the device (QDU100) and the host is PCIe/MHI. The device has the Ethernet interface and is exposed as the MHI channel to the host. So this patch creates the Ethernet interface on the host based on the 'IP_ETH' channel so that the host can use this interface for exchanging the NETCONF packets. The patch primarily addresses host-to-DU(QDU100) communication. However, the NETCONF/M-Plane packets originating from the host will eventually be transmitted from the DU to the RU over the fronthaul, which uses Ethernet. For additional details on this architecture and data flow, refer to the O-RAN Management Plane Specification: O-RAN.WG4.MP.0-v07.00 O-RAN Alliance Working Group 4 – Management Plane Specification Chapter 4: O-RU to O-DU Interface Management MHI_CHANNEL_CONFIG defines channel attributes for the host controller to set up channel rings. These entries are part of the MHI controller’s configuration so that client drivers, such as the MHI network driver, can attach to them. Each interface is mapped to an MHI channel (for example, eth0 → IP_ETH0 channels 50/51), which is why this configuration resides in the bus code. Allocate MHI netdev's using NET_NAME_ENUM to reflect kernel-enumerated naming. This updates the reported name_assign_type for MHI net interfaces created by this driver, aligning naming semantics across existing and new devices. No functional or interface naming changes are introduced. Signed-off-by: Vivek Pernamitta <redacted> --- patchset link for V7 : https://lore.kernel.org/all/20260205-eth_vdev_next-20260204_eth-v7-0-f85645210f81@qti.qualcomm.com/ (local) patchset link for V6 : https://lore.kernel.org/all/20251209-vdev_next-20251208_eth_v6-v6-0-80898204f5d8@quicinc.com/ (local) patchset link for V1 (first post) : https://lore.kernel.org/all/20250724-b4-eth_us-v1-0-4dff04a9a128@quicinc.com/ (local) changes to v8: - Removed skb_copy_to_linear_data call as it is not needed, updated as per Loic Poulain and Paolo Abeni. - Removed ethernet_if member in struct mhi_net_dev instead used !!ndev->header_ops check for ethernet protocol as per paolo Abeni. - Updated more infromation in commit text for change from NET_NAME_PREDICTABLE to NET_NAME_ENUM. changes to v7: - Updated to NET_NAME_ENUM while allocating netdev as per Andrew - Updated more information as per comments from Jakub and Mani changes to v6: - Removed interm variable useage as per comments from Simon and Dmirty. - Squashed gerrits 1 and 2 in single gerrit. - Added more description for M-plane, Netconf and S-plane. changes to v5: - change in email ID from "quic_vpernami@quicinc.com" to "vivek.pernamitta@oss.qualcomm.com" - Renamed to patch v5 as per comments from Manivannan - Restored to original name as per comments from Jakub - Renamed the ethernet interfce to eth%d as per Jakub --- --- Vivek Pernamitta (2): net: mhi: Enable Ethernet interface support bus: mhi: host: pci: Enable IP_SW1, IP_ETH0 and IP_ETH1 channels for QDU100 drivers/bus/mhi/host/pci_generic.c | 8 +++++ drivers/net/mhi_net.c | 67 +++++++++++++++++++++++++++++++------- 2 files changed, 64 insertions(+), 11 deletions(-) --- base-commit: 9152bc8cebcb14dc16b03ec81f2377ee8ce12268 change-id: 20260212-eth_vdev_next-20260211-bc83e286fb52 Best regards, -- Vivek Pernamitta [off-list ref]