1 /* SPDX-License-Identifier: GPL-2.0 */ 2 3 #ifndef __NETMEM_PRIV_H 4 #define __NETMEM_PRIV_H 5 6 static inline unsigned long netmem_get_pp_magic(netmem_ref netmem) 7 { 8 return __netmem_clear_lsb(netmem)->pp_magic & ~PP_DMA_INDEX_MASK; 9 } 10 11 static inline void netmem_or_pp_magic(netmem_ref netmem, unsigned long pp_magic) 12 { 13 __netmem_clear_lsb(netmem)->pp_magic |= pp_magic; 14 } 15 16 static inline void netmem_clear_pp_magic(netmem_ref netmem) 17 { 18 WARN_ON_ONCE(__netmem_clear_lsb(netmem)->pp_magic & PP_DMA_INDEX_MASK); 19 20 __netmem_clear_lsb(netmem)->pp_magic = 0; 21 } 22 23 static inline bool netmem_is_pp(netmem_ref netmem) 24 { 25 return (netmem_get_pp_magic(netmem) & PP_MAGIC_MASK) == PP_SIGNATURE; 26 } 27 28 static inline void netmem_set_pp(netmem_ref netmem, struct page_pool *pool) 29 { 30 __netmem_clear_lsb(netmem)->pp = pool; 31 } 32 33 static inline void netmem_set_dma_addr(netmem_ref netmem, 34 unsigned long dma_addr) 35 { 36 __netmem_clear_lsb(netmem)->dma_addr = dma_addr; 37 } 38 39 static inline unsigned long netmem_get_dma_index(netmem_ref netmem) 40 { 41 unsigned long magic; 42 43 if (WARN_ON_ONCE(netmem_is_net_iov(netmem))) 44 return 0; 45 46 magic = __netmem_clear_lsb(netmem)->pp_magic; 47 48 return (magic & PP_DMA_INDEX_MASK) >> PP_DMA_INDEX_SHIFT; 49 } 50 51 static inline void netmem_set_dma_index(netmem_ref netmem, 52 unsigned long id) 53 { 54 unsigned long magic; 55 56 if (WARN_ON_ONCE(netmem_is_net_iov(netmem))) 57 return; 58 59 magic = netmem_get_pp_magic(netmem) | (id << PP_DMA_INDEX_SHIFT); 60 __netmem_clear_lsb(netmem)->pp_magic = magic; 61 } 62 #endif 63