kernel_samsung_a34x-permissive/drivers/misc/mediatek/eccci/hif/dpmaif_drv.h
2024-04-28 15:49:01 +02:00

125 lines
4.8 KiB
C
Executable file

/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright (C) 2016 MediaTek Inc.
*/
#ifndef __MODEM_DPMAIF_DRV_H__
#define __MODEM_DPMAIF_DRV_H__
#include "ccci_config.h"
#include "dpmaif_reg.h"
/* == RX part == */
#ifdef HW_FRG_FEATURE_ENABLE
unsigned short drv_dpmaif_dl_get_frg_bat_ridx(unsigned char q_num);
int drv_dpmaif_dl_add_frg_bat_cnt(unsigned char q_num,
unsigned short frg_entry_cnt);
#endif
unsigned short drv_dpmaif_dl_get_bat_ridx(unsigned char q_num);
int drv_dpmaif_dl_add_bat_cnt(unsigned char q_num,
unsigned short bat_entry_cnt);
int drv_dpmaif_dl_add_pit_remain_cnt(unsigned char q_num,
unsigned short pit_remain_cnt);
unsigned int drv_dpmaif_dl_get_wridx(unsigned char q_num);
void drv_dpmaif_mask_dl_interrupt(unsigned char q_num);
void drv_dpmaif_unmask_dl_interrupt(unsigned char q_num);
int drv_dpmaif_dl_all_queue_en(bool enable);
int drv_dpmaif_dl_idle_check(void);
/* == TX part == */
void drv_dpmaif_mask_ul_que_interrupt(unsigned char q_num);
void drv_dpmaif_unmask_ul_interrupt(unsigned char q_num);
unsigned int drv_dpmaif_ul_get_ridx(unsigned char q_num);
unsigned int drv_dpmaif_ul_get_rwidx(unsigned char q_num);
unsigned int drv_dpmaif_ul_get_hw_widx_01(void);
int drv_dpmaif_ul_add_wcnt(unsigned char q_num, unsigned short drb_wcnt);
/* isr part */
#define drv_dpmaif_get_dl_isr_event() \
DPMA_READ_PD_MISC(DPMAIF_PD_AP_DL_L2TISAR0)
#define drv_dpmaif_get_ul_isr_event() \
DPMA_READ_PD_MISC(DPMAIF_PD_AP_UL_L2TISAR0)
#define drv_dpmaif_get_dl_interrupt_mask() \
DPMA_READ_PD_MISC(DPMAIF_PD_AP_DL_L2TIMR0)
/* use ao domain:
* (DPMA_READ_AO_DL(DPMAIF_AO_DL_RDY_CHK_THRES)&DPMAIF_AO_DL_ISR_MSK)
*/
#ifdef MT6297
#define drv_dpmaif_ul_get_ul_interrupt_mask() \
DPMA_READ_AO_UL(DPMAIF_PD_AP_UL_L2TIMR0)
#else
#define drv_dpmaif_ul_get_ul_interrupt_mask() \
DPMA_READ_PD_MISC(DPMAIF_PD_AP_UL_L2TIMR0)
#endif
void drv_dpmaif_clear_ip_busy(void);
/* == state part == */
/*void drv_dpmaif_set_dl_interrupt_mask(unsigned int mask);*/
int drv_dpmaif_intr_hw_init(void);
/* init: rx init */
int drv_dpmaif_dl_bat_init_done(unsigned char q_num, bool frg_en);
void drv_dpmaif_dl_pit_init_done(unsigned char q_num);
void drv_dpmaif_dl_set_bat_base_addr(unsigned char q_num,
dma_addr_t base_addr);
void drv_dpmaif_dl_set_bat_size(unsigned char q_num, unsigned int size);
void drv_dpmaif_dl_bat_en(unsigned char q_num, bool enable);
void drv_dpmaif_dl_set_pit_base_addr(unsigned char q_num,
dma_addr_t base_addr);
void drv_dpmaif_dl_set_pit_size(unsigned char q_num, unsigned int size);
void drv_dpmaif_dl_pit_en(unsigned char q_num, bool enable);
void drv_dpmaif_dl_set_bid_maxcnt(unsigned char q_num, unsigned int cnt);
void drv_dpmaif_dl_set_remain_minsz(unsigned char q_num, unsigned int sz);
#ifdef _HW_REORDER_SW_WORKAROUND_
void drv_dpmaif_dl_set_apit_idx(unsigned char q_num, unsigned int idx);
int drv_dpmaif_dl_add_apit_num(unsigned short ap_entry_cnt);
#endif
void drv_dpmaif_dl_set_mtu(unsigned int mtu_sz);
void drv_dpmaif_dl_set_pit_chknum(unsigned char q_num, unsigned int number);
void drv_dpmaif_dl_set_bat_bufsz(unsigned char q_num, unsigned int buf_sz);
void drv_dpmaif_dl_set_bat_rsv_len(unsigned char q_num, unsigned int length);
void drv_dpmaif_dl_set_pkt_align(unsigned char q_num, bool enable,
unsigned int mode);
void drv_dpmaif_dl_set_bat_chk_thres(unsigned char q_num, unsigned int size);
#ifdef HW_FRG_FEATURE_ENABLE
void drv_dpmaif_dl_set_ao_frag_check_thres(unsigned char q_num,
unsigned int size);
void drv_dpmaif_dl_set_ao_frg_bat_feature(unsigned char q_num, bool enable);
void drv_dpmaif_dl_set_ao_frg_bat_bufsz(unsigned char q_num,
unsigned int buf_sz);
int drv_dpmaif_dl_all_frg_queue_en(bool enable);
#endif
#ifdef HW_CHECK_SUM_ENABLE
void drv_dpmaif_dl_set_ao_chksum_en(unsigned char q_num, bool enable);
#endif
/* init: tx init */
void drv_dpmaif_init_ul_intr(void);
void drv_dpmaif_ul_update_drb_size(unsigned char q_num, unsigned int size);
void drv_dpmaif_ul_update_drb_base_addr(unsigned char q_num,
unsigned int lb_addr, unsigned int hb_addr);
void drv_dpmaif_ul_rdy_en(unsigned char q_num, bool ready);
void drv_dpmaif_ul_arb_en(unsigned char q_num, bool enable);
void drv_dpmaif_ul_all_queue_en(bool enable);
int drv_dpmaif_ul_idle_check(void);
/* suspend resume */
bool drv_dpmaif_check_power_down(void);
int drv_dpmaif_dl_restore(unsigned int mask);
#ifdef _E1_SB_SW_WORKAROUND_
unsigned int drv_dpmaif_dl_get_pit_ridx(unsigned char q_num);
unsigned int drv_dpmaif_dl_get_bat_wridx(unsigned char q_num);
void drv_dpmaif_unmask_dl_full_intr(unsigned char q_num);
void dpmaif_mask_pitcnt_len_error_intr(unsigned char q_num);
void dpmaif_mask_batcnt_len_error_intr(unsigned char q_num);
#endif
#ifdef MT6297
void drv_dpmaif_dl_set_performance(void);
void drv_dpmaif_dl_set_wdma(void);
void drv_dpmaif_dl_set_chk_rbnum(unsigned char q_num, unsigned int cnt);
void drv_dpmaif_common_hw_init(void);
void drv_dpmaif_md_hw_bus_remap(void);
#endif
#endif