diff options
author | Marc Kleine-Budde <mkl@pengutronix.de> | 2020-07-03 12:33:15 +0200 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2020-07-29 10:16:53 +0200 |
commit | 545f4f98e29e2c8346b83c3f42df0a3d907c4df9 (patch) | |
tree | 18854eef60a0907ff389829631568bc390b8b371 /drivers/base | |
parent | d3703082e838681cdb98700b9c1cceefc644e5cc (diff) | |
download | linux-stable-545f4f98e29e2c8346b83c3f42df0a3d907c4df9.tar.gz linux-stable-545f4f98e29e2c8346b83c3f42df0a3d907c4df9.tar.bz2 linux-stable-545f4f98e29e2c8346b83c3f42df0a3d907c4df9.zip |
regmap: dev_get_regmap_match(): fix string comparison
[ Upstream commit e84861fec32dee8a2e62bbaa52cded6b05a2a456 ]
This function is used by dev_get_regmap() to retrieve a regmap for the
specified device. If the device has more than one regmap, the name parameter
can be used to specify one.
The code here uses a pointer comparison to check for equal strings. This
however will probably always fail, as the regmap->name is allocated via
kstrdup_const() from the regmap's config->name.
Fix this by using strcmp() instead.
Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
Link: https://lore.kernel.org/r/20200703103315.267996-1-mkl@pengutronix.de
Signed-off-by: Mark Brown <broonie@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
Diffstat (limited to 'drivers/base')
-rw-r--r-- | drivers/base/regmap/regmap.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/base/regmap/regmap.c b/drivers/base/regmap/regmap.c index c7d946b745ef..d26b485ccc7d 100644 --- a/drivers/base/regmap/regmap.c +++ b/drivers/base/regmap/regmap.c @@ -1343,7 +1343,7 @@ static int dev_get_regmap_match(struct device *dev, void *res, void *data) /* If the user didn't specify a name match any */ if (data) - return (*r)->name == data; + return !strcmp((*r)->name, data); else return 1; } |