2018-06-22 16:48:32 +00:00
|
|
|
/******************************************************************************
|
|
|
|
*
|
2018-08-24 20:52:34 +00:00
|
|
|
* Copyright(c) 2007 - 2017 Realtek Corporation.
|
2018-06-22 16:48:32 +00:00
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of version 2 of the GNU General Public License as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
2018-08-24 20:52:34 +00:00
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
2018-06-22 16:48:32 +00:00
|
|
|
* more details.
|
|
|
|
*
|
2018-08-24 20:52:34 +00:00
|
|
|
* The full GNU General Public License is included in this distribution in the
|
|
|
|
* file called LICENSE.
|
|
|
|
*
|
|
|
|
* Contact Information:
|
|
|
|
* wlanfae <wlanfae@realtek.com>
|
|
|
|
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
|
|
|
|
* Hsinchu 300, Taiwan.
|
|
|
|
*
|
|
|
|
* Larry Finger <Larry.Finger@lwfinger.net>
|
|
|
|
*
|
2018-06-22 16:48:32 +00:00
|
|
|
*****************************************************************************/
|
|
|
|
|
|
|
|
#ifndef __INC_ADCSMP_H
|
|
|
|
#define __INC_ADCSMP_H
|
|
|
|
|
2019-05-24 19:43:57 +00:00
|
|
|
#if (PHYDM_LA_MODE_SUPPORT)
|
2018-06-22 16:48:32 +00:00
|
|
|
|
2019-05-24 19:43:57 +00:00
|
|
|
#define DYNAMIC_LA_MODE "3.0"
|
|
|
|
|
|
|
|
#define FULL_BUFF_MODE_SUPPORT (ODM_RTL8821C | ODM_RTL8195B | ODM_RTL8822C |\
|
|
|
|
ODM_RTL8812F | ODM_RTL8814B)
|
2018-06-22 16:48:32 +00:00
|
|
|
|
2018-08-24 20:52:34 +00:00
|
|
|
struct rt_adcsmp_string {
|
2018-06-22 16:48:32 +00:00
|
|
|
u32 *octet;
|
|
|
|
u32 length;
|
|
|
|
u32 buffer_size;
|
|
|
|
u32 start_pos;
|
2019-05-24 19:43:57 +00:00
|
|
|
u32 end_pos; /*@buf addr*/
|
2018-06-22 16:48:32 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
enum rt_adcsmp_trig_sel {
|
|
|
|
PHYDM_ADC_BB_TRIG = 0,
|
|
|
|
PHYDM_ADC_MAC_TRIG = 1,
|
|
|
|
PHYDM_ADC_RF0_TRIG = 2,
|
|
|
|
PHYDM_ADC_RF1_TRIG = 3,
|
|
|
|
PHYDM_MAC_TRIG = 4
|
|
|
|
};
|
|
|
|
|
|
|
|
enum rt_adcsmp_trig_sig_sel {
|
|
|
|
ADCSMP_TRIG_CRCOK = 0,
|
|
|
|
ADCSMP_TRIG_CRCFAIL = 1,
|
|
|
|
ADCSMP_TRIG_CCA = 2,
|
|
|
|
ADCSMP_TRIG_REG = 3
|
|
|
|
};
|
|
|
|
|
|
|
|
enum rt_adcsmp_state {
|
2019-05-24 19:43:57 +00:00
|
|
|
ADCSMP_STATE_IDLE = 0,
|
|
|
|
ADCSMP_STATE_SET = 1,
|
|
|
|
ADCSMP_STATE_QUERY = 2
|
2018-06-22 16:48:32 +00:00
|
|
|
};
|
|
|
|
|
2019-05-24 19:43:57 +00:00
|
|
|
enum la_buff_mode {
|
|
|
|
ADCSMP_BUFF_HALF = 0,
|
|
|
|
ADCSMP_BUFF_ALL = 1 /*Only use in MP Driver*/
|
|
|
|
};
|
2018-06-22 16:48:32 +00:00
|
|
|
|
2018-08-24 20:52:34 +00:00
|
|
|
struct rt_adcsmp {
|
2019-05-24 19:43:57 +00:00
|
|
|
struct rt_adcsmp_string adc_smp_buf;
|
|
|
|
enum rt_adcsmp_state adc_smp_state;
|
|
|
|
enum la_buff_mode la_buff_mode;
|
|
|
|
u8 la_trig_mode;
|
|
|
|
u32 la_trig_sig_sel;
|
|
|
|
u8 la_dma_type;
|
|
|
|
u32 la_trigger_time;
|
|
|
|
/*
|
|
|
|
* @1.BB mode: for debug port header sel;
|
|
|
|
* 2.MAC mode: for reference mask
|
|
|
|
*/
|
|
|
|
u32 la_mac_mask_or_hdr_sel;
|
|
|
|
u32 la_dbg_port;
|
|
|
|
u8 la_trigger_edge;
|
|
|
|
u8 la_smp_rate;
|
|
|
|
u32 la_count;
|
|
|
|
u8 is_bb_trigger;
|
|
|
|
u8 la_work_item_index;
|
|
|
|
boolean la_en_new_bbtrigger;
|
|
|
|
boolean la_ori_bb_dis;
|
|
|
|
u8 la_and1_sel;
|
|
|
|
u8 la_and1_val;
|
|
|
|
u8 la_and2_sel;
|
|
|
|
u8 la_and2_val;
|
|
|
|
u8 la_and3_sel;
|
|
|
|
u8 la_and3_val;
|
|
|
|
u32 la_and4_en;
|
|
|
|
u32 la_and4_val;
|
|
|
|
boolean is_fake_trig;
|
|
|
|
boolean is_la_print;
|
|
|
|
boolean en_fake_trig;
|
2018-06-22 16:48:32 +00:00
|
|
|
|
|
|
|
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
|
|
|
|
RT_WORK_ITEM adc_smp_work_item;
|
|
|
|
RT_WORK_ITEM adc_smp_work_item_1;
|
|
|
|
#endif
|
|
|
|
};
|
|
|
|
|
|
|
|
#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
|
2019-05-24 19:43:57 +00:00
|
|
|
void adc_smp_work_item_callback(
|
|
|
|
void *context);
|
2018-06-22 16:48:32 +00:00
|
|
|
#endif
|
|
|
|
|
2019-05-24 19:43:57 +00:00
|
|
|
void adc_smp_set(void *dm_void, u8 trig_mode, u32 trig_sig_sel,
|
|
|
|
u8 dma_data_sig_sel, u32 trig_time, u16 polling_time);
|
2018-06-22 16:48:32 +00:00
|
|
|
|
|
|
|
#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
|
|
|
|
enum rt_status
|
2019-05-24 19:43:57 +00:00
|
|
|
adc_smp_query(void *dm_void, ULONG info_buf_length, void *info_buf,
|
|
|
|
PULONG bytes_written);
|
2018-06-22 16:48:32 +00:00
|
|
|
#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
|
2019-05-24 19:43:57 +00:00
|
|
|
void adc_smp_query(void *dm_void, void *output, u32 out_len, u32 *pused);
|
|
|
|
|
|
|
|
s32 adc_smp_get_sample_counts(void *dm_void);
|
|
|
|
|
|
|
|
s32 adc_smp_query_single_data(void *dm_void, void *output, u32 out_len,
|
|
|
|
u32 idx);
|
2018-06-22 16:48:32 +00:00
|
|
|
|
|
|
|
#endif
|
2019-05-24 19:43:57 +00:00
|
|
|
void adc_smp_stop(void *dm_void);
|
|
|
|
|
|
|
|
void phydm_la_bb_adv_reset_jgr3(void *dm_void);
|
2018-06-22 16:48:32 +00:00
|
|
|
|
2019-05-24 19:43:57 +00:00
|
|
|
void adc_smp_init(void *dm_void);
|
2018-06-22 16:48:32 +00:00
|
|
|
|
|
|
|
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
|
2019-05-24 19:43:57 +00:00
|
|
|
void adc_smp_de_init(void *dm_void);
|
2018-06-22 16:48:32 +00:00
|
|
|
#endif
|
|
|
|
|
2019-05-24 19:43:57 +00:00
|
|
|
void phydm_la_set_buff_mode(void *dm_void, enum la_buff_mode mode);
|
|
|
|
|
|
|
|
void phydm_la_mode_bb_setting(void *dm_void, boolean en_fake_trig);
|
|
|
|
|
|
|
|
void phydm_la_mode_set_trigger_time(void *dm_void, u32 trigger_time_mu_sec);
|
|
|
|
|
|
|
|
void phydm_lamode_trigger_cmd(void *dm_void, char input[][16], u32 *_used,
|
|
|
|
char *output, u32 *_out_len);
|
|
|
|
void phydm_la_pre_run(void *dm_void);
|
|
|
|
|
2018-06-22 16:48:32 +00:00
|
|
|
#endif
|
|
|
|
#endif
|