diff options
| -rw-r--r-- | arch/arm/mach-at91/board-sam9g20ek.c | 1 | ||||
| -rw-r--r-- | sound/soc/atmel/sam9g20_wm8731.c | 36 |
2 files changed, 1 insertions, 36 deletions
diff --git a/arch/arm/mach-at91/board-sam9g20ek.c b/arch/arm/mach-at91/board-sam9g20ek.c index cc270beadd5d..4c2598700882 100644 --- a/arch/arm/mach-at91/board-sam9g20ek.c +++ b/arch/arm/mach-at91/board-sam9g20ek.c | |||
| @@ -221,6 +221,7 @@ static struct gpio_led ek_leds[] = { | |||
| 221 | static struct i2c_board_info __initdata ek_i2c_devices[] = { | 221 | static struct i2c_board_info __initdata ek_i2c_devices[] = { |
| 222 | { | 222 | { |
| 223 | I2C_BOARD_INFO("24c512", 0x50), | 223 | I2C_BOARD_INFO("24c512", 0x50), |
| 224 | I2C_BOARD_INFO("wm8731", 0x1b), | ||
| 224 | }, | 225 | }, |
| 225 | }; | 226 | }; |
| 226 | 227 | ||
diff --git a/sound/soc/atmel/sam9g20_wm8731.c b/sound/soc/atmel/sam9g20_wm8731.c index 173a239a541c..bb0db55e0e98 100644 --- a/sound/soc/atmel/sam9g20_wm8731.c +++ b/sound/soc/atmel/sam9g20_wm8731.c | |||
| @@ -281,38 +281,6 @@ static struct snd_soc_card snd_soc_at91sam9g20ek = { | |||
| 281 | .set_bias_level = at91sam9g20ek_set_bias_level, | 281 | .set_bias_level = at91sam9g20ek_set_bias_level, |
| 282 | }; | 282 | }; |
| 283 | 283 | ||
| 284 | /* | ||
| 285 | * FIXME: This is a temporary bodge to avoid cross-tree merge issues. | ||
| 286 | * New drivers should register the wm8731 I2C device in the machine | ||
| 287 | * setup code (under arch/arm for ARM systems). | ||
| 288 | */ | ||
| 289 | static int wm8731_i2c_register(void) | ||
| 290 | { | ||
| 291 | struct i2c_board_info info; | ||
| 292 | struct i2c_adapter *adapter; | ||
| 293 | struct i2c_client *client; | ||
| 294 | |||
| 295 | memset(&info, 0, sizeof(struct i2c_board_info)); | ||
| 296 | info.addr = 0x1b; | ||
| 297 | strlcpy(info.type, "wm8731", I2C_NAME_SIZE); | ||
| 298 | |||
| 299 | adapter = i2c_get_adapter(0); | ||
| 300 | if (!adapter) { | ||
| 301 | printk(KERN_ERR "can't get i2c adapter 0\n"); | ||
| 302 | return -ENODEV; | ||
| 303 | } | ||
| 304 | |||
| 305 | client = i2c_new_device(adapter, &info); | ||
| 306 | i2c_put_adapter(adapter); | ||
| 307 | if (!client) { | ||
| 308 | printk(KERN_ERR "can't add i2c device at 0x%x\n", | ||
| 309 | (unsigned int)info.addr); | ||
| 310 | return -ENODEV; | ||
| 311 | } | ||
| 312 | |||
| 313 | return 0; | ||
| 314 | } | ||
| 315 | |||
| 316 | static struct snd_soc_device at91sam9g20ek_snd_devdata = { | 284 | static struct snd_soc_device at91sam9g20ek_snd_devdata = { |
| 317 | .card = &snd_soc_at91sam9g20ek, | 285 | .card = &snd_soc_at91sam9g20ek, |
| 318 | .codec_dev = &soc_codec_dev_wm8731, | 286 | .codec_dev = &soc_codec_dev_wm8731, |
| @@ -367,10 +335,6 @@ static int __init at91sam9g20ek_init(void) | |||
| 367 | } | 335 | } |
| 368 | ssc_p->ssc = ssc; | 336 | ssc_p->ssc = ssc; |
| 369 | 337 | ||
| 370 | ret = wm8731_i2c_register(); | ||
| 371 | if (ret != 0) | ||
| 372 | goto err_ssc; | ||
| 373 | |||
| 374 | at91sam9g20ek_snd_device = platform_device_alloc("soc-audio", -1); | 338 | at91sam9g20ek_snd_device = platform_device_alloc("soc-audio", -1); |
| 375 | if (!at91sam9g20ek_snd_device) { | 339 | if (!at91sam9g20ek_snd_device) { |
| 376 | printk(KERN_ERR "ASoC: Platform device allocation failed\n"); | 340 | printk(KERN_ERR "ASoC: Platform device allocation failed\n"); |
