Commit 06a3f584 authored by Felipe Balbi's avatar Felipe Balbi Committed by Mauro Carvalho Chehab

V4L/DVB (8724): dvb: drx397xD: checkpatch.pl cleanups

This driver sure needs some rework. For now, let's
try to clean it up a bit before start reimplementing
anything.

checkpatch.pl still not happy with this driver after
this patch, but the most annoying errors are gone,
comments now use C-style only, labels are well placed
and some other minor fixes.

Some more clean up patches will come as I work on this
driver. Please review it carefully.

Cc: Mauro Carvalho Chehab <mchehab@infradead.org>
Cc: Henk Vergonet <henk.vergonet@gmail.com>
[mchehab@infradead.org: Manually fixed some conflicts with a previous patch]
Signed-off-by: default avatarFelipe Balbi <felipe.balbi@nokia.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent e758c6f8
...@@ -38,35 +38,32 @@ static const char mod_name[] = "drx397xD"; ...@@ -38,35 +38,32 @@ static const char mod_name[] = "drx397xD";
#define F_SET_0D0h 1 #define F_SET_0D0h 1
#define F_SET_0D4h 2 #define F_SET_0D4h 2
typedef enum fw_ix { enum fw_ix {
#define _FW_ENTRY(a, b) b #define _FW_ENTRY(a, b) b
#include "drx397xD_fw.h" #include "drx397xD_fw.h"
} fw_ix_t; };
/* chip specifics */ /* chip specifics */
struct drx397xD_state { struct drx397xD_state {
struct i2c_adapter *i2c; struct i2c_adapter *i2c;
struct dvb_frontend frontend; struct dvb_frontend frontend;
struct drx397xD_config config; struct drx397xD_config config;
fw_ix_t chip_rev; enum fw_ix chip_rev;
int flags; int flags;
u32 bandwidth_parm; /* internal bandwidth conversions */ u32 bandwidth_parm; /* internal bandwidth conversions */
u32 f_osc; /* w90: actual osc frequency [Hz] */ u32 f_osc; /* w90: actual osc frequency [Hz] */
}; };
/******************************************************************************* /* Firmware */
* Firmware
******************************************************************************/
static const char *blob_name[] = { static const char *blob_name[] = {
#define _BLOB_ENTRY(a, b) a #define _BLOB_ENTRY(a, b) a
#include "drx397xD_fw.h" #include "drx397xD_fw.h"
}; };
typedef enum blob_ix { enum blob_ix {
#define _BLOB_ENTRY(a, b) b #define _BLOB_ENTRY(a, b) b
#include "drx397xD_fw.h" #include "drx397xD_fw.h"
} blob_ix_t; };
static struct { static struct {
const char *name; const char *name;
...@@ -85,7 +82,7 @@ static struct { ...@@ -85,7 +82,7 @@ static struct {
}; };
/* use only with writer lock aquired */ /* use only with writer lock aquired */
static void _drx_release_fw(struct drx397xD_state *s, fw_ix_t ix) static void _drx_release_fw(struct drx397xD_state *s, enum fw_ix ix)
{ {
memset(&fw[ix].data[0], 0, sizeof(fw[0].data)); memset(&fw[ix].data[0], 0, sizeof(fw[0].data));
if (fw[ix].file) if (fw[ix].file)
...@@ -94,7 +91,7 @@ static void _drx_release_fw(struct drx397xD_state *s, fw_ix_t ix) ...@@ -94,7 +91,7 @@ static void _drx_release_fw(struct drx397xD_state *s, fw_ix_t ix)
static void drx_release_fw(struct drx397xD_state *s) static void drx_release_fw(struct drx397xD_state *s)
{ {
fw_ix_t ix = s->chip_rev; enum fw_ix ix = s->chip_rev;
pr_debug("%s\n", __func__); pr_debug("%s\n", __func__);
...@@ -107,7 +104,7 @@ static void drx_release_fw(struct drx397xD_state *s) ...@@ -107,7 +104,7 @@ static void drx_release_fw(struct drx397xD_state *s)
write_unlock(&fw[ix].lock); write_unlock(&fw[ix].lock);
} }
static int drx_load_fw(struct drx397xD_state *s, fw_ix_t ix) static int drx_load_fw(struct drx397xD_state *s, enum fw_ix ix)
{ {
const u8 *data; const u8 *data;
size_t size, len; size_t size, len;
...@@ -175,26 +172,28 @@ static int drx_load_fw(struct drx397xD_state *s, fw_ix_t ix) ...@@ -175,26 +172,28 @@ static int drx_load_fw(struct drx397xD_state *s, fw_ix_t ix)
goto exit_corrupt; goto exit_corrupt;
} }
} while (i < size); } while (i < size);
exit_corrupt:
exit_corrupt:
printk(KERN_ERR "%s: Firmware is corrupt\n", mod_name); printk(KERN_ERR "%s: Firmware is corrupt\n", mod_name);
exit_err: exit_err:
_drx_release_fw(s, ix); _drx_release_fw(s, ix);
fw[ix].refcnt--; fw[ix].refcnt--;
exit_ok: exit_ok:
fw[ix].refcnt++; fw[ix].refcnt++;
write_unlock(&fw[ix].lock); write_unlock(&fw[ix].lock);
return rc; return rc;
} }
/******************************************************************************* /* i2c bus IO */
* i2c bus IO static int write_fw(struct drx397xD_state *s, enum blob_ix ix)
******************************************************************************/
static int write_fw(struct drx397xD_state *s, blob_ix_t ix)
{ {
struct i2c_msg msg = {.addr = s->config.demod_address,.flags = 0 };
const u8 *data; const u8 *data;
int len, rc = 0, i = 0; int len, rc = 0, i = 0;
struct i2c_msg msg = {
.addr = s->config.demod_address,
.flags = 0
};
if (ix < 0 || ix >= ARRAY_SIZE(blob_name)) { if (ix < 0 || ix >= ARRAY_SIZE(blob_name)) {
pr_debug("%s drx_fw_ix_t out of range\n", __func__); pr_debug("%s drx_fw_ix_t out of range\n", __func__);
...@@ -229,8 +228,9 @@ static int write_fw(struct drx397xD_state *s, blob_ix_t ix) ...@@ -229,8 +228,9 @@ static int write_fw(struct drx397xD_state *s, blob_ix_t ix)
goto exit_rc; goto exit_rc;
} }
} }
exit_rc: exit_rc:
read_unlock(&fw[s->chip_rev].lock); read_unlock(&fw[s->chip_rev].lock);
return 0; return 0;
} }
...@@ -246,11 +246,10 @@ static int _read16(struct drx397xD_state *s, u32 i2c_adr) ...@@ -246,11 +246,10 @@ static int _read16(struct drx397xD_state *s, u32 i2c_adr)
.flags = 0, .flags = 0,
.buf = a, .buf = a,
.len = sizeof(a) .len = sizeof(a)
} }, {
, {
.addr = s->config.demod_address, .addr = s->config.demod_address,
.flags = I2C_M_RD, .flags = I2C_M_RD,
.buf = (u8 *) & v, .buf = (u8 *) &v,
.len = sizeof(v) .len = sizeof(v)
} }
}; };
...@@ -277,27 +276,27 @@ static int _write16(struct drx397xD_state *s, u32 i2c_adr, u16 val) ...@@ -277,27 +276,27 @@ static int _write16(struct drx397xD_state *s, u32 i2c_adr, u16 val)
}; };
*(u32 *) a = i2c_adr; *(u32 *) a = i2c_adr;
*(u16 *) & a[4] = val; *(u16 *) &a[4] = val;
rc = i2c_transfer(s->i2c, &msg, 1); rc = i2c_transfer(s->i2c, &msg, 1);
if (rc != 1) if (rc != 1)
return -EIO; return -EIO;
return 0; return 0;
} }
#define WR16(ss,adr, val) \ #define WR16(ss, adr, val) \
_write16(ss, I2C_ADR_C0(adr), cpu_to_le16(val)) _write16(ss, I2C_ADR_C0(adr), cpu_to_le16(val))
#define WR16_E0(ss,adr, val) \ #define WR16_E0(ss, adr, val) \
_write16(ss, I2C_ADR_E0(adr), cpu_to_le16(val)) _write16(ss, I2C_ADR_E0(adr), cpu_to_le16(val))
#define RD16(ss,adr) \ #define RD16(ss, adr) \
_read16(ss, I2C_ADR_C0(adr)) _read16(ss, I2C_ADR_C0(adr))
#define EXIT_RC( cmd ) if ( (rc = (cmd)) < 0) goto exit_rc #define EXIT_RC(cmd) \
if ((rc = (cmd)) < 0) \
/******************************************************************************* goto exit_rc
* Tuner callback
******************************************************************************/
/* Tuner callback */
static int PLL_Set(struct drx397xD_state *s, static int PLL_Set(struct drx397xD_state *s,
struct dvb_frontend_parameters *fep, int *df_tuner) struct dvb_frontend_parameters *fep, int *df_tuner)
{ {
...@@ -331,10 +330,7 @@ static int PLL_Set(struct drx397xD_state *s, ...@@ -331,10 +330,7 @@ static int PLL_Set(struct drx397xD_state *s,
return 0; return 0;
} }
/******************************************************************************* /* Demodulator helper functions */
* Demodulator helper functions
******************************************************************************/
static int SC_WaitForReady(struct drx397xD_state *s) static int SC_WaitForReady(struct drx397xD_state *s)
{ {
int cnt = 1000; int cnt = 1000;
...@@ -347,6 +343,7 @@ static int SC_WaitForReady(struct drx397xD_state *s) ...@@ -347,6 +343,7 @@ static int SC_WaitForReady(struct drx397xD_state *s)
if (rc == 0) if (rc == 0)
return 0; return 0;
} }
return -1; return -1;
} }
...@@ -361,6 +358,7 @@ static int SC_SendCommand(struct drx397xD_state *s, int cmd) ...@@ -361,6 +358,7 @@ static int SC_SendCommand(struct drx397xD_state *s, int cmd)
rc = RD16(s, 0x820042); rc = RD16(s, 0x820042);
if ((rc & 0xffff) == 0xffff) if ((rc & 0xffff) == 0xffff)
return -1; return -1;
return 0; return 0;
} }
...@@ -383,6 +381,7 @@ static int HI_Command(struct drx397xD_state *s, u16 cmd) ...@@ -383,6 +381,7 @@ static int HI_Command(struct drx397xD_state *s, u16 cmd)
if (rc < 0) if (rc < 0)
return rc; return rc;
} while (--cnt); } while (--cnt);
return rc; return rc;
} }
...@@ -392,13 +391,14 @@ static int HI_CfgCommand(struct drx397xD_state *s) ...@@ -392,13 +391,14 @@ static int HI_CfgCommand(struct drx397xD_state *s)
pr_debug("%s\n", __func__); pr_debug("%s\n", __func__);
WR16(s, 0x420033, 0x3973); WR16(s, 0x420033, 0x3973);
WR16(s, 0x420034, s->config.w50); // code 4, log 4 WR16(s, 0x420034, s->config.w50); /* code 4, log 4 */
WR16(s, 0x420035, s->config.w52); // code 15, log 9 WR16(s, 0x420035, s->config.w52); /* code 15, log 9 */
WR16(s, 0x420036, s->config.demod_address << 1); WR16(s, 0x420036, s->config.demod_address << 1);
WR16(s, 0x420037, s->config.w56); // code (set_i2c ?? initX 1 ), log 1 WR16(s, 0x420037, s->config.w56); /* code (set_i2c ?? initX 1 ), log 1 */
// WR16(s, 0x420033, 0x3973); /* WR16(s, 0x420033, 0x3973); */
if ((s->config.w56 & 8) == 0) if ((s->config.w56 & 8) == 0)
return HI_Command(s, 3); return HI_Command(s, 3);
return WR16(s, 0x420032, 0x3); return WR16(s, 0x420032, 0x3);
} }
...@@ -468,7 +468,7 @@ static int SetCfgIfAgc(struct drx397xD_state *s, struct drx397xD_CfgIfAgc *agc) ...@@ -468,7 +468,7 @@ static int SetCfgIfAgc(struct drx397xD_state *s, struct drx397xD_CfgIfAgc *agc)
i = slowIncrDecLUT_15272[rem / 28]; i = slowIncrDecLUT_15272[rem / 28];
EXIT_RC(WR16(s, 0x0c2002b, i)); EXIT_RC(WR16(s, 0x0c2002b, i));
rc = WR16(s, 0x0c2002c, i); rc = WR16(s, 0x0c2002c, i);
exit_rc: exit_rc:
return rc; return rc;
} }
...@@ -498,7 +498,7 @@ static int SetCfgRfAgc(struct drx397xD_state *s, struct drx397xD_CfgRfAgc *agc) ...@@ -498,7 +498,7 @@ static int SetCfgRfAgc(struct drx397xD_state *s, struct drx397xD_CfgRfAgc *agc)
rc &= ~2; rc &= ~2;
break; break;
case 0: case 0:
// loc_8000659 /* loc_8000659 */
s->config.w9C &= ~2; s->config.w9C &= ~2;
EXIT_RC(WR16(s, 0x0c20015, s->config.w9C)); EXIT_RC(WR16(s, 0x0c20015, s->config.w9C));
EXIT_RC(RD16(s, 0x0c20010)); EXIT_RC(RD16(s, 0x0c20010));
...@@ -522,7 +522,8 @@ static int SetCfgRfAgc(struct drx397xD_state *s, struct drx397xD_CfgRfAgc *agc) ...@@ -522,7 +522,8 @@ static int SetCfgRfAgc(struct drx397xD_state *s, struct drx397xD_CfgRfAgc *agc)
rc |= 2; rc |= 2;
} }
rc = WR16(s, 0x0c20013, rc); rc = WR16(s, 0x0c20013, rc);
exit_rc:
exit_rc:
return rc; return rc;
} }
...@@ -602,7 +603,8 @@ static int CorrectSysClockDeviation(struct drx397xD_state *s) ...@@ -602,7 +603,8 @@ static int CorrectSysClockDeviation(struct drx397xD_state *s)
s->config.f_osc * 1000, clk - s->config.f_osc * 1000); s->config.f_osc * 1000, clk - s->config.f_osc * 1000);
} }
rc = WR16(s, 0x08200e8, 0); rc = WR16(s, 0x08200e8, 0);
exit_rc:
exit_rc:
return rc; return rc;
} }
...@@ -620,17 +622,17 @@ static int ConfigureMPEGOutput(struct drx397xD_state *s, int type) ...@@ -620,17 +622,17 @@ static int ConfigureMPEGOutput(struct drx397xD_state *s, int type)
si &= ~1; si &= ~1;
bp = 0x200; bp = 0x200;
} }
if (s->config.w9A == 0) { if (s->config.w9A == 0)
si |= 0x80; si |= 0x80;
} else { else
si &= ~0x80; si &= ~0x80;
}
EXIT_RC(WR16(s, 0x2150045, 0)); EXIT_RC(WR16(s, 0x2150045, 0));
EXIT_RC(WR16(s, 0x2150010, si)); EXIT_RC(WR16(s, 0x2150010, si));
EXIT_RC(WR16(s, 0x2150011, bp)); EXIT_RC(WR16(s, 0x2150011, bp));
rc = WR16(s, 0x2150012, (type == 0 ? 0xfff : 0)); rc = WR16(s, 0x2150012, (type == 0 ? 0xfff : 0));
exit_rc:
exit_rc:
return rc; return rc;
} }
...@@ -658,7 +660,7 @@ static int drx_tune(struct drx397xD_state *s, ...@@ -658,7 +660,7 @@ static int drx_tune(struct drx397xD_state *s,
rc = ConfigureMPEGOutput(s, 0); rc = ConfigureMPEGOutput(s, 0);
if (rc < 0) if (rc < 0)
goto set_tuner; goto set_tuner;
set_tuner: set_tuner:
rc = PLL_Set(s, fep, &df_tuner); rc = PLL_Set(s, fep, &df_tuner);
if (rc < 0) { if (rc < 0) {
...@@ -835,16 +837,16 @@ static int drx_tune(struct drx397xD_state *s, ...@@ -835,16 +837,16 @@ static int drx_tune(struct drx397xD_state *s,
rc = WR16(s, 0x2010012, 0); rc = WR16(s, 0x2010012, 0);
if (rc < 0) if (rc < 0)
goto exit_rc; goto exit_rc;
// QPSK QAM16 QAM64 /* QPSK QAM16 QAM64 */
ebx = 0x19f; // 62 ebx = 0x19f; /* 62 */
ebp = 0x1fb; // 15 ebp = 0x1fb; /* 15 */
v20 = 0x16a; // 62 v20 = 0x16a; /* 62 */
v1E = 0x195; // 62 v1E = 0x195; /* 62 */
v16 = 0x1bb; // 15 v16 = 0x1bb; /* 15 */
v14 = 0x1ef; // 15 v14 = 0x1ef; /* 15 */
v12 = 5; // 16 v12 = 5; /* 16 */
v10 = 5; // 16 v10 = 5; /* 16 */
v0E = 5; // 16 v0E = 5; /* 16 */
} }
switch (fep->u.ofdm.constellation) { switch (fep->u.ofdm.constellation) {
...@@ -997,17 +999,17 @@ static int drx_tune(struct drx397xD_state *s, ...@@ -997,17 +999,17 @@ static int drx_tune(struct drx397xD_state *s,
case BANDWIDTH_8_MHZ: /* 0 */ case BANDWIDTH_8_MHZ: /* 0 */
case BANDWIDTH_AUTO: case BANDWIDTH_AUTO:
rc = WR16(s, 0x0c2003f, 0x32); rc = WR16(s, 0x0c2003f, 0x32);
s->bandwidth_parm = ebx = 0x8b8249; // 9142857 s->bandwidth_parm = ebx = 0x8b8249;
edx = 0; edx = 0;
break; break;
case BANDWIDTH_7_MHZ: case BANDWIDTH_7_MHZ:
rc = WR16(s, 0x0c2003f, 0x3b); rc = WR16(s, 0x0c2003f, 0x3b);
s->bandwidth_parm = ebx = 0x7a1200; // 8000000 s->bandwidth_parm = ebx = 0x7a1200;
edx = 0x4807; edx = 0x4807;
break; break;
case BANDWIDTH_6_MHZ: case BANDWIDTH_6_MHZ:
rc = WR16(s, 0x0c2003f, 0x47); rc = WR16(s, 0x0c2003f, 0x47);
s->bandwidth_parm = ebx = 0x68a1b6; // 6857142 s->bandwidth_parm = ebx = 0x68a1b6;
edx = 0x0f07; edx = 0x0f07;
break; break;
}; };
...@@ -1060,8 +1062,6 @@ static int drx_tune(struct drx397xD_state *s, ...@@ -1060,8 +1062,6 @@ static int drx_tune(struct drx397xD_state *s,
WR16(s, 0x0820040, 1); WR16(s, 0x0820040, 1);
SC_SendCommand(s, 1); SC_SendCommand(s, 1);
// rc = WR16(s, 0x2150000, 1);
// if (rc < 0) goto exit_rc;
rc = WR16(s, 0x2150000, 2); rc = WR16(s, 0x2150000, 2);
rc = WR16(s, 0x2150016, a); rc = WR16(s, 0x2150016, a);
...@@ -1069,7 +1069,8 @@ static int drx_tune(struct drx397xD_state *s, ...@@ -1069,7 +1069,8 @@ static int drx_tune(struct drx397xD_state *s,
rc = WR16(s, 0x2150036, 0); rc = WR16(s, 0x2150036, 0);
rc = WR16(s, 0x2150000, 1); rc = WR16(s, 0x2150000, 1);
s->config.d60 = 2; s->config.d60 = 2;
exit_rc:
exit_rc:
return rc; return rc;
} }
...@@ -1102,18 +1103,18 @@ static int drx397x_init(struct dvb_frontend *fe) ...@@ -1102,18 +1103,18 @@ static int drx397x_init(struct dvb_frontend *fe)
/* HI_CfgCommand */ /* HI_CfgCommand */
s->config.w50 = 4; s->config.w50 = 4;
s->config.w52 = 9; // 0xf; s->config.w52 = 9;
s->config.f_if = 42800000; /* d14: intermediate frequency [Hz] */ s->config.f_if = 42800000; /* d14: intermediate frequency [Hz] */
s->config.f_osc = 48000; /* s66 : oscillator frequency [kHz] */ s->config.f_osc = 48000; /* s66 : oscillator frequency [kHz] */
s->config.w92 = 12000; // 20000; s->config.w92 = 12000;
s->config.w9C = 0x000e; s->config.w9C = 0x000e;
s->config.w9E = 0x0000; s->config.w9E = 0x0000;
/* ConfigureMPEGOutput params */ /* ConfigureMPEGOutput params */
s->config.wA0 = 4; s->config.wA0 = 4;
s->config.w98 = 1; // 0; s->config.w98 = 1;
s->config.w9A = 1; s->config.w9A = 1;
/* get chip revision */ /* get chip revision */
...@@ -1248,7 +1249,7 @@ static int drx397x_init(struct dvb_frontend *fe) ...@@ -1248,7 +1249,7 @@ static int drx397x_init(struct dvb_frontend *fe)
rc = WR16(s, 0x0c20012, 1); rc = WR16(s, 0x0c20012, 1);
} }
write_DRXD_InitFE_1: write_DRXD_InitFE_1:
rc = write_fw(s, DRXD_InitFE_1); rc = write_fw(s, DRXD_InitFE_1);
if (rc < 0) if (rc < 0)
...@@ -1311,7 +1312,8 @@ static int drx397x_init(struct dvb_frontend *fe) ...@@ -1311,7 +1312,8 @@ static int drx397x_init(struct dvb_frontend *fe)
s->config.d5C = 0; s->config.d5C = 0;
s->config.d60 = 1; s->config.d60 = 1;
s->config.d48 = 1; s->config.d48 = 1;
error:
error:
return rc; return rc;
} }
...@@ -1326,7 +1328,8 @@ static int drx397x_set_frontend(struct dvb_frontend *fe, ...@@ -1326,7 +1328,8 @@ static int drx397x_set_frontend(struct dvb_frontend *fe,
{ {
struct drx397xD_state *s = fe->demodulator_priv; struct drx397xD_state *s = fe->demodulator_priv;
s->config.s20d24 = 1; // 0; s->config.s20d24 = 1;
return drx_tune(s, params); return drx_tune(s, params);
} }
...@@ -1337,18 +1340,16 @@ static int drx397x_get_tune_settings(struct dvb_frontend *fe, ...@@ -1337,18 +1340,16 @@ static int drx397x_get_tune_settings(struct dvb_frontend *fe,
fe_tune_settings->min_delay_ms = 10000; fe_tune_settings->min_delay_ms = 10000;
fe_tune_settings->step_size = 0; fe_tune_settings->step_size = 0;
fe_tune_settings->max_drift = 0; fe_tune_settings->max_drift = 0;
return 0; return 0;
} }
static int drx397x_read_status(struct dvb_frontend *fe, fe_status_t * status) static int drx397x_read_status(struct dvb_frontend *fe, fe_status_t *status)
{ {
struct drx397xD_state *s = fe->demodulator_priv; struct drx397xD_state *s = fe->demodulator_priv;
int lockstat; int lockstat;
GetLockStatus(s, &lockstat); GetLockStatus(s, &lockstat);
/* TODO */
// if (lockstat & 1)
// CorrectSysClockDeviation(s);
*status = 0; *status = 0;
if (lockstat & 2) { if (lockstat & 2) {
...@@ -1356,9 +1357,8 @@ static int drx397x_read_status(struct dvb_frontend *fe, fe_status_t * status) ...@@ -1356,9 +1357,8 @@ static int drx397x_read_status(struct dvb_frontend *fe, fe_status_t * status)
ConfigureMPEGOutput(s, 1); ConfigureMPEGOutput(s, 1);
*status = FE_HAS_LOCK | FE_HAS_SYNC | FE_HAS_VITERBI; *status = FE_HAS_LOCK | FE_HAS_SYNC | FE_HAS_VITERBI;
} }
if (lockstat & 4) { if (lockstat & 4)
*status |= FE_HAS_CARRIER | FE_HAS_SIGNAL; *status |= FE_HAS_CARRIER | FE_HAS_SIGNAL;
}
return 0; return 0;
} }
...@@ -1366,16 +1366,18 @@ static int drx397x_read_status(struct dvb_frontend *fe, fe_status_t * status) ...@@ -1366,16 +1366,18 @@ static int drx397x_read_status(struct dvb_frontend *fe, fe_status_t * status)
static int drx397x_read_ber(struct dvb_frontend *fe, unsigned int *ber) static int drx397x_read_ber(struct dvb_frontend *fe, unsigned int *ber)
{ {
*ber = 0; *ber = 0;
return 0; return 0;
} }
static int drx397x_read_snr(struct dvb_frontend *fe, u16 * snr) static int drx397x_read_snr(struct dvb_frontend *fe, u16 *snr)
{ {
*snr = 0; *snr = 0;
return 0; return 0;
} }
static int drx397x_read_signal_strength(struct dvb_frontend *fe, u16 * strength) static int drx397x_read_signal_strength(struct dvb_frontend *fe, u16 *strength)
{ {
struct drx397xD_state *s = fe->demodulator_priv; struct drx397xD_state *s = fe->demodulator_priv;
int rc; int rc;
...@@ -1401,6 +1403,7 @@ static int drx397x_read_signal_strength(struct dvb_frontend *fe, u16 * strength) ...@@ -1401,6 +1403,7 @@ static int drx397x_read_signal_strength(struct dvb_frontend *fe, u16 * strength)
* The following does the same but with less rounding errors: * The following does the same but with less rounding errors:
*/ */
*strength = ~(7720 + (rc * 30744 >> 10)); *strength = ~(7720 + (rc * 30744 >> 10));
return 0; return 0;
} }
...@@ -1408,6 +1411,7 @@ static int drx397x_read_ucblocks(struct dvb_frontend *fe, ...@@ -1408,6 +1411,7 @@ static int drx397x_read_ucblocks(struct dvb_frontend *fe,
unsigned int *ucblocks) unsigned int *ucblocks)
{ {
*ucblocks = 0; *ucblocks = 0;
return 0; return 0;
} }
...@@ -1437,21 +1441,21 @@ static struct dvb_frontend_ops drx397x_ops = { ...@@ -1437,21 +1441,21 @@ static struct dvb_frontend_ops drx397x_ops = {
.frequency_stepsize = 166667, .frequency_stepsize = 166667,
.frequency_tolerance = 0, .frequency_tolerance = 0,
.caps = /* 0x0C01B2EAE */ .caps = /* 0x0C01B2EAE */
FE_CAN_FEC_1_2 | // = 0x2, FE_CAN_FEC_1_2 | /* = 0x2, */
FE_CAN_FEC_2_3 | // = 0x4, FE_CAN_FEC_2_3 | /* = 0x4, */
FE_CAN_FEC_3_4 | // = 0x8, FE_CAN_FEC_3_4 | /* = 0x8, */
FE_CAN_FEC_5_6 | // = 0x20, FE_CAN_FEC_5_6 | /* = 0x20, */
FE_CAN_FEC_7_8 | // = 0x80, FE_CAN_FEC_7_8 | /* = 0x80, */
FE_CAN_FEC_AUTO | // = 0x200, FE_CAN_FEC_AUTO | /* = 0x200, */
FE_CAN_QPSK | // = 0x400, FE_CAN_QPSK | /* = 0x400, */
FE_CAN_QAM_16 | // = 0x800, FE_CAN_QAM_16 | /* = 0x800, */
FE_CAN_QAM_64 | // = 0x2000, FE_CAN_QAM_64 | /* = 0x2000, */
FE_CAN_QAM_AUTO | // = 0x10000, FE_CAN_QAM_AUTO | /* = 0x10000, */
FE_CAN_TRANSMISSION_MODE_AUTO | // = 0x20000, FE_CAN_TRANSMISSION_MODE_AUTO | /* = 0x20000, */
FE_CAN_GUARD_INTERVAL_AUTO | // = 0x80000, FE_CAN_GUARD_INTERVAL_AUTO | /* = 0x80000, */
FE_CAN_HIERARCHY_AUTO | // = 0x100000, FE_CAN_HIERARCHY_AUTO | /* = 0x100000, */
FE_CAN_RECOVER | // = 0x40000000, FE_CAN_RECOVER | /* = 0x40000000, */
FE_CAN_MUTE_TS // = 0x80000000 FE_CAN_MUTE_TS /* = 0x80000000 */
}, },
.release = drx397x_release, .release = drx397x_release,
...@@ -1472,33 +1476,35 @@ static struct dvb_frontend_ops drx397x_ops = { ...@@ -1472,33 +1476,35 @@ static struct dvb_frontend_ops drx397x_ops = {
struct dvb_frontend *drx397xD_attach(const struct drx397xD_config *config, struct dvb_frontend *drx397xD_attach(const struct drx397xD_config *config,
struct i2c_adapter *i2c) struct i2c_adapter *i2c)
{ {
struct drx397xD_state *s = NULL; struct drx397xD_state *state;
/* allocate memory for the internal state */ /* allocate memory for the internal state */
s = kzalloc(sizeof(struct drx397xD_state), GFP_KERNEL); state = kzalloc(sizeof(struct drx397xD_state), GFP_KERNEL);
if (s == NULL) if (!state)
goto error; goto error;
/* setup the state */ /* setup the state */
s->i2c = i2c; state->i2c = i2c;
memcpy(&s->config, config, sizeof(struct drx397xD_config)); memcpy(&state->config, config, sizeof(struct drx397xD_config));
/* check if the demod is there */ /* check if the demod is there */
if (RD16(s, 0x2410019) < 0) if (RD16(s, 0x2410019) < 0)
goto error; goto error;
/* create dvb_frontend */ /* create dvb_frontend */
memcpy(&s->frontend.ops, &drx397x_ops, sizeof(struct dvb_frontend_ops)); memcpy(&state->frontend.ops, &drx397x_ops,
s->frontend.demodulator_priv = s; sizeof(struct dvb_frontend_ops));
state->frontend.demodulator_priv = s;
return &state->frontend;
error:
kfree(state);
return &s->frontend;
error:
kfree(s);
return NULL; return NULL;
} }
EXPORT_SYMBOL(drx397xD_attach);
MODULE_DESCRIPTION("Micronas DRX397xD DVB-T Frontend"); MODULE_DESCRIPTION("Micronas DRX397xD DVB-T Frontend");
MODULE_AUTHOR("Henk Vergonet"); MODULE_AUTHOR("Henk Vergonet");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
EXPORT_SYMBOL(drx397xD_attach);
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