Skip to content
Snippets Groups Projects
Commit a0cfd188 authored by Reinhard Meyer's avatar Reinhard Meyer Committed by Albert ARIBAUD
Browse files

ATMEL: fix dataflash (dirty) this file should be converted to struct SoC access

parent 86592f60
No related branches found
No related tags found
No related merge requests found
...@@ -21,13 +21,21 @@ ...@@ -21,13 +21,21 @@
#include <common.h> #include <common.h>
#ifndef CONFIG_AT91_LEGACY #ifndef CONFIG_AT91_LEGACY
#define CONFIG_AT91_LEGACY # define CONFIG_ATMEL_LEGACY
#warning Please update to use C structur SoC access ! # warning Please update to use C structure SoC access !
#endif #endif
#include <asm/arch/hardware.h> #include <common.h>
#include <spi.h>
#include <malloc.h>
#include <asm/io.h>
#include <asm/arch/clk.h> #include <asm/arch/clk.h>
#include <asm/arch/hardware.h>
#include "atmel_spi.h"
#include <asm/arch/gpio.h> #include <asm/arch/gpio.h>
#include <asm/arch/io.h>
#include <asm/arch/at91_pio.h> #include <asm/arch/at91_pio.h>
#include <asm/arch/at91_spi.h> #include <asm/arch/at91_spi.h>
...@@ -41,18 +49,18 @@ ...@@ -41,18 +49,18 @@
void AT91F_SpiInit(void) void AT91F_SpiInit(void)
{ {
/* Reset the SPI */ /* Reset the SPI */
writel(AT91_SPI_SWRST, AT91_BASE_SPI + AT91_SPI_CR); writel(AT91_SPI_SWRST, ATMEL_BASE_SPI0 + AT91_SPI_CR);
/* Configure SPI in Master Mode with No CS selected !!! */ /* Configure SPI in Master Mode with No CS selected !!! */
writel(AT91_SPI_MSTR | AT91_SPI_MODFDIS | AT91_SPI_PCS, writel(AT91_SPI_MSTR | AT91_SPI_MODFDIS | AT91_SPI_PCS,
AT91_BASE_SPI + AT91_SPI_MR); ATMEL_BASE_SPI0 + AT91_SPI_MR);
/* Configure CS0 */ /* Configure CS0 */
writel(AT91_SPI_NCPHA | writel(AT91_SPI_NCPHA |
(AT91_SPI_DLYBS & DATAFLASH_TCSS) | (AT91_SPI_DLYBS & DATAFLASH_TCSS) |
(AT91_SPI_DLYBCT & DATAFLASH_TCHS) | (AT91_SPI_DLYBCT & DATAFLASH_TCHS) |
((get_mck_clk_rate() / AT91_SPI_CLK) << 8), ((get_mck_clk_rate() / AT91_SPI_CLK) << 8),
AT91_BASE_SPI + AT91_SPI_CSR(0)); ATMEL_BASE_SPI0 + AT91_SPI_CSR(0));
#ifdef CONFIG_SYS_DATAFLASH_LOGIC_ADDR_CS1 #ifdef CONFIG_SYS_DATAFLASH_LOGIC_ADDR_CS1
/* Configure CS1 */ /* Configure CS1 */
...@@ -60,7 +68,7 @@ void AT91F_SpiInit(void) ...@@ -60,7 +68,7 @@ void AT91F_SpiInit(void)
(AT91_SPI_DLYBS & DATAFLASH_TCSS) | (AT91_SPI_DLYBS & DATAFLASH_TCSS) |
(AT91_SPI_DLYBCT & DATAFLASH_TCHS) | (AT91_SPI_DLYBCT & DATAFLASH_TCHS) |
((get_mck_clk_rate() / AT91_SPI_CLK) << 8), ((get_mck_clk_rate() / AT91_SPI_CLK) << 8),
AT91_BASE_SPI + AT91_SPI_CSR(1)); ATMEL_BASE_SPI0 + AT91_SPI_CSR(1));
#endif #endif
#ifdef CONFIG_SYS_DATAFLASH_LOGIC_ADDR_CS2 #ifdef CONFIG_SYS_DATAFLASH_LOGIC_ADDR_CS2
/* Configure CS2 */ /* Configure CS2 */
...@@ -68,7 +76,7 @@ void AT91F_SpiInit(void) ...@@ -68,7 +76,7 @@ void AT91F_SpiInit(void)
(AT91_SPI_DLYBS & DATAFLASH_TCSS) | (AT91_SPI_DLYBS & DATAFLASH_TCSS) |
(AT91_SPI_DLYBCT & DATAFLASH_TCHS) | (AT91_SPI_DLYBCT & DATAFLASH_TCHS) |
((get_mck_clk_rate() / AT91_SPI_CLK) << 8), ((get_mck_clk_rate() / AT91_SPI_CLK) << 8),
AT91_BASE_SPI + AT91_SPI_CSR(2)); ATMEL_BASE_SPI0 + AT91_SPI_CSR(2));
#endif #endif
#ifdef CONFIG_SYS_DATAFLASH_LOGIC_ADDR_CS3 #ifdef CONFIG_SYS_DATAFLASH_LOGIC_ADDR_CS3
/* Configure CS3 */ /* Configure CS3 */
...@@ -76,21 +84,22 @@ void AT91F_SpiInit(void) ...@@ -76,21 +84,22 @@ void AT91F_SpiInit(void)
(AT91_SPI_DLYBS & DATAFLASH_TCSS) | (AT91_SPI_DLYBS & DATAFLASH_TCSS) |
(AT91_SPI_DLYBCT & DATAFLASH_TCHS) | (AT91_SPI_DLYBCT & DATAFLASH_TCHS) |
((get_mck_clk_rate() / AT91_SPI_CLK) << 8), ((get_mck_clk_rate() / AT91_SPI_CLK) << 8),
AT91_BASE_SPI + AT91_SPI_CSR(3)); ATMEL_BASE_SPI0 + AT91_SPI_CSR(3));
#endif #endif
/* SPI_Enable */ /* SPI_Enable */
writel(AT91_SPI_SPIEN, AT91_BASE_SPI + AT91_SPI_CR); writel(AT91_SPI_SPIEN, ATMEL_BASE_SPI0 + AT91_SPI_CR);
while (!(readl(AT91_BASE_SPI + AT91_SPI_SR) & AT91_SPI_SPIENS)); while (!(readl(ATMEL_BASE_SPI0 + AT91_SPI_SR) & AT91_SPI_SPIENS))
;
/* /*
* Add tempo to get SPI in a safe state. * Add tempo to get SPI in a safe state.
* Should not be needed for new silicon (Rev B) * Should not be needed for new silicon (Rev B)
*/ */
udelay(500000); udelay(500000);
readl(AT91_BASE_SPI + AT91_SPI_SR); readl(ATMEL_BASE_SPI0 + AT91_SPI_SR);
readl(AT91_BASE_SPI + AT91_SPI_RDR); readl(ATMEL_BASE_SPI0 + AT91_SPI_RDR);
} }
...@@ -100,33 +109,33 @@ void AT91F_SpiEnable(int cs) ...@@ -100,33 +109,33 @@ void AT91F_SpiEnable(int cs)
switch (cs) { switch (cs) {
case 0: /* Configure SPI CS0 for Serial DataFlash AT45DBxx */ case 0: /* Configure SPI CS0 for Serial DataFlash AT45DBxx */
mode = readl(AT91_BASE_SPI + AT91_SPI_MR); mode = readl(ATMEL_BASE_SPI0 + AT91_SPI_MR);
mode &= 0xFFF0FFFF; mode &= 0xFFF0FFFF;
writel(mode | ((AT91_SPI_PCS0_DATAFLASH_CARD<<16) & AT91_SPI_PCS), writel(mode | ((AT91_SPI_PCS0_DATAFLASH_CARD<<16) & AT91_SPI_PCS),
AT91_BASE_SPI + AT91_SPI_MR); ATMEL_BASE_SPI0 + AT91_SPI_MR);
break; break;
case 1: /* Configure SPI CS1 for Serial DataFlash AT45DBxx */ case 1: /* Configure SPI CS1 for Serial DataFlash AT45DBxx */
mode = readl(AT91_BASE_SPI + AT91_SPI_MR); mode = readl(ATMEL_BASE_SPI0 + AT91_SPI_MR);
mode &= 0xFFF0FFFF; mode &= 0xFFF0FFFF;
writel(mode | ((AT91_SPI_PCS1_DATAFLASH_CARD<<16) & AT91_SPI_PCS), writel(mode | ((AT91_SPI_PCS1_DATAFLASH_CARD<<16) & AT91_SPI_PCS),
AT91_BASE_SPI + AT91_SPI_MR); ATMEL_BASE_SPI0 + AT91_SPI_MR);
break; break;
case 2: /* Configure SPI CS2 for Serial DataFlash AT45DBxx */ case 2: /* Configure SPI CS2 for Serial DataFlash AT45DBxx */
mode = readl(AT91_BASE_SPI + AT91_SPI_MR); mode = readl(ATMEL_BASE_SPI0 + AT91_SPI_MR);
mode &= 0xFFF0FFFF; mode &= 0xFFF0FFFF;
writel(mode | ((AT91_SPI_PCS2_DATAFLASH_CARD<<16) & AT91_SPI_PCS), writel(mode | ((AT91_SPI_PCS2_DATAFLASH_CARD<<16) & AT91_SPI_PCS),
AT91_BASE_SPI + AT91_SPI_MR); ATMEL_BASE_SPI0 + AT91_SPI_MR);
break; break;
case 3: case 3:
mode = readl(AT91_BASE_SPI + AT91_SPI_MR); mode = readl(ATMEL_BASE_SPI0 + AT91_SPI_MR);
mode &= 0xFFF0FFFF; mode &= 0xFFF0FFFF;
writel(mode | ((AT91_SPI_PCS3_DATAFLASH_CARD<<16) & AT91_SPI_PCS), writel(mode | ((AT91_SPI_PCS3_DATAFLASH_CARD<<16) & AT91_SPI_PCS),
AT91_BASE_SPI + AT91_SPI_MR); ATMEL_BASE_SPI0 + AT91_SPI_MR);
break; break;
} }
/* SPI_Enable */ /* SPI_Enable */
writel(AT91_SPI_SPIEN, AT91_BASE_SPI + AT91_SPI_CR); writel(AT91_SPI_SPIEN, ATMEL_BASE_SPI0 + AT91_SPI_CR);
} }
unsigned int AT91F_SpiWrite1(AT91PS_DataflashDesc pDesc); unsigned int AT91F_SpiWrite1(AT91PS_DataflashDesc pDesc);
...@@ -134,37 +143,48 @@ unsigned int AT91F_SpiWrite1(AT91PS_DataflashDesc pDesc); ...@@ -134,37 +143,48 @@ unsigned int AT91F_SpiWrite1(AT91PS_DataflashDesc pDesc);
unsigned int AT91F_SpiWrite(AT91PS_DataflashDesc pDesc) unsigned int AT91F_SpiWrite(AT91PS_DataflashDesc pDesc)
{ {
unsigned int timeout; unsigned int timeout;
unsigned int timebase;
pDesc->state = BUSY; pDesc->state = BUSY;
writel(AT91_SPI_TXTDIS + AT91_SPI_RXTDIS, AT91_BASE_SPI + AT91_SPI_PTCR); writel(AT91_SPI_TXTDIS + AT91_SPI_RXTDIS,
ATMEL_BASE_SPI0 + AT91_SPI_PTCR);
/* Initialize the Transmit and Receive Pointer */ /* Initialize the Transmit and Receive Pointer */
writel((unsigned int)pDesc->rx_cmd_pt, AT91_BASE_SPI + AT91_SPI_RPR); writel((unsigned int)pDesc->rx_cmd_pt,
writel((unsigned int)pDesc->tx_cmd_pt, AT91_BASE_SPI + AT91_SPI_TPR); ATMEL_BASE_SPI0 + AT91_SPI_RPR);
writel((unsigned int)pDesc->tx_cmd_pt,
ATMEL_BASE_SPI0 + AT91_SPI_TPR);
/* Intialize the Transmit and Receive Counters */ /* Intialize the Transmit and Receive Counters */
writel(pDesc->rx_cmd_size, AT91_BASE_SPI + AT91_SPI_RCR); writel(pDesc->rx_cmd_size, ATMEL_BASE_SPI0 + AT91_SPI_RCR);
writel(pDesc->tx_cmd_size, AT91_BASE_SPI + AT91_SPI_TCR); writel(pDesc->tx_cmd_size, ATMEL_BASE_SPI0 + AT91_SPI_TCR);
if (pDesc->tx_data_size != 0) { if (pDesc->tx_data_size != 0) {
/* Initialize the Next Transmit and Next Receive Pointer */ /* Initialize the Next Transmit and Next Receive Pointer */
writel((unsigned int)pDesc->rx_data_pt, AT91_BASE_SPI + AT91_SPI_RNPR); writel((unsigned int)pDesc->rx_data_pt,
writel((unsigned int)pDesc->tx_data_pt, AT91_BASE_SPI + AT91_SPI_TNPR); ATMEL_BASE_SPI0 + AT91_SPI_RNPR);
writel((unsigned int)pDesc->tx_data_pt,
ATMEL_BASE_SPI0 + AT91_SPI_TNPR);
/* Intialize the Next Transmit and Next Receive Counters */ /* Intialize the Next Transmit and Next Receive Counters */
writel(pDesc->rx_data_size, AT91_BASE_SPI + AT91_SPI_RNCR); writel(pDesc->rx_data_size,
writel(pDesc->tx_data_size, AT91_BASE_SPI + AT91_SPI_TNCR); ATMEL_BASE_SPI0 + AT91_SPI_RNCR);
writel(pDesc->tx_data_size,
ATMEL_BASE_SPI0 + AT91_SPI_TNCR);
} }
/* arm simple, non interrupt dependent timer */ /* arm simple, non interrupt dependent timer */
reset_timer_masked(); timebase = get_timer(0);
timeout = 0; timeout = 0;
writel(AT91_SPI_TXTEN + AT91_SPI_RXTEN, AT91_BASE_SPI + AT91_SPI_PTCR); writel(AT91_SPI_TXTEN + AT91_SPI_RXTEN,
while (!(readl(AT91_BASE_SPI + AT91_SPI_SR) & AT91_SPI_RXBUFF) && ATMEL_BASE_SPI0 + AT91_SPI_PTCR);
((timeout = get_timer_masked()) < CONFIG_SYS_SPI_WRITE_TOUT)); while (!(readl(ATMEL_BASE_SPI0 + AT91_SPI_SR) & AT91_SPI_RXBUFF) &&
writel(AT91_SPI_TXTDIS + AT91_SPI_RXTDIS, AT91_BASE_SPI + AT91_SPI_PTCR); ((timeout = get_timer(timebase)) < CONFIG_SYS_SPI_WRITE_TOUT))
;
writel(AT91_SPI_TXTDIS + AT91_SPI_RXTDIS,
ATMEL_BASE_SPI0 + AT91_SPI_PTCR);
pDesc->state = IDLE; pDesc->state = IDLE;
if (timeout >= CONFIG_SYS_SPI_WRITE_TOUT) { if (timeout >= CONFIG_SYS_SPI_WRITE_TOUT) {
......
...@@ -34,7 +34,6 @@ ...@@ -34,7 +34,6 @@
#define _DataFlash_h #define _DataFlash_h
#include <asm/arch/hardware.h>
#include "config.h" #include "config.h"
/*number of protected area*/ /*number of protected area*/
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment