Message ID | 20210413031523.73507-5-xuanzhuo@linux.alibaba.com (mailing list archive) |
---|---|
State | Changes Requested |
Delegated to: | Netdev Maintainers |
Headers | show |
Series | virtio-net support xdp socket zero copy xmit | expand |
Context | Check | Description |
---|---|---|
netdev/cover_letter | success | Link |
netdev/fixes_present | success | Link |
netdev/patch_count | success | Link |
netdev/tree_selection | success | Clearly marked for net-next |
netdev/subject_prefix | success | Link |
netdev/cc_maintainers | warning | 5 maintainers not CCed: yhs@fb.com kpsingh@kernel.org andrii@kernel.org kafai@fb.com songliubraving@fb.com |
netdev/source_inline | success | Was 0 now: 0 |
netdev/verify_signedoff | success | Link |
netdev/module_param | success | Was 0 now: 0 |
netdev/build_32bit | success | Errors and warnings before: 2 this patch: 2 |
netdev/kdoc | success | Errors and warnings before: 0 this patch: 0 |
netdev/verify_fixes | success | Link |
netdev/checkpatch | warning | WARNING: line length of 86 exceeds 80 columns |
netdev/build_allmodconfig_warn | success | Errors and warnings before: 2 this patch: 2 |
netdev/header_inline | success | Link |
On Tue, Apr 13, 2021 at 9:58 AM Xuan Zhuo <xuanzhuo@linux.alibaba.com> wrote: > > xsk adds an interface and returns the page corresponding to > data. virtio-net does not initialize dma, so it needs page to construct > scatterlist to pass to vring. > > Signed-off-by: Xuan Zhuo <xuanzhuo@linux.alibaba.com> > Reviewed-by: Dust Li <dust.li@linux.alibaba.com> Acked-by: Magnus Karlsson <magnus.karlsson@intel.com> > --- > include/net/xdp_sock_drv.h | 11 +++++++++++ > 1 file changed, 11 insertions(+) > > diff --git a/include/net/xdp_sock_drv.h b/include/net/xdp_sock_drv.h > index 4e295541e396..1d08b5d8d15f 100644 > --- a/include/net/xdp_sock_drv.h > +++ b/include/net/xdp_sock_drv.h > @@ -72,6 +72,12 @@ static inline dma_addr_t xsk_buff_xdp_get_frame_dma(struct xdp_buff *xdp) > return xp_get_frame_dma(xskb); > } > > +static inline struct page *xsk_buff_xdp_get_page(struct xsk_buff_pool *pool, u64 addr) > +{ > + addr = pool->unaligned ? xp_unaligned_add_offset_to_addr(addr) : addr; > + return pool->umem->pgs[addr >> PAGE_SHIFT]; > +} > + > static inline struct xdp_buff *xsk_buff_alloc(struct xsk_buff_pool *pool) > { > return xp_alloc(pool); > @@ -207,6 +213,11 @@ static inline dma_addr_t xsk_buff_xdp_get_frame_dma(struct xdp_buff *xdp) > return 0; > } > > +static inline struct page *xsk_buff_xdp_get_page(struct xsk_buff_pool *pool, u64 addr) > +{ > + return NULL; > +} > + > static inline struct xdp_buff *xsk_buff_alloc(struct xsk_buff_pool *pool) > { > return NULL; > -- > 2.31.0 >
diff --git a/include/net/xdp_sock_drv.h b/include/net/xdp_sock_drv.h index 4e295541e396..1d08b5d8d15f 100644 --- a/include/net/xdp_sock_drv.h +++ b/include/net/xdp_sock_drv.h @@ -72,6 +72,12 @@ static inline dma_addr_t xsk_buff_xdp_get_frame_dma(struct xdp_buff *xdp) return xp_get_frame_dma(xskb); } +static inline struct page *xsk_buff_xdp_get_page(struct xsk_buff_pool *pool, u64 addr) +{ + addr = pool->unaligned ? xp_unaligned_add_offset_to_addr(addr) : addr; + return pool->umem->pgs[addr >> PAGE_SHIFT]; +} + static inline struct xdp_buff *xsk_buff_alloc(struct xsk_buff_pool *pool) { return xp_alloc(pool); @@ -207,6 +213,11 @@ static inline dma_addr_t xsk_buff_xdp_get_frame_dma(struct xdp_buff *xdp) return 0; } +static inline struct page *xsk_buff_xdp_get_page(struct xsk_buff_pool *pool, u64 addr) +{ + return NULL; +} + static inline struct xdp_buff *xsk_buff_alloc(struct xsk_buff_pool *pool) { return NULL;