123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165 |
- #ifndef _DP_RX_H
- #define _DP_RX_H
- #include "hal_rx.h"
- #include "dp_tx.h"
- #define DP_PEER_METADATA_PEER_ID_MASK 0x0000ffff
- #define DP_PEER_METADATA_PEER_ID_SHIFT 0
- #define DP_PEER_METADATA_VDEV_ID_MASK 0x00070000
- #define DP_PEER_METADATA_VDEV_ID_SHIFT 16
- #define DP_PEER_METADATA_PEER_ID_GET(_peer_metadata) \
- (((_peer_metadata) & DP_PEER_METADATA_PEER_ID_MASK) \
- >> DP_PEER_METADATA_PEER_ID_SHIFT)
- #define DP_PEER_METADATA_ID_GET(_peer_metadata) \
- (((_peer_metadata) & DP_PEER_METADATA_VDEV_ID_MASK) \
- >> DP_PEER_METADATA_VDEV_ID_SHIFT)
- struct dp_rx_desc {
- qdf_nbuf_t nbuf;
- uint8_t *rx_buf_start;
- uint16_t cookie;
- uint8_t pool_id;
- };
- #define RX_DESC_COOKIE_INDEX_SHIFT 0
- #define RX_DESC_COOKIE_INDEX_MASK 0x3ffff
- #define RX_DESC_COOKIE_POOL_ID_SHIFT 18
- #define RX_DESC_COOKIE_POOL_ID_MASK 0x1c0000
- #define DP_RX_DESC_COOKIE_POOL_ID_GET(_cookie) \
- (((_cookie) & RX_DESC_COOKIE_POOL_ID_MASK) >> \
- RX_DESC_COOKIE_POOL_ID_SHIFT)
- #define DP_RX_DESC_COOKIE_INDEX_GET(_cookie) \
- (((_cookie) & RX_DESC_COOKIE_INDEX_MASK) >> \
- RX_DESC_COOKIE_INDEX_SHIFT)
- union dp_rx_desc_list_elem_t {
- union dp_rx_desc_list_elem_t *next;
- struct dp_rx_desc rx_desc;
- };
- static inline
- void *dp_rx_cookie_2_va(struct dp_soc *soc, uint32_t cookie)
- {
- uint8_t pool_id = DP_RX_DESC_COOKIE_POOL_ID_GET(cookie);
- uint16_t index = DP_RX_DESC_COOKIE_INDEX_GET(cookie);
-
-
- return &(soc->rx_desc[pool_id].array[index].rx_desc);
- }
- void dp_rx_add_desc_list_to_free_list(struct dp_soc *soc,
- union dp_rx_desc_list_elem_t **local_desc_list,
- union dp_rx_desc_list_elem_t **tail,
- uint16_t pool_id);
- uint16_t dp_rx_get_free_desc_list(struct dp_soc *soc, uint32_t pool_id,
- uint16_t num_descs,
- union dp_rx_desc_list_elem_t **desc_list,
- union dp_rx_desc_list_elem_t **tail);
- QDF_STATUS dp_rx_desc_pool_alloc(struct dp_soc *soc, uint32_t pool_id);
- void dp_rx_desc_pool_free(struct dp_soc *soc, uint32_t pool_id);
- QDF_STATUS dp_rx_pdev_attach(struct dp_pdev *pdev);
- void dp_rx_pdev_detach(struct dp_pdev *pdev);
- QDF_STATUS dp_rx_buffers_replenish(struct dp_soc *dp_soc, uint32_t mac_id,
- uint32_t num_req_buffers,
- union dp_rx_desc_list_elem_t **desc_list,
- union dp_rx_desc_list_elem_t **tail,
- uint8_t owner);
- uint32_t dp_rx_process(struct dp_soc *soc, void *hal_ring, uint32_t quota);
- uint32_t dp_rx_err_process(struct dp_soc *soc, void *hal_ring, uint32_t quota);
- uint32_t
- dp_rx_wbm_err_process(struct dp_soc *soc, void *hal_ring, uint32_t quota);
- static inline
- void dp_rx_add_to_free_desc_list(union dp_rx_desc_list_elem_t **head,
- union dp_rx_desc_list_elem_t **tail,
- struct dp_rx_desc *new)
- {
- qdf_assert(head && new);
- new->nbuf = NULL;
- ((union dp_rx_desc_list_elem_t *)new)->next = *head;
- *head = (union dp_rx_desc_list_elem_t *)new;
- if (*tail == NULL)
- *tail = *head;
- }
- #define DP_RX_LIST_APPEND(head, tail, elem) \
- do { \
- if (!(head)) { \
- (head) = (elem); \
- } else { \
- qdf_nbuf_set_next((tail), (elem)); \
- } \
- (tail) = (elem); \
- } while (0)
- #endif
|