ARM: 5640/1: This patch modifies the support of AC97 on the at91sam9263 ek board

This patch modifies the support of AC97 on the at91sam9263 ek board, so it would
share the code with AVR32.
Plus it removes a typo in at91sam9263_devices.c.

Signed-off-by: Sedji Gaouaou <sedji.gaouaou@atmel.com>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
This commit is contained in:
sedji gaouaou 2009-08-06 15:20:22 +01:00 committed by Russell King
parent 0c30df6fe0
commit d656f07a74
3 changed files with 10 additions and 12 deletions

View File

@ -707,9 +707,9 @@ void __init at91_add_device_spi(struct spi_board_info *devices, int nr_devices)
* AC97 * AC97
* -------------------------------------------------------------------- */ * -------------------------------------------------------------------- */
#if defined(CONFIG_SND_AT91_AC97) || defined(CONFIG_SND_AT91_AC97_MODULE) #if defined(CONFIG_SND_ATMEL_AC97C) || defined(CONFIG_SND_ATMEL_AC97C_MODULE)
static u64 ac97_dmamask = DMA_BIT_MASK(32); static u64 ac97_dmamask = DMA_BIT_MASK(32);
static struct atmel_ac97_data ac97_data; static struct ac97c_platform_data ac97_data;
static struct resource ac97_resources[] = { static struct resource ac97_resources[] = {
[0] = { [0] = {
@ -725,8 +725,8 @@ static struct resource ac97_resources[] = {
}; };
static struct platform_device at91sam9263_ac97_device = { static struct platform_device at91sam9263_ac97_device = {
.name = "ac97c", .name = "atmel_ac97c",
.id = 1, .id = 0,
.dev = { .dev = {
.dma_mask = &ac97_dmamask, .dma_mask = &ac97_dmamask,
.coherent_dma_mask = DMA_BIT_MASK(32), .coherent_dma_mask = DMA_BIT_MASK(32),
@ -736,7 +736,7 @@ static struct platform_device at91sam9263_ac97_device = {
.num_resources = ARRAY_SIZE(ac97_resources), .num_resources = ARRAY_SIZE(ac97_resources),
}; };
void __init at91_add_device_ac97(struct atmel_ac97_data *data) void __init at91_add_device_ac97(struct ac97c_platform_data *data)
{ {
if (!data) if (!data)
return; return;
@ -750,11 +750,11 @@ void __init at91_add_device_ac97(struct atmel_ac97_data *data)
if (data->reset_pin) if (data->reset_pin)
at91_set_gpio_output(data->reset_pin, 0); at91_set_gpio_output(data->reset_pin, 0);
ac97_data = *ek_data; ac97_data = *data;
platform_device_register(&at91sam9263_ac97_device); platform_device_register(&at91sam9263_ac97_device);
} }
#else #else
void __init at91_add_device_ac97(struct atmel_ac97_data *data) {} void __init at91_add_device_ac97(struct ac97c_platform_data *data) {}
#endif #endif

View File

@ -365,7 +365,7 @@ static void __init ek_add_device_buttons(void) {}
/* /*
* AC97 * AC97
*/ */
static struct atmel_ac97_data ek_ac97_data = { static struct ac97c_platform_data ek_ac97_data = {
.reset_pin = AT91_PIN_PA13, .reset_pin = AT91_PIN_PA13,
}; };

View File

@ -37,6 +37,7 @@
#include <linux/leds.h> #include <linux/leds.h>
#include <linux/spi/spi.h> #include <linux/spi/spi.h>
#include <linux/usb/atmel_usba_udc.h> #include <linux/usb/atmel_usba_udc.h>
#include <sound/atmel-ac97c.h>
/* USB Device */ /* USB Device */
struct at91_udc_data { struct at91_udc_data {
@ -174,10 +175,7 @@ struct atmel_lcdfb_info;
extern void __init at91_add_device_lcdc(struct atmel_lcdfb_info *data); extern void __init at91_add_device_lcdc(struct atmel_lcdfb_info *data);
/* AC97 */ /* AC97 */
struct atmel_ac97_data { extern void __init at91_add_device_ac97(struct ac97c_platform_data *data);
u8 reset_pin; /* reset */
};
extern void __init at91_add_device_ac97(struct atmel_ac97_data *data);
/* ISI */ /* ISI */
extern void __init at91_add_device_isi(void); extern void __init at91_add_device_isi(void);