| // SPDX-License-Identifier: (GPL-2.0+ OR MIT) |
| /* |
| * Copyright (c) 2019 Amlogic, Inc. All rights reserved. |
| */ |
| |
| #include <linux/kernel.h> |
| #include <linux/delay.h> |
| #include "aml_demod.h" |
| #include "demod_func.h" |
| #include "dvbc_func.h" |
| |
| u32 dvbc_get_status(struct aml_dtvdemod *demod) |
| { |
| /*PR_DVBC("c4 is %x\n",dvbc_read_reg(QAM_BASE+0xc4));*/ |
| return qam_read_reg(demod, 0x31) & 0xf; |
| } |
| |
| static u32 dvbc_get_ch_power(struct aml_dtvdemod *demod) |
| { |
| u32 tmp; |
| u32 ad_power; |
| u32 agc_gain; |
| u32 ch_power; |
| |
| tmp = qam_read_reg(demod, 0x27); |
| |
| ad_power = (tmp >> 22) & 0x1ff; |
| agc_gain = (tmp >> 0) & 0x7ff; |
| |
| ad_power = ad_power >> 4; |
| /* ch_power = lookuptable(agc_gain) + ad_power; TODO */ |
| ch_power = (ad_power & 0xffff) + ((agc_gain & 0xffff) << 16); |
| |
| return ch_power; |
| } |
| |
| static u32 dvbc_get_snr(struct aml_dtvdemod *demod) |
| { |
| u32 tmp, snr; |
| |
| tmp = qam_read_reg(demod, 0x5) & 0xfff; |
| snr = tmp * 100 / 32; /* * 1e2 */ |
| |
| return snr; |
| } |
| |
| static u32 dvbc_get_ber(struct aml_dtvdemod *demod) |
| { |
| u32 rs_ber; |
| u32 rs_packet_len; |
| |
| rs_packet_len = qam_read_reg(demod, 0x4) & 0xffff; |
| rs_ber = qam_read_reg(demod, 0x5) >> 12 & 0xfffff; |
| |
| /* rs_ber = rs_ber / 204.0 / 8.0 / rs_packet_len; */ |
| if (rs_packet_len == 0) |
| rs_ber = 1000000; |
| else |
| rs_ber = rs_ber * 613 / rs_packet_len; /* 1e-6 */ |
| |
| return rs_ber; |
| } |
| |
| static u32 dvbc_get_per(struct aml_dtvdemod *demod) |
| { |
| u32 rs_per; |
| u32 rs_packet_len; |
| u32 acc_rs_per_times; |
| |
| rs_packet_len = qam_read_reg(demod, 0x4) & 0xffff; |
| rs_per = qam_read_reg(demod, 0x6) >> 16 & 0xffff; |
| |
| acc_rs_per_times = qam_read_reg(demod, 0x33) & 0xffff; |
| /*rs_per = rs_per / rs_packet_len; */ |
| |
| if (rs_packet_len == 0) |
| rs_per = 10000; |
| else |
| rs_per = 10000 * rs_per / rs_packet_len; /* 1e-4 */ |
| |
| /*return rs_per; */ |
| return acc_rs_per_times; |
| } |
| |
| u32 dvbc_get_symb_rate(struct aml_dtvdemod *demod) |
| { |
| u32 tmp; |
| u32 adc_freq; |
| u32 symb_rate; |
| |
| adc_freq = qam_read_reg(demod, 0xd) >> 16 & 0xffff; |
| tmp = qam_read_reg(demod, 0x2e); |
| |
| if ((tmp >> 15) == 0) |
| symb_rate = 0; |
| else |
| symb_rate = 10 * (adc_freq << 12) / (tmp >> 15); |
| |
| return symb_rate / 10; |
| } |
| |
| static int dvbc_get_freq_off(struct aml_dtvdemod *demod) |
| { |
| int tmp; |
| int symb_rate; |
| int freq_off; |
| |
| symb_rate = dvbc_get_symb_rate(demod); |
| tmp = qam_read_reg(demod, 0x38) & 0x3fffffff; |
| if (tmp >> 29 & 1) |
| tmp -= (1 << 30); |
| |
| freq_off = ((tmp >> 16) * 25 * (symb_rate >> 10)) >> 3; |
| |
| return freq_off; |
| } |
| |
| void qam_auto_scan(struct aml_dtvdemod *demod, int auto_qam_enable) |
| { |
| if (auto_qam_enable) { |
| qam_write_reg(demod, SR_SCAN_SPEED, 0x235cf459); |
| /* j83b */ |
| if (demod->atsc_mode == QAM_64 || demod->atsc_mode == QAM_256 || |
| (!is_meson_t5d_cpu() && !is_meson_s4d_cpu() && !is_meson_s4_cpu() && |
| !is_meson_t3_cpu() && !is_meson_t5w_cpu())) { |
| // qam_write_reg(demod, SR_SCAN_SPEED, 0x235cf459); |
| qam_write_reg(demod, TIM_SWEEP_RANGE_CFG, 0x400); |
| } else { |
| // qam_write_reg(demod, SR_SCAN_SPEED, 0x235cf459); |
| qam_write_reg(demod, TIM_SWEEP_RANGE_CFG, 0x400000); |
| } |
| qam_write_reg(demod, 0x4e, 0x12010012); |
| } else |
| qam_write_reg(demod, 0x4e, 0x12000012); |
| |
| } |
| |
| static unsigned int get_adc_freq(void) |
| { |
| return 24000; |
| } |
| |
| void demod_dvbc_set_qam(struct aml_dtvdemod *demod, enum qam_md_e qam) |
| { |
| /* QAM_GCTL0 */ |
| qam_write_reg(demod, 0x2, (qam_read_reg(demod, 0x2) & ~7) | (qam & 7)); |
| |
| switch (qam) { |
| case QAM_MODE_16: |
| qam_write_reg(demod, 0x71, 0x000a2200); |
| |
| if (cpu_after_eq(MESON_CPU_MAJOR_ID_TL1)) |
| qam_write_reg(demod, 0x72, 0xc2b0c49); |
| else |
| qam_write_reg(demod, 0x72, 0x0c2b04a9); |
| |
| qam_write_reg(demod, 0x73, 0x02020000); |
| qam_write_reg(demod, 0x75, 0x000e9178); |
| qam_write_reg(demod, 0x76, 0x0001c100); |
| qam_write_reg(demod, 0x7a, 0x002ab7ff); |
| qam_write_reg(demod, 0x93, 0x641a180c); |
| qam_write_reg(demod, 0x94, 0x0c141400); |
| break; |
| case QAM_MODE_32: |
| qam_write_reg(demod, 0x71, 0x00061200); |
| qam_write_reg(demod, 0x72, 0x099301ae); |
| qam_write_reg(demod, 0x73, 0x08080000); |
| qam_write_reg(demod, 0x75, 0x000bf10c); |
| qam_write_reg(demod, 0x76, 0x0000a05c); |
| qam_write_reg(demod, 0x77, 0x001000d6); |
| qam_write_reg(demod, 0x7a, 0x0019a7ff); |
| qam_write_reg(demod, 0x7c, 0x00111222); |
| |
| if (cpu_after_eq(MESON_CPU_MAJOR_ID_TL1)) |
| qam_write_reg(demod, 0x7d, 0x2020305); |
| else |
| qam_write_reg(demod, 0x7d, 0x05050505); |
| |
| qam_write_reg(demod, 0x7e, 0x03000d0d); |
| qam_write_reg(demod, 0x93, 0x641f1d0c); |
| qam_write_reg(demod, 0x94, 0x0c1a1a00); |
| break; |
| case QAM_MODE_64: |
| if (cpu_after_eq(MESON_CPU_MAJOR_ID_TL1)) { |
| qam_write_reg(demod, 0x9c, 0x2a132100); |
| qam_write_reg(demod, 0x57, 0x606060d); |
| } |
| break; |
| case QAM_MODE_128: |
| qam_write_reg(demod, 0x71, 0x0002c200); |
| qam_write_reg(demod, 0x72, 0x0a6e0059); |
| qam_write_reg(demod, 0x73, 0x08080000); |
| qam_write_reg(demod, 0x75, 0x000a70e9); |
| qam_write_reg(demod, 0x76, 0x00002013); |
| qam_write_reg(demod, 0x77, 0x00035068); |
| qam_write_reg(demod, 0x78, 0x000ab100); |
| |
| if (cpu_after_eq(MESON_CPU_MAJOR_ID_TL1)) |
| qam_write_reg(demod, 0x7a, 0xba7ff); |
| else |
| qam_write_reg(demod, 0x7a, 0x002ba7ff); |
| |
| qam_write_reg(demod, 0x7c, 0x00111222); |
| |
| if (cpu_after_eq(MESON_CPU_MAJOR_ID_TL1)) |
| qam_write_reg(demod, 0x7d, 0x2020305); |
| else |
| qam_write_reg(demod, 0x7d, 0x05050505); |
| |
| qam_write_reg(demod, 0x7e, 0x03000d0d); |
| qam_write_reg(demod, 0x93, 0x642a240c); |
| qam_write_reg(demod, 0x94, 0x0c262600); |
| break; |
| case QAM_MODE_256: |
| if (cpu_after_eq(MESON_CPU_MAJOR_ID_TL1)) { |
| qam_write_reg(demod, 0x9c, 0x2a232100); |
| qam_write_reg(demod, 0x57, 0x606040d); |
| } |
| break; |
| |
| case QAM_MODE_NUM: |
| default: |
| break; |
| } |
| } |
| |
| void dvbc_reg_initial(struct aml_dtvdemod *demod, struct dvb_frontend *fe) |
| { |
| u32 clk_freq; |
| u32 adc_freq; |
| /*ary no use u8 tuner;*/ |
| u8 ch_mode; |
| u8 agc_mode; |
| u32 ch_freq; |
| u16 ch_if; |
| u16 ch_bw; |
| u16 symb_rate; |
| u32 phs_cfg; |
| int afifo_ctr; |
| int max_frq_off, tmp, adc_format; |
| |
| clk_freq = demod->demod_status.clk_freq; /* kHz */ |
| if (cpu_after_eq(MESON_CPU_MAJOR_ID_TL1)) |
| adc_freq = demod->demod_status.adc_freq; |
| else |
| adc_freq = get_adc_freq();/*24000*/; |
| adc_format = 1; |
| ch_mode = demod->demod_status.ch_mode; |
| agc_mode = demod->demod_status.agc_mode; |
| ch_freq = demod->demod_status.ch_freq; /* kHz */ |
| ch_if = demod->demod_status.ch_if; /* kHz */ |
| ch_bw = demod->demod_status.ch_bw; /* kHz */ |
| symb_rate = demod->demod_status.symb_rate; /* k/sec */ |
| PR_DVBC("ch_if is %d, %d, %d, %d, %d %d\n", |
| ch_if, ch_mode, ch_freq, ch_bw, symb_rate, adc_freq); |
| /* disable irq */ |
| qam_write_reg(demod, 0x34, 0); |
| |
| /* reset */ |
| /*dvbc_reset(); */ |
| qam_write_reg(demod, 0x7, qam_read_reg(demod, 0x7) & ~(1 << 4)); |
| /* disable fsm_en */ |
| qam_write_reg(demod, 0x7, qam_read_reg(demod, 0x7) & ~(1 << 0)); |
| /* Sw disable demod */ |
| qam_write_reg(demod, 0x7, qam_read_reg(demod, 0x7) | (1 << 0)); |
| |
| if (cpu_after_eq(MESON_CPU_MAJOR_ID_TL1)) { |
| if (agc_mode == 1) { |
| qam_write_reg(demod, 0x25, |
| qam_read_reg(demod, 0x25) & ~(0x1 << 10)); |
| qam_write_reg(demod, 0x24, |
| qam_read_reg(demod, 0x24) | (0x1 << 17)); |
| #if 0 |
| qam_write_reg(demod, 0x3d, |
| qam_read_reg(demod, 0x3d) | 0xf); |
| #endif |
| } |
| |
| if (!strncmp(fe->ops.tuner_ops.info.name, "r842", 4)) { |
| qam_write_reg(demod, 0x25, |
| (qam_read_reg(demod, 0x25) & 0xFFFFFFF0) | 0xe); |
| } |
| } |
| |
| /* Sw enable demod */ |
| qam_write_reg(demod, 0x0, 0x0); |
| /* QAM_STATUS */ |
| qam_write_reg(demod, 0x7, 0x00000f00); |
| demod_dvbc_set_qam(demod, ch_mode); |
| /*dvbc_write_reg(QAM_BASE+0x00c, 0xfffffffe);*/ |
| /* // adc_cnt, symb_cnt*/ |
| // if (demod->atsc_mode == QAM_64 || demod->atsc_mode == QAM_256 || |
| // !is_meson_t5d_cpu()) |
| // qam_write_reg(demod, SYMB_CNT_CFG, 0xffff8ffe); |
| // else |
| // qam_write_reg(demod, SYMB_CNT_CFG, 0xffff03ff);//change 0xffff03ff |
| qam_write_reg(demod, SYMB_CNT_CFG, 0xffff8ffe);//change 0xffff03ff |
| /* adc_cnt, symb_cnt by raymond 20121213 */ |
| if (clk_freq == 0) |
| afifo_ctr = 0; |
| else |
| afifo_ctr = (adc_freq * 256 / clk_freq) + 2; |
| if (afifo_ctr > 255) |
| afifo_ctr = 255; |
| qam_write_reg(demod, 0x4, (afifo_ctr << 16) | 8000); |
| /* afifo, rs_cnt_cfg */ |
| |
| /*dvbc_write_reg(QAM_BASE+0x020, 0x21353e54);*/ |
| /* // PHS_reset & TIM_CTRO_ACCURATE sw_tim_select=0*/ |
| /*dvbc_write_reg(QAM_BASE+0x020, 0x21b53e54);*/ |
| /* //modified by qiancheng*/ |
| qam_write_reg(demod, SR_OFFSET_ACC, 0x61b53e54); |
| /*modified by qiancheng by raymond 20121208 0x63b53e54 for cci */ |
| /* dvbc_write_reg(QAM_BASE+0x020, 0x6192bfe2);*/ |
| /* //modifed by ligg 20130613 auto symb_rate scan*/ |
| if (adc_freq == 0) |
| phs_cfg = 0; |
| else |
| phs_cfg = (1 << 31) / adc_freq * ch_if / (1 << 8); |
| /* 8*fo/fs*2^20 fo=36.125, fs = 28.57114, = 21d775 */ |
| /* PR_DVBC("phs_cfg = %x\n", phs_cfg); */ |
| qam_write_reg(demod, 0x9, 0x4c000000 | (phs_cfg & 0x7fffff)); |
| /* PHS_OFFSET, IF offset, */ |
| |
| if (adc_freq == 0) { |
| max_frq_off = 0; |
| } else { |
| max_frq_off = (1 << 29) / symb_rate; |
| /* max_frq_off = (400KHz * 2^29) / */ |
| /* (AD=28571 * symbol_rate=6875) */ |
| tmp = 40000000 / adc_freq; |
| max_frq_off = tmp * max_frq_off; |
| } |
| PR_DVBC("max_frq_off is %x,\n", max_frq_off); |
| |
| if (cpu_after_eq(MESON_CPU_MAJOR_ID_TL1)) { |
| /* j83b */ |
| if (demod->atsc_mode == QAM_64 || demod->atsc_mode == QAM_256 || |
| (!is_meson_t5d_cpu() && !is_meson_s4d_cpu() && !is_meson_s4_cpu() && |
| !is_meson_t3_cpu() && !is_meson_t5w_cpu())) |
| qam_write_reg(demod, SR_SCAN_SPEED, 0x245cf450); |
| else |
| qam_write_reg(demod, SR_SCAN_SPEED, 0x235cf459); |
| } else { |
| qam_write_reg(demod, 0xb, max_frq_off & 0x3fffffff); |
| } |
| /* max frequency offset, by raymond 20121208 */ |
| |
| /* modified by ligg 20130613 --auto symb_rate scan */ |
| qam_write_reg(demod, 0xd, ((adc_freq & 0xffff) << 16) | (symb_rate & 0xffff)); |
| |
| /************* hw state machine config **********/ |
| /*dvbc_write_reg(QAM_BASE + (0x10 << 2), 0x003c);*/ |
| /* configure symbol rate step step 0*/ |
| |
| /* modified 0x44 0x48 */ |
| qam_write_reg(demod, 0x11, (symb_rate & 0xffff) * 256); |
| /* support CI+ card */ |
| //ts_clk and ts_data direction 0x98 0x90 |
| if (demod->ci_mode == 1) |
| qam_write_bits(demod, 0x11, 0x00, 24, 8); |
| else |
| qam_write_bits(demod, 0x11, 0x90, 24, 8); |
| /* blind search, configure max symbol_rate for 7218 fb=3.6M */ |
| /*dvbc_write_reg(QAM_BASE+0x048, 3600*256);*/ |
| /* // configure min symbol_rate fb = 6.95M*/ |
| qam_write_reg(demod, 0x12, (qam_read_reg(demod, 0x12) & ~(0xff << 8)) | 3400 * 256); |
| |
| /************* hw state machine config **********/ |
| if (!cpu_after_eq(MESON_CPU_MAJOR_ID_TL1)) { |
| if ((agc_mode & 1) == 0) |
| /* freeze if agc */ |
| qam_write_reg(demod, 0x25, |
| qam_read_reg(demod, 0x25) | (0x1 << 10)); |
| if ((agc_mode & 2) == 0) { |
| /* IF control */ |
| /*freeze rf agc */ |
| qam_write_reg(demod, 0x25, |
| qam_read_reg(demod, 0x25) | (0x1 << 13)); |
| } |
| } |
| |
| if (!cpu_after_eq(MESON_CPU_MAJOR_ID_TL1)) |
| qam_write_reg(demod, 0x28, |
| qam_read_reg(demod, 0x28) | (adc_format << 27)); |
| |
| qam_write_reg(demod, 0x7, qam_read_reg(demod, 0x7) | 0x33); |
| /* IMQ, QAM Enable */ |
| |
| /* start hardware machine */ |
| qam_write_reg(demod, 0x7, qam_read_reg(demod, 0x7) | (1 << 4)); |
| qam_write_reg(demod, 0x3a, qam_read_reg(demod, 0x3a) | (1 << 2)); |
| |
| /* clear irq status */ |
| qam_read_reg(demod, 0x35); |
| |
| /* enable irq */ |
| qam_write_reg(demod, 0x34, 0x7fff << 3); |
| |
| if (is_meson_txlx_cpu() || cpu_after_eq(MESON_CPU_MAJOR_ID_TL1)) { |
| /*my_tool setting j83b mode*/ |
| qam_write_reg(demod, 0x7, 0x10f33); |
| |
| switch (demod->demod_status.delsys) { |
| case SYS_ATSC: |
| case SYS_ATSCMH: |
| case SYS_DVBC_ANNEX_B: |
| #ifndef CONFIG_AMLOGIC_REMOVE_OLD |
| if (is_meson_txlx_cpu()) { |
| /*j83b filter para*/ |
| qam_write_reg(demod, 0x40, 0x3f010201); |
| qam_write_reg(demod, 0x41, 0x0a003a3b); |
| qam_write_reg(demod, 0x42, 0xe1ee030e); |
| qam_write_reg(demod, 0x43, 0x002601f2); |
| qam_write_reg(demod, 0x44, 0x009b006b); |
| qam_write_reg(demod, 0x45, 0xb3a1905); |
| qam_write_reg(demod, 0x46, 0x1c396e07); |
| qam_write_reg(demod, 0x47, 0x3801cc08); |
| qam_write_reg(demod, 0x48, 0x10800a2); |
| qam_write_reg(demod, 0x12, 0x50e1000); |
| qam_write_reg(demod, 0x30, 0x41f2f69); |
| /*j83b_symbolrate(please see register doc)*/ |
| qam_write_reg(demod, 0x4d, 0x23d125f7); |
| /*for phase noise case 256qam*/ |
| qam_write_reg(demod, 0x9c, 0x2a232100); |
| qam_write_reg(demod, 0x57, 0x606040d); |
| /*for phase noise case 64qam*/ |
| qam_write_reg(demod, 0x54, 0x606050d); |
| qam_write_reg(demod, 0x52, 0x346dc); |
| } |
| #endif |
| break; |
| default: |
| break; |
| } |
| |
| qam_auto_scan(demod, 1); |
| } |
| |
| qam_write_reg(demod, 0x7, 0x10f23); |
| qam_write_reg(demod, 0x3a, 0x0); |
| qam_write_reg(demod, 0x7, 0x10f33); |
| /*enable fsm, sm start work, need wait some time(2ms) for AGC stable*/ |
| qam_write_reg(demod, 0x3a, 0x4); |
| /*auto track*/ |
| /*dvbc_set_auto_symtrack(demod); */ |
| } |
| |
| u32 dvbc_set_auto_symtrack(struct aml_dtvdemod *demod) |
| { |
| if (cpu_after_eq(MESON_CPU_MAJOR_ID_TL1)) |
| return 0; |
| |
| qam_write_reg(demod, SR_SCAN_SPEED, 0x245bf45c); /*open track */ |
| qam_write_reg(demod, SR_OFFSET_ACC, 0x61b2bf5c); |
| qam_write_reg(demod, 0x11, (7000 & 0xffff) * 256); |
| qam_write_reg(demod, TIM_SWEEP_RANGE_CFG, 0x00220000); |
| qam_write_reg(demod, 0x7, qam_read_reg(demod, 0x7) & ~(1 << 0)); |
| /* Sw disable demod */ |
| qam_write_reg(demod, 0x7, qam_read_reg(demod, 0x7) | (1 << 0)); |
| /* Sw enable demod */ |
| return 0; |
| } |
| |
| int dvbc_status(struct aml_dtvdemod *demod, struct aml_demod_sts *demod_sts, struct seq_file *seq) |
| { |
| struct amldtvdemod_device_s *devp = (struct amldtvdemod_device_s *)demod->priv; |
| |
| if (unlikely(!devp)) { |
| PR_ERR("devp is NULL, return\n"); |
| return -1; |
| } |
| |
| demod_sts->ch_sts = qam_read_reg(demod, 0x6); |
| demod_sts->ch_pow = dvbc_get_ch_power(demod); |
| demod_sts->ch_snr = dvbc_get_snr(demod); |
| demod_sts->ch_ber = dvbc_get_ber(demod); |
| demod_sts->ch_per = dvbc_get_per(demod); |
| demod_sts->symb_rate = dvbc_get_symb_rate(demod); |
| demod_sts->freq_off = dvbc_get_freq_off(demod); |
| demod_sts->dat1 = tuner_get_ch_power(&demod->frontend); |
| |
| if (seq) { |
| seq_printf(seq, "ch_sts:0x%x,snr:%ddB,ber:%d,per:%d,srate:%d,freqoff:%dkHz\n", |
| demod_sts->ch_sts, demod_sts->ch_snr / 100, demod_sts->ch_ber, |
| demod_sts->ch_per, demod_sts->symb_rate, demod_sts->freq_off); |
| seq_printf(seq, "strength:%ddb,0xe0 status:%u,b4 status:%u,dagc_gain:%u\n", |
| demod_sts->dat1, qam_read_reg(demod, 0x38) & 0xffff, |
| qam_read_reg(demod, 0x2d) & 0xffff, qam_read_reg(demod, 0x29) & 0x7f); |
| seq_printf(seq, "power:%ddb,0x31=0x%x\n", demod_sts->ch_pow & 0xffff, |
| qam_read_reg(demod, 0x31)); |
| } else { |
| PR_DVBC("ch_sts is 0x%x, snr %ddB, ber %d, per %d, srate %d, freqoff %dkHz\n", |
| demod_sts->ch_sts, demod_sts->ch_snr / 100, demod_sts->ch_ber, |
| demod_sts->ch_per, demod_sts->symb_rate, demod_sts->freq_off); |
| PR_DVBC("strength %ddb,0xe0 status %u,b4 status %u, dagc_gain %u, power %ddb\n\n", |
| demod_sts->dat1, qam_read_reg(demod, 0x38) & 0xffff, |
| qam_read_reg(demod, 0x2d) & 0xffff, qam_read_reg(demod, 0x29) & 0x7f, |
| demod_sts->ch_pow & 0xffff); |
| PR_DVBC("0x31=0x%x\n", qam_read_reg(demod, 0x31)); |
| } |
| |
| return 0; |
| } |
| |
| void dvbc_enable_irq(struct aml_dtvdemod *demod, int dvbc_irq) |
| { |
| u32 mask; |
| |
| /* clear status */ |
| qam_read_reg(demod, 0x35); |
| /* enable irq */ |
| mask = qam_read_reg(demod, 0x34); |
| mask |= (1 << dvbc_irq); |
| qam_write_reg(demod, 0x34, mask); |
| } |
| |
| void dvbc_init_reg_ext(struct aml_dtvdemod *demod) |
| { |
| /*ary move from amlfrontend.c */ |
| qam_write_reg(demod, 0x7, 0xf33); |
| |
| if (cpu_after_eq(MESON_CPU_MAJOR_ID_TL1)) { |
| /* set min sr to 2000 for cover 3000 ~ 7000 */ |
| qam_write_reg(demod, 0x12, 0x507d000); |
| qam_write_reg(demod, 0x30, 0x41f2f69); |
| } |
| } |
| |
| u32 dvbc_get_ch_sts(struct aml_dtvdemod *demod) |
| { |
| return qam_read_reg(demod, 0x6); |
| } |
| |
| u32 dvbc_get_qam_mode(struct aml_dtvdemod *demod) |
| { |
| return qam_read_reg(demod, 0x2) & 7; |
| } |