diff options
Diffstat (limited to 'sound/aoa/codecs/tas.c')
| -rw-r--r-- | sound/aoa/codecs/tas.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/sound/aoa/codecs/tas.c b/sound/aoa/codecs/tas.c index f0ebc971c686..1dd66ddffcaf 100644 --- a/sound/aoa/codecs/tas.c +++ b/sound/aoa/codecs/tas.c | |||
| @@ -897,6 +897,15 @@ static int tas_create(struct i2c_adapter *adapter, | |||
| 897 | client = i2c_new_device(adapter, &info); | 897 | client = i2c_new_device(adapter, &info); |
| 898 | if (!client) | 898 | if (!client) |
| 899 | return -ENODEV; | 899 | return -ENODEV; |
| 900 | /* | ||
| 901 | * We know the driver is already loaded, so the device should be | ||
| 902 | * already bound. If not it means binding failed, and then there | ||
| 903 | * is no point in keeping the device instantiated. | ||
| 904 | */ | ||
| 905 | if (!client->driver) { | ||
| 906 | i2c_unregister_device(client); | ||
| 907 | return -ENODEV; | ||
| 908 | } | ||
| 900 | 909 | ||
| 901 | /* | 910 | /* |
| 902 | * Let i2c-core delete that device on driver removal. | 911 | * Let i2c-core delete that device on driver removal. |
