Commit d92532d9 authored by Patrick Boettcher's avatar Patrick Boettcher Committed by Mauro Carvalho Chehab

V4L/DVB (4773): Misc fixes for DiB3000 and DiB7000

This patch contains several fixes for the autosearch algorithm and other small ones.
Signed-off-by: default avatarPatrick Boettcher <pb@linuxtv.org>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@infradead.org>
parent a75763ff
...@@ -511,16 +511,11 @@ static int dib3000mc_autosearch_start(struct dvb_frontend *demod, struct dibx000 ...@@ -511,16 +511,11 @@ static int dib3000mc_autosearch_start(struct dvb_frontend *demod, struct dibx000
/* a channel for autosearch */ /* a channel for autosearch */
reg = 0;
if (chan->nfft == -1 && chan->guard == -1) reg = 7;
if (chan->nfft == -1 && chan->guard != -1) reg = 2;
if (chan->nfft != -1 && chan->guard == -1) reg = 3;
fchan.nfft = 1; fchan.guard = 0; fchan.nqam = 2; fchan.nfft = 1; fchan.guard = 0; fchan.nqam = 2;
fchan.vit_alpha = 1; fchan.vit_code_rate_hp = 2; fchan.vit_code_rate_lp = 2; fchan.vit_alpha = 1; fchan.vit_code_rate_hp = 2; fchan.vit_code_rate_lp = 2;
fchan.vit_hrch = 0; fchan.vit_select_hp = 1; fchan.vit_hrch = 0; fchan.vit_select_hp = 1;
dib3000mc_set_channel_cfg(state, &fchan, reg); dib3000mc_set_channel_cfg(state, &fchan, 7);
reg = dib3000mc_read_word(state, 0); reg = dib3000mc_read_word(state, 0);
dib3000mc_write_word(state, 0, reg | (1 << 8)); dib3000mc_write_word(state, 0, reg | (1 << 8));
......
...@@ -637,15 +637,14 @@ static int dib7000m_autosearch_start(struct dvb_frontend *demod, struct dibx000_ ...@@ -637,15 +637,14 @@ static int dib7000m_autosearch_start(struct dvb_frontend *demod, struct dibx000_
struct dib7000m_state *state = demod->demodulator_priv; struct dib7000m_state *state = demod->demodulator_priv;
struct dibx000_ofdm_channel auto_ch; struct dibx000_ofdm_channel auto_ch;
int ret = 0; int ret = 0;
u8 seq;
u32 value; u32 value;
INIT_OFDM_CHANNEL(&auto_ch); INIT_OFDM_CHANNEL(&auto_ch);
auto_ch.RF_kHz = ch->RF_kHz; auto_ch.RF_kHz = ch->RF_kHz;
auto_ch.Bw = ch->Bw; auto_ch.Bw = ch->Bw;
auto_ch.nqam = 2; auto_ch.nqam = 2;
auto_ch.guard = ch->guard == GUARD_INTERVAL_AUTO ? 0 : ch->guard; auto_ch.guard = 0;
auto_ch.nfft = ch->nfft == -1 ? 1 : ch->nfft; auto_ch.nfft = 1;
auto_ch.vit_alpha = 1; auto_ch.vit_alpha = 1;
auto_ch.vit_select_hp = 1; auto_ch.vit_select_hp = 1;
auto_ch.vit_code_rate_hp = 2; auto_ch.vit_code_rate_hp = 2;
...@@ -653,20 +652,16 @@ static int dib7000m_autosearch_start(struct dvb_frontend *demod, struct dibx000_ ...@@ -653,20 +652,16 @@ static int dib7000m_autosearch_start(struct dvb_frontend *demod, struct dibx000_
auto_ch.vit_hrch = 0; auto_ch.vit_hrch = 0;
auto_ch.intlv_native = 1; auto_ch.intlv_native = 1;
seq = 0; dib7000m_set_channel(state, &auto_ch, 7);
if (ch->nfft == -1 && ch->guard == GUARD_INTERVAL_AUTO) seq = 7;
if (ch->nfft == -1 && ch->guard != GUARD_INTERVAL_AUTO) seq = 2;
if (ch->nfft != -1 && ch->guard == GUARD_INTERVAL_AUTO) seq = 3;
dib7000m_set_channel(state, &auto_ch, seq);
// always use the setting for 8MHz here lock_time for 7,6 MHz are longer // always use the setting for 8MHz here lock_time for 7,6 MHz are longer
value = 30 * state->cfg.bw[BANDWIDTH_8_MHZ].internal; value = 30 * state->cfg.bw->internal;
ret |= dib7000m_write_word(state, 6, (u16) ((value >> 16) & 0xffff)); // lock0 wait time ret |= dib7000m_write_word(state, 6, (u16) ((value >> 16) & 0xffff)); // lock0 wait time
ret |= dib7000m_write_word(state, 7, (u16) (value & 0xffff)); // lock0 wait time ret |= dib7000m_write_word(state, 7, (u16) (value & 0xffff)); // lock0 wait time
value = 100 * state->cfg.bw[BANDWIDTH_8_MHZ].internal; value = 100 * state->cfg.bw->internal;
ret |= dib7000m_write_word(state, 8, (u16) ((value >> 16) & 0xffff)); // lock1 wait time ret |= dib7000m_write_word(state, 8, (u16) ((value >> 16) & 0xffff)); // lock1 wait time
ret |= dib7000m_write_word(state, 9, (u16) (value & 0xffff)); // lock1 wait time ret |= dib7000m_write_word(state, 9, (u16) (value & 0xffff)); // lock1 wait time
value = 500 * state->cfg.bw[BANDWIDTH_8_MHZ].internal; value = 500 * state->cfg.bw->internal;
ret |= dib7000m_write_word(state, 10, (u16) ((value >> 16) & 0xffff)); // lock2 wait time ret |= dib7000m_write_word(state, 10, (u16) ((value >> 16) & 0xffff)); // lock2 wait time
ret |= dib7000m_write_word(state, 11, (u16) (value & 0xffff)); // lock2 wait time ret |= dib7000m_write_word(state, 11, (u16) (value & 0xffff)); // lock2 wait time
...@@ -919,7 +914,7 @@ static int dib7000m_get_frontend(struct dvb_frontend* fe, ...@@ -919,7 +914,7 @@ static int dib7000m_get_frontend(struct dvb_frontend* fe,
fep->u.ofdm.bandwidth = state->current_bandwidth; fep->u.ofdm.bandwidth = state->current_bandwidth;
switch ((tps >> 8) & 0x2) { switch ((tps >> 8) & 0x3) {
case 0: fep->u.ofdm.transmission_mode = TRANSMISSION_MODE_2K; break; case 0: fep->u.ofdm.transmission_mode = TRANSMISSION_MODE_2K; break;
case 1: fep->u.ofdm.transmission_mode = TRANSMISSION_MODE_8K; break; case 1: fep->u.ofdm.transmission_mode = TRANSMISSION_MODE_8K; break;
/* case 2: fep->u.ofdm.transmission_mode = TRANSMISSION_MODE_4K; break; */ /* case 2: fep->u.ofdm.transmission_mode = TRANSMISSION_MODE_4K; break; */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment