blob: 2bd48597b105be0b9cfd0c7a603817377171f92b [file]
/* SPDX-License-Identifier: (GPL-2.0+ OR MIT) */
/*
* Copyright (c) 2019 Amlogic, Inc. All rights reserved.
*/
#ifndef __DEMOD_FUNC_H__
#define __DEMOD_FUNC_H__
#include <linux/types.h>
#include "aml_demod.h"
#include "dvb_frontend.h" /**/
#include "amlfrontend.h"
#include "addr_dtmb_top.h"
#include "addr_atsc_demod.h"
#include "addr_atsc_eq.h"
#include "addr_atsc_cntr.h"
#include "dtv_demod_regs.h"
/*#include "c_stb_define.h"*/
/*#include "c_stb_regs_define.h"*/
#include <linux/io.h>
#include <linux/jiffies.h>
#include "atsc_func.h"
#if defined DEMOD_FPGA_VERSION
#include "fpga_func.h"
#endif
#define PWR_ON 1
#define PWR_OFF 0
/* offset define */
#define DEMOD_REG_ADDR_OFFSET(reg) (reg & 0xfffff)
#define QAM_BASE (0x400) /* is offset */
#define DEMOD_CFG_BASE (0xC00) /* is offset */
/* adc */
#define D_HHI_DADC_RDBK0_I (0x29 << 2)
#define D_HHI_DADC_CNTL4 (0x2b << 2)
/*redefine*/
#define HHI_DEMOD_MEM_PD_REG (0x43)
/*redefine*/
#define RESET_RESET0_LEVEL (0x80)
/*----------------------------------*/
/*register offset define in C_stb_regs_define.h*/
#define AO_RTI_GEN_PWR_SLEEP0 ((0x00 << 10) | (0x3a << 2))
#define AO_RTI_GEN_PWR_ISO0 ((0x00 << 10) | (0x3b << 2))
/*----------------------------------*/
/* demod register */
#define DEMOD_TOP_REG0 (0x00)
#define DEMOD_TOP_REG4 (0x04)
#define DEMOD_TOP_REG8 (0x08)
#define DEMOD_TOP_REGC (0x0C)
#define DEMOD_TOP_CFG_REG_4 (0x10)
/*reset register*/
#define reg_reset (0x1c)
#define IO_CBUS_PHY_BASE (0xc0800000)
#define DEMOD_REG0_VALUE 0x0000d007
#define DEMOD_REG4_VALUE 0x2e805400
#define DEMOD_REG8_VALUE 0x201
/* for table end */
#define TABLE_FLG_END 0xffffffff
/* debug info=====================================================*/
extern int aml_demod_debug;
#define DBG_INFO BIT(0)
#define DBG_REG BIT(1)
#define DBG_ATSC BIT(2)
#define DBG_DTMB BIT(3)
#define DBG_LOOP BIT(4)
#define DBG_DVBC BIT(5)
#define DBG_DVBT BIT(6)
#define DBG_DVBS BIT(7)
#define DBG_ISDBT BIT(8)
#define DBG_TIME BIT(9)
#define PR_INFO(fmt, args ...) printk("dtv_dmd:"fmt, ##args)
#define PR_TIME(fmt, args ...) \
do { \
if (aml_demod_debug & DBG_TIME) { \
printk("dtv_dmd:" fmt, ##args); \
} \
} while (0)
#define PR_DBG(fmt, args ...) \
do { \
if (aml_demod_debug & DBG_INFO) { \
printk("dtv_dmd:"fmt, ##args); \
} \
} while (0)
#define PR_ATSC(fmt, args ...) \
do { \
if (aml_demod_debug & DBG_ATSC) { \
printk("dtv_dmd:"fmt, ##args); \
} \
} while (0)
#define PR_DVBC(fmt, args ...) \
do { \
if (aml_demod_debug & DBG_DVBC) { \
pr_info("dtv_dmd:"fmt, ##args); \
} \
} while (0)
#define PR_DVBT(fmt, args ...) \
do { \
if (aml_demod_debug & DBG_DVBT) { \
pr_info("dtv_dmd:"fmt, ##args); \
} \
} while (0)
#define PR_DVBS(fmt, args ...) \
do { \
if (aml_demod_debug & DBG_DVBS) { \
pr_info("dtv_dmd:"fmt, ##args); \
} \
} while (0)
#define PR_DTMB(fmt, args ...) \
do { \
if (aml_demod_debug & DBG_DTMB) { \
pr_info("dtv_dmd:"fmt, ##args); \
} \
} while (0)
#define PR_ISDBT(fmt, args ...) \
do { \
if (aml_demod_debug & DBG_ISDBT) { \
pr_info("dtv_dmd:"fmt, ##args); \
} \
} while (0)
/*polling*/
#define PR_DBGL(fmt, args ...) \
do { \
if (aml_demod_debug & DBG_LOOP) { \
pr_info("dtv_dmd:"fmt, ##args); \
} \
} while (0)
#define PR_ERR(fmt, args ...) pr_err("dtv_dmd:"fmt, ## args)
#define PR_WAR(fmt, args...) pr_warn("dtv_dmd:" fmt, ## args)
enum demod_reg_mode {
REG_MODE_DTMB,
REG_MODE_DVBT_ISDBT,
REG_MODE_DVBT_T2,
REG_MODE_ATSC,
REG_MODE_DVBC_J83B,
REG_MODE_FRONT,
REG_MODE_TOP,
REG_MODE_CFG,
REG_MODE_BASE,
REG_MODE_FPGA,
REG_MODE_COLLECT_DATA,
REG_MODE_OTHERS
};
enum {
AMLOGIC_DTMB_STEP0,
AMLOGIC_DTMB_STEP1,
AMLOGIC_DTMB_STEP2,
AMLOGIC_DTMB_STEP3,
AMLOGIC_DTMB_STEP4,
AMLOGIC_DTMB_STEP5, /* time eq */
AMLOGIC_DTMB_STEP6, /* set normal mode sc */
AMLOGIC_DTMB_STEP7,
AMLOGIC_DTMB_STEP8, /* set time eq mode */
AMLOGIC_DTMB_STEP9, /* reset */
AMLOGIC_DTMB_STEP10, /* set normal mode mc */
AMLOGIC_DTMB_STEP11,
};
enum {
DTMB_IDLE = 0,
DTMB_AGC_READY = 1,
DTMB_TS1_READY = 2,
DTMB_TS2_READY = 3,
DTMB_FE_READY = 4,
DTMB_PNPHASE_READY = 5,
DTMB_SFO_INIT_READY = 6,
DTMB_TS3_READY = 7,
DTMB_PM_INIT_READY = 8,
DTMB_CHE_INIT_READY = 9,
DTMB_FEC_READY = 10
};
enum dtv_demod_reg_access_mode_e {
ACCESS_WORD,
ACCESS_BITS,
ACCESS_BYTE,
ACCESS_NUM
};
struct aml_demod_reg {
enum demod_reg_mode mode;
u8_t rw;/* 0: read, 1: write. */
u32_t addr;
u32_t val;
enum dtv_demod_reg_access_mode_e access_mode;
u32_t start_bit;
u32_t bit_width;
};
struct stchip_register_t {
unsigned short addr; /* Address */
char value; /* Current value */
};
void st_dvbs2_init(void);
void tuner_set_params(struct dvb_frontend *fe);
int tuner_get_ch_power(struct dvb_frontend *fe);
int dtmb_get_power_strength(int agc_gain);
int dvbc_get_power_strength(int agc_gain, int tuner_strength);
int j83b_get_power_strength(int agc_gain, int tuner_strength);
int atsc_get_power_strength(int agc_gain, int tuner_strength);
/* dvbt */
int dvbt_isdbt_set_ch(struct aml_dtvdemod *demod,
struct aml_demod_dvbt *demod_dvbt);
unsigned int dvbt_set_ch(struct aml_dtvdemod *demod,
struct aml_demod_dvbt *demod_dvbt, struct dvb_frontend *fe);
int dvbt2_set_ch(struct aml_dtvdemod *demod, struct dvb_frontend *fe);
struct demod_status_ops {
int (*get_status)(void);
int (*get_ber)(void);
int (*get_snr)(struct aml_demod_sta *demod_sta);
int (*get_strength)(struct aml_demod_sta *demod_sta);
int (*get_ucblocks)(struct aml_demod_sta *demod_sta);
};
struct demod_status_ops *dvbt_get_status_ops(void);
/* dvbc */
int dvbc_set_ch(struct aml_dtvdemod *demod, struct aml_demod_dvbc *demod_dvbc,
struct dvb_frontend *fe);
int dvbc_status(struct aml_dtvdemod *demod, struct aml_demod_sts *demod_sts,
struct seq_file *seq);
int dvbc_isr_islock(void);
void dvbc_isr(struct aml_demod_sta *demod_sta);
u32 dvbc_set_qam_mode(unsigned char mode);
u32 dvbc_get_status(struct aml_dtvdemod *demod);
u32 dvbc_set_auto_symtrack(struct aml_dtvdemod *demod);
int dvbc_timer_init(void);
void dvbc_timer_exit(void);
int dvbc_cci_task(void *data);
int dvbc_get_cci_task(struct aml_dtvdemod *demod);
void dvbc_create_cci_task(struct aml_dtvdemod *demod);
void dvbc_kill_cci_task(struct aml_dtvdemod *demod);
/* DVBC */
/*gxtvbb*/
void dvbc_reg_initial_old(struct aml_dtvdemod *demod);
/*txlx*/
void dvbc_reg_initial(struct aml_dtvdemod *demod, struct dvb_frontend *fe);
void demod_dvbc_set_qam(struct aml_dtvdemod *demod, unsigned int qam);
void dvbc_init_reg_ext(struct aml_dtvdemod *demod);
u32 dvbc_get_ch_sts(struct aml_dtvdemod *demod);
u32 dvbc_get_qam_mode(struct aml_dtvdemod *demod);
/* dtmb */
int dtmb_set_ch(struct aml_dtvdemod *demod,
struct aml_demod_dtmb *demod_atsc);
void dtmb_reset(void);
int dtmb_check_status_gxtv(struct dvb_frontend *fe);
int dtmb_check_status_txl(struct dvb_frontend *fe);
int dtmb_bch_check(void);
void dtmb_write_reg(int reg_addr, int reg_data);
unsigned int dtmb_read_reg(unsigned int reg_addr);
void dtmb_write_reg_bits(u32 addr, const u32 data, const u32 start, const u32 len);
void dtmb_register_reset(void);
/*
* dtmb register write / read
*/
/*test only*/
enum REG_DTMB_D9 {
DTMB_D9_IF_GAIN,
DTMB_D9_RF_GAIN,
DTMB_D9_POWER,
DTMB_D9_ALL,
};
void dtmb_set_mem_st(int mem_start);
int dtmb_read_agc(enum REG_DTMB_D9 type, unsigned int *buf);
unsigned int dtmb_reg_r_che_snr(void);
unsigned int dtmb_reg_r_fec_lock(void);
unsigned int dtmb_reg_r_bch(void);
int check_dtmb_fec_lock(void);
int dtmb_constell_check(void);
void dtmb_no_signal_check_v3(struct aml_dtvdemod *demod);
void dtmb_no_signal_check_finishi_v3(struct aml_dtvdemod *demod);
unsigned int dtmb_detect_first(void);
/* demod functions */
unsigned long apb_read_reg_collect(unsigned long addr);
void apb_write_reg_collect(unsigned int addr, unsigned int data);
void apb_write_reg(unsigned int reg, unsigned int val);
unsigned long apb_read_reg_high(unsigned long addr);
unsigned long apb_read_reg(unsigned long reg);
int app_apb_write_reg(int addr, int data);
int app_apb_read_reg(int addr);
void demod_set_cbus_reg(unsigned int data, unsigned int addr);
unsigned int demod_read_cbus_reg(unsigned int addr);
void demod_set_demod_reg(unsigned int data, unsigned int addr);
void demod_set_tvfe_reg(unsigned int data, unsigned int addr);
unsigned int demod_read_demod_reg(unsigned int addr);
/* extern int clk_measure(char index); */
void ofdm_initial(int bandwidth,
/* 00:8M 01:7M 10:6M 11:5M */
int samplerate,
/* 00:45M 01:20.8333M 10:20.7M 11:28.57 */
int IF,
/* 000:36.13M 001:-5.5M 010:4.57M 011:4M 100:5M */
int mode,
/* 00:DVBT,01:ISDBT */
int tc_mode
/* 0: Unsigned, 1:TC */);
/*no use void monitor_isdbt(void);*/
void demod_set_reg(struct aml_dtvdemod *demod, struct aml_demod_reg *demod_reg);
void demod_get_reg(struct aml_dtvdemod *demod, struct aml_demod_reg *demod_reg);
/* void demod_calc_clk(struct aml_demod_sta *demod_sta); */
int demod_set_sys(struct aml_dtvdemod *demod, struct aml_demod_sys *demod_sys);
void set_j83b_filter_reg_v4(struct aml_dtvdemod *demod);
/* for g9tv */
void adc_dpll_setup(int clk_a, int clk_b, int clk_sys, struct aml_demod_sta *demod_sta);
void demod_power_switch(int pwr_cntl);
union adc_pll_cntl {
/** raw register data */
uint32_t d32;
/** register bits */
struct {
unsigned pll_m:9;
unsigned pll_n:5;
unsigned pll_od0:2;
unsigned pll_od1:2;
unsigned pll_od2:2;
unsigned pll_xd0:6;
unsigned pll_xd1:6;
} b;
};
union adc_pll_cntl2 {
/** raw register data */
uint32_t d32;
/** register bits */
struct {
unsigned output_mux_ctrl:4;
unsigned div2_ctrl:1;
unsigned b_polar_control:1;
unsigned a_polar_control:1;
unsigned gate_ctrl:6;
unsigned tdc_buf:8;
unsigned lm_s:6;
unsigned lm_w:4;
unsigned reserved:1;
} b;
};
union adc_pll_cntl3 {
/** raw register data */
uint32_t d32;
/** register bits */
struct {
unsigned afc_dsel_in:1;
unsigned afc_dsel_bypass:1;
unsigned dco_sdmck_sel:2;
unsigned dc_vc_in:2;
unsigned dco_m_en:1;
unsigned dpfd_lmode:1;
unsigned filter_acq1:11;
unsigned enable:1;
unsigned filter_acq2:11;
unsigned reset:1;
} b;
};
union adc_pll_cntl4 {
/** raw register data */
uint32_t d32;
/** register bits */
struct {
unsigned reve:12;
unsigned tdc_en:1;
unsigned dco_sdm_en:1;
unsigned dco_iup:2;
unsigned pvt_fix_en:1;
unsigned iir_bypass_n:1;
unsigned pll_od3:2;
unsigned filter_pvt1:4;
unsigned filter_pvt2:4;
unsigned reserved:4;
} b;
};
/* ///////////////////////////////////////////////////////////////// */
union demod_dig_clk {
/** raw register data */
uint32_t d32;
/** register bits */
struct {
unsigned demod_clk_div:7;
unsigned reserved0:1;
unsigned demod_clk_en:1;
unsigned demod_clk_sel:2;
unsigned reserved1:5;
unsigned adc_extclk_div:7; /* 34 */
unsigned use_adc_extclk:1; /* 1 */
unsigned adc_extclk_en:1; /* 1 */
unsigned adc_extclk_sel:3; /* 1 */
unsigned reserved2:4;
} b;
};
union demod_adc_clk {
/** raw register data */
uint32_t d32;
/** register bits */
struct {
unsigned pll_m:9;
unsigned pll_n:5;
unsigned pll_od:2;
unsigned pll_xd:5;
unsigned reserved0:3;
unsigned pll_ss_clk:4;
unsigned pll_ss_en:1;
unsigned reset:1;
unsigned pll_pd:1;
unsigned reserved1:1;
} b;
};
union demod_cfg0 {
/** raw register data */
uint32_t d32;
/** register bits */
struct {
unsigned mode:4;
unsigned ts_sel:4;
unsigned test_bus_clk:1;
unsigned adc_ext:1;
unsigned adc_rvs:1;
unsigned adc_swap:1;
unsigned adc_format:1;
unsigned adc_regout:1;
unsigned adc_regsel:1;
unsigned adc_regadj:5;
unsigned adc_value:10;
unsigned adc_test:1;
unsigned ddr_sel:1;
} b;
};
union demod_cfg1 {
/** raw register data */
uint32_t d32;
/** register bits */
struct {
unsigned reserved:8;
unsigned ref_top:2;
unsigned ref_bot:2;
unsigned cml_xs:2;
unsigned cml_1s:2;
unsigned vdda_sel:2;
unsigned bias_sel_sha:2;
unsigned bias_sel_mdac2:2;
unsigned bias_sel_mdac1:2;
unsigned fast_chg:1;
unsigned rin_sel:3;
unsigned en_ext_vbg:1;
unsigned en_cmlgen_res:1;
unsigned en_ext_vdd12:1;
unsigned en_ext_ref:1;
} b;
};
union demod_cfg2 {
/** raw register data */
uint32_t d32;
/** register bits */
struct {
unsigned en_adc:1;
unsigned biasgen_ibipt_sel:2;
unsigned biasgen_ibic_sel:2;
unsigned biasgen_rsv:4;
unsigned biasgen_en:1;
unsigned biasgen_bias_sel_adc:2;
unsigned biasgen_bias_sel_cml1:2;
unsigned biasgen_bias_sel_ref_op:2;
unsigned clk_phase_sel:1;
unsigned reserved:15;
} b;
};
union demod_cfg3 {
/** raw register data */
uint32_t d32;
/** register bits */
struct {
unsigned dc_arb_mask:3;
unsigned dc_arb_enable:1;
unsigned reserved:28;
} b;
};
struct atsc_cfg {
int adr;
int dat;
int rw;
};
struct agc_power_tab {
char name[128];
int level;
int ncalcE;
int *calcE;
};
struct dtmb_cfg {
int dat;
int adr;
int rw;
};
void dtvpll_lock_init(void);
void dtvpll_init_flag(int on);
void demod_set_irq_mask(void);
void demod_clr_irq_stat(void);
void demod_set_adc_core_clk(int adc_clk, int sys_clk, struct aml_demod_sta *demod_sta);
void demod_set_adc_core_clk_fix(int clk_adc, int clk_dem);
void calculate_cordic_para(void);
/*extern int aml_fe_analog_set_frontend(struct dvb_frontend *fe);*/
int get_dtvpll_init_flag(void);
void demod_set_mode_ts(enum fe_delivery_system delsys);
void qam_write_reg(struct aml_dtvdemod *demod,
unsigned int reg_addr, unsigned int reg_data);
unsigned int qam_read_reg(struct aml_dtvdemod *demod, unsigned int reg_addr);
void qam_write_bits(struct aml_dtvdemod *demod,
u32 reg_addr, const u32 reg_data,
const u32 start, const u32 len);
void dvbc_write_reg(unsigned int addr, unsigned int data);
unsigned int dvbc_read_reg(unsigned int addr);
void demod_top_write_reg(unsigned int addr, unsigned int data);
void demod_top_write_bits(u32 reg_addr, const u32 reg_data, const u32 start, const u32 len);
unsigned int demod_top_read_reg(unsigned int addr);
void demod_init_mutex(void);
void front_write_reg(unsigned int addr, unsigned int data);
void front_write_bits(u32 reg_addr, const u32 reg_data,
const u32 start, const u32 len);
unsigned int front_read_reg(unsigned int addr);
unsigned int isdbt_read_reg_v4(unsigned int addr);
void isdbt_write_reg_v4(unsigned int addr, unsigned int data);
int dd_hiu_reg_write(unsigned int reg, unsigned int val);
unsigned int dd_hiu_reg_read(unsigned int addr);
void dtvdemod_dmc_reg_write(unsigned int reg, unsigned int val);
unsigned int dtvdemod_dmc_reg_read(unsigned int addr);
void dtvdemod_ddr_reg_write(unsigned int reg, unsigned int val);
unsigned int dtvdemod_ddr_reg_read(unsigned int addr);
int reset_reg_write(unsigned int reg, unsigned int val);
unsigned int reset_reg_read(unsigned int addr);
void clocks_set_sys_defaults(struct aml_dtvdemod *demod, unsigned int adc_clk);
void demod_set_demod_default(void);
unsigned int demod_get_adc_clk(struct aml_dtvdemod *demod);
unsigned int demod_get_sys_clk(struct aml_dtvdemod *demod);
/*register access api new*/
void dvbt_isdbt_wr_reg(unsigned int addr, unsigned int data);
void dvbt_isdtb_wr_reg_new(unsigned int addr, unsigned int data);
void dvbt_isdbt_wr_bits_new(u32 reg_addr, const u32 reg_data,
const u32 start, const u32 len);
unsigned int dvbt_isdbt_rd_reg(unsigned int addr);
unsigned int dvbt_isdbt_rd_reg_new(unsigned int addr);
void dvbt_t2_wrb(unsigned int addr, char data);
void dvbt_t2_write_w(unsigned int addr, unsigned int data);
void dvbt_t2_wr_byte_bits(u32 addr, const u32 data, const u32 start, const u32 len);
void dvbt_t2_wr_word_bits(u32 addr, const u32 data, const u32 start, const u32 len);
unsigned int dvbt_t2_read_w(unsigned int addr);
char dvbt_t2_rdb(unsigned int addr);
void riscv_ctl_write_reg(unsigned int addr, unsigned int data);
void dvbs_write_bits(u32 reg_addr, const u32 reg_data,
const u32 start, const u32 len);
void dvbs_wr_byte(unsigned int addr, char data);
char dvbs_rd_byte(unsigned int addr);
int aml_demod_init(void);
void aml_demod_exit(void);
unsigned int write_riscv_ram(void);
unsigned int dvbs_get_quality(void);
void dvbs2_reg_initial(unsigned int symb_rate, unsigned int is_blind_scan);
int dvbs_get_signal_strength_off(void);
#endif