summaryrefslogtreecommitdiffstats
path: root/drivers/gpio/gpio-mockup.c
diff options
context:
space:
mode:
authorBartosz Golaszewski <brgl@bgdev.pl>2017-06-09 07:41:28 -0400
committerLinus Walleij <linus.walleij@linaro.org>2017-06-20 03:18:55 -0400
commitb652336d3fb70b95a5b0a5ea3a32e7116b15be29 (patch)
tree9eb90868ac9f4afe3b88e80fa33ec0e41361a178 /drivers/gpio/gpio-mockup.c
parentb6c2e77d34ff775e4cf4ca803877dafd74737551 (diff)
gpio: mockup: improve readability
We currently shift bits here and there without actually explaining what we're doing. Add some helper variables with names indicating their purpose to improve the code readability. Signed-off-by: Bartosz Golaszewski <brgl@bgdev.pl> Reviewed-by: Andy Shevchenko <andy.shevchenko@gmail.com> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Diffstat (limited to 'drivers/gpio/gpio-mockup.c')
-rw-r--r--drivers/gpio/gpio-mockup.c20
1 files changed, 13 insertions, 7 deletions
diff --git a/drivers/gpio/gpio-mockup.c b/drivers/gpio/gpio-mockup.c
index d95d37aeb91f..0cb6cbacc069 100644
--- a/drivers/gpio/gpio-mockup.c
+++ b/drivers/gpio/gpio-mockup.c
@@ -27,6 +27,11 @@
27 27
28#define GPIO_MOCKUP_NAME "gpio-mockup" 28#define GPIO_MOCKUP_NAME "gpio-mockup"
29#define GPIO_MOCKUP_MAX_GC 10 29#define GPIO_MOCKUP_MAX_GC 10
30/*
31 * We're storing two values per chip: the GPIO base and the number
32 * of GPIO lines.
33 */
34#define GPIO_MOCKUP_MAX_RANGES (GPIO_MOCKUP_MAX_GC * 2)
30 35
31enum { 36enum {
32 GPIO_MOCKUP_DIR_OUT = 0, 37 GPIO_MOCKUP_DIR_OUT = 0,
@@ -62,7 +67,7 @@ struct gpio_mockup_dbgfs_private {
62 int offset; 67 int offset;
63}; 68};
64 69
65static int gpio_mockup_ranges[GPIO_MOCKUP_MAX_GC << 1]; 70static int gpio_mockup_ranges[GPIO_MOCKUP_MAX_RANGES];
66static int gpio_mockup_params_nr; 71static int gpio_mockup_params_nr;
67module_param_array(gpio_mockup_ranges, int, &gpio_mockup_params_nr, 0400); 72module_param_array(gpio_mockup_ranges, int, &gpio_mockup_params_nr, 0400);
68 73
@@ -329,23 +334,24 @@ static int gpio_mockup_add(struct device *dev,
329 334
330static int gpio_mockup_probe(struct platform_device *pdev) 335static int gpio_mockup_probe(struct platform_device *pdev)
331{ 336{
332 struct gpio_mockup_chip *chips; 337 int ret, i, base, ngpio, num_chips;
333 struct device *dev = &pdev->dev; 338 struct device *dev = &pdev->dev;
334 int ret, i, base, ngpio; 339 struct gpio_mockup_chip *chips;
335 char *chip_name; 340 char *chip_name;
336 341
337 if (gpio_mockup_params_nr < 2 || (gpio_mockup_params_nr % 2)) 342 if (gpio_mockup_params_nr < 2 || (gpio_mockup_params_nr % 2))
338 return -EINVAL; 343 return -EINVAL;
339 344
340 chips = devm_kzalloc(dev, 345 /* Each chip is described by two values. */
341 sizeof(*chips) * (gpio_mockup_params_nr >> 1), 346 num_chips = gpio_mockup_params_nr / 2;
342 GFP_KERNEL); 347
348 chips = devm_kzalloc(dev, sizeof(*chips) * num_chips, GFP_KERNEL);
343 if (!chips) 349 if (!chips)
344 return -ENOMEM; 350 return -ENOMEM;
345 351
346 platform_set_drvdata(pdev, chips); 352 platform_set_drvdata(pdev, chips);
347 353
348 for (i = 0; i < gpio_mockup_params_nr >> 1; i++) { 354 for (i = 0; i < num_chips; i++) {
349 base = gpio_mockup_ranges[i * 2]; 355 base = gpio_mockup_ranges[i * 2];
350 356
351 if (base == -1) 357 if (base == -1)