Message ID | 20231013040628.354323-1-matt@codeconstruct.com.au |
---|---|
Headers | show |
Series | I3C MCTP net driver | expand |
On Tue, 2023-10-17 at 10:24 +0200, Simon Horman wrote: > On Fri, Oct 13, 2023 at 12:06:25PM +0800, Matt Johnston wrote: > > Provides MCTP network transport over an I3C bus, as specified in > > DMTF DSP0233. > > > > Each I3C bus (with "mctp-controller" devicetree property) gets an > > "mctpi3cX" net device created. I3C devices are reachable as remote > > endpoints through that net device. Link layer addressing uses the > > I3C PID as a fixed hardware address for neighbour table entries. > > > > The driver matches I3C devices that have the MIPI assigned DCR 0xCC for > > MCTP. > > > > Signed-off-by: Matt Johnston <matt@codeconstruct.com.au> > > Hi Matt, > > one minor nit below, which you can take, leave, or leave for later > as far as I am concerned. > > Overall the patch looks good to me and I see that Paolo's review of v5 has > has been addressed. > > Reviewed-by: Simon Horman <horms@kernel.org> > > > +/* List of mctp_i3c_busdev */ > > +static LIST_HEAD(busdevs); > > +/* Protects busdevs, as well as mctp_i3c_bus.devs lists */ > > +static DEFINE_MUTEX(busdevs_lock); > > + > > +struct mctp_i3c_bus { > > + struct net_device *ndev; > > + > > + struct task_struct *tx_thread; > > + wait_queue_head_t tx_wq; > > + /* tx_lock protects tx_skb and devs */ > > + spinlock_t tx_lock; > > + /* Next skb to transmit */ > > + struct sk_buff *tx_skb; > > + /* Scratch buffer for xmit */ > > + u8 tx_scratch[MCTP_I3C_MAXBUF]; > > + > > + /* Element of busdevs */ > > + struct list_head list; > > I am unsure if it is important, but I observe that on x86_64 > list spans a cacheline. It looks like 'list' is only touched on control path, so it's should not critical. Cheers, Paolo
Hello: This series was applied to netdev/net-next.git (main) by Paolo Abeni <pabeni@redhat.com>: On Fri, 13 Oct 2023 12:06:22 +0800 you wrote: > This series adds an I3C transport for the kernel's MCTP network > protocol. MCTP is a communication protocol between system components > (BMCs, drives, NICs etc), with higher level protocols such as NVMe-MI or > PLDM built on top of it (in userspace). It runs over various transports > such as I2C, PCIe, or I3C. > > The mctp-i3c driver follows a similar approach to the kernel's existing > mctp-i2c driver, creating a "mctpi3cX" network interface for each > numbered I3C bus. Busses opt in to support by adding a "mctp-controller" > property to the devicetree: > > [...] Here is the summary with links: - [net-next,v6,1/3] dt-bindings: i3c: Add mctp-controller property https://git.kernel.org/netdev/net-next/c/ee71d6d5f18b - [net-next,v6,2/3] i3c: Add support for bus enumeration & notification https://git.kernel.org/netdev/net-next/c/0ac6486e5cbd - [net-next,v6,3/3] mctp i3c: MCTP I3C driver https://git.kernel.org/netdev/net-next/c/c8755b29b58e You are awesome, thank you!