2011-04-23 07:28:34 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2011 Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
|
|
|
|
*
|
|
|
|
* Under GPLv2
|
|
|
|
*/
|
|
|
|
|
2011-04-23 14:12:57 +00:00
|
|
|
struct at91_init_soc {
|
2011-04-23 07:28:34 +00:00
|
|
|
unsigned int *default_irq_priority;
|
2011-04-23 07:28:34 +00:00
|
|
|
void (*map_io)(void);
|
2011-10-13 17:17:18 +00:00
|
|
|
void (*ioremap_registers)(void);
|
2011-04-24 10:15:34 +00:00
|
|
|
void (*register_clocks)(void);
|
2011-04-24 10:20:28 +00:00
|
|
|
void (*init)(void);
|
2011-04-23 07:28:34 +00:00
|
|
|
};
|
|
|
|
|
2011-04-23 14:12:57 +00:00
|
|
|
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;
|
|
|
|
|
|
|
|
static inline int at91_soc_is_enabled(void)
|
|
|
|
{
|
|
|
|
return at91_boot_soc.init != NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
#if !defined(CONFIG_ARCH_AT91RM9200)
|
|
|
|
#define at91rm9200_soc at91_boot_soc
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !(defined(CONFIG_ARCH_AT91SAM9260) || defined(CONFIG_ARCH_AT91SAM9G20))
|
|
|
|
#define at91sam9260_soc at91_boot_soc
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !(defined(CONFIG_ARCH_AT91SAM9261) || defined(CONFIG_ARCH_AT91SAM9G10))
|
|
|
|
#define at91sam9261_soc at91_boot_soc
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !defined(CONFIG_ARCH_AT91SAM9263)
|
|
|
|
#define at91sam9263_soc at91_boot_soc
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !defined(CONFIG_ARCH_AT91SAM9G45)
|
|
|
|
#define at91sam9g45_soc at91_boot_soc
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !defined(CONFIG_ARCH_AT91SAM9RL)
|
|
|
|
#define at91sam9rl_soc at91_boot_soc
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !defined(CONFIG_ARCH_AT91SAM9X5)
|
|
|
|
#define at91sam9x5_soc at91_boot_soc
|
|
|
|
#endif
|