mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-14 08:57:58 +00:00
Migrate esd 405EP boards to new NAND subsystem
Migrate esd 405EP boards to new NAND subsystem -cleanup -use correct io accessors (in/out_be32()) Signed-off-by: Matthias Fuchs <matthias.fuchs@esd-electronics.com>
This commit is contained in:
parent
e09f7ab574
commit
bd84ee4c20
21 changed files with 114 additions and 450 deletions
|
@ -28,7 +28,9 @@ endif
|
||||||
|
|
||||||
LIB = $(obj)lib$(BOARD).a
|
LIB = $(obj)lib$(BOARD).a
|
||||||
|
|
||||||
COBJS = $(BOARD).o flash.o ../common/misc.o
|
COBJS = $(BOARD).o flash.o \
|
||||||
|
../common/misc.o \
|
||||||
|
../common/esd405ep_nand.o \
|
||||||
|
|
||||||
SRCS := $(SOBJS:.o=.S) $(COBJS:.o=.c)
|
SRCS := $(SOBJS:.o=.S) $(COBJS:.o=.c)
|
||||||
OBJS := $(addprefix $(obj),$(COBJS))
|
OBJS := $(addprefix $(obj),$(COBJS))
|
||||||
|
|
|
@ -23,6 +23,7 @@
|
||||||
|
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
#include <asm/processor.h>
|
#include <asm/processor.h>
|
||||||
|
#include <asm/io.h>
|
||||||
#include <command.h>
|
#include <command.h>
|
||||||
#include <malloc.h>
|
#include <malloc.h>
|
||||||
|
|
||||||
|
@ -33,6 +34,7 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern int do_reset (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]);
|
extern int do_reset (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]);
|
||||||
|
extern void lxt971_no_sleep(void);
|
||||||
|
|
||||||
/* fpga configuration data - gzip compressed and generated by bin2c */
|
/* fpga configuration data - gzip compressed and generated by bin2c */
|
||||||
const unsigned char fpgadata[] =
|
const unsigned char fpgadata[] =
|
||||||
|
@ -164,17 +166,11 @@ int misc_init_r (void)
|
||||||
/*
|
/*
|
||||||
* Reset external DUARTs
|
* Reset external DUARTs
|
||||||
*/
|
*/
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) | CFG_DUART_RST); /* set reset to high */
|
out_be32((void *)GPIO0_OR, in_be32((void *)GPIO0_OR) | CFG_DUART_RST);
|
||||||
udelay(10); /* wait 10us */
|
udelay(10); /* wait 10us */
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_DUART_RST); /* set reset to low */
|
out_be32((void *)GPIO0_OR, in_be32((void *)GPIO0_OR) & ~CFG_DUART_RST);
|
||||||
udelay(1000); /* wait 1ms */
|
udelay(1000); /* wait 1ms */
|
||||||
|
|
||||||
/*
|
|
||||||
* Set NAND-FLASH GPIO signals to default
|
|
||||||
*/
|
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) & ~(CFG_NAND_CLE | CFG_NAND_ALE));
|
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CE);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Enable interrupts in exar duart mcr[3]
|
* Enable interrupts in exar duart mcr[3]
|
||||||
*/
|
*/
|
||||||
|
@ -218,35 +214,18 @@ long int initdram (int board_type)
|
||||||
mtdcr(memcfga, mem_mb0cf);
|
mtdcr(memcfga, mem_mb0cf);
|
||||||
val = mfdcr(memcfgd);
|
val = mfdcr(memcfgd);
|
||||||
|
|
||||||
#if 0
|
|
||||||
printf("\nmb0cf=%x\n", val); /* test-only */
|
|
||||||
printf("strap=%x\n", mfdcr(strap)); /* test-only */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return (4*1024*1024 << ((val & 0x000e0000) >> 17));
|
return (4*1024*1024 << ((val & 0x000e0000) >> 17));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------- */
|
||||||
|
|
||||||
int testdram (void)
|
void reset_phy(void)
|
||||||
{
|
{
|
||||||
/* TODO: XXX XXX XXX */
|
#ifdef CONFIG_LXT971_NO_SLEEP
|
||||||
printf ("test: 16 MB - ok\n");
|
|
||||||
|
|
||||||
return (0);
|
/*
|
||||||
}
|
* Disable sleep mode in LXT971
|
||||||
|
*/
|
||||||
/* ------------------------------------------------------------------------- */
|
lxt971_no_sleep();
|
||||||
|
|
||||||
#if (CONFIG_COMMANDS & CFG_CMD_NAND)
|
|
||||||
#include <linux/mtd/nand_legacy.h>
|
|
||||||
extern struct nand_chip nand_dev_desc[CFG_MAX_NAND_DEVICE];
|
|
||||||
|
|
||||||
void nand_init(void)
|
|
||||||
{
|
|
||||||
nand_probe(CFG_NAND_BASE);
|
|
||||||
if (nand_dev_desc[0].ChipID != NAND_ChipID_UNKNOWN) {
|
|
||||||
print_size(nand_dev_desc[0].totlen, "\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
}
|
||||||
|
|
|
@ -33,7 +33,10 @@ CPLD = ../common/xilinx_jtag/lenval.o \
|
||||||
../common/xilinx_jtag/micro.o \
|
../common/xilinx_jtag/micro.o \
|
||||||
../common/xilinx_jtag/ports.o
|
../common/xilinx_jtag/ports.o
|
||||||
|
|
||||||
COBJS = $(BOARD).o flash.o ../common/misc.o $(CPLD)
|
COBJS = $(BOARD).o flash.o \
|
||||||
|
../common/misc.o \
|
||||||
|
$(CPLD) \
|
||||||
|
../common/esd405ep_nand.o \
|
||||||
|
|
||||||
SRCS := $(SOBJS:.o=.S) $(COBJS:.o=.c)
|
SRCS := $(SOBJS:.o=.S) $(COBJS:.o=.c)
|
||||||
OBJS := $(addprefix $(obj),$(COBJS))
|
OBJS := $(addprefix $(obj),$(COBJS))
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* (C) Copyright 2005
|
* (C) Copyright 2005-2007
|
||||||
* Matthias Fuchs, esd gmbh germany, matthias.fuchs@esd-electronics.com
|
* Matthias Fuchs, esd gmbh germany, matthias.fuchs@esd-electronics.com
|
||||||
*
|
*
|
||||||
* See file CREDITS for list of people who contributed to this
|
* See file CREDITS for list of people who contributed to this
|
||||||
|
@ -23,6 +23,7 @@
|
||||||
|
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
#include <asm/processor.h>
|
#include <asm/processor.h>
|
||||||
|
#include <asm/io.h>
|
||||||
#include <command.h>
|
#include <command.h>
|
||||||
#include <malloc.h>
|
#include <malloc.h>
|
||||||
|
|
||||||
|
@ -68,9 +69,9 @@ int board_early_init_f (void)
|
||||||
/*
|
/*
|
||||||
* Reset CPLD via GPIO12 (CS3) pin
|
* Reset CPLD via GPIO12 (CS3) pin
|
||||||
*/
|
*/
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_PLD_RESET);
|
out_be32((void *)GPIO0_OR, in_be32((void *)GPIO0_OR) & ~CFG_PLD_RESET);
|
||||||
udelay(1000); /* wait 1ms */
|
udelay(1000); /* wait 1ms */
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) | CFG_PLD_RESET);
|
out_be32((void *)GPIO0_OR, in_be32((void *)GPIO0_OR) | CFG_PLD_RESET);
|
||||||
udelay(1000); /* wait 1ms */
|
udelay(1000); /* wait 1ms */
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -94,13 +95,7 @@ int misc_init_r (void)
|
||||||
/*
|
/*
|
||||||
* Setup and enable EEPROM write protection
|
* Setup and enable EEPROM write protection
|
||||||
*/
|
*/
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) | CFG_EEPROM_WP);
|
out_be32((void *)GPIO0_OR, in_be32((void *)GPIO0_OR) | CFG_EEPROM_WP);
|
||||||
|
|
||||||
/*
|
|
||||||
* Set NAND-FLASH GPIO signals to default
|
|
||||||
*/
|
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) & ~(CFG_NAND_CLE | CFG_NAND_ALE));
|
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CE);
|
|
||||||
|
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
@ -153,11 +148,6 @@ long int initdram (int board_type)
|
||||||
mtdcr(memcfga, mem_mb0cf);
|
mtdcr(memcfga, mem_mb0cf);
|
||||||
val = mfdcr(memcfgd);
|
val = mfdcr(memcfgd);
|
||||||
|
|
||||||
#if 0
|
|
||||||
printf("\nmb0cf=%x\n", val); /* test-only */
|
|
||||||
printf("strap=%x\n", mfdcr(strap)); /* test-only */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return (4*1024*1024 << ((val & 0x000e0000) >> 17));
|
return (4*1024*1024 << ((val & 0x000e0000) >> 17));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -180,17 +170,17 @@ int eeprom_write_enable (unsigned dev_addr, int state)
|
||||||
switch (state) {
|
switch (state) {
|
||||||
case 1:
|
case 1:
|
||||||
/* Enable write access, clear bit GPIO_SINT2. */
|
/* Enable write access, clear bit GPIO_SINT2. */
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_EEPROM_WP);
|
out_be32((void *)GPIO0_OR, in_be32((void *)GPIO0_OR) & ~CFG_EEPROM_WP);
|
||||||
state = 0;
|
state = 0;
|
||||||
break;
|
break;
|
||||||
case 0:
|
case 0:
|
||||||
/* Disable write access, set bit GPIO_SINT2. */
|
/* Disable write access, set bit GPIO_SINT2. */
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) | CFG_EEPROM_WP);
|
out_be32((void *)GPIO0_OR, in_be32((void *)GPIO0_OR) | CFG_EEPROM_WP);
|
||||||
state = 0;
|
state = 0;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
/* Read current status back. */
|
/* Read current status back. */
|
||||||
state = (0 == (in32(GPIO0_OR) & CFG_EEPROM_WP));
|
state = (0 == (in_be32((void *)GPIO0_OR) & CFG_EEPROM_WP));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -235,19 +225,6 @@ U_BOOT_CMD(eepwren, 2, 0, do_eep_wren,
|
||||||
|
|
||||||
/* ------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------- */
|
||||||
|
|
||||||
#if (CONFIG_COMMANDS & CFG_CMD_NAND)
|
|
||||||
#include <linux/mtd/nand_legacy.h>
|
|
||||||
extern struct nand_chip nand_dev_desc[CFG_MAX_NAND_DEVICE];
|
|
||||||
|
|
||||||
void nand_init(void)
|
|
||||||
{
|
|
||||||
nand_probe(CFG_NAND_BASE);
|
|
||||||
if (nand_dev_desc[0].ChipID != NAND_ChipID_UNKNOWN) {
|
|
||||||
print_size(nand_dev_desc[0].totlen, "\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void reset_phy(void)
|
void reset_phy(void)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_LXT971_NO_SLEEP
|
#ifdef CONFIG_LXT971_NO_SLEEP
|
||||||
|
|
|
@ -28,7 +28,10 @@ endif
|
||||||
|
|
||||||
LIB = $(obj)lib$(BOARD).a
|
LIB = $(obj)lib$(BOARD).a
|
||||||
|
|
||||||
COBJS = $(BOARD).o flash.o ../common/misc.o ../common/auto_update.o
|
COBJS = $(BOARD).o flash.o \
|
||||||
|
../common/misc.o \
|
||||||
|
../common/esd405ep_nand.o \
|
||||||
|
../common/auto_update.o
|
||||||
|
|
||||||
SRCS := $(SOBJS:.o=.S) $(COBJS:.o=.c)
|
SRCS := $(SOBJS:.o=.S) $(COBJS:.o=.c)
|
||||||
OBJS := $(addprefix $(obj),$(COBJS))
|
OBJS := $(addprefix $(obj),$(COBJS))
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
* (C) Copyright 2005
|
* (C) Copyright 2005
|
||||||
* Stefan Roese, DENX Software Engineering, sr@denx.de.
|
* Stefan Roese, DENX Software Engineering, sr@denx.de.
|
||||||
*
|
*
|
||||||
* (C) Copyright 2006
|
* (C) Copyright 2006-2007
|
||||||
* Matthias Fuchs, esd GmbH, matthias.fuchs@esd-electronics.com
|
* Matthias Fuchs, esd GmbH, matthias.fuchs@esd-electronics.com
|
||||||
*
|
*
|
||||||
* See file CREDITS for list of people who contributed to this
|
* See file CREDITS for list of people who contributed to this
|
||||||
|
@ -476,12 +476,6 @@ int misc_init_r (void)
|
||||||
*/
|
*/
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) | CFG_EEPROM_WP);
|
out32(GPIO0_OR, in32(GPIO0_OR) | CFG_EEPROM_WP);
|
||||||
|
|
||||||
/*
|
|
||||||
* Set NAND-FLASH GPIO signals to default
|
|
||||||
*/
|
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) & ~(CFG_NAND_CLE | CFG_NAND_ALE));
|
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CE);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Reset touch-screen controller
|
* Reset touch-screen controller
|
||||||
*/
|
*/
|
||||||
|
@ -690,20 +684,6 @@ void ide_set_reset(int on)
|
||||||
#endif /* CONFIG_IDE_RESET */
|
#endif /* CONFIG_IDE_RESET */
|
||||||
|
|
||||||
|
|
||||||
#if (CONFIG_COMMANDS & CFG_CMD_NAND)
|
|
||||||
#include <linux/mtd/nand_legacy.h>
|
|
||||||
extern struct nand_chip nand_dev_desc[CFG_MAX_NAND_DEVICE];
|
|
||||||
|
|
||||||
void nand_init(void)
|
|
||||||
{
|
|
||||||
nand_probe(CFG_NAND_BASE);
|
|
||||||
if (nand_dev_desc[0].ChipID != NAND_ChipID_UNKNOWN) {
|
|
||||||
print_size(nand_dev_desc[0].totlen, "\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#if defined(CFG_EEPROM_WREN)
|
#if defined(CFG_EEPROM_WREN)
|
||||||
/* Input: <dev_addr> I2C address of EEPROM device to enable.
|
/* Input: <dev_addr> I2C address of EEPROM device to enable.
|
||||||
* <state> -1: deliver current state
|
* <state> -1: deliver current state
|
||||||
|
|
|
@ -28,7 +28,9 @@ endif
|
||||||
|
|
||||||
LIB = $(obj)lib$(BOARD).a
|
LIB = $(obj)lib$(BOARD).a
|
||||||
|
|
||||||
COBJS = $(BOARD).o flash.o ../common/misc.o
|
COBJS = $(BOARD).o flash.o \
|
||||||
|
../common/misc.o \
|
||||||
|
../common/esd405ep_nand.o \
|
||||||
|
|
||||||
SRCS := $(SOBJS:.o=.S) $(COBJS:.o=.c)
|
SRCS := $(SOBJS:.o=.S) $(COBJS:.o=.c)
|
||||||
OBJS := $(addprefix $(obj),$(COBJS))
|
OBJS := $(addprefix $(obj),$(COBJS))
|
||||||
|
|
|
@ -152,12 +152,6 @@ int misc_init_r (void)
|
||||||
|
|
||||||
out32(GPIO0_OR, val);
|
out32(GPIO0_OR, val);
|
||||||
|
|
||||||
/*
|
|
||||||
* Set NAND-FLASH GPIO signals to default
|
|
||||||
*/
|
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) & ~(CFG_NAND_CLE | CFG_NAND_ALE));
|
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CE);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* check board type and setup AP power
|
* check board type and setup AP power
|
||||||
*/
|
*/
|
||||||
|
@ -242,33 +236,5 @@ long int initdram (int board_type)
|
||||||
mtdcr(memcfga, mem_mb0cf);
|
mtdcr(memcfga, mem_mb0cf);
|
||||||
val = mfdcr(memcfgd);
|
val = mfdcr(memcfgd);
|
||||||
|
|
||||||
#if 0
|
|
||||||
printf("\nmb0cf=%x\n", val); /* test-only */
|
|
||||||
printf("strap=%x\n", mfdcr(strap)); /* test-only */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return (4*1024*1024 << ((val & 0x000e0000) >> 17));
|
return (4*1024*1024 << ((val & 0x000e0000) >> 17));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int testdram (void)
|
|
||||||
{
|
|
||||||
/* TODO: XXX XXX XXX */
|
|
||||||
printf ("test: 16 MB - ok\n");
|
|
||||||
|
|
||||||
return (0);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#if (CONFIG_COMMANDS & CFG_CMD_NAND)
|
|
||||||
#include <linux/mtd/nand_legacy.h>
|
|
||||||
extern struct nand_chip nand_dev_desc[CFG_MAX_NAND_DEVICE];
|
|
||||||
|
|
||||||
void nand_init(void)
|
|
||||||
{
|
|
||||||
nand_probe(CFG_NAND_BASE);
|
|
||||||
if (nand_dev_desc[0].ChipID != NAND_ChipID_UNKNOWN) {
|
|
||||||
print_size(nand_dev_desc[0].totlen, "\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
|
@ -28,7 +28,10 @@ endif
|
||||||
|
|
||||||
LIB = $(obj)lib$(BOARD).a
|
LIB = $(obj)lib$(BOARD).a
|
||||||
|
|
||||||
COBJS = $(BOARD).o flash.o ../common/misc.o ../common/auto_update.o
|
COBJS = $(BOARD).o flash.o \
|
||||||
|
../common/misc.o \
|
||||||
|
../common/esd405ep_nand.o \
|
||||||
|
../common/auto_update.o
|
||||||
|
|
||||||
SRCS := $(SOBJS:.o=.S) $(COBJS:.o=.c)
|
SRCS := $(SOBJS:.o=.S) $(COBJS:.o=.c)
|
||||||
OBJS := $(addprefix $(obj),$(COBJS))
|
OBJS := $(addprefix $(obj),$(COBJS))
|
||||||
|
|
|
@ -23,6 +23,7 @@
|
||||||
|
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
#include <asm/processor.h>
|
#include <asm/processor.h>
|
||||||
|
#include <asm/io.h>
|
||||||
#include <command.h>
|
#include <command.h>
|
||||||
#include <malloc.h>
|
#include <malloc.h>
|
||||||
|
|
||||||
|
@ -31,6 +32,8 @@
|
||||||
#define FPGA_DEBUG
|
#define FPGA_DEBUG
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
DECLARE_GLOBAL_DATA_PTR;
|
||||||
|
|
||||||
extern int do_reset (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]);
|
extern int do_reset (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]);
|
||||||
extern void lxt971_no_sleep(void);
|
extern void lxt971_no_sleep(void);
|
||||||
|
|
||||||
|
@ -114,6 +117,10 @@ int misc_init_r (void)
|
||||||
int index;
|
int index;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
/* adjust flash start and offset */
|
||||||
|
gd->bd->bi_flashstart = 0 - gd->bd->bi_flashsize;
|
||||||
|
gd->bd->bi_flashoffset = 0;
|
||||||
|
|
||||||
dst = malloc(CFG_FPGA_MAX_SIZE);
|
dst = malloc(CFG_FPGA_MAX_SIZE);
|
||||||
if (gunzip (dst, CFG_FPGA_MAX_SIZE, (uchar *)fpgadata, &len) != 0) {
|
if (gunzip (dst, CFG_FPGA_MAX_SIZE, (uchar *)fpgadata, &len) != 0) {
|
||||||
printf ("GUNZIP ERROR - must RESET board to recover\n");
|
printf ("GUNZIP ERROR - must RESET board to recover\n");
|
||||||
|
@ -177,17 +184,11 @@ int misc_init_r (void)
|
||||||
/*
|
/*
|
||||||
* Reset external DUARTs
|
* Reset external DUARTs
|
||||||
*/
|
*/
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) | CFG_DUART_RST); /* set reset to high */
|
out_be32((void *)GPIO0_OR, in_be32((void *)GPIO0_OR) | CFG_DUART_RST);
|
||||||
udelay(10); /* wait 10us */
|
udelay(10); /* wait 10us */
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_DUART_RST); /* set reset to low */
|
out_be32((void *)GPIO0_OR, in_be32((void *)GPIO0_OR) & ~CFG_DUART_RST);
|
||||||
udelay(1000); /* wait 1ms */
|
udelay(1000); /* wait 1ms */
|
||||||
|
|
||||||
/*
|
|
||||||
* Set NAND-FLASH GPIO signals to default
|
|
||||||
*/
|
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) & ~(CFG_NAND_CLE | CFG_NAND_ALE));
|
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CE);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Enable interrupts in exar duart mcr[3]
|
* Enable interrupts in exar duart mcr[3]
|
||||||
*/
|
*/
|
||||||
|
@ -226,24 +227,10 @@ long int initdram (int board_type)
|
||||||
mtdcr(memcfga, mem_mb0cf);
|
mtdcr(memcfga, mem_mb0cf);
|
||||||
val = mfdcr(memcfgd);
|
val = mfdcr(memcfgd);
|
||||||
|
|
||||||
#if 0
|
|
||||||
printf("\nmb0cf=%x\n", val); /* test-only */
|
|
||||||
printf("strap=%x\n", mfdcr(strap)); /* test-only */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return (4*1024*1024 << ((val & 0x000e0000) >> 17));
|
return (4*1024*1024 << ((val & 0x000e0000) >> 17));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int testdram (void)
|
|
||||||
{
|
|
||||||
/* TODO: XXX XXX XXX */
|
|
||||||
printf ("test: 16 MB - ok\n");
|
|
||||||
|
|
||||||
return (0);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef CONFIG_IDE_RESET
|
#ifdef CONFIG_IDE_RESET
|
||||||
void ide_set_reset(int on)
|
void ide_set_reset(int on)
|
||||||
{
|
{
|
||||||
|
@ -262,31 +249,6 @@ void ide_set_reset(int on)
|
||||||
#endif /* CONFIG_IDE_RESET */
|
#endif /* CONFIG_IDE_RESET */
|
||||||
|
|
||||||
|
|
||||||
#if (CONFIG_COMMANDS & CFG_CMD_NAND)
|
|
||||||
#include <linux/mtd/nand_legacy.h>
|
|
||||||
extern struct nand_chip nand_dev_desc[CFG_MAX_NAND_DEVICE];
|
|
||||||
|
|
||||||
void nand_init(void)
|
|
||||||
{
|
|
||||||
nand_probe(CFG_NAND_BASE);
|
|
||||||
if (nand_dev_desc[0].ChipID != NAND_ChipID_UNKNOWN) {
|
|
||||||
print_size(nand_dev_desc[0].totlen, "\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef CONFIG_AUTO_UPDATE_SHOW
|
|
||||||
void board_auto_update_show(int au_active)
|
|
||||||
{
|
|
||||||
if (au_active) {
|
|
||||||
printf("\n Dies ist die board-funktion: Updating!!!\n");
|
|
||||||
} else {
|
|
||||||
printf("\n Dies ist die board-funktion: Updating done!!!\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void reset_phy(void)
|
void reset_phy(void)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_LXT971_NO_SLEEP
|
#ifdef CONFIG_LXT971_NO_SLEEP
|
||||||
|
|
|
@ -28,7 +28,9 @@ endif
|
||||||
|
|
||||||
LIB = $(obj)lib$(BOARD).a
|
LIB = $(obj)lib$(BOARD).a
|
||||||
|
|
||||||
COBJS = $(BOARD).o flash.o ../common/misc.o
|
COBJS = $(BOARD).o flash.o \
|
||||||
|
../common/misc.o \
|
||||||
|
../common/esd405ep_nand.o \
|
||||||
|
|
||||||
SRCS := $(SOBJS:.o=.S) $(COBJS:.o=.c)
|
SRCS := $(SOBJS:.o=.S) $(COBJS:.o=.c)
|
||||||
OBJS := $(addprefix $(obj),$(COBJS))
|
OBJS := $(addprefix $(obj),$(COBJS))
|
||||||
|
|
|
@ -194,12 +194,6 @@ int misc_init_r (void)
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_DUART_RST); /* set reset to low */
|
out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_DUART_RST); /* set reset to low */
|
||||||
udelay(1000); /* wait 1ms */
|
udelay(1000); /* wait 1ms */
|
||||||
|
|
||||||
/*
|
|
||||||
* Set NAND-FLASH GPIO signals to default
|
|
||||||
*/
|
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) & ~(CFG_NAND_CLE | CFG_NAND_ALE));
|
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CE);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Enable interrupts in exar duart mcr[3]
|
* Enable interrupts in exar duart mcr[3]
|
||||||
*/
|
*/
|
||||||
|
@ -340,17 +334,3 @@ void ide_set_reset(int on)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_IDE_RESET */
|
#endif /* CONFIG_IDE_RESET */
|
||||||
|
|
||||||
|
|
||||||
#if (CONFIG_COMMANDS & CFG_CMD_NAND)
|
|
||||||
#include <linux/mtd/nand_legacy.h>
|
|
||||||
extern struct nand_chip nand_dev_desc[CFG_MAX_NAND_DEVICE];
|
|
||||||
|
|
||||||
void nand_init(void)
|
|
||||||
{
|
|
||||||
nand_probe(CFG_NAND_BASE);
|
|
||||||
if (nand_dev_desc[0].ChipID != NAND_ChipID_UNKNOWN) {
|
|
||||||
print_size(nand_dev_desc[0].totlen, "\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
|
@ -28,7 +28,9 @@ endif
|
||||||
|
|
||||||
LIB = $(obj)lib$(BOARD).a
|
LIB = $(obj)lib$(BOARD).a
|
||||||
|
|
||||||
COBJS = $(BOARD).o flash.o ../common/misc.o
|
COBJS = $(BOARD).o flash.o \
|
||||||
|
../common/misc.o \
|
||||||
|
../common/esd405ep_nand.o \
|
||||||
|
|
||||||
SRCS := $(SOBJS:.o=.S) $(COBJS:.o=.c)
|
SRCS := $(SOBJS:.o=.S) $(COBJS:.o=.c)
|
||||||
OBJS := $(addprefix $(obj),$(COBJS))
|
OBJS := $(addprefix $(obj),$(COBJS))
|
||||||
|
|
|
@ -169,12 +169,6 @@ int misc_init_r (void)
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_DUART_RST); /* set reset to low */
|
out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_DUART_RST); /* set reset to low */
|
||||||
udelay(1000); /* wait 1ms */
|
udelay(1000); /* wait 1ms */
|
||||||
|
|
||||||
/*
|
|
||||||
* Set NAND-FLASH GPIO signals to default
|
|
||||||
*/
|
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) & ~(CFG_NAND_CLE | CFG_NAND_ALE));
|
|
||||||
out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CE);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Enable interrupts in exar duart mcr[3]
|
* Enable interrupts in exar duart mcr[3]
|
||||||
*/
|
*/
|
||||||
|
@ -218,35 +212,8 @@ long int initdram (int board_type)
|
||||||
mtdcr(memcfga, mem_mb0cf);
|
mtdcr(memcfga, mem_mb0cf);
|
||||||
val = mfdcr(memcfgd);
|
val = mfdcr(memcfgd);
|
||||||
|
|
||||||
#if 0
|
|
||||||
printf("\nmb0cf=%x\n", val); /* test-only */
|
|
||||||
printf("strap=%x\n", mfdcr(strap)); /* test-only */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return (4*1024*1024 << ((val & 0x000e0000) >> 17));
|
return (4*1024*1024 << ((val & 0x000e0000) >> 17));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------- */
|
||||||
|
|
||||||
int testdram (void)
|
|
||||||
{
|
|
||||||
/* TODO: XXX XXX XXX */
|
|
||||||
printf ("test: 16 MB - ok\n");
|
|
||||||
|
|
||||||
return (0);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------------------- */
|
|
||||||
|
|
||||||
#if (CONFIG_COMMANDS & CFG_CMD_NAND)
|
|
||||||
#include <linux/mtd/nand_legacy.h>
|
|
||||||
extern struct nand_chip nand_dev_desc[CFG_MAX_NAND_DEVICE];
|
|
||||||
|
|
||||||
void nand_init(void)
|
|
||||||
{
|
|
||||||
nand_probe(CFG_NAND_BASE);
|
|
||||||
if (nand_dev_desc[0].ChipID != NAND_ChipID_UNKNOWN) {
|
|
||||||
print_size(nand_dev_desc[0].totlen, "\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
|
@ -53,9 +53,13 @@
|
||||||
#define CONFIG_LOADS_ECHO 1 /* echo on for serial download */
|
#define CONFIG_LOADS_ECHO 1 /* echo on for serial download */
|
||||||
#define CFG_LOADS_BAUD_CHANGE 1 /* allow baudrate change */
|
#define CFG_LOADS_BAUD_CHANGE 1 /* allow baudrate change */
|
||||||
|
|
||||||
|
#define CONFIG_NET_MULTI 1
|
||||||
|
#undef CONFIG_HAS_ETH1
|
||||||
|
|
||||||
#define CONFIG_MII 1 /* MII PHY management */
|
#define CONFIG_MII 1 /* MII PHY management */
|
||||||
#define CONFIG_PHY_ADDR 0 /* PHY address */
|
#define CONFIG_PHY_ADDR 0 /* PHY address */
|
||||||
#define CONFIG_LXT971_NO_SLEEP 1 /* disable sleep mode in LXT971 */
|
#define CONFIG_LXT971_NO_SLEEP 1 /* disable sleep mode in LXT971 */
|
||||||
|
#define CONFIG_RESET_PHY_R 1 /* use reset_phy() to disable phy sleep mode */
|
||||||
|
|
||||||
#define CONFIG_PHY_CLK_FREQ EMAC_STACR_CLK_66MHZ /* 66 MHz OPB clock*/
|
#define CONFIG_PHY_CLK_FREQ EMAC_STACR_CLK_66MHZ /* 66 MHz OPB clock*/
|
||||||
|
|
||||||
|
@ -132,39 +136,16 @@
|
||||||
* NAND-FLASH stuff
|
* NAND-FLASH stuff
|
||||||
*-----------------------------------------------------------------------
|
*-----------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
|
#define CFG_NAND_BASE_LIST { CFG_NAND_BASE }
|
||||||
#define CFG_NAND_LEGACY
|
|
||||||
|
|
||||||
#define CFG_MAX_NAND_DEVICE 1 /* Max number of NAND devices */
|
|
||||||
#define SECTORSIZE 512
|
|
||||||
|
|
||||||
#define ADDR_COLUMN 1
|
|
||||||
#define ADDR_PAGE 2
|
|
||||||
#define ADDR_COLUMN_PAGE 3
|
|
||||||
|
|
||||||
#define NAND_ChipID_UNKNOWN 0x00
|
|
||||||
#define NAND_MAX_FLOORS 1
|
|
||||||
#define NAND_MAX_CHIPS 1
|
#define NAND_MAX_CHIPS 1
|
||||||
|
#define CFG_MAX_NAND_DEVICE 1 /* Max number of NAND devices */
|
||||||
|
#define NAND_BIG_DELAY_US 25
|
||||||
|
|
||||||
#define CFG_NAND_CE (0x80000000 >> 1) /* our CE is GPIO1 */
|
#define CFG_NAND_CE (0x80000000 >> 1) /* our CE is GPIO1 */
|
||||||
|
#define CFG_NAND_RDY (0x80000000 >> 4) /* our RDY is GPIO4 */
|
||||||
#define CFG_NAND_CLE (0x80000000 >> 2) /* our CLE is GPIO2 */
|
#define CFG_NAND_CLE (0x80000000 >> 2) /* our CLE is GPIO2 */
|
||||||
#define CFG_NAND_ALE (0x80000000 >> 3) /* our ALE is GPIO3 */
|
#define CFG_NAND_ALE (0x80000000 >> 3) /* our ALE is GPIO3 */
|
||||||
#define CFG_NAND_RDY (0x80000000 >> 4) /* our RDY is GPIO4 */
|
|
||||||
|
|
||||||
#define NAND_DISABLE_CE(nand) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CE);} while(0)
|
|
||||||
#define NAND_ENABLE_CE(nand) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_CE);} while(0)
|
|
||||||
#define NAND_CTL_CLRALE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_ALE);} while(0)
|
|
||||||
#define NAND_CTL_SETALE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_ALE);} while(0)
|
|
||||||
#define NAND_CTL_CLRCLE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_CLE);} while(0)
|
|
||||||
#define NAND_CTL_SETCLE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CLE);} while(0)
|
|
||||||
#define NAND_WAIT_READY(nand) while (!(in32(GPIO0_IR) & CFG_NAND_RDY))
|
|
||||||
|
|
||||||
#define WRITE_NAND_COMMAND(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)(d); } while(0)
|
|
||||||
#define WRITE_NAND_ADDRESS(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)(d); } while(0)
|
|
||||||
#define WRITE_NAND(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)d; } while(0)
|
|
||||||
#define READ_NAND(adr) ((volatile unsigned char)(*(volatile __u8 *)(unsigned long)adr))
|
|
||||||
|
|
||||||
#define CONFIG_MTD_NAND_VERIFY_WRITE 1 /* verify all writes!!! */
|
|
||||||
#define CFG_NAND_SKIP_BAD_DOT_I 1 /* ".i" read skips bad blocks */
|
#define CFG_NAND_SKIP_BAD_DOT_I 1 /* ".i" read skips bad blocks */
|
||||||
|
|
||||||
/*-----------------------------------------------------------------------
|
/*-----------------------------------------------------------------------
|
||||||
|
|
|
@ -81,8 +81,6 @@
|
||||||
/* this must be included AFTER the definition of CONFIG_COMMANDS (if any) */
|
/* this must be included AFTER the definition of CONFIG_COMMANDS (if any) */
|
||||||
#include <cmd_confdefs.h>
|
#include <cmd_confdefs.h>
|
||||||
|
|
||||||
#define CFG_NAND_LEGACY
|
|
||||||
|
|
||||||
#undef CONFIG_WATCHDOG /* watchdog disabled */
|
#undef CONFIG_WATCHDOG /* watchdog disabled */
|
||||||
|
|
||||||
#define CONFIG_SDRAM_BANK0 1 /* init onboard SDRAM bank 0 */
|
#define CONFIG_SDRAM_BANK0 1 /* init onboard SDRAM bank 0 */
|
||||||
|
@ -148,34 +146,15 @@
|
||||||
* NAND-FLASH stuff
|
* NAND-FLASH stuff
|
||||||
*-----------------------------------------------------------------------
|
*-----------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
#define CFG_MAX_NAND_DEVICE 1 /* Max number of NAND devices */
|
#define CFG_NAND_BASE_LIST { CFG_NAND_BASE }
|
||||||
#define SECTORSIZE 512
|
|
||||||
|
|
||||||
#define ADDR_COLUMN 1
|
|
||||||
#define ADDR_PAGE 2
|
|
||||||
#define ADDR_COLUMN_PAGE 3
|
|
||||||
|
|
||||||
#define NAND_ChipID_UNKNOWN 0x00
|
|
||||||
#define NAND_MAX_FLOORS 1
|
|
||||||
#define NAND_MAX_CHIPS 1
|
#define NAND_MAX_CHIPS 1
|
||||||
|
#define CFG_MAX_NAND_DEVICE 1 /* Max number of NAND devices */
|
||||||
|
#define NAND_BIG_DELAY_US 25
|
||||||
|
|
||||||
#define CFG_NAND_CE (0x80000000 >> 1) /* our CE is GPIO1 */
|
#define CFG_NAND_CE (0x80000000 >> 1) /* our CE is GPIO1 */
|
||||||
|
#define CFG_NAND_RDY (0x80000000 >> 4) /* our RDY is GPIO4 */
|
||||||
#define CFG_NAND_CLE (0x80000000 >> 2) /* our CLE is GPIO2 */
|
#define CFG_NAND_CLE (0x80000000 >> 2) /* our CLE is GPIO2 */
|
||||||
#define CFG_NAND_ALE (0x80000000 >> 3) /* our ALE is GPIO3 */
|
#define CFG_NAND_ALE (0x80000000 >> 3) /* our ALE is GPIO3 */
|
||||||
#define CFG_NAND_RDY (0x80000000 >> 4) /* our RDY is GPIO4 */
|
|
||||||
|
|
||||||
#define NAND_DISABLE_CE(nand) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CE);} while(0)
|
|
||||||
#define NAND_ENABLE_CE(nand) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_CE);} while(0)
|
|
||||||
#define NAND_CTL_CLRALE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_ALE);} while(0)
|
|
||||||
#define NAND_CTL_SETALE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_ALE);} while(0)
|
|
||||||
#define NAND_CTL_CLRCLE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_CLE);} while(0)
|
|
||||||
#define NAND_CTL_SETCLE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CLE);} while(0)
|
|
||||||
#define NAND_WAIT_READY(nand) while (!(in32(GPIO0_IR) & CFG_NAND_RDY))
|
|
||||||
|
|
||||||
#define WRITE_NAND_COMMAND(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)(d); } while(0)
|
|
||||||
#define WRITE_NAND_ADDRESS(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)(d); } while(0)
|
|
||||||
#define WRITE_NAND(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)d; } while(0)
|
|
||||||
#define READ_NAND(adr) ((volatile unsigned char)(*(volatile __u8 *)(unsigned long)adr))
|
|
||||||
|
|
||||||
#define CFG_NAND_SKIP_BAD_DOT_I 1 /* ".i" read skips bad blocks */
|
#define CFG_NAND_SKIP_BAD_DOT_I 1 /* ".i" read skips bad blocks */
|
||||||
|
|
||||||
|
|
|
@ -130,8 +130,6 @@
|
||||||
/* this must be included AFTER the definition of CONFIG_COMMANDS (if any) */
|
/* this must be included AFTER the definition of CONFIG_COMMANDS (if any) */
|
||||||
#include <cmd_confdefs.h>
|
#include <cmd_confdefs.h>
|
||||||
|
|
||||||
#define CFG_NAND_LEGACY
|
|
||||||
|
|
||||||
#undef CONFIG_BZIP2 /* include support for bzip2 compressed images */
|
#undef CONFIG_BZIP2 /* include support for bzip2 compressed images */
|
||||||
#undef CONFIG_WATCHDOG /* watchdog disabled */
|
#undef CONFIG_WATCHDOG /* watchdog disabled */
|
||||||
|
|
||||||
|
@ -198,34 +196,15 @@
|
||||||
* NAND-FLASH stuff
|
* NAND-FLASH stuff
|
||||||
*-----------------------------------------------------------------------
|
*-----------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
#define CFG_MAX_NAND_DEVICE 1 /* Max number of NAND devices */
|
#define CFG_NAND_BASE_LIST { CFG_NAND_BASE }
|
||||||
#define SECTORSIZE 512
|
|
||||||
|
|
||||||
#define ADDR_COLUMN 1
|
|
||||||
#define ADDR_PAGE 2
|
|
||||||
#define ADDR_COLUMN_PAGE 3
|
|
||||||
|
|
||||||
#define NAND_ChipID_UNKNOWN 0x00
|
|
||||||
#define NAND_MAX_FLOORS 1
|
|
||||||
#define NAND_MAX_CHIPS 1
|
#define NAND_MAX_CHIPS 1
|
||||||
|
#define CFG_MAX_NAND_DEVICE 1 /* Max number of NAND devices */
|
||||||
|
#define NAND_BIG_DELAY_US 25
|
||||||
|
|
||||||
#define CFG_NAND_CE (0x80000000 >> 1) /* our CE is GPIO1 */
|
#define CFG_NAND_CE (0x80000000 >> 1) /* our CE is GPIO1 */
|
||||||
|
#define CFG_NAND_RDY (0x80000000 >> 4) /* our RDY is GPIO4 */
|
||||||
#define CFG_NAND_CLE (0x80000000 >> 2) /* our CLE is GPIO2 */
|
#define CFG_NAND_CLE (0x80000000 >> 2) /* our CLE is GPIO2 */
|
||||||
#define CFG_NAND_ALE (0x80000000 >> 3) /* our ALE is GPIO3 */
|
#define CFG_NAND_ALE (0x80000000 >> 3) /* our ALE is GPIO3 */
|
||||||
#define CFG_NAND_RDY (0x80000000 >> 4) /* our RDY is GPIO4 */
|
|
||||||
|
|
||||||
#define NAND_DISABLE_CE(nand) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CE);} while(0)
|
|
||||||
#define NAND_ENABLE_CE(nand) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_CE);} while(0)
|
|
||||||
#define NAND_CTL_CLRALE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_ALE);} while(0)
|
|
||||||
#define NAND_CTL_SETALE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_ALE);} while(0)
|
|
||||||
#define NAND_CTL_CLRCLE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_CLE);} while(0)
|
|
||||||
#define NAND_CTL_SETCLE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CLE);} while(0)
|
|
||||||
#define NAND_WAIT_READY(nand) while (!(in32(GPIO0_IR) & CFG_NAND_RDY))
|
|
||||||
|
|
||||||
#define WRITE_NAND_COMMAND(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)(d); } while(0)
|
|
||||||
#define WRITE_NAND_ADDRESS(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)(d); } while(0)
|
|
||||||
#define WRITE_NAND(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)d; } while(0)
|
|
||||||
#define READ_NAND(adr) ((volatile unsigned char)(*(volatile __u8 *)(unsigned long)adr))
|
|
||||||
|
|
||||||
#define CFG_NAND_SKIP_BAD_DOT_I 1 /* ".i" read skips bad blocks */
|
#define CFG_NAND_SKIP_BAD_DOT_I 1 /* ".i" read skips bad blocks */
|
||||||
|
|
||||||
|
|
|
@ -135,36 +135,15 @@
|
||||||
* NAND-FLASH stuff
|
* NAND-FLASH stuff
|
||||||
*-----------------------------------------------------------------------
|
*-----------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
#define CFG_NAND_LEGACY
|
#define CFG_NAND_BASE_LIST { CFG_NAND_BASE }
|
||||||
|
|
||||||
#define CFG_MAX_NAND_DEVICE 1 /* Max number of NAND devices */
|
|
||||||
#define SECTORSIZE 512
|
|
||||||
|
|
||||||
#define ADDR_COLUMN 1
|
|
||||||
#define ADDR_PAGE 2
|
|
||||||
#define ADDR_COLUMN_PAGE 3
|
|
||||||
|
|
||||||
#define NAND_ChipID_UNKNOWN 0x00
|
|
||||||
#define NAND_MAX_FLOORS 1
|
|
||||||
#define NAND_MAX_CHIPS 1
|
#define NAND_MAX_CHIPS 1
|
||||||
|
#define CFG_MAX_NAND_DEVICE 1 /* Max number of NAND devices */
|
||||||
|
#define NAND_BIG_DELAY_US 25
|
||||||
|
|
||||||
#define CFG_NAND_CE (0x80000000 >> 1) /* our CE is GPIO1 */
|
#define CFG_NAND_CE (0x80000000 >> 1) /* our CE is GPIO1 */
|
||||||
|
#define CFG_NAND_RDY (0x80000000 >> 4) /* our RDY is GPIO4 */
|
||||||
#define CFG_NAND_CLE (0x80000000 >> 2) /* our CLE is GPIO2 */
|
#define CFG_NAND_CLE (0x80000000 >> 2) /* our CLE is GPIO2 */
|
||||||
#define CFG_NAND_ALE (0x80000000 >> 3) /* our ALE is GPIO3 */
|
#define CFG_NAND_ALE (0x80000000 >> 3) /* our ALE is GPIO3 */
|
||||||
#define CFG_NAND_RDY (0x80000000 >> 4) /* our RDY is GPIO4 */
|
|
||||||
|
|
||||||
#define NAND_DISABLE_CE(nand) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CE);} while(0)
|
|
||||||
#define NAND_ENABLE_CE(nand) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_CE);} while(0)
|
|
||||||
#define NAND_CTL_CLRALE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_ALE);} while(0)
|
|
||||||
#define NAND_CTL_SETALE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_ALE);} while(0)
|
|
||||||
#define NAND_CTL_CLRCLE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_CLE);} while(0)
|
|
||||||
#define NAND_CTL_SETCLE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CLE);} while(0)
|
|
||||||
#define NAND_WAIT_READY(nand) while (!(in32(GPIO0_IR) & CFG_NAND_RDY))
|
|
||||||
|
|
||||||
#define WRITE_NAND_COMMAND(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)(d); } while(0)
|
|
||||||
#define WRITE_NAND_ADDRESS(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)(d); } while(0)
|
|
||||||
#define WRITE_NAND(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)d; } while(0)
|
|
||||||
#define READ_NAND(adr) ((volatile unsigned char)(*(volatile __u8 *)(unsigned long)adr))
|
|
||||||
|
|
||||||
#define CFG_NAND_SKIP_BAD_DOT_I 1 /* ".i" read skips bad blocks */
|
#define CFG_NAND_SKIP_BAD_DOT_I 1 /* ".i" read skips bad blocks */
|
||||||
|
|
||||||
|
|
|
@ -81,7 +81,6 @@
|
||||||
#define CONFIG_SUPPORT_VFAT
|
#define CONFIG_SUPPORT_VFAT
|
||||||
|
|
||||||
#define CONFIG_AUTO_UPDATE 1 /* autoupdate via compactflash */
|
#define CONFIG_AUTO_UPDATE 1 /* autoupdate via compactflash */
|
||||||
#define CONFIG_AUTO_UPDATE_SHOW 1 /* use board show routine */
|
|
||||||
|
|
||||||
/* this must be included AFTER the definition of CONFIG_COMMANDS (if any) */
|
/* this must be included AFTER the definition of CONFIG_COMMANDS (if any) */
|
||||||
#include <cmd_confdefs.h>
|
#include <cmd_confdefs.h>
|
||||||
|
@ -156,36 +155,15 @@
|
||||||
* NAND-FLASH stuff
|
* NAND-FLASH stuff
|
||||||
*-----------------------------------------------------------------------
|
*-----------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
#define CFG_NAND_LEGACY
|
#define CFG_NAND_BASE_LIST { CFG_NAND_BASE }
|
||||||
|
|
||||||
#define CFG_MAX_NAND_DEVICE 1 /* Max number of NAND devices */
|
|
||||||
#define SECTORSIZE 512
|
|
||||||
|
|
||||||
#define ADDR_COLUMN 1
|
|
||||||
#define ADDR_PAGE 2
|
|
||||||
#define ADDR_COLUMN_PAGE 3
|
|
||||||
|
|
||||||
#define NAND_ChipID_UNKNOWN 0x00
|
|
||||||
#define NAND_MAX_FLOORS 1
|
|
||||||
#define NAND_MAX_CHIPS 1
|
#define NAND_MAX_CHIPS 1
|
||||||
|
#define CFG_MAX_NAND_DEVICE 1 /* Max number of NAND devices */
|
||||||
|
#define NAND_BIG_DELAY_US 25
|
||||||
|
|
||||||
#define CFG_NAND_CE (0x80000000 >> 1) /* our CE is GPIO1 */
|
#define CFG_NAND_CE (0x80000000 >> 1) /* our CE is GPIO1 */
|
||||||
|
#define CFG_NAND_RDY (0x80000000 >> 4) /* our RDY is GPIO4 */
|
||||||
#define CFG_NAND_CLE (0x80000000 >> 2) /* our CLE is GPIO2 */
|
#define CFG_NAND_CLE (0x80000000 >> 2) /* our CLE is GPIO2 */
|
||||||
#define CFG_NAND_ALE (0x80000000 >> 3) /* our ALE is GPIO3 */
|
#define CFG_NAND_ALE (0x80000000 >> 3) /* our ALE is GPIO3 */
|
||||||
#define CFG_NAND_RDY (0x80000000 >> 4) /* our RDY is GPIO4 */
|
|
||||||
|
|
||||||
#define NAND_DISABLE_CE(nand) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CE);} while(0)
|
|
||||||
#define NAND_ENABLE_CE(nand) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_CE);} while(0)
|
|
||||||
#define NAND_CTL_CLRALE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_ALE);} while(0)
|
|
||||||
#define NAND_CTL_SETALE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_ALE);} while(0)
|
|
||||||
#define NAND_CTL_CLRCLE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_CLE);} while(0)
|
|
||||||
#define NAND_CTL_SETCLE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CLE);} while(0)
|
|
||||||
#define NAND_WAIT_READY(nand) while (!(in32(GPIO0_IR) & CFG_NAND_RDY))
|
|
||||||
|
|
||||||
#define WRITE_NAND_COMMAND(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)(d); } while(0)
|
|
||||||
#define WRITE_NAND_ADDRESS(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)(d); } while(0)
|
|
||||||
#define WRITE_NAND(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)d; } while(0)
|
|
||||||
#define READ_NAND(adr) ((volatile unsigned char)(*(volatile __u8 *)(unsigned long)adr))
|
|
||||||
|
|
||||||
#define CFG_NAND_SKIP_BAD_DOT_I 1 /* ".i" read skips bad blocks */
|
#define CFG_NAND_SKIP_BAD_DOT_I 1 /* ".i" read skips bad blocks */
|
||||||
|
|
||||||
|
@ -264,11 +242,6 @@
|
||||||
|
|
||||||
#define CFG_FLASH_EMPTY_INFO /* print 'E' for empty sector on flinfo */
|
#define CFG_FLASH_EMPTY_INFO /* print 'E' for empty sector on flinfo */
|
||||||
|
|
||||||
#if 0 /* test-only */
|
|
||||||
#define CFG_JFFS2_FIRST_BANK 0 /* use for JFFS2 */
|
|
||||||
#define CFG_JFFS2_NUM_BANKS 1 /* ! second bank contains U-Boot */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*-----------------------------------------------------------------------
|
/*-----------------------------------------------------------------------
|
||||||
* Start addresses for the final memory configuration
|
* Start addresses for the final memory configuration
|
||||||
* (Set up by the startup code)
|
* (Set up by the startup code)
|
||||||
|
@ -294,9 +267,6 @@
|
||||||
#define CFG_ENV_SIZE 0x700 /* 2048 bytes may be used for env vars*/
|
#define CFG_ENV_SIZE 0x700 /* 2048 bytes may be used for env vars*/
|
||||||
/* total size of a CAT24WC16 is 2048 bytes */
|
/* total size of a CAT24WC16 is 2048 bytes */
|
||||||
|
|
||||||
#define CFG_NVRAM_BASE_ADDR 0xF0000500 /* NVRAM base address */
|
|
||||||
#define CFG_NVRAM_SIZE 242 /* NVRAM size */
|
|
||||||
|
|
||||||
/*-----------------------------------------------------------------------
|
/*-----------------------------------------------------------------------
|
||||||
* I2C EEPROM (CAT24WC16) for environment
|
* I2C EEPROM (CAT24WC16) for environment
|
||||||
*/
|
*/
|
||||||
|
@ -305,7 +275,7 @@
|
||||||
#define CFG_I2C_SLAVE 0x7F
|
#define CFG_I2C_SLAVE 0x7F
|
||||||
|
|
||||||
#define CFG_I2C_EEPROM_ADDR 0x50 /* EEPROM CAT24WC08 */
|
#define CFG_I2C_EEPROM_ADDR 0x50 /* EEPROM CAT24WC08 */
|
||||||
#if 1 /* test-only */
|
|
||||||
/* CAT24WC08/16... */
|
/* CAT24WC08/16... */
|
||||||
#define CFG_I2C_EEPROM_ADDR_LEN 1 /* Bytes of address */
|
#define CFG_I2C_EEPROM_ADDR_LEN 1 /* Bytes of address */
|
||||||
/* mask of address bits that overflow into the "EEPROM chip address" */
|
/* mask of address bits that overflow into the "EEPROM chip address" */
|
||||||
|
@ -313,15 +283,6 @@
|
||||||
#define CFG_EEPROM_PAGE_WRITE_BITS 4 /* The Catalyst CAT24WC08 has */
|
#define CFG_EEPROM_PAGE_WRITE_BITS 4 /* The Catalyst CAT24WC08 has */
|
||||||
/* 16 byte page write mode using*/
|
/* 16 byte page write mode using*/
|
||||||
/* last 4 bits of the address */
|
/* last 4 bits of the address */
|
||||||
#else
|
|
||||||
/* CAT24WC32/64... */
|
|
||||||
#define CFG_I2C_EEPROM_ADDR_LEN 2 /* Bytes of address */
|
|
||||||
/* mask of address bits that overflow into the "EEPROM chip address" */
|
|
||||||
#define CFG_I2C_EEPROM_ADDR_OVERFLOW 0x01
|
|
||||||
#define CFG_EEPROM_PAGE_WRITE_BITS 5 /* The Catalyst CAT24WC32 has */
|
|
||||||
/* 32 byte page write mode using*/
|
|
||||||
/* last 5 bits of the address */
|
|
||||||
#endif
|
|
||||||
#define CFG_EEPROM_PAGE_WRITE_DELAY_MS 10 /* and takes up to 10 msec */
|
#define CFG_EEPROM_PAGE_WRITE_DELAY_MS 10 /* and takes up to 10 msec */
|
||||||
#define CFG_EEPROM_PAGE_WRITE_ENABLE
|
#define CFG_EEPROM_PAGE_WRITE_ENABLE
|
||||||
|
|
||||||
|
|
|
@ -141,36 +141,15 @@
|
||||||
* NAND-FLASH stuff
|
* NAND-FLASH stuff
|
||||||
*-----------------------------------------------------------------------
|
*-----------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
#define CFG_NAND_LEGACY
|
#define CFG_NAND_BASE_LIST { CFG_NAND_BASE }
|
||||||
|
|
||||||
#define CFG_MAX_NAND_DEVICE 1 /* Max number of NAND devices */
|
|
||||||
#define SECTORSIZE 512
|
|
||||||
|
|
||||||
#define ADDR_COLUMN 1
|
|
||||||
#define ADDR_PAGE 2
|
|
||||||
#define ADDR_COLUMN_PAGE 3
|
|
||||||
|
|
||||||
#define NAND_ChipID_UNKNOWN 0x00
|
|
||||||
#define NAND_MAX_FLOORS 1
|
|
||||||
#define NAND_MAX_CHIPS 1
|
#define NAND_MAX_CHIPS 1
|
||||||
|
#define CFG_MAX_NAND_DEVICE 1 /* Max number of NAND devices */
|
||||||
|
#define NAND_BIG_DELAY_US 25
|
||||||
|
|
||||||
#define CFG_NAND_CE (0x80000000 >> 1) /* our CE is GPIO1 */
|
#define CFG_NAND_CE (0x80000000 >> 1) /* our CE is GPIO1 */
|
||||||
|
#define CFG_NAND_RDY (0x80000000 >> 4) /* our RDY is GPIO4 */
|
||||||
#define CFG_NAND_CLE (0x80000000 >> 2) /* our CLE is GPIO2 */
|
#define CFG_NAND_CLE (0x80000000 >> 2) /* our CLE is GPIO2 */
|
||||||
#define CFG_NAND_ALE (0x80000000 >> 3) /* our ALE is GPIO3 */
|
#define CFG_NAND_ALE (0x80000000 >> 3) /* our ALE is GPIO3 */
|
||||||
#define CFG_NAND_RDY (0x80000000 >> 4) /* our RDY is GPIO4 */
|
|
||||||
|
|
||||||
#define NAND_DISABLE_CE(nand) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CE);} while(0)
|
|
||||||
#define NAND_ENABLE_CE(nand) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_CE);} while(0)
|
|
||||||
#define NAND_CTL_CLRALE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_ALE);} while(0)
|
|
||||||
#define NAND_CTL_SETALE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_ALE);} while(0)
|
|
||||||
#define NAND_CTL_CLRCLE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_CLE);} while(0)
|
|
||||||
#define NAND_CTL_SETCLE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CLE);} while(0)
|
|
||||||
#define NAND_WAIT_READY(nand) while (!(in32(GPIO0_IR) & CFG_NAND_RDY))
|
|
||||||
|
|
||||||
#define WRITE_NAND_COMMAND(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)(d); } while(0)
|
|
||||||
#define WRITE_NAND_ADDRESS(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)(d); } while(0)
|
|
||||||
#define WRITE_NAND(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)d; } while(0)
|
|
||||||
#define READ_NAND(adr) ((volatile unsigned char)(*(volatile __u8 *)(unsigned long)adr))
|
|
||||||
|
|
||||||
#define CFG_NAND_SKIP_BAD_DOT_I 1 /* ".i" read skips bad blocks */
|
#define CFG_NAND_SKIP_BAD_DOT_I 1 /* ".i" read skips bad blocks */
|
||||||
|
|
||||||
|
|
|
@ -133,38 +133,16 @@
|
||||||
* NAND-FLASH stuff
|
* NAND-FLASH stuff
|
||||||
*-----------------------------------------------------------------------
|
*-----------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
#define CFG_NAND_LEGACY
|
#define CFG_NAND_BASE_LIST { CFG_NAND_BASE }
|
||||||
|
|
||||||
#define CFG_MAX_NAND_DEVICE 1 /* Max number of NAND devices */
|
|
||||||
#define SECTORSIZE 512
|
|
||||||
|
|
||||||
#define ADDR_COLUMN 1
|
|
||||||
#define ADDR_PAGE 2
|
|
||||||
#define ADDR_COLUMN_PAGE 3
|
|
||||||
|
|
||||||
#define NAND_ChipID_UNKNOWN 0x00
|
|
||||||
#define NAND_MAX_FLOORS 1
|
|
||||||
#define NAND_MAX_CHIPS 1
|
#define NAND_MAX_CHIPS 1
|
||||||
|
#define CFG_MAX_NAND_DEVICE 1 /* Max number of NAND devices */
|
||||||
|
#define NAND_BIG_DELAY_US 25
|
||||||
|
|
||||||
#define CFG_NAND_CE (0x80000000 >> 1) /* our CE is GPIO1 */
|
#define CFG_NAND_CE (0x80000000 >> 1) /* our CE is GPIO1 */
|
||||||
|
#define CFG_NAND_RDY (0x80000000 >> 4) /* our RDY is GPIO4 */
|
||||||
#define CFG_NAND_CLE (0x80000000 >> 2) /* our CLE is GPIO2 */
|
#define CFG_NAND_CLE (0x80000000 >> 2) /* our CLE is GPIO2 */
|
||||||
#define CFG_NAND_ALE (0x80000000 >> 3) /* our ALE is GPIO3 */
|
#define CFG_NAND_ALE (0x80000000 >> 3) /* our ALE is GPIO3 */
|
||||||
#define CFG_NAND_RDY (0x80000000 >> 4) /* our RDY is GPIO4 */
|
|
||||||
|
|
||||||
#define NAND_DISABLE_CE(nand) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CE);} while(0)
|
|
||||||
#define NAND_ENABLE_CE(nand) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_CE);} while(0)
|
|
||||||
#define NAND_CTL_CLRALE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_ALE);} while(0)
|
|
||||||
#define NAND_CTL_SETALE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_ALE);} while(0)
|
|
||||||
#define NAND_CTL_CLRCLE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) & ~CFG_NAND_CLE);} while(0)
|
|
||||||
#define NAND_CTL_SETCLE(nandptr) do { out32(GPIO0_OR, in32(GPIO0_OR) | CFG_NAND_CLE);} while(0)
|
|
||||||
#define NAND_WAIT_READY(nand) while (!(in32(GPIO0_IR) & CFG_NAND_RDY))
|
|
||||||
|
|
||||||
#define WRITE_NAND_COMMAND(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)(d); } while(0)
|
|
||||||
#define WRITE_NAND_ADDRESS(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)(d); } while(0)
|
|
||||||
#define WRITE_NAND(d, adr) do{ *(volatile __u8 *)((unsigned long)adr) = (__u8)d; } while(0)
|
|
||||||
#define READ_NAND(adr) ((volatile unsigned char)(*(volatile __u8 *)(unsigned long)adr))
|
|
||||||
|
|
||||||
#define CONFIG_MTD_NAND_VERIFY_WRITE 1 /* verify all writes!!! */
|
|
||||||
#define CFG_NAND_SKIP_BAD_DOT_I 1 /* ".i" read skips bad blocks */
|
#define CFG_NAND_SKIP_BAD_DOT_I 1 /* ".i" read skips bad blocks */
|
||||||
|
|
||||||
/*-----------------------------------------------------------------------
|
/*-----------------------------------------------------------------------
|
||||||
|
|
Loading…
Reference in a new issue