diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/media/dvb/frontends/mt352.c | 28 |
1 files changed, 14 insertions, 14 deletions
diff --git a/drivers/media/dvb/frontends/mt352.c b/drivers/media/dvb/frontends/mt352.c index 50326c7248fa..2d13a412ce6a 100644 --- a/drivers/media/dvb/frontends/mt352.c +++ b/drivers/media/dvb/frontends/mt352.c | |||
@@ -46,7 +46,7 @@ struct mt352_state { | |||
46 | struct dvb_frontend_ops ops; | 46 | struct dvb_frontend_ops ops; |
47 | 47 | ||
48 | /* configuration settings */ | 48 | /* configuration settings */ |
49 | const struct mt352_config* config; | 49 | struct mt352_config config; |
50 | }; | 50 | }; |
51 | 51 | ||
52 | static int debug; | 52 | static int debug; |
@@ -59,7 +59,7 @@ static int mt352_single_write(struct dvb_frontend *fe, u8 reg, u8 val) | |||
59 | { | 59 | { |
60 | struct mt352_state* state = fe->demodulator_priv; | 60 | struct mt352_state* state = fe->demodulator_priv; |
61 | u8 buf[2] = { reg, val }; | 61 | u8 buf[2] = { reg, val }; |
62 | struct i2c_msg msg = { .addr = state->config->demod_address, .flags = 0, | 62 | struct i2c_msg msg = { .addr = state->config.demod_address, .flags = 0, |
63 | .buf = buf, .len = 2 }; | 63 | .buf = buf, .len = 2 }; |
64 | int err = i2c_transfer(state->i2c, &msg, 1); | 64 | int err = i2c_transfer(state->i2c, &msg, 1); |
65 | if (err != 1) { | 65 | if (err != 1) { |
@@ -84,10 +84,10 @@ static int mt352_read_register(struct mt352_state* state, u8 reg) | |||
84 | int ret; | 84 | int ret; |
85 | u8 b0 [] = { reg }; | 85 | u8 b0 [] = { reg }; |
86 | u8 b1 [] = { 0 }; | 86 | u8 b1 [] = { 0 }; |
87 | struct i2c_msg msg [] = { { .addr = state->config->demod_address, | 87 | struct i2c_msg msg [] = { { .addr = state->config.demod_address, |
88 | .flags = 0, | 88 | .flags = 0, |
89 | .buf = b0, .len = 1 }, | 89 | .buf = b0, .len = 1 }, |
90 | { .addr = state->config->demod_address, | 90 | { .addr = state->config.demod_address, |
91 | .flags = I2C_M_RD, | 91 | .flags = I2C_M_RD, |
92 | .buf = b1, .len = 1 } }; | 92 | .buf = b1, .len = 1 } }; |
93 | 93 | ||
@@ -134,8 +134,8 @@ static void mt352_calc_nominal_rate(struct mt352_state* state, | |||
134 | bw = 8; | 134 | bw = 8; |
135 | break; | 135 | break; |
136 | } | 136 | } |
137 | if (state->config->adc_clock) | 137 | if (state->config.adc_clock) |
138 | adc_clock = state->config->adc_clock; | 138 | adc_clock = state->config.adc_clock; |
139 | 139 | ||
140 | value = 64 * bw * (1<<16) / (7 * 8); | 140 | value = 64 * bw * (1<<16) / (7 * 8); |
141 | value = value * 1000 / adc_clock; | 141 | value = value * 1000 / adc_clock; |
@@ -152,10 +152,10 @@ static void mt352_calc_input_freq(struct mt352_state* state, | |||
152 | int if2 = 36167; /* 36.166667 MHz */ | 152 | int if2 = 36167; /* 36.166667 MHz */ |
153 | int ife,value; | 153 | int ife,value; |
154 | 154 | ||
155 | if (state->config->adc_clock) | 155 | if (state->config.adc_clock) |
156 | adc_clock = state->config->adc_clock; | 156 | adc_clock = state->config.adc_clock; |
157 | if (state->config->if2) | 157 | if (state->config.if2) |
158 | if2 = state->config->if2; | 158 | if2 = state->config.if2; |
159 | 159 | ||
160 | ife = (2*adc_clock - if2); | 160 | ife = (2*adc_clock - if2); |
161 | value = -16374 * ife / adc_clock; | 161 | value = -16374 * ife / adc_clock; |
@@ -289,10 +289,10 @@ static int mt352_set_parameters(struct dvb_frontend* fe, | |||
289 | 289 | ||
290 | mt352_calc_nominal_rate(state, op->bandwidth, buf+4); | 290 | mt352_calc_nominal_rate(state, op->bandwidth, buf+4); |
291 | mt352_calc_input_freq(state, buf+6); | 291 | mt352_calc_input_freq(state, buf+6); |
292 | state->config->pll_set(fe, param, buf+8); | 292 | state->config.pll_set(fe, param, buf+8); |
293 | 293 | ||
294 | mt352_write(fe, buf, sizeof(buf)); | 294 | mt352_write(fe, buf, sizeof(buf)); |
295 | if (state->config->no_tuner) { | 295 | if (state->config.no_tuner) { |
296 | /* start decoding */ | 296 | /* start decoding */ |
297 | mt352_write(fe, fsm_go, 2); | 297 | mt352_write(fe, fsm_go, 2); |
298 | } else { | 298 | } else { |
@@ -516,7 +516,7 @@ static int mt352_init(struct dvb_frontend* fe) | |||
516 | 516 | ||
517 | /* Do a "hard" reset */ | 517 | /* Do a "hard" reset */ |
518 | mt352_write(fe, mt352_reset_attach, sizeof(mt352_reset_attach)); | 518 | mt352_write(fe, mt352_reset_attach, sizeof(mt352_reset_attach)); |
519 | return state->config->demod_init(fe); | 519 | return state->config.demod_init(fe); |
520 | } | 520 | } |
521 | 521 | ||
522 | return 0; | 522 | return 0; |
@@ -541,8 +541,8 @@ struct dvb_frontend* mt352_attach(const struct mt352_config* config, | |||
541 | memset(state,0,sizeof(*state)); | 541 | memset(state,0,sizeof(*state)); |
542 | 542 | ||
543 | /* setup the state */ | 543 | /* setup the state */ |
544 | state->config = config; | ||
545 | state->i2c = i2c; | 544 | state->i2c = i2c; |
545 | memcpy(&state->config,config,sizeof(struct mt352_config)); | ||
546 | memcpy(&state->ops, &mt352_ops, sizeof(struct dvb_frontend_ops)); | 546 | memcpy(&state->ops, &mt352_ops, sizeof(struct dvb_frontend_ops)); |
547 | 547 | ||
548 | /* check if the demod is there */ | 548 | /* check if the demod is there */ |