mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-12 21:44:06 +08:00
8f4b47949f
This patch introduces the SAMA5 support and a generic board file for SAMA5 devices. It also updates the PMC driver to manage clock division which is a requirement since some peripherals can't work at the bus frequency on SAMA5. Signed-off-by: Ludovic Desroches <ludovic.desroches@atmel.com> Signed-off-by: Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com> Signed-off-by: Nicolas Ferre <nicolas.ferre@atmel.com>
76 lines
1.7 KiB
C
76 lines
1.7 KiB
C
/*
|
|
* Copyright (C) 2011 Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
|
|
*
|
|
* Under GPLv2
|
|
*/
|
|
|
|
struct at91_init_soc {
|
|
int builtin;
|
|
unsigned int *default_irq_priority;
|
|
void (*map_io)(void);
|
|
void (*ioremap_registers)(void);
|
|
void (*register_clocks)(void);
|
|
void (*init)(void);
|
|
};
|
|
|
|
extern struct at91_init_soc at91_boot_soc;
|
|
extern struct at91_init_soc at91rm9200_soc;
|
|
extern struct at91_init_soc at91sam9260_soc;
|
|
extern struct at91_init_soc at91sam9261_soc;
|
|
extern struct at91_init_soc at91sam9263_soc;
|
|
extern struct at91_init_soc at91sam9g45_soc;
|
|
extern struct at91_init_soc at91sam9rl_soc;
|
|
extern struct at91_init_soc at91sam9x5_soc;
|
|
extern struct at91_init_soc at91sam9n12_soc;
|
|
extern struct at91_init_soc sama5d3_soc;
|
|
|
|
#define AT91_SOC_START(_name) \
|
|
struct at91_init_soc __initdata _name##_soc \
|
|
__used \
|
|
= { \
|
|
.builtin = 1, \
|
|
|
|
#define AT91_SOC_END \
|
|
};
|
|
|
|
static inline int at91_soc_is_enabled(void)
|
|
{
|
|
return at91_boot_soc.builtin;
|
|
}
|
|
|
|
#if !defined(CONFIG_SOC_AT91RM9200)
|
|
#define at91rm9200_soc at91_boot_soc
|
|
#endif
|
|
|
|
#if !defined(CONFIG_SOC_AT91SAM9260)
|
|
#define at91sam9260_soc at91_boot_soc
|
|
#endif
|
|
|
|
#if !defined(CONFIG_SOC_AT91SAM9261)
|
|
#define at91sam9261_soc at91_boot_soc
|
|
#endif
|
|
|
|
#if !defined(CONFIG_SOC_AT91SAM9263)
|
|
#define at91sam9263_soc at91_boot_soc
|
|
#endif
|
|
|
|
#if !defined(CONFIG_SOC_AT91SAM9G45)
|
|
#define at91sam9g45_soc at91_boot_soc
|
|
#endif
|
|
|
|
#if !defined(CONFIG_SOC_AT91SAM9RL)
|
|
#define at91sam9rl_soc at91_boot_soc
|
|
#endif
|
|
|
|
#if !defined(CONFIG_SOC_AT91SAM9X5)
|
|
#define at91sam9x5_soc at91_boot_soc
|
|
#endif
|
|
|
|
#if !defined(CONFIG_SOC_AT91SAM9N12)
|
|
#define at91sam9n12_soc at91_boot_soc
|
|
#endif
|
|
|
|
#if !defined(CONFIG_SOC_SAMA5D3)
|
|
#define sama5d3_soc at91_boot_soc
|
|
#endif
|