hc
2023-03-21 4b55d97acc464242bcd6a8ae77b8ff37c22dec58
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
/* SPDX-License-Identifier: GPL-2.0 */
/* Copyright(c) 2013 - 2018 Intel Corporation. */
 
#ifndef _I40E_ALLOC_H_
#define _I40E_ALLOC_H_
 
struct i40e_hw;
 
/* Memory allocation types */
enum i40e_memory_type {
   i40e_mem_arq_buf = 0,        /* ARQ indirect command buffer */
   i40e_mem_asq_buf = 1,
   i40e_mem_atq_buf = 2,        /* ATQ indirect command buffer */
   i40e_mem_arq_ring = 3,        /* ARQ descriptor ring */
   i40e_mem_atq_ring = 4,        /* ATQ descriptor ring */
   i40e_mem_pd = 5,        /* Page Descriptor */
   i40e_mem_bp = 6,        /* Backing Page - 4KB */
   i40e_mem_bp_jumbo = 7,        /* Backing Page - > 4KB */
   i40e_mem_reserved
};
 
/* prototype for functions used for dynamic memory allocation */
i40e_status i40e_allocate_dma_mem(struct i40e_hw *hw,
                       struct i40e_dma_mem *mem,
                       enum i40e_memory_type type,
                       u64 size, u32 alignment);
i40e_status i40e_free_dma_mem(struct i40e_hw *hw,
                   struct i40e_dma_mem *mem);
i40e_status i40e_allocate_virt_mem(struct i40e_hw *hw,
                        struct i40e_virt_mem *mem,
                        u32 size);
i40e_status i40e_free_virt_mem(struct i40e_hw *hw,
                    struct i40e_virt_mem *mem);
 
#endif /* _I40E_ALLOC_H_ */