summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--linux/drivers/media/dvb/frontends/alps_bsru6.c49
1 files changed, 10 insertions, 39 deletions
diff --git a/linux/drivers/media/dvb/frontends/alps_bsru6.c b/linux/drivers/media/dvb/frontends/alps_bsru6.c
index 60877c8c5..5b6acf34a 100644
--- a/linux/drivers/media/dvb/frontends/alps_bsru6.c
+++ b/linux/drivers/media/dvb/frontends/alps_bsru6.c
@@ -27,7 +27,6 @@
#include "compat.h"
#include "dvb_frontend.h"
-#define CONFIG_ALPS_BSRU6_IS_LG_TDQBS00X 1
static int debug = 0;
#define dprintk if (debug) printk
@@ -39,11 +38,7 @@ static int debug = 0;
static
struct dvb_frontend_info bsru6_info = {
-#ifdef CONFIG_ALPS_BSRU6_IS_LG_TDQBS00X
- name: "LG TDQB-S00x",
-#else
- name: "Alps BSRU6",
-#endif
+ name: "stv0299 based (e.g. Alps BSRU6 or LG TDQB-S00x)",
type: FE_QPSK,
frequency_min: 950000,
frequency_max: 2150000,
@@ -55,7 +50,7 @@ struct dvb_frontend_info bsru6_info = {
notifier_delay: 0,
caps: FE_CAN_FEC_1_2 | FE_CAN_FEC_2_3 | FE_CAN_FEC_3_4 |
FE_CAN_FEC_5_6 | FE_CAN_FEC_7_8 | FE_CAN_FEC_AUTO |
- FE_CAN_QPSK
+ FE_CAN_INVERSION_AUTO | FE_CAN_QPSK
};
@@ -262,40 +257,16 @@ int stv0299_init (struct dvb_i2c_bus *i2c)
static
-int stv0299_set_inversion (struct dvb_i2c_bus *i2c,
- fe_spectral_inversion_t inversion)
+int stv0299_check_inversion (struct dvb_i2c_bus *i2c)
{
- u8 val;
-
dprintk ("%s\n", __FUNCTION__);
-#ifdef CONFIG_ALPS_BSRU6_IS_LG_TDQBS00X /* reversed I/Q pins */
- switch (inversion) {
- case INVERSION_AUTO:
- return -EOPNOTSUPP;
- case INVERSION_OFF:
- val = stv0299_readreg (i2c, 0x0c);
- return stv0299_writereg (i2c, 0x0c, val & 0xfe);
- case INVERSION_ON:
- val = stv0299_readreg (i2c, 0x0c);
- return stv0299_writereg (i2c, 0x0c, val | 0x01);
- default:
- return -EINVAL;
- };
-#else
- switch (inversion) {
- case INVERSION_AUTO:
- return -EOPNOTSUPP;
- case INVERSION_OFF:
- val = stv0299_readreg (i2c, 0x0c);
- return stv0299_writereg (i2c, 0x0c, val | 0x01);
- case INVERSION_ON:
- val = stv0299_readreg (i2c, 0x0c);
- return stv0299_writereg (i2c, 0x0c, val & 0xfe);
- default:
- return -EINVAL;
- };
-#endif
+ if ((stv0299_readreg (i2c, 0x1b) & 0x98) != 0x98) {
+ u8 val = stv0299_readreg (i2c, 0x0c);
+ return stv0299_writereg (i2c, 0x0c, val ^ 0x01);
+ }
+
+ return 0;
}
@@ -628,9 +599,9 @@ int bsru6_ioctl (struct dvb_frontend *fe, unsigned int cmd, void *arg)
struct dvb_frontend_parameters *p = arg;
tsa5059_set_tv_freq (i2c, p->frequency, 3);
- stv0299_set_inversion (i2c, p->inversion);
stv0299_set_FEC (i2c, p->u.qpsk.fec_inner);
stv0299_set_symbolrate (i2c, p->u.qpsk.symbol_rate);
+ stv0299_check_inversion (i2c);
tsa5059_set_tv_freq (i2c, p->frequency, 0);
stv0299_writereg (i2c, 0x22, 0x00);
stv0299_writereg (i2c, 0x23, 0x00);