From: Stefan Ringel <[email protected]>
Signed-off-by: Stefan Ringel <[email protected]>
---
drivers/media/common/tuners/mt2063.c | 57 +++++++++++++++++++++++-----------
1 files changed, 39 insertions(+), 18 deletions(-)
diff --git a/drivers/media/common/tuners/mt2063.c
b/drivers/media/common/tuners/mt2063.c
index 9f3a546..d5a9dd9 100644
--- a/drivers/media/common/tuners/mt2063.c
+++ b/drivers/media/common/tuners/mt2063.c
@@ -32,6 +32,8 @@ static unsigned int debug;
module_param(debug, int, 0644);
MODULE_PARM_DESC(debug, "Set debug level");
+static DEFINE_MUTEX(mt2063_list_mutex);
+static LIST_HEAD(hybrid_tuner_instance_list);
/* debug level
* 0 don't debug
@@ -2247,29 +2249,48 @@ static struct dvb_tuner_ops mt2063_ops = {
};
struct dvb_frontend *mt2063_attach(struct dvb_frontend *fe,
- struct mt2063_config *config,
- struct i2c_adapter *i2c)
+ struct mt2063_config *config,
+ struct i2c_adapter *i2c)
{
struct mt2063_state *state = NULL;
+ int instance, ret;
+
+ dprintk(1, "\n");
+
+ mutex_lock(&mt2063_list_mutex);
+
+ instance = hybrid_tuner_request_state(struct mt2063_state, state,
+ hybrid_tuner_instance_list,
+ i2c, config->tuner_address,
+ "mt2063");
+
+ switch(instance) {
+ case 0:
+ goto fail;
+ case 1:
+ /* new instance */
+ state->i2c = i2c;
+ state->i2c_addr = config->tuner_address;
+ /* find chip */
+ mutex_init(&state->lock);
+ state->frontend = fe;
+ if (ret < 0)
+ goto fail;
+ fe->tuner_priv = state;
+ fe->ops.tuner_ops = mt2063_ops;
+ break;
+ default:
+ fe->tuner_priv = state;
+ fe->ops.tuner_ops = mt2063_ops;
+ break;
+ }
+ mutex_unlock(&mt2063_list_mutex);
- dprintk(2, "\n");
-
- state = kzalloc(sizeof(struct mt2063_state), GFP_KERNEL);
- if (state == NULL)
- goto error;
-
- state->config = config;
- state->i2c = i2c;
- state->frontend = fe;
- state->reference = config->refclock / 1000; /* kHz */
- fe->tuner_priv = state;
- fe->ops.tuner_ops = mt2063_ops;
-
- printk(KERN_INFO "%s: Attaching MT2063\n", __func__);
return fe;
-error:
- kfree(state);
+fail:
+ hybrid_tuner_release_state(state);
+ mutex_unlock(&mt2063_list_mutex);
return NULL;
}
EXPORT_SYMBOL_GPL(mt2063_attach);
--
1.7.7.6
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html