[media] drxk: Allow enabling MERR/MVAL cfg
authorMauro Carvalho Chehab <mchehab@redhat.com>
Sat, 21 Jan 2012 10:57:06 +0000 (07:57 -0300)
committerMauro Carvalho Chehab <mchehab@redhat.com>
Sat, 21 Jan 2012 15:46:39 +0000 (13:46 -0200)
Those two settings are different when used with az6007. Add
a config option to enable it.

Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
drivers/media/dvb/dvb-usb/az6007.c
drivers/media/dvb/frontends/drxk.h
drivers/media/dvb/frontends/drxk_hard.c
drivers/media/dvb/frontends/drxk_hard.h

index bf8d20151b05e4482d1eec2171a7b13aa79bb256..81fdc90be449e7d1a5dbc933ad17c200bf0fd010 100644 (file)
@@ -67,6 +67,7 @@ static struct drxk_config terratec_h7_drxk = {
        .parallel_ts = true,
        .dynamic_clk = true,
        .single_master = true,
+       .enable_merr_cfg = true,
        .no_i2c_bridge = false,
        .chunk_size = 64,
        .mpeg_out_clk_strength = 0x02,
index ca921c77f71fbec244fa5d83ac60fe7d0faa3676..9d64e4fea066818969ad54a39a7eff03a6e368c2 100644 (file)
@@ -12,6 +12,7 @@
  *                     Serial otherwise.
  * @dynamic_clk:       True means that the clock will be dynamically
  *                     adjusted. Static clock otherwise.
+ * @enable_merr_cfg:   Enable SIO_PDR_PERR_CFG/SIO_PDR_MVAL_CFG.
  * @single_master:     Device is on the single master mode
  * @no_i2c_bridge:     Don't switch the I2C bridge to talk with tuner
  * @antenna_gpio:      GPIO bit used to control the antenna
@@ -29,6 +30,7 @@ struct drxk_config {
        bool    no_i2c_bridge;
        bool    parallel_ts;
        bool    dynamic_clk;
+       bool    enable_merr_cfg;
 
        bool    antenna_dvbt;
        u16     antenna_gpio;
index d25b0d20038b761cda3d8ea75c56186d880ed1c7..5fa192731fcd34671790c5cb8f94e8800c7f7ee6 100644 (file)
@@ -1179,6 +1179,7 @@ static int MPEGTSConfigurePins(struct drxk_state *state, bool mpegEnable)
        int status = -1;
        u16 sioPdrMclkCfg = 0;
        u16 sioPdrMdxCfg = 0;
+       u16 err_cfg = 0;
 
        dprintk(1, ": mpeg %s, %s mode\n",
                mpegEnable ? "enable" : "disable",
@@ -1244,12 +1245,17 @@ static int MPEGTSConfigurePins(struct drxk_state *state, bool mpegEnable)
                status = write16(state, SIO_PDR_MSTRT_CFG__A, sioPdrMdxCfg);
                if (status < 0)
                        goto error;
-               status = write16(state, SIO_PDR_MERR_CFG__A, 0x0000);   /* Disable */
+
+               if (state->enable_merr_cfg)
+                       err_cfg = sioPdrMdxCfg;
+
+               status = write16(state, SIO_PDR_MERR_CFG__A, err_cfg);
                if (status < 0)
                        goto error;
-               status = write16(state, SIO_PDR_MVAL_CFG__A, 0x0000);   /* Disable */
+               status = write16(state, SIO_PDR_MVAL_CFG__A, err_cfg);
                if (status < 0)
                        goto error;
+
                if (state->m_enableParallel == true) {
                        /* paralel -> enable MD1 to MD7 */
                        status = write16(state, SIO_PDR_MD1_CFG__A, sioPdrMdxCfg);
@@ -6379,6 +6385,7 @@ struct dvb_frontend *drxk_attach(const struct drxk_config *config,
        state->antenna_gpio = config->antenna_gpio;
        state->antenna_dvbt = config->antenna_dvbt;
        state->m_ChunkSize = config->chunk_size;
+       state->enable_merr_cfg = config->enable_merr_cfg;
 
        if (config->dynamic_clk) {
                state->m_DVBTStaticCLK = 0;
index 3a58b73eb9b97f158e16f28b43c41a47a704bddd..4bbf841de83a77b90d70e092922ff8d88aa36682 100644 (file)
@@ -332,6 +332,7 @@ struct drxk_state {
 
        u16     UIO_mask;       /* Bits used by UIO */
 
+       bool    enable_merr_cfg;
        bool    single_master;
        bool    no_i2c_bridge;
        bool    antenna_dvbt;