root/drivers/net/wireless/ath/ath12k/dbring.h
/* SPDX-License-Identifier: BSD-3-Clause-Clear */
/*
 * Copyright (c) 2019-2021 The Linux Foundation. All rights reserved.
 * Copyright (c) 2021-2022 Qualcomm Innovation Center, Inc. All rights reserved.
 */

#ifndef ATH12K_DBRING_H
#define ATH12K_DBRING_H

#include <linux/types.h>
#include <linux/idr.h>
#include <linux/spinlock.h>
#include "dp.h"

struct ath12k_dbring_element {
        dma_addr_t paddr;
        u8 payload[];
};

struct ath12k_dbring_data {
        void *data;
        u32 data_sz;
        struct ath12k_wmi_dma_buf_release_meta_data_params meta;
};

struct ath12k_dbring_buf_release_event {
        struct ath12k_wmi_dma_buf_release_fixed_params fixed;
        const struct ath12k_wmi_dma_buf_release_entry_params *buf_entry;
        const struct ath12k_wmi_dma_buf_release_meta_data_params *meta_data;
        u32 num_buf_entry;
        u32 num_meta;
};

struct ath12k_dbring_cap {
        u32 pdev_id;
        enum wmi_direct_buffer_module id;
        u32 min_elem;
        u32 min_buf_sz;
        u32 min_buf_align;
};

struct ath12k_dbring {
        struct dp_srng refill_srng;
        struct idr bufs_idr;
        /* Protects bufs_idr */
        spinlock_t idr_lock;
        dma_addr_t tp_addr;
        dma_addr_t hp_addr;
        int bufs_max;
        u32 pdev_id;
        u32 buf_sz;
        u32 buf_align;
        u32 num_resp_per_event;
        u32 event_timeout_ms;
        int (*handler)(struct ath12k *ar, struct ath12k_dbring_data *data);
};

int ath12k_dbring_set_cfg(struct ath12k *ar,
                          struct ath12k_dbring *ring,
                          u32 num_resp_per_event,
                          u32 event_timeout_ms,
                          int (*handler)(struct ath12k *,
                                         struct ath12k_dbring_data *));
int ath12k_dbring_wmi_cfg_setup(struct ath12k *ar,
                                struct ath12k_dbring *ring,
                                enum wmi_direct_buffer_module id);
int ath12k_dbring_buf_setup(struct ath12k *ar,
                            struct ath12k_dbring *ring,
                            struct ath12k_dbring_cap *db_cap);
int ath12k_dbring_srng_setup(struct ath12k *ar, struct ath12k_dbring *ring,
                             int ring_num, int num_entries);
int ath12k_dbring_buffer_release_event(struct ath12k_base *ab,
                                       struct ath12k_dbring_buf_release_event *ev);
int ath12k_dbring_get_cap(struct ath12k_base *ab,
                          u8 pdev_idx,
                          enum wmi_direct_buffer_module id,
                          struct ath12k_dbring_cap *db_cap);
void ath12k_dbring_srng_cleanup(struct ath12k *ar, struct ath12k_dbring *ring);
void ath12k_dbring_buf_cleanup(struct ath12k *ar, struct ath12k_dbring *ring);
#endif /* ATH12K_DBRING_H */