> -----Original Message----- > From: Intel-wired-lan [mailto:[email protected]] On > Behalf Of Kevin Laatz > Sent: Monday, July 15, 2019 8:07 PM > To: [email protected]; [email protected]; [email protected]; Topel, > Bjorn <[email protected]>; Karlsson, Magnus > <[email protected]>; [email protected]; > [email protected] > Cc: Richardson, Bruce <[email protected]>; Loftus, Ciara > <[email protected]>; [email protected]; > [email protected]; Laatz, Kevin <[email protected]> > Subject: [Intel-wired-lan] [PATCH v2 03/10] xsk: add support to allow > unaligned chunk placement > > Currently, addresses are chunk size aligned. This means, we are very > restricted in terms of where we can place chunk within the umem. For > example, if we have a chunk size of 2k, then our chunks can only be placed at > 0,2k,4k,6k,8k... and so on (ie. every 2k starting from 0). > > This patch introduces the ability to use unaligned chunks. With these > changes, we are no longer bound to having to place chunks at a 2k (or > whatever your chunk size is) interval. Since we are no longer dealing with > aligned chunks, they can now cross page boundaries. Checks for page > contiguity have been added in order to keep track of which pages are > followed by a physically contiguous page. > > Signed-off-by: Kevin Laatz <[email protected]> > Signed-off-by: Ciara Loftus <[email protected]> > Signed-off-by: Bruce Richardson <[email protected]> > > --- > v2: > - Add checks for the flags coming from userspace > - Fix how we get chunk_size in xsk_diag.c > - Add defines for masking the new descriptor format > - Modified the rx functions to use new descriptor format > - Modified the tx functions to use new descriptor format > --- > include/net/xdp_sock.h | 2 + > include/uapi/linux/if_xdp.h | 9 ++++ > net/xdp/xdp_umem.c | 17 ++++--- > net/xdp/xsk.c | 89 ++++++++++++++++++++++++++++++------- > net/xdp/xsk_diag.c | 2 +- > net/xdp/xsk_queue.h | 70 +++++++++++++++++++++++++---- > 6 files changed, 159 insertions(+), 30 deletions(-)
Tested-by: Andrew Bowers <[email protected]>
