Commit 0a196b6f authored by Chris Pascoe's avatar Chris Pascoe Committed by Mauro Carvalho Chehab

V4L/DVB (6642): xc2028: don't duplicate max_len in priv

There is no need to duplicate the max_len field from the ctrl structure
in the private data.  If we use it directly from priv->ctrl, we can memcpy
the structure (apart from strings) to reduce maintenance as it grows.

Enforce a minimum max_len length of 8 data bytes (+ 1 address byte) as seems
to be required by the tuner.

Also, use kstrdup instead of open coding the string duplication.
Signed-off-by: default avatarChris Pascoe <c.pascoe@itee.uq.edu.au>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@infradead.org>
parent a44f1c43
...@@ -75,9 +75,6 @@ struct xc2028_data { ...@@ -75,9 +75,6 @@ struct xc2028_data {
6M, 7M or 8M */ 6M, 7M or 8M */
int need_load_generic; /* The generic firmware int need_load_generic; /* The generic firmware
were loaded? */ were loaded? */
int max_len; /* Max firmware chunk */
enum tuner_mode mode; enum tuner_mode mode;
struct i2c_client *i2c_client; struct i2c_client *i2c_client;
...@@ -426,7 +423,7 @@ static int load_firmware(struct dvb_frontend *fe, unsigned int type, ...@@ -426,7 +423,7 @@ static int load_firmware(struct dvb_frontend *fe, unsigned int type,
{ {
struct xc2028_data *priv = fe->tuner_priv; struct xc2028_data *priv = fe->tuner_priv;
int pos, rc; int pos, rc;
unsigned char *p, *endp, buf[priv->max_len]; unsigned char *p, *endp, buf[priv->ctrl.max_len];
tuner_dbg("%s called\n", __FUNCTION__); tuner_dbg("%s called\n", __FUNCTION__);
...@@ -505,8 +502,8 @@ static int load_firmware(struct dvb_frontend *fe, unsigned int type, ...@@ -505,8 +502,8 @@ static int load_firmware(struct dvb_frontend *fe, unsigned int type,
/* Sends message chunks */ /* Sends message chunks */
while (size > 0) { while (size > 0) {
int len = (size < priv->max_len - 1) ? int len = (size < priv->ctrl.max_len - 1) ?
size : priv->max_len - 1; size : priv->ctrl.max_len - 1;
memcpy(buf + 1, p, len); memcpy(buf + 1, p, len);
...@@ -881,32 +878,30 @@ static int xc2028_set_config(struct dvb_frontend *fe, void *priv_cfg) ...@@ -881,32 +878,30 @@ static int xc2028_set_config(struct dvb_frontend *fe, void *priv_cfg)
{ {
struct xc2028_data *priv = fe->tuner_priv; struct xc2028_data *priv = fe->tuner_priv;
struct xc2028_ctrl *p = priv_cfg; struct xc2028_ctrl *p = priv_cfg;
int rc = 0;
tuner_dbg("%s called\n", __FUNCTION__); tuner_dbg("%s called\n", __FUNCTION__);
mutex_lock(&priv->lock); mutex_lock(&priv->lock);
priv->ctrl.type = p->type; kfree(priv->ctrl.fname);
free_firmware(priv);
if (p->fname) {
kfree(priv->ctrl.fname);
priv->ctrl.fname = kmalloc(strlen(p->fname) + 1, GFP_KERNEL); memcpy(&priv->ctrl, p, sizeof(priv->ctrl));
if (priv->ctrl.fname == NULL) { priv->ctrl.fname = NULL;
mutex_unlock(&priv->lock);
return -ENOMEM;
}
free_firmware(priv); if (p->fname) {
strcpy(priv->ctrl.fname, p->fname); priv->ctrl.fname = kstrdup(p->fname, GFP_KERNEL);
if (priv->ctrl.fname == NULL)
rc = -ENOMEM;
} }
if (p->max_len > 0) if (priv->ctrl.max_len < 9)
priv->max_len = p->max_len; priv->ctrl.max_len = 13;
mutex_unlock(&priv->lock); mutex_unlock(&priv->lock);
return 0; return rc;
} }
static const struct dvb_tuner_ops xc2028_dvb_tuner_ops = { static const struct dvb_tuner_ops xc2028_dvb_tuner_ops = {
...@@ -967,7 +962,7 @@ void *xc2028_attach(struct dvb_frontend *fe, struct xc2028_config *cfg) ...@@ -967,7 +962,7 @@ void *xc2028_attach(struct dvb_frontend *fe, struct xc2028_config *cfg)
priv->i2c_props.adap = cfg->i2c_adap; priv->i2c_props.adap = cfg->i2c_adap;
priv->video_dev = video_dev; priv->video_dev = video_dev;
priv->tuner_callback = cfg->callback; priv->tuner_callback = cfg->callback;
priv->max_len = 13; priv->ctrl.max_len = 13;
mutex_init(&priv->lock); mutex_init(&priv->lock);
......
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