[PATCH] mfd: tps6105x: Fix NULL pointer access.

From: Grigoryev Denis
Date: Fri Sep 04 2015 - 11:20:24 EST


When tps6105x used in TPS6105X_MODE_SHUTDOWN mode the driver calls
mfd_add_devices() with mfd_cell->name == NULL, that causes an ooops in
platform_device_register() later.

This patch reorders mfd_cell structures and makes code to call
mfd_add_devices() with proper number of cells.

Signed-off-by: Denis Grigoryev <grigoryev@xxxxxxxxxxxxxx>
---
drivers/mfd/tps6105x.c | 16 +++++++++-------
1 file changed, 9 insertions(+), 7 deletions(-)

diff --git a/drivers/mfd/tps6105x.c b/drivers/mfd/tps6105x.c
index 5de95c2..be2c286 100644
--- a/drivers/mfd/tps6105x.c
+++ b/drivers/mfd/tps6105x.c
@@ -124,11 +124,11 @@ static int tps6105x_startup(struct tps6105x *tps6105x)
*/
static struct mfd_cell tps6105x_cells[] = {
{
- /* name will be runtime assigned */
+ .name = "tps6105x-gpio",
.id = -1,
},
{
- .name = "tps6105x-gpio",
+ /* name will be runtime assigned */
.id = -1,
},
};
@@ -138,6 +138,7 @@ static int tps6105x_probe(struct i2c_client *client,
{
struct tps6105x *tps6105x;
struct tps6105x_platform_data *pdata;
+ int n_cells = ARRAY_SIZE(tps6105x_cells);
int ret;
int i;

@@ -162,33 +163,34 @@ static int tps6105x_probe(struct i2c_client *client,
case TPS6105X_MODE_SHUTDOWN:
dev_info(&client->dev,
"present, not used for anything, only GPIO\n");
+ n_cells = 1;
break;
case TPS6105X_MODE_TORCH:
- tps6105x_cells[0].name = "tps6105x-leds";
+ tps6105x_cells[1].name = "tps6105x-leds";
dev_warn(&client->dev,
"torch mode is unsupported\n");
break;
case TPS6105X_MODE_TORCH_FLASH:
- tps6105x_cells[0].name = "tps6105x-flash";
+ tps6105x_cells[1].name = "tps6105x-flash";
dev_warn(&client->dev,
"flash mode is unsupported\n");
break;
case TPS6105X_MODE_VOLTAGE:
- tps6105x_cells[0].name ="tps6105x-regulator";
+ tps6105x_cells[1].name = "tps6105x-regulator";
break;
default:
break;
}

/* Set up and register the platform devices. */
- for (i = 0; i < ARRAY_SIZE(tps6105x_cells); i++) {
+ for (i = 0; i < n_cells; i++) {
/* One state holder for all drivers, this is simple */
tps6105x_cells[i].platform_data = tps6105x;
tps6105x_cells[i].pdata_size = sizeof(*tps6105x);
}

return mfd_add_devices(&client->dev, 0, tps6105x_cells,
- ARRAY_SIZE(tps6105x_cells), NULL, 0, NULL);
+ n_cells, NULL, 0, NULL);
}

static int tps6105x_remove(struct i2c_client *client)
--
1.7.10.4