8014d6f4dd
Both AIC and GPIO controllers are now using the standard of_irq_init() function to initialize IRQs in case of DT use. The DT specific initialization functions are now separated from the non-DT case and are now using "linear" irq domains. The .map() irqdomain operation is responsible for positioning the IRQ handlers. In AIC case, the Linux IRQ number is directly programmed in the hardware to avoid an additional reverse mapping operation. The AIC position its irq domain as the "default" irq domain. For DT case, the priority is not yet filled in the SMR. It will be the subject of another patch. Signed-off-by: Nicolas Ferre <nicolas.ferre@atmel.com>
121 lines
2.7 KiB
C
121 lines
2.7 KiB
C
/*
|
|
* Setup code for AT91SAM Evaluation Kits with Device Tree support
|
|
*
|
|
* Covers: * AT91SAM9G45-EKES board
|
|
* * AT91SAM9M10-EKES board
|
|
* * AT91SAM9M10G45-EK board
|
|
*
|
|
* Copyright (C) 2011 Atmel,
|
|
* 2011 Nicolas Ferre <nicolas.ferre@atmel.com>
|
|
*
|
|
* Licensed under GPLv2 or later.
|
|
*/
|
|
|
|
#include <linux/types.h>
|
|
#include <linux/init.h>
|
|
#include <linux/module.h>
|
|
#include <linux/gpio.h>
|
|
#include <linux/of.h>
|
|
#include <linux/of_irq.h>
|
|
#include <linux/of_platform.h>
|
|
|
|
#include <mach/hardware.h>
|
|
#include <mach/board.h>
|
|
#include <mach/system_rev.h>
|
|
#include <mach/at91sam9_smc.h>
|
|
|
|
#include <asm/setup.h>
|
|
#include <asm/irq.h>
|
|
#include <asm/mach/arch.h>
|
|
#include <asm/mach/map.h>
|
|
#include <asm/mach/irq.h>
|
|
|
|
#include "sam9_smc.h"
|
|
#include "generic.h"
|
|
|
|
|
|
static void __init ek_init_early(void)
|
|
{
|
|
/* Initialize processor: 12.000 MHz crystal */
|
|
at91_initialize(12000000);
|
|
}
|
|
|
|
/* det_pin is not connected */
|
|
static struct atmel_nand_data __initdata ek_nand_data = {
|
|
.ale = 21,
|
|
.cle = 22,
|
|
.det_pin = -EINVAL,
|
|
.rdy_pin = AT91_PIN_PC8,
|
|
.enable_pin = AT91_PIN_PC14,
|
|
};
|
|
|
|
static struct sam9_smc_config __initdata ek_nand_smc_config = {
|
|
.ncs_read_setup = 0,
|
|
.nrd_setup = 2,
|
|
.ncs_write_setup = 0,
|
|
.nwe_setup = 2,
|
|
|
|
.ncs_read_pulse = 4,
|
|
.nrd_pulse = 4,
|
|
.ncs_write_pulse = 4,
|
|
.nwe_pulse = 4,
|
|
|
|
.read_cycle = 7,
|
|
.write_cycle = 7,
|
|
|
|
.mode = AT91_SMC_READMODE | AT91_SMC_WRITEMODE | AT91_SMC_EXNWMODE_DISABLE,
|
|
.tdf_cycles = 3,
|
|
};
|
|
|
|
static void __init ek_add_device_nand(void)
|
|
{
|
|
ek_nand_data.bus_width_16 = board_have_nand_16bit();
|
|
/* setup bus-width (8 or 16) */
|
|
if (ek_nand_data.bus_width_16)
|
|
ek_nand_smc_config.mode |= AT91_SMC_DBW_16;
|
|
else
|
|
ek_nand_smc_config.mode |= AT91_SMC_DBW_8;
|
|
|
|
/* configure chip-select 3 (NAND) */
|
|
sam9_smc_configure(0, 3, &ek_nand_smc_config);
|
|
|
|
at91_add_device_nand(&ek_nand_data);
|
|
}
|
|
|
|
static const struct of_device_id irq_of_match[] __initconst = {
|
|
|
|
{ .compatible = "atmel,at91rm9200-aic", .data = at91_aic_of_init },
|
|
{ .compatible = "atmel,at91rm9200-gpio", .data = at91_gpio_of_irq_setup },
|
|
{ /*sentinel*/ }
|
|
};
|
|
|
|
static void __init at91_dt_init_irq(void)
|
|
{
|
|
of_irq_init(irq_of_match);
|
|
}
|
|
|
|
static void __init at91_dt_device_init(void)
|
|
{
|
|
of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL);
|
|
|
|
/* NAND */
|
|
ek_add_device_nand();
|
|
}
|
|
|
|
static const char *at91_dt_board_compat[] __initdata = {
|
|
"atmel,at91sam9m10g45ek",
|
|
"atmel,at91sam9x5ek",
|
|
"calao,usb-a9g20",
|
|
NULL
|
|
};
|
|
|
|
DT_MACHINE_START(at91sam_dt, "Atmel AT91SAM (Device Tree)")
|
|
/* Maintainer: Atmel */
|
|
.timer = &at91sam926x_timer,
|
|
.map_io = at91_map_io,
|
|
.init_early = ek_init_early,
|
|
.init_irq = at91_dt_init_irq,
|
|
.init_machine = at91_dt_device_init,
|
|
.dt_compat = at91_dt_board_compat,
|
|
MACHINE_END
|