Commit 9b6a5ad9 authored by Lee Jones's avatar Lee Jones

mfd: htc-i2cpld: Rectify pointer offset error

Checking the result of container_of() against NULL will always result to
false.  Using the offset of member 'chip_out' to find the start of 'struct
htcpld_chip' will result in an offset error when .get_chip() is attempting
to obtain 'htcpld-in'.  Instead, we'll use the correct member based on a
previously the set chip label.
Signed-off-by: default avatarLee Jones <lee.jones@linaro.org>
parent 41cc08e9
...@@ -258,31 +258,18 @@ static void htcpld_chip_set_ni(struct work_struct *work) ...@@ -258,31 +258,18 @@ static void htcpld_chip_set_ni(struct work_struct *work)
static int htcpld_chip_get(struct gpio_chip *chip, unsigned offset) static int htcpld_chip_get(struct gpio_chip *chip, unsigned offset)
{ {
struct htcpld_chip *chip_data; struct htcpld_chip *chip_data;
int val = 0; u8 cache;
int is_input = 0;
/* Try out first */
chip_data = container_of(chip, struct htcpld_chip, chip_out);
if (!chip_data) {
/* Try in */
is_input = 1;
chip_data = container_of(chip, struct htcpld_chip, chip_in);
if (!chip_data)
return -EINVAL;
}
/* Determine if this is an input or output GPIO */ if (!strncmp(chip->label, "htcpld-out", 10)) {
if (!is_input) chip_data = container_of(chip, struct htcpld_chip, chip_out);
/* Use the output cache */ cache = chip_data->cache_out;
val = (chip_data->cache_out >> offset) & 1; } else if (!strncmp(chip->label, "htcpld-in", 9)) {
else chip_data = container_of(chip, struct htcpld_chip, chip_in);
/* Use the input cache */ cache = chip_data->cache_in;
val = (chip_data->cache_in >> offset) & 1; } else
return -EINVAL;
if (val) return (cache >> offset) & 1;
return 1;
else
return 0;
} }
static int htcpld_direction_output(struct gpio_chip *chip, static int htcpld_direction_output(struct gpio_chip *chip,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment