summaryrefslogtreecommitdiff
path: root/drivers/staging/greybus/pwm.c
diff options
context:
space:
mode:
authorViresh Kumar <viresh.kumar@linaro.org>2015-01-21 18:12:36 +0530
committerGreg Kroah-Hartman <greg@kroah.com>2015-01-22 11:29:39 +0800
commit36e79dec96f652110ae2b06bfcf9e67e1b770787 (patch)
tree333e41723bf440abb77c0dc1ea89cbacf198a480 /drivers/staging/greybus/pwm.c
parent530430b717f02843fe1f2e77e6f52a41e05d6c3a (diff)
greybus: create get_version() routines with the help of a macro
This gets rid of lots of duplication of code. Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org> Reviewed-by: Alex Elder <elder@linaro.org> Signed-off-by: Greg Kroah-Hartman <greg@kroah.com>
Diffstat (limited to 'drivers/staging/greybus/pwm.c')
-rw-r--r--drivers/staging/greybus/pwm.c28
1 files changed, 3 insertions, 25 deletions
diff --git a/drivers/staging/greybus/pwm.c b/drivers/staging/greybus/pwm.c
index 91f7b87a1cae..7b7252358575 100644
--- a/drivers/staging/greybus/pwm.c
+++ b/drivers/staging/greybus/pwm.c
@@ -79,30 +79,8 @@ struct gb_pwm_disable_request {
__u8 which;
};
-/*
- * This request only uses the connection field, and if successful,
- * fills in the major and minor protocol version of the target.
- */
-static int gb_pwm_proto_version_operation(struct gb_pwm_chip *pwmc)
-{
- struct gb_pwm_proto_version_response response;
- int ret;
-
- ret = gb_operation_sync(pwmc->connection, GB_PWM_TYPE_PROTOCOL_VERSION,
- NULL, 0, &response, sizeof(response));
-
- if (ret)
- return ret;
-
- if (response.major > GB_PWM_VERSION_MAJOR) {
- pr_err("unsupported major version (%hhu > %hhu)\n",
- response.major, GB_PWM_VERSION_MAJOR);
- return -ENOTSUPP;
- }
- pwmc->version_major = response.major;
- pwmc->version_minor = response.minor;
- return 0;
-}
+/* Define get_version() routine */
+define_get_version(gb_pwm_chip, PWM);
static int gb_pwm_count_operation(struct gb_pwm_chip *pwmc)
{
@@ -269,7 +247,7 @@ static int gb_pwm_connection_init(struct gb_connection *connection)
connection->private = pwmc;
/* Check for compatible protocol version */
- ret = gb_pwm_proto_version_operation(pwmc);
+ ret = get_version(pwmc);
if (ret)
goto out_err;