Lines Matching full:state
58 state->bt->nr, __func__ , ##arg); \
61 state->bt->nr, __func__ , ##arg); \
64 state->bt->nr, __func__ , ##arg); \
67 state->bt->nr, __func__ , ##arg); \
74 static int dst_command(struct dst_state *state, u8 *data, u8 len);
76 static void dst_packsize(struct dst_state *state, int psize) in dst_packsize() argument
81 bt878_device_control(state->bt, DST_IG_TS, &bits); in dst_packsize()
84 static int dst_gpio_outb(struct dst_state *state, u32 mask, u32 enbb, in dst_gpio_outb() argument
95 if ((err = bt878_device_control(state->bt, DST_IG_ENABLE, &enb)) < 0) { in dst_gpio_outb()
107 if ((err = bt878_device_control(state->bt, DST_IG_WRITE, &bits)) < 0) { in dst_gpio_outb()
115 static int dst_gpio_inb(struct dst_state *state, u8 *result) in dst_gpio_inb() argument
121 if ((err = bt878_device_control(state->bt, DST_IG_READ, &rd_packet)) < 0) { in dst_gpio_inb()
130 int rdc_reset_state(struct dst_state *state) in rdc_reset_state() argument
132 dprintk(verbose, DST_INFO, 1, "Resetting state machine"); in rdc_reset_state()
133 if (dst_gpio_outb(state, RDC_8820_INT, RDC_8820_INT, 0, NO_DELAY) < 0) { in rdc_reset_state()
138 if (dst_gpio_outb(state, RDC_8820_INT, RDC_8820_INT, RDC_8820_INT, NO_DELAY) < 0) { in rdc_reset_state()
148 static int rdc_8820_reset(struct dst_state *state) in rdc_8820_reset() argument
151 if (dst_gpio_outb(state, RDC_8820_RESET, RDC_8820_RESET, 0, NO_DELAY) < 0) { in rdc_8820_reset()
156 if (dst_gpio_outb(state, RDC_8820_RESET, RDC_8820_RESET, RDC_8820_RESET, DELAY) < 0) { in rdc_8820_reset()
164 static int dst_pio_enable(struct dst_state *state) in dst_pio_enable() argument
166 if (dst_gpio_outb(state, ~0, RDC_8820_PIO_0_ENABLE, 0, NO_DELAY) < 0) { in dst_pio_enable()
175 int dst_pio_disable(struct dst_state *state) in dst_pio_disable() argument
177 if (dst_gpio_outb(state, ~0, RDC_8820_PIO_0_DISABLE, RDC_8820_PIO_0_DISABLE, NO_DELAY) < 0) { in dst_pio_disable()
181 if (state->type_flags & DST_TYPE_HAS_FW_1) in dst_pio_disable()
188 int dst_wait_dst_ready(struct dst_state *state, u8 delay_mode) in dst_wait_dst_ready() argument
194 if (dst_gpio_inb(state, &reply) < 0) { in dst_wait_dst_ready()
210 int dst_error_recovery(struct dst_state *state) in dst_error_recovery() argument
213 dst_pio_disable(state); in dst_error_recovery()
215 dst_pio_enable(state); in dst_error_recovery()
222 int dst_error_bailout(struct dst_state *state) in dst_error_bailout() argument
225 rdc_8820_reset(state); in dst_error_bailout()
226 dst_pio_disable(state); in dst_error_bailout()
233 int dst_comm_init(struct dst_state *state) in dst_comm_init() argument
236 if ((dst_pio_enable(state)) < 0) { in dst_comm_init()
240 if ((rdc_reset_state(state)) < 0) { in dst_comm_init()
241 dprintk(verbose, DST_ERROR, 1, "RDC 8820 State RESET Failed."); in dst_comm_init()
244 if (state->type_flags & DST_TYPE_HAS_FW_1) in dst_comm_init()
253 int write_dst(struct dst_state *state, u8 *data, u8 len) in write_dst() argument
256 .addr = state->config->demod_address, in write_dst()
271 if ((err = i2c_transfer(state->i2c, &msg, 1)) < 0) { in write_dst()
273 dst_error_recovery(state); in write_dst()
280 dst_error_bailout(state); in write_dst()
289 int read_dst(struct dst_state *state, u8 *ret, u8 len) in read_dst() argument
292 .addr = state->config->demod_address, in read_dst()
302 if ((err = i2c_transfer(state->i2c, &msg, 1)) < 0) { in read_dst()
304 dst_error_recovery(state); in read_dst()
311 dst_error_bailout(state); in read_dst()
325 static int dst_set_polarization(struct dst_state *state) in dst_set_polarization() argument
327 switch (state->voltage) { in dst_set_polarization()
330 state->tx_tuna[8] &= ~0x40; in dst_set_polarization()
334 state->tx_tuna[8] |= 0x40; in dst_set_polarization()
343 static int dst_set_freq(struct dst_state *state, u32 freq) in dst_set_freq() argument
345 state->frequency = freq; in dst_set_freq()
348 if (state->dst_type == DST_TYPE_IS_SAT) { in dst_set_freq()
352 state->tx_tuna[2] = (freq >> 8); in dst_set_freq()
353 state->tx_tuna[3] = (u8) freq; in dst_set_freq()
354 state->tx_tuna[4] = 0x01; in dst_set_freq()
355 state->tx_tuna[8] &= ~0x04; in dst_set_freq()
356 if (state->type_flags & DST_TYPE_HAS_OBS_REGS) { in dst_set_freq()
358 state->tx_tuna[8] |= 0x04; in dst_set_freq()
360 } else if (state->dst_type == DST_TYPE_IS_TERR) { in dst_set_freq()
364 state->tx_tuna[2] = (freq >> 16) & 0xff; in dst_set_freq()
365 state->tx_tuna[3] = (freq >> 8) & 0xff; in dst_set_freq()
366 state->tx_tuna[4] = (u8) freq; in dst_set_freq()
367 } else if (state->dst_type == DST_TYPE_IS_CABLE) { in dst_set_freq()
369 state->tx_tuna[2] = (freq >> 16) & 0xff; in dst_set_freq()
370 state->tx_tuna[3] = (freq >> 8) & 0xff; in dst_set_freq()
371 state->tx_tuna[4] = (u8) freq; in dst_set_freq()
372 } else if (state->dst_type == DST_TYPE_IS_ATSC) { in dst_set_freq()
376 state->tx_tuna[2] = (freq >> 16) & 0xff; in dst_set_freq()
377 state->tx_tuna[3] = (freq >> 8) & 0xff; in dst_set_freq()
378 state->tx_tuna[4] = (u8) freq; in dst_set_freq()
379 state->tx_tuna[5] = 0x00; /* ATSC */ in dst_set_freq()
380 state->tx_tuna[6] = 0x00; in dst_set_freq()
381 if (state->dst_hw_cap & DST_TYPE_HAS_ANALOG) in dst_set_freq()
382 state->tx_tuna[7] = 0x00; /* Digital */ in dst_set_freq()
389 static int dst_set_bandwidth(struct dst_state *state, u32 bandwidth) in dst_set_bandwidth() argument
391 state->bandwidth = bandwidth; in dst_set_bandwidth()
393 if (state->dst_type != DST_TYPE_IS_TERR) in dst_set_bandwidth()
398 if (state->dst_hw_cap & DST_TYPE_HAS_CA) in dst_set_bandwidth()
399 state->tx_tuna[7] = 0x06; in dst_set_bandwidth()
401 state->tx_tuna[6] = 0x06; in dst_set_bandwidth()
402 state->tx_tuna[7] = 0x00; in dst_set_bandwidth()
406 if (state->dst_hw_cap & DST_TYPE_HAS_CA) in dst_set_bandwidth()
407 state->tx_tuna[7] = 0x07; in dst_set_bandwidth()
409 state->tx_tuna[6] = 0x07; in dst_set_bandwidth()
410 state->tx_tuna[7] = 0x00; in dst_set_bandwidth()
414 if (state->dst_hw_cap & DST_TYPE_HAS_CA) in dst_set_bandwidth()
415 state->tx_tuna[7] = 0x08; in dst_set_bandwidth()
417 state->tx_tuna[6] = 0x08; in dst_set_bandwidth()
418 state->tx_tuna[7] = 0x00; in dst_set_bandwidth()
428 static int dst_set_inversion(struct dst_state *state, fe_spectral_inversion_t inversion) in dst_set_inversion() argument
430 state->inversion = inversion; in dst_set_inversion()
433 state->tx_tuna[8] &= ~0x80; in dst_set_inversion()
436 state->tx_tuna[8] |= 0x80; in dst_set_inversion()
445 static int dst_set_fec(struct dst_state *state, fe_code_rate_t fec) in dst_set_fec() argument
447 state->fec = fec; in dst_set_fec()
451 static fe_code_rate_t dst_get_fec(struct dst_state *state) in dst_get_fec() argument
453 return state->fec; in dst_get_fec()
456 static int dst_set_symbolrate(struct dst_state *state, u32 srate) in dst_set_symbolrate() argument
461 state->symbol_rate = srate; in dst_set_symbolrate()
462 if (state->dst_type == DST_TYPE_IS_TERR) { in dst_set_symbolrate()
467 if (state->dst_type == DST_TYPE_IS_SAT) { in dst_set_symbolrate()
468 if (state->type_flags & DST_TYPE_HAS_SYMDIV) { in dst_set_symbolrate()
474 state->tx_tuna[5] = (u8) (symcalc >> 12); in dst_set_symbolrate()
475 state->tx_tuna[6] = (u8) (symcalc >> 4); in dst_set_symbolrate()
476 state->tx_tuna[7] = (u8) (symcalc << 4); in dst_set_symbolrate()
478 state->tx_tuna[5] = (u8) (srate >> 16) & 0x7f; in dst_set_symbolrate()
479 state->tx_tuna[6] = (u8) (srate >> 8); in dst_set_symbolrate()
480 state->tx_tuna[7] = (u8) srate; in dst_set_symbolrate()
482 state->tx_tuna[8] &= ~0x20; in dst_set_symbolrate()
483 if (state->type_flags & DST_TYPE_HAS_OBS_REGS) { in dst_set_symbolrate()
485 state->tx_tuna[8] |= 0x20; in dst_set_symbolrate()
487 } else if (state->dst_type == DST_TYPE_IS_CABLE) { in dst_set_symbolrate()
488 dprintk(verbose, DST_DEBUG, 1, "%s", state->fw_name); in dst_set_symbolrate()
489 if (!strncmp(state->fw_name, "DCTNEW", 6)) { in dst_set_symbolrate()
490 state->tx_tuna[5] = (u8) (srate >> 8); in dst_set_symbolrate()
491 state->tx_tuna[6] = (u8) srate; in dst_set_symbolrate()
492 state->tx_tuna[7] = 0x00; in dst_set_symbolrate()
493 } else if (!strncmp(state->fw_name, "DCT-CI", 6)) { in dst_set_symbolrate()
494 state->tx_tuna[5] = 0x00; in dst_set_symbolrate()
495 state->tx_tuna[6] = (u8) (srate >> 8); in dst_set_symbolrate()
496 state->tx_tuna[7] = (u8) srate; in dst_set_symbolrate()
502 static int dst_set_modulation(struct dst_state *state, fe_modulation_t modulation) in dst_set_modulation() argument
504 if (state->dst_type != DST_TYPE_IS_CABLE) in dst_set_modulation()
507 state->modulation = modulation; in dst_set_modulation()
510 state->tx_tuna[8] = 0x10; in dst_set_modulation()
513 state->tx_tuna[8] = 0x20; in dst_set_modulation()
516 state->tx_tuna[8] = 0x40; in dst_set_modulation()
519 state->tx_tuna[8] = 0x80; in dst_set_modulation()
522 if (!strncmp(state->fw_name, "DCTNEW", 6)) in dst_set_modulation()
523 state->tx_tuna[8] = 0xff; in dst_set_modulation()
524 else if (!strncmp(state->fw_name, "DCT-CI", 6)) in dst_set_modulation()
525 state->tx_tuna[8] = 0x00; in dst_set_modulation()
539 static fe_modulation_t dst_get_modulation(struct dst_state *state) in dst_get_modulation() argument
541 return state->modulation; in dst_get_modulation()
558 static void dst_type_flags_print(struct dst_state *state) in dst_type_flags_print() argument
560 u32 type_flags = state->type_flags; in dst_type_flags_print()
583 static int dst_type_print(struct dst_state *state, u8 type) in dst_type_print() argument
910 static int dst_get_mac(struct dst_state *state) in dst_get_mac() argument
914 if (dst_command(state, get_mac, 8) < 0) { in dst_get_mac()
918 memset(&state->mac_address, '\0', 8); in dst_get_mac()
919 memcpy(&state->mac_address, &state->rxbuffer, 6); in dst_get_mac()
920 dprintk(verbose, DST_ERROR, 1, "MAC Address=[%pM]", state->mac_address); in dst_get_mac()
925 static int dst_fw_ver(struct dst_state *state) in dst_fw_ver() argument
929 if (dst_command(state, get_ver, 8) < 0) { in dst_fw_ver()
933 memcpy(&state->fw_version, &state->rxbuffer, 8); in dst_fw_ver()
935 state->fw_version[0] >> 4, state->fw_version[0] & 0x0f, in dst_fw_ver()
936 state->fw_version[1], in dst_fw_ver()
937 state->fw_version[5], state->fw_version[6], in dst_fw_ver()
938 state->fw_version[4], state->fw_version[3], state->fw_version[2]); in dst_fw_ver()
943 static int dst_card_type(struct dst_state *state) in dst_card_type() argument
950 if (dst_command(state, get_type, 8) < 0) { in dst_card_type()
954 memset(&state->card_info, '\0', 8); in dst_card_type()
955 memcpy(&state->card_info, &state->rxbuffer, 7); in dst_card_type()
956 dprintk(verbose, DST_ERROR, 1, "Device Model=[%s]", &state->card_info[0]); in dst_card_type()
959 if (!strcmp(&state->card_info[0], p_tuner_list->board_name)) { in dst_card_type()
960 state->tuner_type = p_tuner_list->tuner_type; in dst_card_type()
969 static int dst_get_vendor(struct dst_state *state) in dst_get_vendor() argument
973 if (dst_command(state, get_vendor, 8) < 0) { in dst_get_vendor()
977 memset(&state->vendor, '\0', 8); in dst_get_vendor()
978 memcpy(&state->vendor, &state->rxbuffer, 7); in dst_get_vendor()
979 dprintk(verbose, DST_ERROR, 1, "Vendor=[%s]", &state->vendor[0]); in dst_get_vendor()
984 static void debug_dst_buffer(struct dst_state *state) in debug_dst_buffer() argument
991 printk(" %02x", state->rxbuffer[i]); in debug_dst_buffer()
996 static int dst_check_stv0299(struct dst_state *state) in dst_check_stv0299() argument
1001 if (dst_command(state, check_stv0299, 8) < 0) { in dst_check_stv0299()
1005 debug_dst_buffer(state); in dst_check_stv0299()
1007 if (memcmp(&check_stv0299, &state->rxbuffer, 8)) { in dst_check_stv0299()
1009 state->tuner_type = TUNER_TYPE_STV0299; in dst_check_stv0299()
1016 static int dst_check_mb86a15(struct dst_state *state) in dst_check_mb86a15() argument
1021 if (dst_command(state, check_mb86a15, 8) < 0) { in dst_check_mb86a15()
1025 debug_dst_buffer(state); in dst_check_mb86a15()
1027 if (memcmp(&check_mb86a15, &state->rxbuffer, 8) < 0) { in dst_check_mb86a15()
1029 state->tuner_type = TUNER_TYPE_MB86A15; in dst_check_mb86a15()
1036 static int dst_get_tuner_info(struct dst_state *state) in dst_get_tuner_info() argument
1044 if (state->type_flags & DST_TYPE_HAS_MULTI_FE) { in dst_get_tuner_info()
1045 if (dst_command(state, get_tuner_1, 8) < 0) { in dst_get_tuner_info()
1050 if (dst_command(state, get_tuner_2, 8) < 0) { in dst_get_tuner_info()
1055 memcpy(&state->board_info, &state->rxbuffer, 8); in dst_get_tuner_info()
1056 if (state->type_flags & DST_TYPE_HAS_MULTI_FE) { in dst_get_tuner_info()
1059 if (state->board_info[0] == 0xbc) { in dst_get_tuner_info()
1060 if (state->dst_type != DST_TYPE_IS_ATSC) in dst_get_tuner_info()
1061 state->type_flags |= DST_TYPE_HAS_TS188; in dst_get_tuner_info()
1063 state->type_flags |= DST_TYPE_HAS_NEWTUNE_2; in dst_get_tuner_info()
1065 if (state->board_info[1] == 0x01) { in dst_get_tuner_info()
1066 state->dst_hw_cap |= DST_TYPE_HAS_DBOARD; in dst_get_tuner_info()
1073 if (!strncmp(state->fw_name, "DCT-CI", 6)) { in dst_get_tuner_info()
1074 state->type_flags |= DST_TYPE_HAS_TS204; in dst_get_tuner_info()
1075 dprintk(verbose, DST_ERROR, 1, "Forcing [%s] to TS188", state->fw_name); in dst_get_tuner_info()
1081 static int dst_get_device_id(struct dst_state *state) in dst_get_device_id() argument
1094 state->tuner_type = 0; in dst_get_device_id()
1097 if (write_dst(state, device_type, FIXED_COMM)) in dst_get_device_id()
1099 if ((dst_pio_disable(state)) < 0) in dst_get_device_id()
1101 if (read_dst(state, &reply, GET_ACK)) in dst_get_device_id()
1107 if (!dst_wait_dst_ready(state, DEVICE_INIT)) in dst_get_device_id()
1109 if (read_dst(state, state->rxbuffer, FIXED_COMM)) in dst_get_device_id()
1112 dst_pio_disable(state); in dst_get_device_id()
1113 if (state->rxbuffer[7] != dst_check_sum(state->rxbuffer, 7)) { in dst_get_device_id()
1117 state->rxbuffer[7] = '\0'; in dst_get_device_id()
1120 …if (!strncmp (&state->rxbuffer[p_dst_type->offset], p_dst_type->device_id, strlen (p_dst_type->dev… in dst_get_device_id()
1125 state->dst_hw_cap = p_dst_type->dst_feature; in dst_get_device_id()
1127 strncpy(&state->fw_name[0], p_dst_type->device_id, 6); in dst_get_device_id()
1133 if (dst_check_stv0299(state) < 0) { in dst_get_device_id()
1135 state->tuner_type = TUNER_TYPE_MB86A15; in dst_get_device_id()
1141 if (dst_check_mb86a15(state) < 0) in dst_get_device_id()
1145 state->tuner_type = p_dst_type->tuner_type; in dst_get_device_id()
1149 p_tuner_list->tuner_type == state->tuner_type) { in dst_get_device_id()
1159 …dprintk(verbose, DST_ERROR, 1, "Unable to recognize %s or %s", &state->rxbuffer[0], &state->rxbuff… in dst_get_device_id()
1164 dst_type_print(state, use_dst_type); in dst_get_device_id()
1165 state->type_flags = use_type_flags; in dst_get_device_id()
1166 state->dst_type = use_dst_type; in dst_get_device_id()
1167 dst_type_flags_print(state); in dst_get_device_id()
1172 static int dst_probe(struct dst_state *state) in dst_probe() argument
1174 mutex_init(&state->dst_mutex); in dst_probe()
1176 if ((rdc_8820_reset(state)) < 0) { in dst_probe()
1184 if ((dst_comm_init(state)) < 0) { in dst_probe()
1189 if (dst_get_device_id(state) < 0) { in dst_probe()
1193 if (dst_get_mac(state) < 0) { in dst_probe()
1196 if ((state->type_flags & DST_TYPE_HAS_MULTI_FE) || (state->type_flags & DST_TYPE_HAS_FW_BUILD)) { in dst_probe()
1197 if (dst_get_tuner_info(state) < 0) in dst_probe()
1200 if (state->type_flags & DST_TYPE_HAS_TS204) { in dst_probe()
1201 dst_packsize(state, 204); in dst_probe()
1203 if (state->type_flags & DST_TYPE_HAS_FW_BUILD) { in dst_probe()
1204 if (dst_fw_ver(state) < 0) { in dst_probe()
1208 if (dst_card_type(state) < 0) { in dst_probe()
1212 if (dst_get_vendor(state) < 0) { in dst_probe()
1221 static int dst_command(struct dst_state *state, u8 *data, u8 len) in dst_command() argument
1225 mutex_lock(&state->dst_mutex); in dst_command()
1226 if ((dst_comm_init(state)) < 0) { in dst_command()
1230 if (write_dst(state, data, len)) { in dst_command()
1232 if ((dst_error_recovery(state)) < 0) { in dst_command()
1238 if ((dst_pio_disable(state)) < 0) { in dst_command()
1242 if (state->type_flags & DST_TYPE_HAS_FW_1) in dst_command()
1244 if (read_dst(state, &reply, GET_ACK)) { in dst_command()
1246 if ((dst_error_recovery(state)) < 0) { in dst_command()
1258 if (state->type_flags & DST_TYPE_HAS_FW_1) in dst_command()
1262 if (!dst_wait_dst_ready(state, NO_DELAY)) in dst_command()
1264 if (read_dst(state, state->rxbuffer, FIXED_COMM)) { in dst_command()
1266 if ((dst_error_recovery(state)) < 0) { in dst_command()
1272 if (state->rxbuffer[7] != dst_check_sum(state->rxbuffer, 7)) { in dst_command()
1276 mutex_unlock(&state->dst_mutex); in dst_command()
1280 mutex_unlock(&state->dst_mutex); in dst_command()
1285 static int dst_get_signal(struct dst_state *state) in dst_get_signal() argument
1290 if ((state->diseq_flags & ATTEMPT_TUNE) == 0) { in dst_get_signal()
1291 state->decode_lock = state->decode_strength = state->decode_snr = 0; in dst_get_signal()
1294 if (0 == (state->diseq_flags & HAS_LOCK)) { in dst_get_signal()
1295 state->decode_lock = state->decode_strength = state->decode_snr = 0; in dst_get_signal()
1298 if (time_after_eq(jiffies, state->cur_jiff + (HZ / 5))) { in dst_get_signal()
1299 retval = dst_command(state, get_signal, 8); in dst_get_signal()
1302 if (state->dst_type == DST_TYPE_IS_SAT) { in dst_get_signal()
1303 state->decode_lock = ((state->rxbuffer[6] & 0x10) == 0) ? 1 : 0; in dst_get_signal()
1304 state->decode_strength = state->rxbuffer[5] << 8; in dst_get_signal()
1305 state->decode_snr = state->rxbuffer[2] << 8 | state->rxbuffer[3]; in dst_get_signal()
1306 } else if ((state->dst_type == DST_TYPE_IS_TERR) || (state->dst_type == DST_TYPE_IS_CABLE)) { in dst_get_signal()
1307 state->decode_lock = (state->rxbuffer[1]) ? 1 : 0; in dst_get_signal()
1308 state->decode_strength = state->rxbuffer[4] << 8; in dst_get_signal()
1309 state->decode_snr = state->rxbuffer[3] << 8; in dst_get_signal()
1310 } else if (state->dst_type == DST_TYPE_IS_ATSC) { in dst_get_signal()
1311 state->decode_lock = (state->rxbuffer[6] == 0x00) ? 1 : 0; in dst_get_signal()
1312 state->decode_strength = state->rxbuffer[4] << 8; in dst_get_signal()
1313 state->decode_snr = state->rxbuffer[2] << 8 | state->rxbuffer[3]; in dst_get_signal()
1315 state->cur_jiff = jiffies; in dst_get_signal()
1320 static int dst_tone_power_cmd(struct dst_state *state) in dst_tone_power_cmd() argument
1324 if (state->dst_type != DST_TYPE_IS_SAT) in dst_tone_power_cmd()
1326 paket[4] = state->tx_tuna[4]; in dst_tone_power_cmd()
1327 paket[2] = state->tx_tuna[2]; in dst_tone_power_cmd()
1328 paket[3] = state->tx_tuna[3]; in dst_tone_power_cmd()
1330 return dst_command(state, paket, 8); in dst_tone_power_cmd()
1333 static int dst_get_tuna(struct dst_state *state) in dst_get_tuna() argument
1337 if ((state->diseq_flags & ATTEMPT_TUNE) == 0) in dst_get_tuna()
1339 state->diseq_flags &= ~(HAS_LOCK); in dst_get_tuna()
1340 if (!dst_wait_dst_ready(state, NO_DELAY)) in dst_get_tuna()
1342 if ((state->type_flags & DST_TYPE_HAS_VLF) && in dst_get_tuna()
1343 !(state->dst_type == DST_TYPE_IS_ATSC)) in dst_get_tuna()
1345 retval = read_dst(state, state->rx_tuna, 10); in dst_get_tuna()
1347 retval = read_dst(state, &state->rx_tuna[2], FIXED_COMM); in dst_get_tuna()
1352 if ((state->type_flags & DST_TYPE_HAS_VLF) && in dst_get_tuna()
1353 !(state->dst_type == DST_TYPE_IS_ATSC)) { in dst_get_tuna()
1355 if (state->rx_tuna[9] != dst_check_sum(&state->rx_tuna[0], 9)) { in dst_get_tuna()
1360 if (state->rx_tuna[9] != dst_check_sum(&state->rx_tuna[2], 7)) { in dst_get_tuna()
1365 if (state->rx_tuna[2] == 0 && state->rx_tuna[3] == 0) in dst_get_tuna()
1367 if (state->dst_type == DST_TYPE_IS_SAT) { in dst_get_tuna()
1368 state->decode_freq = ((state->rx_tuna[2] & 0x7f) << 8) + state->rx_tuna[3]; in dst_get_tuna()
1370 …state->decode_freq = ((state->rx_tuna[2] & 0x7f) << 16) + (state->rx_tuna[3] << 8) + state->rx_tun… in dst_get_tuna()
1372 state->decode_freq = state->decode_freq * 1000; in dst_get_tuna()
1373 state->decode_lock = 1; in dst_get_tuna()
1374 state->diseq_flags |= HAS_LOCK; in dst_get_tuna()
1383 struct dst_state *state = fe->demodulator_priv; in dst_write_tuna() local
1387 dprintk(verbose, DST_INFO, 1, "type_flags 0x%x ", state->type_flags); in dst_write_tuna()
1388 state->decode_freq = 0; in dst_write_tuna()
1389 state->decode_lock = state->decode_strength = state->decode_snr = 0; in dst_write_tuna()
1390 if (state->dst_type == DST_TYPE_IS_SAT) { in dst_write_tuna()
1391 if (!(state->diseq_flags & HAS_POWER)) in dst_write_tuna()
1394 state->diseq_flags &= ~(HAS_LOCK | ATTEMPT_TUNE); in dst_write_tuna()
1395 mutex_lock(&state->dst_mutex); in dst_write_tuna()
1396 if ((dst_comm_init(state)) < 0) { in dst_write_tuna()
1400 // if (state->type_flags & DST_TYPE_HAS_NEWTUNE) { in dst_write_tuna()
1401 if ((state->type_flags & DST_TYPE_HAS_VLF) && in dst_write_tuna()
1402 (!(state->dst_type == DST_TYPE_IS_ATSC))) { in dst_write_tuna()
1404 state->tx_tuna[9] = dst_check_sum(&state->tx_tuna[0], 9); in dst_write_tuna()
1405 retval = write_dst(state, &state->tx_tuna[0], 10); in dst_write_tuna()
1407 state->tx_tuna[9] = dst_check_sum(&state->tx_tuna[2], 7); in dst_write_tuna()
1408 retval = write_dst(state, &state->tx_tuna[2], FIXED_COMM); in dst_write_tuna()
1411 dst_pio_disable(state); in dst_write_tuna()
1415 if ((dst_pio_disable(state)) < 0) { in dst_write_tuna()
1419 if ((read_dst(state, &reply, GET_ACK) < 0)) { in dst_write_tuna()
1427 state->diseq_flags |= ATTEMPT_TUNE; in dst_write_tuna()
1428 retval = dst_get_tuna(state); in dst_write_tuna()
1430 mutex_unlock(&state->dst_mutex); in dst_write_tuna()
1434 mutex_unlock(&state->dst_mutex); in dst_write_tuna()
1454 struct dst_state *state = fe->demodulator_priv; in dst_set_diseqc() local
1457 if (state->dst_type != DST_TYPE_IS_SAT) in dst_set_diseqc()
1461 else if (cmd->msg_len == 5 && state->dst_hw_cap & DST_TYPE_HAS_DISEQC5) in dst_set_diseqc()
1466 return dst_command(state, paket, 8); in dst_set_diseqc()
1472 struct dst_state *state = fe->demodulator_priv; in dst_set_voltage() local
1474 state->voltage = voltage; in dst_set_voltage()
1475 if (state->dst_type != DST_TYPE_IS_SAT) in dst_set_voltage()
1483 if ((state->diseq_flags & HAS_POWER) == 0) in dst_set_voltage()
1485 state->diseq_flags |= HAS_POWER; in dst_set_voltage()
1486 state->tx_tuna[4] = 0x01; in dst_set_voltage()
1490 state->diseq_flags &= ~(HAS_POWER | HAS_LOCK | ATTEMPT_TUNE); in dst_set_voltage()
1491 state->tx_tuna[4] = 0x00; in dst_set_voltage()
1498 retval = dst_tone_power_cmd(state); in dst_set_voltage()
1505 struct dst_state *state = fe->demodulator_priv; in dst_set_tone() local
1507 state->tone = tone; in dst_set_tone()
1508 if (state->dst_type != DST_TYPE_IS_SAT) in dst_set_tone()
1513 if (state->type_flags & DST_TYPE_HAS_OBS_REGS) in dst_set_tone()
1514 state->tx_tuna[2] = 0x00; in dst_set_tone()
1516 state->tx_tuna[2] = 0xff; in dst_set_tone()
1520 state->tx_tuna[2] = 0x02; in dst_set_tone()
1525 return dst_tone_power_cmd(state); in dst_set_tone()
1530 struct dst_state *state = fe->demodulator_priv; in dst_send_burst() local
1532 if (state->dst_type != DST_TYPE_IS_SAT) in dst_send_burst()
1534 state->minicmd = minicmd; in dst_send_burst()
1537 state->tx_tuna[3] = 0x02; in dst_send_burst()
1540 state->tx_tuna[3] = 0xff; in dst_send_burst()
1543 return dst_tone_power_cmd(state); in dst_send_burst()
1549 struct dst_state *state = fe->demodulator_priv; in dst_init() local
1559 state->inversion = INVERSION_OFF; in dst_init()
1560 state->voltage = SEC_VOLTAGE_13; in dst_init()
1561 state->tone = SEC_TONE_OFF; in dst_init()
1562 state->diseq_flags = 0; in dst_init()
1563 state->k22 = 0x02; in dst_init()
1564 state->bandwidth = 7000000; in dst_init()
1565 state->cur_jiff = jiffies; in dst_init()
1566 if (state->dst_type == DST_TYPE_IS_SAT) in dst_init()
1567 …memcpy(state->tx_tuna, ((state->type_flags & DST_TYPE_HAS_VLF) ? sat_tuna_188 : sat_tuna_204), siz… in dst_init()
1568 else if (state->dst_type == DST_TYPE_IS_TERR) in dst_init()
1569 …memcpy(state->tx_tuna, ((state->type_flags & DST_TYPE_HAS_VLF) ? ter_tuna_188 : ter_tuna_204), siz… in dst_init()
1570 else if (state->dst_type == DST_TYPE_IS_CABLE) in dst_init()
1571 …memcpy(state->tx_tuna, ((state->type_flags & DST_TYPE_HAS_VLF) ? cab_tuna_188 : cab_tuna_204), siz… in dst_init()
1572 else if (state->dst_type == DST_TYPE_IS_ATSC) in dst_init()
1573 memcpy(state->tx_tuna, atsc_tuner, sizeof (atsc_tuner)); in dst_init()
1580 struct dst_state *state = fe->demodulator_priv; in dst_read_status() local
1583 if (state->diseq_flags & HAS_LOCK) { in dst_read_status()
1584 // dst_get_signal(state); // don't require(?) to ask MCU in dst_read_status()
1585 if (state->decode_lock) in dst_read_status()
1594 struct dst_state *state = fe->demodulator_priv; in dst_read_signal_strength() local
1596 int retval = dst_get_signal(state); in dst_read_signal_strength()
1597 *strength = state->decode_strength; in dst_read_signal_strength()
1604 struct dst_state *state = fe->demodulator_priv; in dst_read_snr() local
1606 int retval = dst_get_signal(state); in dst_read_snr()
1607 *snr = state->decode_snr; in dst_read_snr()
1616 struct dst_state *state = fe->demodulator_priv; in dst_set_frontend() local
1619 retval = dst_set_freq(state, p->frequency); in dst_set_frontend()
1624 if (state->dst_type == DST_TYPE_IS_SAT) { in dst_set_frontend()
1625 if (state->type_flags & DST_TYPE_HAS_OBS_REGS) in dst_set_frontend()
1626 dst_set_inversion(state, p->inversion); in dst_set_frontend()
1627 dst_set_fec(state, p->fec_inner); in dst_set_frontend()
1628 dst_set_symbolrate(state, p->symbol_rate); in dst_set_frontend()
1629 dst_set_polarization(state); in dst_set_frontend()
1632 } else if (state->dst_type == DST_TYPE_IS_TERR) in dst_set_frontend()
1633 dst_set_bandwidth(state, p->bandwidth_hz); in dst_set_frontend()
1634 else if (state->dst_type == DST_TYPE_IS_CABLE) { in dst_set_frontend()
1635 dst_set_fec(state, p->fec_inner); in dst_set_frontend()
1636 dst_set_symbolrate(state, p->symbol_rate); in dst_set_frontend()
1637 dst_set_modulation(state, p->modulation); in dst_set_frontend()
1651 struct dst_state *state = fe->demodulator_priv; in dst_tune_frontend() local
1655 dst_set_freq(state, p->frequency); in dst_tune_frontend()
1658 if (state->dst_type == DST_TYPE_IS_SAT) { in dst_tune_frontend()
1659 if (state->type_flags & DST_TYPE_HAS_OBS_REGS) in dst_tune_frontend()
1660 dst_set_inversion(state, p->inversion); in dst_tune_frontend()
1661 dst_set_fec(state, p->fec_inner); in dst_tune_frontend()
1662 dst_set_symbolrate(state, p->symbol_rate); in dst_tune_frontend()
1663 dst_set_polarization(state); in dst_tune_frontend()
1666 } else if (state->dst_type == DST_TYPE_IS_TERR) in dst_tune_frontend()
1667 dst_set_bandwidth(state, p->bandwidth_hz); in dst_tune_frontend()
1668 else if (state->dst_type == DST_TYPE_IS_CABLE) { in dst_tune_frontend()
1669 dst_set_fec(state, p->fec_inner); in dst_tune_frontend()
1670 dst_set_symbolrate(state, p->symbol_rate); in dst_tune_frontend()
1671 dst_set_modulation(state, p->modulation); in dst_tune_frontend()
1691 struct dst_state *state = fe->demodulator_priv; in dst_get_frontend() local
1693 p->frequency = state->decode_freq; in dst_get_frontend()
1694 if (state->dst_type == DST_TYPE_IS_SAT) { in dst_get_frontend()
1695 if (state->type_flags & DST_TYPE_HAS_OBS_REGS) in dst_get_frontend()
1696 p->inversion = state->inversion; in dst_get_frontend()
1697 p->symbol_rate = state->symbol_rate; in dst_get_frontend()
1698 p->fec_inner = dst_get_fec(state); in dst_get_frontend()
1699 } else if (state->dst_type == DST_TYPE_IS_TERR) { in dst_get_frontend()
1700 p->bandwidth_hz = state->bandwidth; in dst_get_frontend()
1701 } else if (state->dst_type == DST_TYPE_IS_CABLE) { in dst_get_frontend()
1702 p->symbol_rate = state->symbol_rate; in dst_get_frontend()
1703 p->fec_inner = dst_get_fec(state); in dst_get_frontend()
1704 p->modulation = dst_get_modulation(state); in dst_get_frontend()
1712 struct dst_state *state = fe->demodulator_priv; in dst_release() local
1713 if (state->dst_ca) { in dst_release()
1714 dvb_unregister_device(state->dst_ca); in dst_release()
1719 kfree(state); in dst_release()
1727 struct dst_state *dst_attach(struct dst_state *state, struct dvb_adapter *dvb_adapter) in dst_attach() argument
1730 if (dst_probe(state) < 0) { in dst_attach()
1731 kfree(state); in dst_attach()
1736 switch (state->dst_type) { in dst_attach()
1738 memcpy(&state->frontend.ops, &dst_dvbt_ops, sizeof(struct dvb_frontend_ops)); in dst_attach()
1741 memcpy(&state->frontend.ops, &dst_dvbc_ops, sizeof(struct dvb_frontend_ops)); in dst_attach()
1744 memcpy(&state->frontend.ops, &dst_dvbs_ops, sizeof(struct dvb_frontend_ops)); in dst_attach()
1747 memcpy(&state->frontend.ops, &dst_atsc_ops, sizeof(struct dvb_frontend_ops)); in dst_attach()
1751 kfree(state); in dst_attach()
1754 state->frontend.demodulator_priv = state; in dst_attach()
1756 return state; /* Manu (DST is a card not a frontend) */ in dst_attach()