memory: atmel-ebi: add sam9x60 EBI support
authorTudor Ambarus <tudor.ambarus@microchip.com>
Wed, 13 Feb 2019 08:59:55 +0000 (08:59 +0000)
committerMiquel Raynal <miquel.raynal@bootlin.com>
Thu, 21 Mar 2019 15:45:04 +0000 (16:45 +0100)
The sam9x60 board defines the CCFG_EBICSA register under SFR,
and not as a MATRIX register, as previous boards do.

Signed-off-by: Tudor Ambarus <tudor.ambarus@microchip.com>
Acked-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
Signed-off-by: Miquel Raynal <miquel.raynal@bootlin.com>
drivers/memory/atmel-ebi.c

index b45914cfa2129bcda6b0d5a6ed5c8b082a9df29d..0322df9dc2497288f94a818b83bff4b42b15264f 100644 (file)
@@ -17,6 +17,7 @@
 #include <linux/init.h>
 #include <linux/of_device.h>
 #include <linux/regmap.h>
+#include <soc/at91/atmel-sfr.h>
 
 struct atmel_ebi_dev_config {
        int cs;
@@ -440,6 +441,15 @@ static const struct atmel_ebi_caps sama5d3_ebi_caps = {
        .apply_config = sama5_ebi_apply_config,
 };
 
+static const struct atmel_ebi_caps sam9x60_ebi_caps = {
+       .available_cs = 0x3f,
+       .ebi_csa_offs = AT91_SFR_CCFG_EBICSA,
+       .regmap_name = "microchip,sfr",
+       .get_config = at91sam9_ebi_get_config,
+       .xlate_config = atmel_ebi_xslate_smc_config,
+       .apply_config = at91sam9_ebi_apply_config,
+};
+
 static const struct of_device_id atmel_ebi_id_table[] = {
        {
                .compatible = "atmel,at91sam9260-ebi",
@@ -473,6 +483,10 @@ static const struct of_device_id atmel_ebi_id_table[] = {
                .compatible = "atmel,sama5d3-ebi",
                .data = &sama5d3_ebi_caps,
        },
+       {
+               .compatible = "microchip,sam9x60-ebi",
+               .data = &sam9x60_ebi_caps,
+       },
        { /* sentinel */ }
 };