63 lines
1.5 KiB
C
63 lines
1.5 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
|
|
#ifndef __NETMEM_PRIV_H
|
|
#define __NETMEM_PRIV_H
|
|
|
|
static inline unsigned long netmem_get_pp_magic(netmem_ref netmem)
|
|
{
|
|
return __netmem_clear_lsb(netmem)->pp_magic & ~PP_DMA_INDEX_MASK;
|
|
}
|
|
|
|
static inline void netmem_or_pp_magic(netmem_ref netmem, unsigned long pp_magic)
|
|
{
|
|
__netmem_clear_lsb(netmem)->pp_magic |= pp_magic;
|
|
}
|
|
|
|
static inline void netmem_clear_pp_magic(netmem_ref netmem)
|
|
{
|
|
WARN_ON_ONCE(__netmem_clear_lsb(netmem)->pp_magic & PP_DMA_INDEX_MASK);
|
|
|
|
__netmem_clear_lsb(netmem)->pp_magic = 0;
|
|
}
|
|
|
|
static inline bool netmem_is_pp(netmem_ref netmem)
|
|
{
|
|
return (netmem_get_pp_magic(netmem) & PP_MAGIC_MASK) == PP_SIGNATURE;
|
|
}
|
|
|
|
static inline void netmem_set_pp(netmem_ref netmem, struct page_pool *pool)
|
|
{
|
|
__netmem_clear_lsb(netmem)->pp = pool;
|
|
}
|
|
|
|
static inline void netmem_set_dma_addr(netmem_ref netmem,
|
|
unsigned long dma_addr)
|
|
{
|
|
__netmem_clear_lsb(netmem)->dma_addr = dma_addr;
|
|
}
|
|
|
|
static inline unsigned long netmem_get_dma_index(netmem_ref netmem)
|
|
{
|
|
unsigned long magic;
|
|
|
|
if (WARN_ON_ONCE(netmem_is_net_iov(netmem)))
|
|
return 0;
|
|
|
|
magic = __netmem_clear_lsb(netmem)->pp_magic;
|
|
|
|
return (magic & PP_DMA_INDEX_MASK) >> PP_DMA_INDEX_SHIFT;
|
|
}
|
|
|
|
static inline void netmem_set_dma_index(netmem_ref netmem,
|
|
unsigned long id)
|
|
{
|
|
unsigned long magic;
|
|
|
|
if (WARN_ON_ONCE(netmem_is_net_iov(netmem)))
|
|
return;
|
|
|
|
magic = netmem_get_pp_magic(netmem) | (id << PP_DMA_INDEX_SHIFT);
|
|
__netmem_clear_lsb(netmem)->pp_magic = magic;
|
|
}
|
|
#endif
|