i2c: free idr when sanity checks in i2c_register_adapter() fail
On error, we should give idr back to the pool in any case. Signed-off-by: Wolfram Sang <wsa-dev@sang-engineering.com> Reviewed-by: Jean Delvare <jdelvare@suse.de> Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
This commit is contained in:
parent
cc4618813e
commit
ce0dffafd4
@ -1554,7 +1554,7 @@ static int __process_new_adapter(struct device_driver *d, void *data)
|
|||||||
|
|
||||||
static int i2c_register_adapter(struct i2c_adapter *adap)
|
static int i2c_register_adapter(struct i2c_adapter *adap)
|
||||||
{
|
{
|
||||||
int res = 0;
|
int res = -EINVAL;
|
||||||
|
|
||||||
/* Can't register until after driver model init */
|
/* Can't register until after driver model init */
|
||||||
if (WARN_ON(!is_registered)) {
|
if (WARN_ON(!is_registered)) {
|
||||||
@ -1566,12 +1566,12 @@ static int i2c_register_adapter(struct i2c_adapter *adap)
|
|||||||
if (unlikely(adap->name[0] == '\0')) {
|
if (unlikely(adap->name[0] == '\0')) {
|
||||||
pr_err("i2c-core: Attempt to register an adapter with "
|
pr_err("i2c-core: Attempt to register an adapter with "
|
||||||
"no name!\n");
|
"no name!\n");
|
||||||
return -EINVAL;
|
goto out_list;
|
||||||
}
|
}
|
||||||
if (unlikely(!adap->algo)) {
|
if (unlikely(!adap->algo)) {
|
||||||
pr_err("i2c-core: Attempt to register adapter '%s' with "
|
pr_err("i2c-core: Attempt to register adapter '%s' with "
|
||||||
"no algo!\n", adap->name);
|
"no algo!\n", adap->name);
|
||||||
return -EINVAL;
|
goto out_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!adap->lock_bus) {
|
if (!adap->lock_bus) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user