提交 209fdf66 编写于 作者: D Devin Heitmueller 提交者: Mauro Carvalho Chehab

V4L/DVB (11064): au8522: make use of hybrid framework so analog/digital demod can share state

Make use of the hybrid tuner framework so the analog and digital parts of the
au8522 demodulator can make use of the same shared state.

Thanks to Michael Krufky <mkrufky@linuxtv.org> and Steven Toth
<stoth@linuxtv.org> for providing sample hardware, engineering level support,
and testing.
Signed-off-by: NDevin Heitmueller <dheitmueller@linuxtv.org>
Signed-off-by: NMichael Krufky <mkrufky@linuxtv.org>
Signed-off-by: NMauro Carvalho Chehab <mchehab@redhat.com>
上级 7bf63eda
...@@ -31,6 +31,10 @@ ...@@ -31,6 +31,10 @@
static int debug; static int debug;
/* Despite the name "hybrid_tuner", the framework works just as well for
hybrid demodulators as well... */
static LIST_HEAD(hybrid_tuner_instance_list);
#define dprintk(arg...) do { \ #define dprintk(arg...) do { \
if (debug) \ if (debug) \
printk(arg); \ printk(arg); \
...@@ -786,23 +790,50 @@ static int au8522_get_tune_settings(struct dvb_frontend *fe, ...@@ -786,23 +790,50 @@ static int au8522_get_tune_settings(struct dvb_frontend *fe,
return 0; return 0;
} }
static struct dvb_frontend_ops au8522_ops;
int au8522_get_state(struct au8522_state **state, struct i2c_adapter *i2c,
u8 client_address)
{
return hybrid_tuner_request_state(struct au8522_state, (*state),
hybrid_tuner_instance_list,
i2c, client_address, "au8522");
}
void au8522_release_state(struct au8522_state *state)
{
if (state != NULL)
hybrid_tuner_release_state(state);
}
static void au8522_release(struct dvb_frontend *fe) static void au8522_release(struct dvb_frontend *fe)
{ {
struct au8522_state *state = fe->demodulator_priv; struct au8522_state *state = fe->demodulator_priv;
kfree(state); au8522_release_state(state);
} }
static struct dvb_frontend_ops au8522_ops;
struct dvb_frontend *au8522_attach(const struct au8522_config *config, struct dvb_frontend *au8522_attach(const struct au8522_config *config,
struct i2c_adapter *i2c) struct i2c_adapter *i2c)
{ {
struct au8522_state *state = NULL; struct au8522_state *state = NULL;
int instance;
/* allocate memory for the internal state */ /* allocate memory for the internal state */
state = kmalloc(sizeof(struct au8522_state), GFP_KERNEL); instance = au8522_get_state(&state, i2c, config->demod_address);
if (state == NULL) switch (instance) {
goto error; case 0:
dprintk("%s state allocation failed\n", __func__);
break;
case 1:
/* new demod instance */
dprintk("%s using new instance\n", __func__);
break;
default:
/* existing demod instance */
dprintk("%s using existing instance\n", __func__);
break;
}
/* setup the state */ /* setup the state */
state->config = config; state->config = config;
...@@ -824,7 +855,7 @@ struct dvb_frontend *au8522_attach(const struct au8522_config *config, ...@@ -824,7 +855,7 @@ struct dvb_frontend *au8522_attach(const struct au8522_config *config,
return &state->frontend; return &state->frontend;
error: error:
kfree(state); au8522_release_state(state);
return NULL; return NULL;
} }
EXPORT_SYMBOL(au8522_attach); EXPORT_SYMBOL(au8522_attach);
......
...@@ -37,6 +37,10 @@ ...@@ -37,6 +37,10 @@
struct au8522_state { struct au8522_state {
struct i2c_adapter *i2c; struct i2c_adapter *i2c;
/* Used for sharing of the state between analog and digital mode */
struct tuner_i2c_props i2c_props;
struct list_head hybrid_tuner_instance_list;
/* configuration settings */ /* configuration settings */
const struct au8522_config *config; const struct au8522_config *config;
...@@ -55,3 +59,7 @@ int au8522_writereg(struct au8522_state *state, u16 reg, u8 data); ...@@ -55,3 +59,7 @@ int au8522_writereg(struct au8522_state *state, u16 reg, u8 data);
u8 au8522_readreg(struct au8522_state *state, u16 reg); u8 au8522_readreg(struct au8522_state *state, u16 reg);
int au8522_init(struct dvb_frontend *fe); int au8522_init(struct dvb_frontend *fe);
int au8522_sleep(struct dvb_frontend *fe); int au8522_sleep(struct dvb_frontend *fe);
int au8522_get_state(struct au8522_state **state, struct i2c_adapter *i2c,
u8 client_address);
void au8522_release_state(struct au8522_state *state);
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册