123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176 |
- /* QLogic qed NIC Driver
- * Copyright (c) 2015 QLogic Corporation
- *
- * This software is available under the terms of the GNU General Public License
- * (GPL) Version 2, available from the file COPYING in the main directory of
- * this source tree.
- */
- #ifndef _QED_OOO_H
- #define _QED_OOO_H
- #include <linux/types.h>
- #include <linux/list.h>
- #include <linux/slab.h>
- #include "qed.h"
- #define QED_MAX_NUM_ISLES 256
- #define QED_MAX_NUM_OOO_HISTORY_ENTRIES 512
- #define QED_OOO_LEFT_BUF 0
- #define QED_OOO_RIGHT_BUF 1
- struct qed_ooo_buffer {
- struct list_head list_entry;
- void *rx_buffer_virt_addr;
- dma_addr_t rx_buffer_phys_addr;
- u32 rx_buffer_size;
- u16 packet_length;
- u16 parse_flags;
- u16 vlan;
- u8 placement_offset;
- };
- struct qed_ooo_isle {
- struct list_head list_entry;
- struct list_head buffers_list;
- };
- struct qed_ooo_archipelago {
- struct list_head list_entry;
- struct list_head isles_list;
- u32 cid;
- };
- struct qed_ooo_history {
- struct ooo_opaque *p_cqes;
- u32 head_idx;
- u32 num_of_cqes;
- };
- struct qed_ooo_info {
- struct list_head free_buffers_list;
- struct list_head ready_buffers_list;
- struct list_head free_isles_list;
- struct list_head free_archipelagos_list;
- struct list_head archipelagos_list;
- struct qed_ooo_archipelago *p_archipelagos_mem;
- struct qed_ooo_isle *p_isles_mem;
- struct qed_ooo_history ooo_history;
- u32 cur_isles_number;
- u32 max_isles_number;
- u32 gen_isles_number;
- };
- #if IS_ENABLED(CONFIG_QED_ISCSI)
- void qed_ooo_save_history_entry(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info,
- struct ooo_opaque *p_cqe);
- struct qed_ooo_info *qed_ooo_alloc(struct qed_hwfn *p_hwfn);
- void qed_ooo_release_connection_isles(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info,
- u32 cid);
- void qed_ooo_release_all_isles(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info);
- void qed_ooo_setup(struct qed_hwfn *p_hwfn, struct qed_ooo_info *p_ooo_info);
- void qed_ooo_free(struct qed_hwfn *p_hwfn, struct qed_ooo_info *p_ooo_info);
- void qed_ooo_put_free_buffer(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info,
- struct qed_ooo_buffer *p_buffer);
- struct qed_ooo_buffer *
- qed_ooo_get_free_buffer(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info);
- void qed_ooo_put_ready_buffer(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info,
- struct qed_ooo_buffer *p_buffer, u8 on_tail);
- struct qed_ooo_buffer *
- qed_ooo_get_ready_buffer(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info);
- void qed_ooo_delete_isles(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info,
- u32 cid, u8 drop_isle, u8 drop_size);
- void qed_ooo_add_new_isle(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info,
- u32 cid,
- u8 ooo_isle, struct qed_ooo_buffer *p_buffer);
- void qed_ooo_add_new_buffer(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info,
- u32 cid,
- u8 ooo_isle,
- struct qed_ooo_buffer *p_buffer, u8 buffer_side);
- void qed_ooo_join_isles(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info, u32 cid,
- u8 left_isle);
- #else /* IS_ENABLED(CONFIG_QED_ISCSI) */
- static inline void qed_ooo_save_history_entry(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info,
- struct ooo_opaque *p_cqe) {}
- static inline struct qed_ooo_info *qed_ooo_alloc(
- struct qed_hwfn *p_hwfn) { return NULL; }
- static inline void
- qed_ooo_release_connection_isles(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info,
- u32 cid) {}
- static inline void qed_ooo_release_all_isles(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info)
- {}
- static inline void qed_ooo_setup(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info) {}
- static inline void qed_ooo_free(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info) {}
- static inline void qed_ooo_put_free_buffer(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info,
- struct qed_ooo_buffer *p_buffer) {}
- static inline struct qed_ooo_buffer *
- qed_ooo_get_free_buffer(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info) { return NULL; }
- static inline void qed_ooo_put_ready_buffer(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info,
- struct qed_ooo_buffer *p_buffer,
- u8 on_tail) {}
- static inline struct qed_ooo_buffer *
- qed_ooo_get_ready_buffer(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info) { return NULL; }
- static inline void qed_ooo_delete_isles(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info,
- u32 cid, u8 drop_isle, u8 drop_size) {}
- static inline void qed_ooo_add_new_isle(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info,
- u32 cid, u8 ooo_isle,
- struct qed_ooo_buffer *p_buffer) {}
- static inline void qed_ooo_add_new_buffer(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info,
- u32 cid, u8 ooo_isle,
- struct qed_ooo_buffer *p_buffer,
- u8 buffer_side) {}
- static inline void qed_ooo_join_isles(struct qed_hwfn *p_hwfn,
- struct qed_ooo_info *p_ooo_info, u32 cid,
- u8 left_isle) {}
- #endif /* IS_ENABLED(CONFIG_QED_ISCSI) */
- #endif
|