Commit 35b2e549 authored by Toke Høiland-Jørgensen's avatar Toke Høiland-Jørgensen Committed by Alexei Starovoitov

page_pool: Add callback to init pages when they are allocated

Add a new callback function to page_pool that, if set, will be called every
time a new page is allocated. This will be used from bpf_test_run() to
initialise the page data with the data provided by userspace when running
XDP programs with redirect turned on.
Signed-off-by: default avatarToke Høiland-Jørgensen <toke@redhat.com>
Signed-off-by: default avatarAlexei Starovoitov <ast@kernel.org>
Acked-by: default avatarJohn Fastabend <john.fastabend@gmail.com>
Acked-by: default avatarJesper Dangaard Brouer <brouer@redhat.com>
Link: https://lore.kernel.org/bpf/20220103150812.87914-3-toke@redhat.com
parent 4a48ef70
...@@ -80,6 +80,8 @@ struct page_pool_params { ...@@ -80,6 +80,8 @@ struct page_pool_params {
enum dma_data_direction dma_dir; /* DMA mapping direction */ enum dma_data_direction dma_dir; /* DMA mapping direction */
unsigned int max_len; /* max DMA sync memory size */ unsigned int max_len; /* max DMA sync memory size */
unsigned int offset; /* DMA addr offset */ unsigned int offset; /* DMA addr offset */
void (*init_callback)(struct page *page, void *arg);
void *init_arg;
}; };
struct page_pool { struct page_pool {
......
...@@ -217,6 +217,8 @@ static void page_pool_set_pp_info(struct page_pool *pool, ...@@ -217,6 +217,8 @@ static void page_pool_set_pp_info(struct page_pool *pool,
{ {
page->pp = pool; page->pp = pool;
page->pp_magic |= PP_SIGNATURE; page->pp_magic |= PP_SIGNATURE;
if (pool->p.init_callback)
pool->p.init_callback(page, pool->p.init_arg);
} }
static void page_pool_clear_pp_info(struct page *page) static void page_pool_clear_pp_info(struct page *page)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment