提交 320c6387 编写于 作者: A Antti Palosaari 提交者: Mauro Carvalho Chehab

[media] e4000: make VIDEO_V4L2 dependency optional

That tuner driver is mainly for DVB API, but there is some V4L2 API
controls for SDR usage. Make driver compile conditional so that V4L2
is not mandatory. Without the V4L2 support driver is build as a DVB
only, without SDR controls.

Fixes following errors reported by kbuild test robot:
ERROR: "v4l2_ctrl_auto_cluster" [drivers/media/tuners/e4000.ko] undefined!
ERROR: "v4l2_ctrl_new_std" [drivers/media/tuners/e4000.ko] undefined!
ERROR: "v4l2_ctrl_handler_init_class" [drivers/media/tuners/e4000.ko] undefined!
ERROR: "v4l2_ctrl_handler_free" [drivers/media/tuners/e4000.ko] undefined!
Reported-by: Nkbuild test robot <fengguang.wu@intel.com>
Cc: Hans Verkuil <hverkuil@xs4all.nl>
Signed-off-by: NAntti Palosaari <crope@iki.fi>
Signed-off-by: NMauro Carvalho Chehab <m.chehab@samsung.com>
上级 ed97a6fe
...@@ -203,7 +203,7 @@ config MEDIA_TUNER_TDA18212 ...@@ -203,7 +203,7 @@ config MEDIA_TUNER_TDA18212
config MEDIA_TUNER_E4000 config MEDIA_TUNER_E4000
tristate "Elonics E4000 silicon tuner" tristate "Elonics E4000 silicon tuner"
depends on MEDIA_SUPPORT && I2C && VIDEO_V4L2 depends on MEDIA_SUPPORT && I2C
select REGMAP_I2C select REGMAP_I2C
default m if !MEDIA_SUBDRV_AUTOSELECT default m if !MEDIA_SUBDRV_AUTOSELECT
help help
......
...@@ -269,6 +269,7 @@ static int e4000_get_if_frequency(struct dvb_frontend *fe, u32 *frequency) ...@@ -269,6 +269,7 @@ static int e4000_get_if_frequency(struct dvb_frontend *fe, u32 *frequency)
return 0; return 0;
} }
#if IS_ENABLED(CONFIG_VIDEO_V4L2)
static int e4000_set_lna_gain(struct dvb_frontend *fe) static int e4000_set_lna_gain(struct dvb_frontend *fe)
{ {
struct e4000 *s = fe->tuner_priv; struct e4000 *s = fe->tuner_priv;
...@@ -456,6 +457,7 @@ static const struct v4l2_ctrl_ops e4000_ctrl_ops = { ...@@ -456,6 +457,7 @@ static const struct v4l2_ctrl_ops e4000_ctrl_ops = {
.g_volatile_ctrl = e4000_g_volatile_ctrl, .g_volatile_ctrl = e4000_g_volatile_ctrl,
.s_ctrl = e4000_s_ctrl, .s_ctrl = e4000_s_ctrl,
}; };
#endif
static const struct dvb_tuner_ops e4000_tuner_ops = { static const struct dvb_tuner_ops e4000_tuner_ops = {
.info = { .info = {
...@@ -522,6 +524,7 @@ static int e4000_probe(struct i2c_client *client, ...@@ -522,6 +524,7 @@ static int e4000_probe(struct i2c_client *client,
if (ret) if (ret)
goto err; goto err;
#if IS_ENABLED(CONFIG_VIDEO_V4L2)
/* Register controls */ /* Register controls */
v4l2_ctrl_handler_init(&s->hdl, 9); v4l2_ctrl_handler_init(&s->hdl, 9);
s->bandwidth_auto = v4l2_ctrl_new_std(&s->hdl, &e4000_ctrl_ops, s->bandwidth_auto = v4l2_ctrl_new_std(&s->hdl, &e4000_ctrl_ops,
...@@ -554,6 +557,7 @@ static int e4000_probe(struct i2c_client *client, ...@@ -554,6 +557,7 @@ static int e4000_probe(struct i2c_client *client,
} }
s->sd.ctrl_handler = &s->hdl; s->sd.ctrl_handler = &s->hdl;
#endif
dev_info(&s->client->dev, dev_info(&s->client->dev,
"%s: Elonics E4000 successfully identified\n", "%s: Elonics E4000 successfully identified\n",
...@@ -584,7 +588,9 @@ static int e4000_remove(struct i2c_client *client) ...@@ -584,7 +588,9 @@ static int e4000_remove(struct i2c_client *client)
dev_dbg(&client->dev, "%s:\n", __func__); dev_dbg(&client->dev, "%s:\n", __func__);
#if IS_ENABLED(CONFIG_VIDEO_V4L2)
v4l2_ctrl_handler_free(&s->hdl); v4l2_ctrl_handler_free(&s->hdl);
#endif
memset(&fe->ops.tuner_ops, 0, sizeof(struct dvb_tuner_ops)); memset(&fe->ops.tuner_ops, 0, sizeof(struct dvb_tuner_ops));
fe->tuner_priv = NULL; fe->tuner_priv = NULL;
kfree(s); kfree(s);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册