Commit 2b64e4de authored by Daniel Scheller's avatar Daniel Scheller Committed by Mauro Carvalho Chehab

media: staging/cxd2099: Add module parameter for buffer mode

The buffer mode of the cxd2099 driver requires more work regarding error
handling and thus can cause issues in some cases, so disable it by default
and make that mode of operation controllable by users via a module
parameter (ie. 'modprobe cxd2099 buffermode=1' enables current behaviour).

The upstream codebase also has the buffer mode disabled by default, so
we should match this (but users still can test things out using the
modparm).
Signed-off-by: default avatarDaniel Scheller <d.scheller@gmx.net>
Signed-off-by: default avatarJasmin Jessich <jasmin@anw.at>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
parent b5967860
...@@ -33,8 +33,9 @@ ...@@ -33,8 +33,9 @@
#include "cxd2099.h" #include "cxd2099.h"
/* comment this line to deactivate the cxd2099ar buffer mode */ static int buffermode;
#define BUFFER_MODE 1 module_param(buffermode, int, 0444);
MODULE_PARM_DESC(buffermode, "Enable use of the CXD2099AR buffer mode (default: disabled)");
static int read_data(struct dvb_ca_en50221 *ca, int slot, u8 *ebuf, int ecount); static int read_data(struct dvb_ca_en50221 *ca, int slot, u8 *ebuf, int ecount);
...@@ -221,7 +222,6 @@ static int write_reg(struct cxd *ci, u8 reg, u8 val) ...@@ -221,7 +222,6 @@ static int write_reg(struct cxd *ci, u8 reg, u8 val)
return write_regm(ci, reg, val, 0xff); return write_regm(ci, reg, val, 0xff);
} }
#ifdef BUFFER_MODE
static int write_block(struct cxd *ci, u8 adr, u8 *data, u16 n) static int write_block(struct cxd *ci, u8 adr, u8 *data, u16 n)
{ {
int status = 0; int status = 0;
...@@ -248,7 +248,6 @@ static int write_block(struct cxd *ci, u8 adr, u8 *data, u16 n) ...@@ -248,7 +248,6 @@ static int write_block(struct cxd *ci, u8 adr, u8 *data, u16 n)
} }
return status; return status;
} }
#endif
static void set_mode(struct cxd *ci, int mode) static void set_mode(struct cxd *ci, int mode)
{ {
...@@ -642,8 +641,6 @@ static int read_data(struct dvb_ca_en50221 *ca, int slot, u8 *ebuf, int ecount) ...@@ -642,8 +641,6 @@ static int read_data(struct dvb_ca_en50221 *ca, int slot, u8 *ebuf, int ecount)
return len; return len;
} }
#ifdef BUFFER_MODE
static int write_data(struct dvb_ca_en50221 *ca, int slot, u8 *ebuf, int ecount) static int write_data(struct dvb_ca_en50221 *ca, int slot, u8 *ebuf, int ecount)
{ {
struct cxd *ci = ca->data; struct cxd *ci = ca->data;
...@@ -658,7 +655,6 @@ static int write_data(struct dvb_ca_en50221 *ca, int slot, u8 *ebuf, int ecount) ...@@ -658,7 +655,6 @@ static int write_data(struct dvb_ca_en50221 *ca, int slot, u8 *ebuf, int ecount)
mutex_unlock(&ci->lock); mutex_unlock(&ci->lock);
return ecount; return ecount;
} }
#endif
static struct dvb_ca_en50221 en_templ = { static struct dvb_ca_en50221 en_templ = {
.read_attribute_mem = read_attribute_mem, .read_attribute_mem = read_attribute_mem,
...@@ -669,11 +665,8 @@ static struct dvb_ca_en50221 en_templ = { ...@@ -669,11 +665,8 @@ static struct dvb_ca_en50221 en_templ = {
.slot_shutdown = slot_shutdown, .slot_shutdown = slot_shutdown,
.slot_ts_enable = slot_ts_enable, .slot_ts_enable = slot_ts_enable,
.poll_slot_status = poll_slot_status, .poll_slot_status = poll_slot_status,
#ifdef BUFFER_MODE
.read_data = read_data, .read_data = read_data,
.write_data = write_data, .write_data = write_data,
#endif
}; };
struct dvb_ca_en50221 *cxd2099_attach(struct cxd2099_cfg *cfg, struct dvb_ca_en50221 *cxd2099_attach(struct cxd2099_cfg *cfg,
...@@ -703,6 +696,14 @@ struct dvb_ca_en50221 *cxd2099_attach(struct cxd2099_cfg *cfg, ...@@ -703,6 +696,14 @@ struct dvb_ca_en50221 *cxd2099_attach(struct cxd2099_cfg *cfg,
ci->en.data = ci; ci->en.data = ci;
init(ci); init(ci);
dev_info(&i2c->dev, "Attached CXD2099AR at %02x\n", ci->cfg.adr); dev_info(&i2c->dev, "Attached CXD2099AR at %02x\n", ci->cfg.adr);
if (!buffermode) {
ci->en.read_data = NULL;
ci->en.write_data = NULL;
} else {
dev_info(&i2c->dev, "Using CXD2099AR buffer mode");
}
return &ci->en; return &ci->en;
} }
EXPORT_SYMBOL(cxd2099_attach); EXPORT_SYMBOL(cxd2099_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