From: Pavel Machek <pavel@ucw.cz>
To: Marcus Folkesson <marcus.folkesson@gmail.com>
Cc: pali.rohar@gmail.com, sre@kernel.org,
kernel list <linux-kernel@vger.kernel.org>,
linux-arm-kernel <linux-arm-kernel@lists.infradead.org>,
linux-omap@vger.kernel.org, tony@atomide.com, khilman@kernel.org,
aaro.koskinen@iki.fi, ivo.g.dimitrov.75@gmail.com,
patrikbachan@gmail.com, serge@hallyn.com,
linux-media@vger.kernel.org, mchehab@osg.samsung.com,
sakari.ailus@iki.fi
Subject: Re: [PATCH] support for AD5820 camera auto-focus coil
Date: Wed, 18 May 2016 10:30:48 +0200 [thread overview]
Message-ID: <20160518083048.GA30870@amd> (raw)
In-Reply-To: <20160517183340.GA10358@gmail.com>
Hi!
...
> Use module_i2c_driver() instead.
Thanks for all the comments, I've fixed it up like this, will post new
version soon.
Best regards,
Pavel
commit 97a793fb20be29e7ed217c007e8bf857f9854968
Author: Pavel <pavel@ucw.cz>
Date: Wed May 18 10:22:06 2016 +0200
Cleanups, as suggested by Marcus Folkesson
diff --git a/drivers/media/i2c/ad5820.c b/drivers/media/i2c/ad5820.c
index b71cc11..7725829 100644
--- a/drivers/media/i2c/ad5820.c
+++ b/drivers/media/i2c/ad5820.c
@@ -147,7 +147,6 @@ static int ad5820_set_ctrl(struct v4l2_ctrl *ctrl)
struct ad5820_device *coil =
container_of(ctrl->handler, struct ad5820_device, ctrls);
u32 code;
- int r = 0;
switch (ctrl->id) {
case V4L2_CID_FOCUS_ABSOLUTE:
@@ -165,7 +164,7 @@ static int ad5820_set_ctrl(struct v4l2_ctrl *ctrl)
break;
}
- return r;
+ return 0;
}
static const struct v4l2_ctrl_ops ad5820_ctrl_ops = {
@@ -245,8 +244,6 @@ static int ad5820_init_controls(struct ad5820_device *coil)
*/
static int ad5820_registered(struct v4l2_subdev *subdev)
{
- static const int CHECK_VALUE = 0x3FF0;
-
struct ad5820_device *coil = to_ad5820_device(subdev);
struct i2c_client *client = v4l2_get_subdevdata(subdev);
@@ -364,16 +361,19 @@ static int ad5820_probe(struct i2c_client *client,
strcpy(coil->subdev.name, "ad5820 focus");
ret = media_entity_pads_init(&coil->subdev.entity, 0, NULL);
- if (ret < 0) {
- kfree(coil);
- return ret;
- }
+ if (ret < 0)
+ goto free;
ret = v4l2_async_register_subdev(&coil->subdev);
if (ret < 0)
- kfree(coil);
+ goto cleanup;
return ret;
+cleanup:
+ media_entity_cleanup(&coil->subdev.entity);
+free:
+ kfree(coil);
+ return ret;
}
static int __exit ad5820_remove(struct i2c_client *client)
@@ -409,26 +409,7 @@ static struct i2c_driver ad5820_i2c_driver = {
.id_table = ad5820_id_table,
};
-static int __init ad5820_init(void)
-{
- int rval;
-
- rval = i2c_add_driver(&ad5820_i2c_driver);
- if (rval)
- printk(KERN_INFO "%s: failed registering " AD5820_NAME "\n",
- __func__);
-
- return rval;
-}
-
-static void __exit ad5820_exit(void)
-{
- i2c_del_driver(&ad5820_i2c_driver);
-}
-
-
-module_init(ad5820_init);
-module_exit(ad5820_exit);
+module_i2c_driver(ad5820_i2c_driver);
MODULE_AUTHOR("Tuukka Toivonen");
MODULE_DESCRIPTION("AD5820 camera lens driver");
--
(english) http://www.livejournal.com/~pavelmachek
(cesky, pictures) http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html
WARNING: multiple messages have this Message-ID (diff)
From: pavel@ucw.cz (Pavel Machek)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH] support for AD5820 camera auto-focus coil
Date: Wed, 18 May 2016 10:30:48 +0200 [thread overview]
Message-ID: <20160518083048.GA30870@amd> (raw)
In-Reply-To: <20160517183340.GA10358@gmail.com>
Hi!
...
> Use module_i2c_driver() instead.
Thanks for all the comments, I've fixed it up like this, will post new
version soon.
Best regards,
Pavel
commit 97a793fb20be29e7ed217c007e8bf857f9854968
Author: Pavel <pavel@ucw.cz>
Date: Wed May 18 10:22:06 2016 +0200
Cleanups, as suggested by Marcus Folkesson
diff --git a/drivers/media/i2c/ad5820.c b/drivers/media/i2c/ad5820.c
index b71cc11..7725829 100644
--- a/drivers/media/i2c/ad5820.c
+++ b/drivers/media/i2c/ad5820.c
@@ -147,7 +147,6 @@ static int ad5820_set_ctrl(struct v4l2_ctrl *ctrl)
struct ad5820_device *coil =
container_of(ctrl->handler, struct ad5820_device, ctrls);
u32 code;
- int r = 0;
switch (ctrl->id) {
case V4L2_CID_FOCUS_ABSOLUTE:
@@ -165,7 +164,7 @@ static int ad5820_set_ctrl(struct v4l2_ctrl *ctrl)
break;
}
- return r;
+ return 0;
}
static const struct v4l2_ctrl_ops ad5820_ctrl_ops = {
@@ -245,8 +244,6 @@ static int ad5820_init_controls(struct ad5820_device *coil)
*/
static int ad5820_registered(struct v4l2_subdev *subdev)
{
- static const int CHECK_VALUE = 0x3FF0;
-
struct ad5820_device *coil = to_ad5820_device(subdev);
struct i2c_client *client = v4l2_get_subdevdata(subdev);
@@ -364,16 +361,19 @@ static int ad5820_probe(struct i2c_client *client,
strcpy(coil->subdev.name, "ad5820 focus");
ret = media_entity_pads_init(&coil->subdev.entity, 0, NULL);
- if (ret < 0) {
- kfree(coil);
- return ret;
- }
+ if (ret < 0)
+ goto free;
ret = v4l2_async_register_subdev(&coil->subdev);
if (ret < 0)
- kfree(coil);
+ goto cleanup;
return ret;
+cleanup:
+ media_entity_cleanup(&coil->subdev.entity);
+free:
+ kfree(coil);
+ return ret;
}
static int __exit ad5820_remove(struct i2c_client *client)
@@ -409,26 +409,7 @@ static struct i2c_driver ad5820_i2c_driver = {
.id_table = ad5820_id_table,
};
-static int __init ad5820_init(void)
-{
- int rval;
-
- rval = i2c_add_driver(&ad5820_i2c_driver);
- if (rval)
- printk(KERN_INFO "%s: failed registering " AD5820_NAME "\n",
- __func__);
-
- return rval;
-}
-
-static void __exit ad5820_exit(void)
-{
- i2c_del_driver(&ad5820_i2c_driver);
-}
-
-
-module_init(ad5820_init);
-module_exit(ad5820_exit);
+module_i2c_driver(ad5820_i2c_driver);
MODULE_AUTHOR("Tuukka Toivonen");
MODULE_DESCRIPTION("AD5820 camera lens driver");
--
(english) http://www.livejournal.com/~pavelmachek
(cesky, pictures) http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html
next prev parent reply other threads:[~2016-05-18 8:30 UTC|newest]
Thread overview: 158+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-05-17 18:19 [PATCH] support for AD5820 camera auto-focus coil Pavel Machek
2016-05-17 18:19 ` Pavel Machek
2016-05-17 18:33 ` Marcus Folkesson
2016-05-17 18:33 ` Marcus Folkesson
2016-05-18 8:30 ` Pavel Machek [this message]
2016-05-18 8:30 ` Pavel Machek
2016-05-21 5:43 ` [PATCHv2] " Pavel Machek
2016-05-21 5:43 ` Pavel Machek
2016-05-21 6:25 ` Ivaylo Dimitrov
2016-05-21 6:25 ` Ivaylo Dimitrov
2016-05-21 10:56 ` [PATCHv3] " Pavel Machek
2016-05-21 10:56 ` Pavel Machek
2016-05-21 11:43 ` Ivaylo Dimitrov
2016-05-21 11:43 ` Ivaylo Dimitrov
2016-05-23 7:41 ` Pali Rohár
2016-05-23 7:41 ` Pali Rohár
2016-05-23 7:41 ` Pali Rohár
2016-05-24 9:04 ` Pavel Machek
2016-05-24 9:04 ` Pavel Machek
2016-05-24 9:16 ` Ivaylo Dimitrov
2016-05-24 9:16 ` Ivaylo Dimitrov
2016-05-24 20:20 ` Pavel Machek
2016-05-24 20:20 ` Pavel Machek
2016-05-26 3:46 ` Ivaylo Dimitrov
2016-05-26 3:46 ` Ivaylo Dimitrov
2016-05-24 9:17 ` [PATCHv4] " Pavel Machek
2016-05-24 9:17 ` Pavel Machek
2016-05-25 21:26 ` Sakari Ailus
2016-05-25 21:26 ` Sakari Ailus
2016-05-27 20:33 ` Pavel Machek
2016-05-27 20:33 ` Pavel Machek
2016-05-27 20:51 ` [PATCHv5] " Pavel Machek
2016-05-27 20:51 ` Pavel Machek
2016-05-31 21:22 ` Sakari Ailus
2016-05-31 21:22 ` Sakari Ailus
2016-05-31 21:34 ` Pavel Machek
2016-05-31 21:34 ` Pavel Machek
2016-06-01 15:24 ` Sakari Ailus
2016-06-01 15:24 ` Sakari Ailus
2016-06-01 22:08 ` Pavel Machek
2016-06-01 22:08 ` Pavel Machek
2016-06-02 7:45 ` Sakari Ailus
2016-06-02 7:45 ` Sakari Ailus
2016-06-02 19:27 ` Pavel Machek
2016-06-02 19:27 ` Pavel Machek
2016-06-02 21:23 ` Sakari Ailus
2016-06-02 21:23 ` Sakari Ailus
[not found] ` <20160602074544.GR26360-S+BSfZ9RZZmRSg0ZkenSGLdO1Tsj/99ntUK59QYPAWc@public.gmane.org>
2016-06-02 19:30 ` [PATCH] device tree description " Pavel Machek
2016-06-02 19:30 ` Pavel Machek
2016-06-02 19:30 ` Pavel Machek
2016-06-02 21:27 ` Sakari Ailus
2016-06-02 21:27 ` Sakari Ailus
2016-06-03 6:19 ` Pavel Machek
2016-06-03 6:19 ` Pavel Machek
[not found] ` <20160602212746.GT26360-S+BSfZ9RZZmRSg0ZkenSGLdO1Tsj/99ntUK59QYPAWc@public.gmane.org>
2016-06-05 19:07 ` [PATCH] userspace API definitions for " Pavel Machek
2016-06-05 19:07 ` Pavel Machek
2016-06-05 19:07 ` Pavel Machek
2016-06-06 6:06 ` Ivaylo Dimitrov
2016-06-06 6:06 ` Ivaylo Dimitrov
2016-06-06 7:21 ` Pavel Machek
2016-06-06 7:21 ` Pavel Machek
[not found] ` <575512E5.5030000-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2016-06-11 22:06 ` Sakari Ailus
2016-06-11 22:06 ` Sakari Ailus
2016-06-11 22:06 ` Sakari Ailus
2016-06-12 7:54 ` Pavel Machek
2016-06-12 7:54 ` Pavel Machek
2016-06-17 21:28 ` Sakari Ailus
2016-06-17 21:28 ` Sakari Ailus
2016-06-17 21:28 ` Sakari Ailus
2016-06-12 8:48 ` Pavel Machek
2016-06-12 8:48 ` Pavel Machek
2016-06-12 11:22 ` Sakari Ailus
2016-06-12 11:22 ` Sakari Ailus
2016-06-12 11:22 ` Sakari Ailus
[not found] ` <20160612112253.GD26360-S+BSfZ9RZZmRSg0ZkenSGLdO1Tsj/99ntUK59QYPAWc@public.gmane.org>
2016-06-13 19:17 ` Pavel Machek
2016-06-13 19:17 ` Pavel Machek
2016-06-13 19:17 ` Pavel Machek
2016-06-17 21:35 ` Sakari Ailus
2016-06-17 21:35 ` Sakari Ailus
2016-06-18 15:37 ` [PATCHv4] support for AD5820 camera " Pavel Machek
2016-06-18 15:37 ` Pavel Machek
2016-06-18 15:38 ` [PATCH] userspace API definitions for " Pavel Machek
2016-06-18 15:38 ` Pavel Machek
2016-07-12 23:32 ` Mauro Carvalho Chehab
2016-07-12 23:32 ` Mauro Carvalho Chehab
2016-07-12 23:32 ` Mauro Carvalho Chehab
2016-07-13 6:57 ` Pavel Machek
2016-07-13 6:57 ` Pavel Machek
2016-07-13 7:26 ` Pavel Machek
2016-07-13 7:26 ` Pavel Machek
2016-06-06 13:29 ` [PATCH] device tree description for AD5820 camera " Rob Herring
2016-06-06 13:29 ` Rob Herring
2016-06-07 7:10 ` [PATCHv2] " Pavel Machek
2016-06-07 7:10 ` Pavel Machek
2016-06-09 22:37 ` Sakari Ailus
2016-06-09 22:37 ` Sakari Ailus
2016-06-04 23:27 ` [PATCHv5] support " kbuild test robot
2016-06-04 23:27 ` kbuild test robot
2016-06-05 0:46 ` kbuild test robot
2016-06-05 0:46 ` kbuild test robot
2016-06-12 20:41 ` [PATCH 1/1] v4l: Add camera voice coil lens control class, current control Sakari Ailus
2016-06-12 21:48 ` Ivaylo Dimitrov
2016-06-17 22:11 ` Pavel Machek
2016-06-17 22:39 ` Laurent Pinchart
2016-06-18 11:28 ` Pavel Machek
2016-06-17 22:06 ` Pavel Machek
2016-08-05 10:26 ` [PATCHv6] support for AD5820 camera auto-focus coil Pavel Machek
2016-08-05 10:26 ` Pavel Machek
2016-08-05 10:30 ` Pali Rohár
2016-08-05 10:30 ` Pali Rohár
2016-08-08 8:09 ` Sakari Ailus
2016-08-08 8:09 ` Sakari Ailus
2016-08-08 21:41 ` Pavel Machek
2016-08-08 21:41 ` Pavel Machek
2016-08-08 21:41 ` Pavel Machek
2016-08-10 12:01 ` Sakari Ailus
2016-08-10 12:01 ` Sakari Ailus
2016-08-10 12:01 ` Sakari Ailus
2016-08-08 23:23 ` Pavel Machek
2016-08-08 23:23 ` Pavel Machek
2016-08-08 23:23 ` Pavel Machek
2016-08-11 11:16 ` Sakari Ailus
2016-08-11 11:16 ` Sakari Ailus
2016-08-18 10:45 ` Pavel Machek
2016-08-18 10:45 ` Pavel Machek
2016-08-18 20:26 ` Sakari Ailus
2016-08-18 20:26 ` Sakari Ailus
2016-08-18 20:26 ` Sakari Ailus
2016-08-18 21:28 ` Pavel Machek
2016-08-18 21:28 ` Pavel Machek
2016-08-18 21:28 ` Pavel Machek
2016-11-03 10:27 ` Pavel Machek
2016-11-03 10:27 ` Pavel Machek
2016-11-03 21:49 ` Sakari Ailus
2016-11-03 21:49 ` Sakari Ailus
2016-11-04 7:45 ` Pavel Machek
2016-11-04 7:45 ` Pavel Machek
2016-11-04 14:49 ` Tony Lindgren
2016-11-04 14:49 ` Tony Lindgren
2016-12-14 13:38 ` Pali Rohár
2016-12-14 13:38 ` Pali Rohár
2016-12-14 15:08 ` Tony Lindgren
2016-12-14 15:08 ` Tony Lindgren
2016-12-14 15:08 ` Tony Lindgren
2016-12-15 6:50 ` Sakari Ailus
2016-12-15 6:50 ` Sakari Ailus
2016-12-15 6:50 ` Sakari Ailus
2016-12-19 22:23 ` Pavel Machek
2016-12-19 22:23 ` Pavel Machek
2016-08-10 7:34 ` Pali Rohár
2016-08-10 7:34 ` Pali Rohár
2016-08-10 7:34 ` Pali Rohár
2016-08-08 21:40 ` Pavel Machek
2016-08-08 21:40 ` Pavel Machek
2016-08-08 21:40 ` Pavel Machek
2016-08-10 12:00 ` Sakari Ailus
2016-08-10 12:00 ` Sakari Ailus
2016-08-10 12:00 ` Sakari Ailus
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20160518083048.GA30870@amd \
--to=pavel@ucw.cz \
--cc=aaro.koskinen@iki.fi \
--cc=ivo.g.dimitrov.75@gmail.com \
--cc=khilman@kernel.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-media@vger.kernel.org \
--cc=linux-omap@vger.kernel.org \
--cc=marcus.folkesson@gmail.com \
--cc=mchehab@osg.samsung.com \
--cc=pali.rohar@gmail.com \
--cc=patrikbachan@gmail.com \
--cc=sakari.ailus@iki.fi \
--cc=serge@hallyn.com \
--cc=sre@kernel.org \
--cc=tony@atomide.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.