Commit a37b4c9b authored by Michel Ludwig's avatar Michel Ludwig Committed by Mauro Carvalho Chehab

V4L/DVB (6611): Change xc2028_attach method to make easier for DVB

Removes uneeded parameters and adds an structure for passing the parameters

This patch is co-authored by Mauro Carvalho Chehab.
Signed-off-by: default avatarMichel Ludwig <michel.ludwig@gmail.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@infradead.org>
parent 2fc580ff
...@@ -336,10 +336,13 @@ static void set_type(struct i2c_client *c, unsigned int type, ...@@ -336,10 +336,13 @@ static void set_type(struct i2c_client *c, unsigned int type,
break; break;
case TUNER_XC2028: case TUNER_XC2028:
{ {
int rc=xc2028_attach(&t->fe, t->i2c->adapter, t->i2c->addr, struct xc2028_config cfg = {
&c->dev, c->adapter->algo_data, .i2c_adap = t->i2c->adapter,
t->tuner_callback); .i2c_addr = t->i2c->addr,
if (rc<0) { .video_dev = c->adapter->algo_data,
.callback = t->tuner_callback,
};
if (!xc2028_attach(&t->fe, &cfg)) {
t->type = TUNER_ABSENT; t->type = TUNER_ABSENT;
t->mode_mask = T_UNINITIALIZED; t->mode_mask = T_UNINITIALIZED;
return; return;
......
...@@ -56,7 +56,6 @@ struct xc2028_data { ...@@ -56,7 +56,6 @@ struct xc2028_data {
struct tuner_i2c_props i2c_props; struct tuner_i2c_props i2c_props;
int (*tuner_callback) (void *dev, int (*tuner_callback) (void *dev,
int command, int arg); int command, int arg);
struct device *dev;
void *video_dev; void *video_dev;
int count; int count;
__u32 frequency; __u32 frequency;
...@@ -240,7 +239,8 @@ static int load_all_firmwares(struct dvb_frontend *fe) ...@@ -240,7 +239,8 @@ static int load_all_firmwares(struct dvb_frontend *fe)
tuner_dbg("%s called\n", __FUNCTION__); tuner_dbg("%s called\n", __FUNCTION__);
tuner_info("Reading firmware %s\n", priv->ctrl.fname); tuner_info("Reading firmware %s\n", priv->ctrl.fname);
rc = request_firmware(&fw, priv->ctrl.fname, priv->dev); rc = request_firmware(&fw, priv->ctrl.fname,
&priv->i2c_props.adap->dev);
if (rc < 0) { if (rc < 0) {
if (rc == -ENOENT) if (rc == -ENOENT)
tuner_err("Error: firmware %s not found.\n", tuner_err("Error: firmware %s not found.\n",
...@@ -546,8 +546,10 @@ static int check_firmware(struct dvb_frontend *fe, enum tuner_mode new_mode, ...@@ -546,8 +546,10 @@ static int check_firmware(struct dvb_frontend *fe, enum tuner_mode new_mode,
tuner_dbg("%s called\n", __FUNCTION__); tuner_dbg("%s called\n", __FUNCTION__);
if (!priv->firm) { if (!priv->firm) {
if (!priv->ctrl.fname) if (!priv->ctrl.fname) {
tuner_info("xc2028/3028 firmware name not set!\n");
return -EINVAL; return -EINVAL;
}
rc = load_all_firmwares(fe); rc = load_all_firmwares(fe);
if (rc < 0) if (rc < 0)
...@@ -882,53 +884,51 @@ static const struct dvb_tuner_ops xc2028_dvb_tuner_ops = { ...@@ -882,53 +884,51 @@ static const struct dvb_tuner_ops xc2028_dvb_tuner_ops = {
}; };
int xc2028_attach(struct dvb_frontend *fe, struct i2c_adapter *i2c_adap, void *xc2028_attach(struct dvb_frontend *fe, struct xc2028_config *cfg)
u8 i2c_addr, struct device *dev, void *video_dev,
int (*tuner_callback) (void *dev, int command, int arg))
{ {
struct xc2028_data *priv; struct xc2028_data *priv;
void *video_dev;
if (debug) if (debug)
printk(KERN_DEBUG PREFIX "Xcv2028/3028 init called!\n"); printk(KERN_DEBUG PREFIX "Xcv2028/3028 init called!\n");
if (NULL == dev) if (NULL == cfg->video_dev)
return -ENODEV; return NULL;
if (NULL == video_dev) if (!fe) {
return -ENODEV; printk(KERN_ERR PREFIX "No frontend!\n");
return NULL;
if (!tuner_callback) {
printk(KERN_ERR PREFIX "No tuner callback!\n");
return -EINVAL;
} }
video_dev = cfg->video_dev;
list_for_each_entry(priv, &xc2028_list, xc2028_list) { list_for_each_entry(priv, &xc2028_list, xc2028_list) {
if (priv->dev == dev) if (priv->video_dev == cfg->video_dev) {
dev = NULL; video_dev = NULL;
break;
}
} }
if (dev) { if (video_dev) {
priv = kzalloc(sizeof(*priv), GFP_KERNEL); priv = kzalloc(sizeof(*priv), GFP_KERNEL);
if (priv == NULL) if (priv == NULL)
return -ENOMEM; return NULL;
fe->tuner_priv = priv;
priv->bandwidth = BANDWIDTH_6_MHZ; priv->bandwidth = BANDWIDTH_6_MHZ;
priv->need_load_generic = 1; priv->need_load_generic = 1;
priv->mode = T_UNINITIALIZED; priv->mode = T_UNINITIALIZED;
priv->i2c_props.addr = i2c_addr; priv->i2c_props.addr = cfg->i2c_addr;
priv->i2c_props.adap = i2c_adap; priv->i2c_props.adap = cfg->i2c_adap;
priv->dev = dev;
priv->video_dev = video_dev; priv->video_dev = video_dev;
priv->tuner_callback = tuner_callback; priv->tuner_callback = cfg->callback;
priv->max_len = 13; priv->max_len = 13;
mutex_init(&priv->lock); mutex_init(&priv->lock);
list_add_tail(&priv->xc2028_list, &xc2028_list); list_add_tail(&priv->xc2028_list, &xc2028_list);
} }
fe->tuner_priv = priv;
priv->count++; priv->count++;
memcpy(&fe->ops.tuner_ops, &xc2028_dvb_tuner_ops, memcpy(&fe->ops.tuner_ops, &xc2028_dvb_tuner_ops,
...@@ -936,8 +936,9 @@ int xc2028_attach(struct dvb_frontend *fe, struct i2c_adapter *i2c_adap, ...@@ -936,8 +936,9 @@ int xc2028_attach(struct dvb_frontend *fe, struct i2c_adapter *i2c_adap,
tuner_info("type set to %s\n", "XCeive xc2028/xc3028 tuner"); tuner_info("type set to %s\n", "XCeive xc2028/xc3028 tuner");
return 0; return fe;
} }
EXPORT_SYMBOL(xc2028_attach); EXPORT_SYMBOL(xc2028_attach);
MODULE_DESCRIPTION("Xceive xc2028/xc3028 tuner driver"); MODULE_DESCRIPTION("Xceive xc2028/xc3028 tuner driver");
......
...@@ -22,22 +22,22 @@ struct xc2028_ctrl { ...@@ -22,22 +22,22 @@ struct xc2028_ctrl {
int max_len; int max_len;
}; };
struct xc2028_config {
struct i2c_adapter *i2c_adap;
u8 i2c_addr;
void *video_dev;
int (*callback) (void *dev, int command, int arg);
};
/* xc2028 commands for callback */ /* xc2028 commands for callback */
#define XC2028_TUNER_RESET 0 #define XC2028_TUNER_RESET 0
#define XC2028_RESET_CLK 1 #define XC2028_RESET_CLK 1
#if defined(CONFIG_TUNER_XC2028) || (defined(CONFIG_TUNER_XC2028_MODULE) && defined(MODULE)) #if defined(CONFIG_TUNER_XC2028) || (defined(CONFIG_TUNER_XC2028_MODULE) && defined(MODULE))
int xc2028_attach(struct dvb_frontend *fe, struct i2c_adapter *i2c_adap, void *xc2028_attach(struct dvb_frontend *fe, struct xc2028_config *cfg);
u8 i2c_addr, struct device *dev, void *video_dev,
int (*tuner_callback) (void *dev, int command, int arg));
#else #else
static inline int xc2028_attach(struct dvb_frontend *fe, void *xc2028_attach(struct dvb_frontend *fe,
struct i2c_adapter *i2c_adap, struct xc2028_config *cfg)
u8 i2c_addr, struct device *dev,
void *video_dev,
int (*tuner_callback) (void *dev, int command,
int arg))
{ {
printk(KERN_INFO "%s: not probed - driver disabled by Kconfig\n", printk(KERN_INFO "%s: not probed - driver disabled by Kconfig\n",
__FUNCTION__); __FUNCTION__);
......
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