- fix cmd_ide.c for non ppc boards (read/write functions did not add ATA base address) - fix for shannon board - #ifdef CONFIG_IDE_8xx_DIRECT some otherwise unused code * Patch by Sangmoon Kim, 07 Oct 2003: add support for debris boardmaster
parent
a0ff7f2eda
commit
15647dc7fd
@ -0,0 +1,40 @@ |
|||||||
|
#
|
||||||
|
# (C) Copyright 2000
|
||||||
|
# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
|
||||||
|
#
|
||||||
|
# See file CREDITS for list of people who contributed to this
|
||||||
|
# project.
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or
|
||||||
|
# modify it under the terms of the GNU General Public License as
|
||||||
|
# published by the Free Software Foundation; either version 2 of
|
||||||
|
# the License, or (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, write to the Free Software
|
||||||
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||||
|
# MA 02111-1307 USA
|
||||||
|
#
|
||||||
|
|
||||||
|
include $(TOPDIR)/config.mk |
||||||
|
|
||||||
|
LIB = lib$(BOARD).a
|
||||||
|
|
||||||
|
OBJS = $(BOARD).o flash.o phantom.o
|
||||||
|
|
||||||
|
$(LIB): .depend $(OBJS) |
||||||
|
$(AR) crv $@ $(OBJS)
|
||||||
|
|
||||||
|
#########################################################################
|
||||||
|
|
||||||
|
.depend: Makefile $(OBJS:.o=.c) |
||||||
|
$(CC) -M $(CFLAGS) $(OBJS:.o=.c) > $@
|
||||||
|
|
||||||
|
sinclude .depend |
||||||
|
|
||||||
|
#########################################################################
|
@ -0,0 +1,31 @@ |
|||||||
|
#
|
||||||
|
# (C) Copyright 2000, 2001
|
||||||
|
# Sangmoon, Etin Systems, dogoil@etinsys.com.
|
||||||
|
#
|
||||||
|
# See file CREDITS for list of people who contributed to this
|
||||||
|
# project.
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or
|
||||||
|
# modify it under the terms of the GNU General Public License as
|
||||||
|
# published by the Free Software Foundation; either version 2 of
|
||||||
|
# the License, or (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, write to the Free Software
|
||||||
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||||
|
# MA 02111-1307 USA
|
||||||
|
#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Debris boards
|
||||||
|
#
|
||||||
|
|
||||||
|
#TEXT_BASE = 0x00090000
|
||||||
|
TEXT_BASE = 0xFFF00000
|
||||||
|
|
||||||
|
PLATFORM_CPPFLAGS += -DTEXT_BASE=$(TEXT_BASE)
|
@ -0,0 +1,158 @@ |
|||||||
|
/*
|
||||||
|
* (C) Copyright 2000 |
||||||
|
* Sangmoon Kim, Etin Systems. dogoil@etinsys.com. |
||||||
|
* |
||||||
|
* See file CREDITS for list of people who contributed to this |
||||||
|
* project. |
||||||
|
* |
||||||
|
* This program is free software; you can redistribute it and/or |
||||||
|
* modify it under the terms of the GNU General Public License as |
||||||
|
* published by the Free Software Foundation; either version 2 of |
||||||
|
* the License, or (at your option) any later version. |
||||||
|
* |
||||||
|
* This program is distributed in the hope that it will be useful, |
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||||
|
* GNU General Public License for more details. |
||||||
|
* |
||||||
|
* You should have received a copy of the GNU General Public License |
||||||
|
* along with this program; if not, write to the Free Software |
||||||
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, |
||||||
|
* MA 02111-1307 USA |
||||||
|
*/ |
||||||
|
|
||||||
|
#include <common.h> |
||||||
|
#include <mpc824x.h> |
||||||
|
#include <pci.h> |
||||||
|
|
||||||
|
int checkboard (void) |
||||||
|
{ |
||||||
|
/*TODO: Check processor type */ |
||||||
|
|
||||||
|
puts ( "Board: Debris " |
||||||
|
#ifdef CONFIG_MPC8240 |
||||||
|
"8240" |
||||||
|
#endif |
||||||
|
#ifdef CONFIG_MPC8245 |
||||||
|
"8245" |
||||||
|
#endif |
||||||
|
" ##Test not implemented yet##\n"); |
||||||
|
return 0; |
||||||
|
} |
||||||
|
|
||||||
|
#if 0 /* NOT USED */
|
||||||
|
int checkflash (void) |
||||||
|
{ |
||||||
|
/* TODO: XXX XXX XXX */ |
||||||
|
printf ("## Test not implemented yet ##\n"); |
||||||
|
|
||||||
|
return (0); |
||||||
|
} |
||||||
|
#endif |
||||||
|
|
||||||
|
long int initdram (int board_type) |
||||||
|
{ |
||||||
|
int i, cnt; |
||||||
|
volatile uchar * base= CFG_SDRAM_BASE; |
||||||
|
volatile ulong * addr; |
||||||
|
ulong save[32]; |
||||||
|
ulong val, ret = 0; |
||||||
|
|
||||||
|
for (i=0, cnt=(CFG_MAX_RAM_SIZE / sizeof(long)) >> 1; cnt > 0; cnt >>= 1) { |
||||||
|
addr = (volatile ulong *)base + cnt; |
||||||
|
save[i++] = *addr; |
||||||
|
*addr = ~cnt; |
||||||
|
} |
||||||
|
|
||||||
|
addr = (volatile ulong *)base; |
||||||
|
save[i] = *addr; |
||||||
|
*addr = 0; |
||||||
|
|
||||||
|
if (*addr != 0) { |
||||||
|
*addr = save[i]; |
||||||
|
goto Done; |
||||||
|
} |
||||||
|
|
||||||
|
for (cnt = 1; cnt <= CFG_MAX_RAM_SIZE / sizeof(long); cnt <<= 1) { |
||||||
|
addr = (volatile ulong *)base + cnt; |
||||||
|
val = *addr; |
||||||
|
*addr = save[--i]; |
||||||
|
if (val != ~cnt) { |
||||||
|
/* ulong new_bank0_end = cnt * sizeof(long) - 1;
|
||||||
|
ulong mear1 = mpc824x_mpc107_getreg(MEAR1); |
||||||
|
ulong emear1 = mpc824x_mpc107_getreg(EMEAR1); |
||||||
|
mear1 = (mear1 & 0xFFFFFF00) | |
||||||
|
((new_bank0_end & MICR_ADDR_MASK) >> MICR_ADDR_SHIFT); |
||||||
|
emear1 = (emear1 & 0xFFFFFF00) | |
||||||
|
((new_bank0_end & MICR_ADDR_MASK) >> MICR_EADDR_SHIFT); |
||||||
|
mpc824x_mpc107_setreg(MEAR1, mear1); |
||||||
|
mpc824x_mpc107_setreg(EMEAR1, emear1);*/ |
||||||
|
|
||||||
|
ret = cnt * sizeof(long); |
||||||
|
goto Done; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
ret = CFG_MAX_RAM_SIZE; |
||||||
|
Done: |
||||||
|
return ret; |
||||||
|
} |
||||||
|
|
||||||
|
/*
|
||||||
|
* Initialize PCI Devices, report devices found. |
||||||
|
*/ |
||||||
|
#ifndef CONFIG_PCI_PNP |
||||||
|
static struct pci_config_table pci_debris_config_table[] = { |
||||||
|
{ PCI_ANY_ID, PCI_ANY_ID, PCI_ANY_ID, PCI_ANY_ID, 0x0f, PCI_ANY_ID, |
||||||
|
pci_cfgfunc_config_device, { PCI_ENET0_IOADDR, |
||||||
|
PCI_ENET0_MEMADDR, |
||||||
|
PCI_COMMAND_MEMORY | PCI_COMMAND_MASTER }}, |
||||||
|
{ PCI_ANY_ID, PCI_ANY_ID, PCI_ANY_ID, PCI_ANY_ID, 0x10, PCI_ANY_ID, |
||||||
|
pci_cfgfunc_config_device, { PCI_ENET1_IOADDR, |
||||||
|
PCI_ENET1_MEMADDR, |
||||||
|
PCI_COMMAND_MEMORY | PCI_COMMAND_MASTER }}, |
||||||
|
{ } |
||||||
|
}; |
||||||
|
#endif |
||||||
|
|
||||||
|
struct pci_controller hose = { |
||||||
|
#ifndef CONFIG_PCI_PNP |
||||||
|
config_table: pci_debris_config_table, |
||||||
|
#endif |
||||||
|
}; |
||||||
|
|
||||||
|
void pci_init_board(void) |
||||||
|
{ |
||||||
|
pci_mpc824x_init(&hose); |
||||||
|
} |
||||||
|
|
||||||
|
void *nvram_read(void *dest, const long src, size_t count) |
||||||
|
{ |
||||||
|
volatile uchar *d = (volatile uchar*) dest; |
||||||
|
volatile uchar *s = (volatile uchar*) src; |
||||||
|
while(count--) { |
||||||
|
*d++ = *s++; |
||||||
|
asm volatile("sync"); |
||||||
|
} |
||||||
|
return dest; |
||||||
|
} |
||||||
|
|
||||||
|
void nvram_write(long dest, const void *src, size_t count) |
||||||
|
{ |
||||||
|
volatile uchar *d = (volatile uchar*)dest; |
||||||
|
volatile uchar *s = (volatile uchar*)src; |
||||||
|
while(count--) { |
||||||
|
*d++ = *s++; |
||||||
|
asm volatile("sync"); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
int misc_init_r(void) |
||||||
|
{ |
||||||
|
DECLARE_GLOBAL_DATA_PTR; |
||||||
|
|
||||||
|
/* Write ethernet addr in NVRAM for VxWorks */ |
||||||
|
nvram_write(CFG_ENV_ADDR + CFG_NVRAM_VXWORKS_OFFS, |
||||||
|
(char*)&gd->bd->bi_enetaddr[0], 6); |
||||||
|
return 0; |
||||||
|
} |
@ -0,0 +1,720 @@ |
|||||||
|
/*
|
||||||
|
* board/eva/flash.c |
||||||
|
* |
||||||
|
* (C) Copyright 2002 |
||||||
|
* Sangmoon Kim, Etin Systems, dogoil@etinsys.com. |
||||||
|
* |
||||||
|
* See file CREDITS for list of people who contributed to this |
||||||
|
* project. |
||||||
|
* |
||||||
|
* This program is free software; you can redistribute it and/or |
||||||
|
* modify it under the terms of the GNU General Public License as |
||||||
|
* published by the Free Software Foundation; either version 2 of |
||||||
|
* the License, or (at your option) any later version. |
||||||
|
* |
||||||
|
* This program is distributed in the hope that it will be useful, |
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||||
|
* GNU General Public License for more details. |
||||||
|
* |
||||||
|
* You should have received a copy of the GNU General Public License |
||||||
|
* along with this program; if not, write to the Free Software |
||||||
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, |
||||||
|
* MA 02111-1307 USA |
||||||
|
*/ |
||||||
|
|
||||||
|
#include <common.h> |
||||||
|
#include <asm/processor.h> |
||||||
|
#include <asm/pci_io.h> |
||||||
|
#include <mpc824x.h> |
||||||
|
|
||||||
|
int (*do_flash_erase)(flash_info_t*, uint32_t, uint32_t); |
||||||
|
int (*write_dword)(flash_info_t*, ulong, uint64_t); |
||||||
|
|
||||||
|
typedef uint64_t cfi_word; |
||||||
|
|
||||||
|
#define cfi_read(flash, addr) *((volatile cfi_word*)(flash->start[0] + addr)) |
||||||
|
|
||||||
|
#define cfi_write(flash, val, addr) \ |
||||||
|
move64((cfi_word*)&val, \
|
||||||
|
(cfi_word*)(flash->start[0] + addr)) |
||||||
|
|
||||||
|
#define CMD(x) ((((cfi_word)x)<<48)|(((cfi_word)x)<<32)|(((cfi_word)x)<<16)|(((cfi_word)x))) |
||||||
|
|
||||||
|
static void write32(unsigned long addr, uint32_t value) |
||||||
|
{ |
||||||
|
*(volatile uint32_t*)(addr) = value; |
||||||
|
asm volatile("sync"); |
||||||
|
} |
||||||
|
|
||||||
|
static uint32_t read32(unsigned long addr) |
||||||
|
{ |
||||||
|
uint32_t value; |
||||||
|
value = *(volatile uint32_t*)addr; |
||||||
|
asm volatile("sync"); |
||||||
|
return value; |
||||||
|
} |
||||||
|
|
||||||
|
static cfi_word cfi_cmd(flash_info_t *flash, uint8_t cmd, uint32_t addr) |
||||||
|
{ |
||||||
|
uint32_t base = flash->start[0]; |
||||||
|
uint32_t val=(cmd << 16) | cmd; |
||||||
|
addr <<= 3; |
||||||
|
write32(base + addr, val); |
||||||
|
return addr; |
||||||
|
} |
||||||
|
|
||||||
|
static uint16_t cfi_read_query(flash_info_t *flash, uint32_t addr) |
||||||
|
{ |
||||||
|
uint32_t base = flash->start[0]; |
||||||
|
addr <<= 3; |
||||||
|
return (uint16_t)read32(base + addr); |
||||||
|
} |
||||||
|
|
||||||
|
flash_info_t flash_info[CFG_MAX_FLASH_BANKS]; /* info for FLASH chips */ |
||||||
|
|
||||||
|
static void move64(uint64_t *src, uint64_t *dest) |
||||||
|
{ |
||||||
|
asm volatile("lfd 0, 0(3)\n\t" /* fpr0 = *scr */ |
||||||
|
"stfd 0, 0(4)" /* *dest = fpr0 */ |
||||||
|
: : : "fr0" ); /* Clobbers fr0 */ |
||||||
|
return; |
||||||
|
} |
||||||
|
|
||||||
|
static int cfi_write_dword(flash_info_t *flash, ulong dest, cfi_word data) |
||||||
|
{ |
||||||
|
unsigned long start; |
||||||
|
cfi_word status = 0; |
||||||
|
|
||||||
|
status = cfi_read(flash, dest); |
||||||
|
data &= status; |
||||||
|
|
||||||
|
cfi_cmd(flash, 0x40, 0); |
||||||
|
cfi_write(flash, data, dest); |
||||||
|
|
||||||
|
udelay(10); |
||||||
|
start = get_timer (0); |
||||||
|
for(;;) { |
||||||
|
status = cfi_read(flash, dest); |
||||||
|
status &= CMD(0x80); |
||||||
|
if(status == CMD(0x80)) |
||||||
|
break; |
||||||
|
if (get_timer(start) > CFG_FLASH_WRITE_TOUT) { |
||||||
|
cfi_cmd(flash, 0xff, 0); |
||||||
|
return 1; |
||||||
|
} |
||||||
|
udelay(1); |
||||||
|
} |
||||||
|
cfi_cmd(flash, 0xff, 0); |
||||||
|
|
||||||
|
return 0; |
||||||
|
} |
||||||
|
|
||||||
|
static int jedec_write_dword (flash_info_t *flash, ulong dest, cfi_word data) |
||||||
|
{ |
||||||
|
ulong start; |
||||||
|
cfi_word status = 0; |
||||||
|
|
||||||
|
status = cfi_read(flash, dest); |
||||||
|
if(status != CMD(0xffff)) return 2; |
||||||
|
|
||||||
|
cfi_cmd(flash, 0xaa, 0x555); |
||||||
|
cfi_cmd(flash, 0x55, 0x2aa); |
||||||
|
cfi_cmd(flash, 0xa0, 0x555); |
||||||
|
|
||||||
|
cfi_write(flash, data, dest); |
||||||
|
|
||||||
|
udelay(10); |
||||||
|
start = get_timer (0); |
||||||
|
status = ~data; |
||||||
|
while(status != data) { |
||||||
|
if (get_timer(start) > CFG_FLASH_WRITE_TOUT) |
||||||
|
return 1; |
||||||
|
status = cfi_read(flash, dest); |
||||||
|
udelay(1); |
||||||
|
} |
||||||
|
return 0; |
||||||
|
} |
||||||
|
|
||||||
|
static __inline__ unsigned long get_msr(void) |
||||||
|
{ |
||||||
|
unsigned long msr; |
||||||
|
__asm__ __volatile__ ("mfmsr %0" : "=r" (msr) :); |
||||||
|
return msr; |
||||||
|
} |
||||||
|
|
||||||
|
static __inline__ void set_msr(unsigned long msr) |
||||||
|
{ |
||||||
|
__asm__ __volatile__ ("mtmsr %0" : : "r" (msr)); |
||||||
|
} |
||||||
|
|
||||||
|
int write_buff (flash_info_t *flash, uchar *src, ulong addr, ulong cnt) |
||||||
|
{ |
||||||
|
ulong wp; |
||||||
|
int i, s, l, rc; |
||||||
|
cfi_word data; |
||||||
|
uint8_t *t = (uint8_t*)&data; |
||||||
|
unsigned long base = flash->start[0]; |
||||||
|
uint32_t msr; |
||||||
|
|
||||||
|
if (flash->flash_id == FLASH_UNKNOWN) |
||||||
|
return 4; |
||||||
|
|
||||||
|
if (cnt == 0) |
||||||
|
return 0; |
||||||
|
|
||||||
|
addr -= base; |
||||||
|
|
||||||
|
msr = get_msr(); |
||||||
|
set_msr(msr|MSR_FP); |
||||||
|
|
||||||
|
wp = (addr & ~7); /* get lower word aligned address */ |
||||||
|
|
||||||
|
if((addr-wp) != 0) { |
||||||
|
data = cfi_read(flash, wp); |
||||||
|
s = addr & 7; |
||||||
|
l = ( cnt < (8-s) ) ? cnt : (8-s); |
||||||
|
for(i = 0; i < l; i++) |
||||||
|
t[s+i] = *src++; |
||||||
|
if ((rc = write_dword(flash, wp, data)) != 0) |
||||||
|
goto DONE; |
||||||
|
wp += 8; |
||||||
|
cnt -= l; |
||||||
|
} |
||||||
|
|
||||||
|
while (cnt >= 8) { |
||||||
|
for (i = 0; i < 8; i++) |
||||||
|
t[i] = *src++; |
||||||
|
if ((rc = write_dword(flash, wp, data)) != 0) |
||||||
|
goto DONE; |
||||||
|
wp += 8; |
||||||
|
cnt -= 8; |
||||||
|
} |
||||||
|
|
||||||
|
if (cnt == 0) { |
||||||
|
rc = 0; |
||||||
|
goto DONE; |
||||||
|
} |
||||||
|
|
||||||
|
data = cfi_read(flash, wp); |
||||||
|
for(i = 0; i < cnt; i++) |
||||||
|
t[i] = *src++; |
||||||
|
rc = write_dword(flash, wp, data); |
||||||
|
DONE: |
||||||
|
set_msr(msr); |
||||||
|
return rc; |
||||||
|
} |
||||||
|
|
||||||
|
static int cfi_erase_oneblock(flash_info_t *flash, uint32_t sect) |
||||||
|
{ |
||||||
|
int sa; |
||||||
|
int flag; |
||||||
|
ulong start, last, now; |
||||||
|
cfi_word status; |
||||||
|
|
||||||
|
flag = disable_interrupts(); |
||||||
|
|
||||||
|
sa = (flash->start[sect] - flash->start[0]); |
||||||
|
write32(flash->start[sect], 0x00200020); |
||||||
|
write32(flash->start[sect], 0x00d000d0); |
||||||
|
|
||||||
|
if (flag) |
||||||
|
enable_interrupts(); |
||||||
|
|
||||||
|
udelay(1000); |
||||||
|
start = get_timer (0); |
||||||
|
last = start; |
||||||
|
|
||||||
|
for (;;) { |
||||||
|
status = cfi_read(flash, sa); |
||||||
|
status &= CMD(0x80); |
||||||
|
if (status == CMD(0x80)) |
||||||
|
break; |
||||||
|
if ((now = get_timer(start)) > CFG_FLASH_ERASE_TOUT) { |
||||||
|
cfi_cmd(flash, 0xff, 0); |
||||||
|
printf ("Timeout\n"); |
||||||
|
return ERR_TIMOUT; |
||||||
|
} |
||||||
|
|
||||||
|
if ((now - last) > 1000) { |
||||||
|
serial_putc ('.'); |
||||||
|
last = now; |
||||||
|
} |
||||||
|
udelay(10); |
||||||
|
} |
||||||
|
cfi_cmd(flash, 0xff, 0); |
||||||
|
return ERR_OK; |
||||||
|
} |
||||||
|
|
||||||
|
static int cfi_erase(flash_info_t *flash, uint32_t s_first, uint32_t s_last) |
||||||
|
{ |
||||||
|
int sect; |
||||||
|
int rc = ERR_OK; |
||||||
|
|
||||||
|
for (sect = s_first; sect <= s_last; sect++) { |
||||||
|
if (flash->protect[sect] == 0) { |
||||||
|
rc = cfi_erase_oneblock(flash, sect); |
||||||
|
if (rc != ERR_OK) break; |
||||||
|
} |
||||||
|
} |
||||||
|
printf (" done\n"); |
||||||
|
return rc; |
||||||
|
} |
||||||
|
|
||||||
|
static int jedec_erase(flash_info_t *flash, uint32_t s_first, uint32_t s_last) |
||||||
|
{ |
||||||
|
int sect; |
||||||
|
cfi_word status; |
||||||
|
int sa = -1; |
||||||
|
int flag; |
||||||
|
ulong start, last, now; |
||||||
|
|
||||||
|
flag = disable_interrupts(); |
||||||
|
|
||||||
|
cfi_cmd(flash, 0xaa, 0x555); |
||||||
|
cfi_cmd(flash, 0x55, 0x2aa); |
||||||
|
cfi_cmd(flash, 0x80, 0x555); |
||||||
|
cfi_cmd(flash, 0xaa, 0x555); |
||||||
|
cfi_cmd(flash, 0x55, 0x2aa); |
||||||
|
for ( sect = s_first; sect <= s_last; sect++) { |
||||||
|
if (flash->protect[sect] == 0) { |
||||||
|
sa = flash->start[sect] - flash->start[0]; |
||||||
|
write32(flash->start[sect], 0x00300030); |
||||||
|
} |
||||||
|
} |
||||||
|
if (flag) |
||||||
|
enable_interrupts(); |
||||||
|
|
||||||
|
if (sa < 0) |
||||||
|
goto DONE; |
||||||
|
|
||||||
|
udelay (1000); |
||||||
|
start = get_timer (0); |
||||||
|
last = start; |
||||||
|
for(;;) { |
||||||
|
status = cfi_read(flash, sa); |
||||||
|
if (status == CMD(0xffff)) |
||||||
|
break; |
||||||
|
|
||||||
|
if ((now = get_timer(start)) > CFG_FLASH_ERASE_TOUT) { |
||||||
|
printf ("Timeout\n"); |
||||||
|
return ERR_TIMOUT; |
||||||
|
} |
||||||
|
|
||||||
|
if ((now - last) > 1000) { |
||||||
|
serial_putc ('.'); |
||||||
|
last = now; |
||||||
|
} |
||||||
|
udelay(10); |
||||||
|
} |
||||||
|
DONE: |
||||||
|
cfi_cmd(flash, 0xf0, 0); |
||||||
|
|
||||||
|
printf (" done\n"); |
||||||
|
|
||||||
|
return ERR_OK; |
||||||
|
} |
||||||
|
|
||||||
|
int flash_erase (flash_info_t *flash, int s_first, int s_last) |
||||||
|
{ |
||||||
|
int sect; |
||||||
|
int prot; |
||||||
|
|
||||||
|
if ((s_first < 0) || (s_first > s_last)) { |
||||||
|
if (flash->flash_id == FLASH_UNKNOWN) |
||||||
|
printf ("- missing\n"); |
||||||
|
else |
||||||
|
printf ("- no sectors to erase\n"); |
||||||
|
return ERR_NOT_ERASED; |
||||||
|
} |
||||||
|
if (flash->flash_id == FLASH_UNKNOWN) { |
||||||
|
printf ("Can't erase unknown flash type - aborted\n"); |
||||||
|
return ERR_NOT_ERASED; |
||||||
|
} |
||||||
|
|
||||||
|
prot = 0; |
||||||
|
for (sect = s_first; sect <= s_last; sect++) |
||||||
|
if (flash->protect[sect]) prot++; |
||||||
|
|
||||||
|
if (prot) |
||||||
|
printf ("- Warning: %d protected sectors will not be erased!\n", |
||||||
|
prot); |
||||||
|
else |
||||||
|
printf ("\n"); |
||||||
|
|
||||||
|
return do_flash_erase(flash, s_first, s_last); |
||||||
|
} |
||||||
|
|
||||||
|
struct jedec_flash_info { |
||||||
|
const uint16_t mfr_id; |
||||||
|
const uint16_t dev_id; |
||||||
|
const char *name; |
||||||
|
const int DevSize; |
||||||
|
const int InterfaceDesc; |
||||||
|
const int NumEraseRegions; |
||||||
|
const ulong regions[4]; |
||||||
|
}; |
||||||
|
|
||||||
|
#define ERASEINFO(size,blocks) (size<<8)|(blocks-1) |
||||||
|
|
||||||
|
#define SIZE_1MiB 20 |
||||||
|
#define SIZE_2MiB 21 |
||||||
|
#define SIZE_4MiB 22 |
||||||
|
|
||||||
|
static const struct jedec_flash_info jedec_table[] = { |
||||||
|
{ |
||||||
|
mfr_id: (uint16_t)AMD_MANUFACT, |
||||||
|
dev_id: (uint16_t)AMD_ID_LV800T, |
||||||
|
name: "AMD AM29LV800T", |
||||||
|
DevSize: SIZE_1MiB, |
||||||
|
NumEraseRegions: 4, |
||||||
|
regions: {ERASEINFO(0x10000,15), |
||||||
|
ERASEINFO(0x08000,1), |
||||||
|
ERASEINFO(0x02000,2), |
||||||
|
ERASEINFO(0x04000,1) |
||||||
|
} |
||||||
|
}, { |
||||||
|
mfr_id: (uint16_t)AMD_MANUFACT, |
||||||
|
dev_id: (uint16_t)AMD_ID_LV800B, |
||||||
|
name: "AMD AM29LV800B", |
||||||
|
DevSize: SIZE_1MiB, |
||||||
|
NumEraseRegions: 4, |
||||||
|
regions: {ERASEINFO(0x10000,15), |
||||||
|
ERASEINFO(0x08000,1), |
||||||
|
ERASEINFO(0x02000,2), |
||||||
|
ERASEINFO(0x04000,1) |
||||||
|
} |
||||||
|
}, { |
||||||
|
mfr_id: (uint16_t)AMD_MANUFACT, |
||||||
|
dev_id: (uint16_t)AMD_ID_LV160T, |
||||||
|
name: "AMD AM29LV160T", |
||||||
|
DevSize: SIZE_2MiB, |
||||||
|
NumEraseRegions: 4, |
||||||
|
regions: {ERASEINFO(0x10000,31), |
||||||
|
ERASEINFO(0x08000,1), |
||||||
|
ERASEINFO(0x02000,2), |
||||||
|
ERASEINFO(0x04000,1) |
||||||
|
} |
||||||
|
}, { |
||||||
|
mfr_id: (uint16_t)AMD_MANUFACT, |
||||||
|
dev_id: (uint16_t)AMD_ID_LV160B, |
||||||
|
name: "AMD AM29LV160B", |
||||||
|
DevSize: SIZE_2MiB, |
||||||
|
NumEraseRegions: 4, |
||||||
|
regions: {ERASEINFO(0x04000,1), |
||||||
|
ERASEINFO(0x02000,2), |
||||||
|
ERASEINFO(0x08000,1), |
||||||
|
ERASEINFO(0x10000,31) |
||||||
|
} |
||||||
|
}, { |
||||||
|
mfr_id: (uint16_t)AMD_MANUFACT, |
||||||
|
dev_id: (uint16_t)AMD_ID_LV320T, |
||||||
|
name: "AMD AM29LV320T", |
||||||
|
DevSize: SIZE_4MiB, |
||||||
|
NumEraseRegions: 2, |
||||||
|
regions: {ERASEINFO(0x10000,63), |
||||||
|
ERASEINFO(0x02000,8) |
||||||
|
} |
||||||
|
|
||||||
|
}, { |
||||||
|
mfr_id: (uint16_t)AMD_MANUFACT, |
||||||
|
dev_id: (uint16_t)AMD_ID_LV320B, |
||||||
|
name: "AMD AM29LV320B", |
||||||
|
DevSize: SIZE_4MiB, |
||||||
|
NumEraseRegions: 2, |
||||||
|
regions: {ERASEINFO(0x02000,8), |
||||||
|
ERASEINFO(0x10000,63) |
||||||
|
} |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
static ulong cfi_init(uint32_t base, flash_info_t *flash) |
||||||
|
{ |
||||||
|
int sector; |
||||||
|
int block; |
||||||
|
int block_count; |
||||||
|
int offset = 0; |
||||||
|
int reverse = 0; |
||||||
|
int primary; |
||||||
|
int mfr_id; |
||||||
|
int dev_id; |
||||||
|
|
||||||
|
flash->start[0] = base; |
||||||
|
cfi_cmd(flash, 0xF0, 0); |
||||||
|
cfi_cmd(flash, 0x98, 0); |
||||||
|
if ( !( cfi_read_query(flash, 0x10) == 'Q' && |
||||||
|
cfi_read_query(flash, 0x11) == 'R' && |
||||||
|
cfi_read_query(flash, 0x12) == 'Y' )) { |
||||||
|
cfi_cmd(flash, 0xff, 0); |
||||||
|
return 0; |
||||||
|
} |
||||||
|
|
||||||
|
flash->size = 1 << cfi_read_query(flash, 0x27); |
||||||
|
flash->size *= 4; |
||||||
|
block_count = cfi_read_query(flash, 0x2c); |
||||||
|
primary = cfi_read_query(flash, 0x15); |
||||||
|
if ( cfi_read_query(flash, primary + 4) == 0x30) |
||||||
|
reverse = (cfi_read_query(flash, 0x1) & 0x01); |
||||||
|
else |
||||||
|
reverse = (cfi_read_query(flash, primary+15) == 3); |
||||||
|
|
||||||
|
flash->sector_count = 0; |
||||||
|
|
||||||
|
for ( block = reverse ? block_count - 1 : 0; |
||||||
|
reverse ? block >= 0 : block < block_count; |
||||||
|
reverse ? block-- : block ++) { |
||||||
|
int sector_size = |
||||||
|
(cfi_read_query(flash, 0x2d + block*4+2) | |
||||||
|
(cfi_read_query(flash, 0x2d + block*4+3) << 8)) << 8; |
||||||
|
int sector_count = |
||||||
|
(cfi_read_query(flash, 0x2d + block*4+0) | |
||||||
|
(cfi_read_query(flash, 0x2d + block*4+1) << 8)) + 1; |
||||||
|
for(sector = 0; sector < sector_count; sector++) { |
||||||
|
flash->start[flash->sector_count++] = base + offset; |
||||||
|
offset += sector_size * 4; |
||||||
|
} |
||||||
|
} |
||||||
|
mfr_id = cfi_read_query(flash, 0x00); |
||||||
|
dev_id = cfi_read_query(flash, 0x01); |
||||||
|
|
||||||
|
cfi_cmd(flash, 0xff, 0); |
||||||
|
|
||||||
|
flash->flash_id = (mfr_id << 16) | dev_id; |
||||||
|
|
||||||
|
for (sector = 0; sector < flash->sector_count; sector++) { |
||||||
|
write32(flash->start[sector], 0x00600060); |
||||||
|
write32(flash->start[sector], 0x00d000d0); |
||||||
|
} |
||||||
|
cfi_cmd(flash, 0xff, 0); |
||||||
|
|
||||||
|
for (sector = 0; sector < flash->sector_count; sector++) |
||||||
|
flash->protect[sector] = 0; |
||||||
|
|
||||||
|
do_flash_erase = cfi_erase; |
||||||
|
write_dword = cfi_write_dword; |
||||||
|
|
||||||
|
return flash->size; |
||||||
|
} |
||||||
|
|
||||||
|
static ulong jedec_init(unsigned long base, flash_info_t *flash) |
||||||
|
{ |
||||||
|
int i; |
||||||
|
int block, block_count; |
||||||
|
int sector, offset; |
||||||
|
int mfr_id, dev_id; |
||||||
|
flash->start[0] = base; |
||||||
|
cfi_cmd(flash, 0xF0, 0x000); |
||||||
|
cfi_cmd(flash, 0xAA, 0x555); |
||||||
|
cfi_cmd(flash, 0x55, 0x2AA); |
||||||
|
cfi_cmd(flash, 0x90, 0x555); |
||||||
|
mfr_id = cfi_read_query(flash, 0x000); |
||||||
|
dev_id = cfi_read_query(flash, 0x0001); |
||||||
|
cfi_cmd(flash, 0xf0, 0x000); |
||||||
|
|
||||||
|
for(i=0; i<sizeof(jedec_table)/sizeof(struct jedec_flash_info); i++) { |
||||||
|
if((jedec_table[i].mfr_id == mfr_id) && |
||||||
|
(jedec_table[i].dev_id == dev_id)) { |
||||||
|
|
||||||
|
flash->flash_id = (mfr_id << 16) | dev_id; |
||||||
|
flash->size = 1 << jedec_table[0].DevSize; |
||||||
|
flash->size *= 4; |
||||||
|
block_count = jedec_table[i].NumEraseRegions; |
||||||
|
offset = 0; |
||||||
|
flash->sector_count = 0; |
||||||
|
for (block = 0; block < block_count; block++) { |
||||||
|
int sector_size = jedec_table[i].regions[block]; |
||||||
|
int sector_count = (sector_size & 0xff) + 1; |
||||||
|
sector_size >>= 8; |
||||||
|
for (sector=0; sector<sector_count; sector++) { |
||||||
|
flash->start[flash->sector_count++] = |
||||||
|
base + offset; |
||||||
|
offset += sector_size * 4; |
||||||
|
} |
||||||
|
} |
||||||
|
break; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
for (sector = 0; sector < flash->sector_count; sector++) |
||||||
|
flash->protect[sector] = 0; |
||||||
|
|
||||||
|
do_flash_erase = jedec_erase; |
||||||
|
write_dword = jedec_write_dword; |
||||||
|
|
||||||
|
return flash->size; |
||||||
|
} |
||||||
|
|
||||||
|
inline void mtibat1u(unsigned int x) |
||||||
|
{ |
||||||
|
__asm__ __volatile__ ("mtspr 530, %0" :: "r" (x)); |
||||||
|
} |
||||||
|
|
||||||
|
inline void mtibat1l(unsigned int x) |
||||||
|
{ |
||||||
|
__asm__ __volatile__ ("mtspr 531, %0" :: "r" (x)); |
||||||
|
} |
||||||
|
|
||||||
|
inline void mtdbat1u(unsigned int x) |
||||||
|
{ |
||||||
|
__asm__ __volatile__ ("mtspr 538, %0" :: "r" (x)); |
||||||
|
} |
||||||
|
|
||||||
|
inline void mtdbat1l(unsigned int x) |
||||||
|
{ |
||||||
|
__asm__ __volatile__ ("mtspr 539, %0" :: "r" (x)); |
||||||
|
} |
||||||
|
|
||||||
|
unsigned long flash_init (void) |
||||||
|
{ |
||||||
|
unsigned long size = 0; |
||||||
|
int i; |
||||||
|
unsigned int msr; |
||||||
|
|
||||||
|
/* BAT1 */ |
||||||
|
CONFIG_WRITE_WORD(ERCR3, 0x0C00000C); |
||||||
|
CONFIG_WRITE_WORD(ERCR4, 0x0800000C); |
||||||
|
msr = get_msr(); |
||||||
|
set_msr(msr & ~(MSR_IR | MSR_DR)); |
||||||
|
mtibat1l(0x70000000 | BATL_PP_10 | BATL_CACHEINHIBIT); |
||||||
|
mtibat1u(0x70000000 | BATU_BL_256M | BATU_VS | BATU_VP); |
||||||
|
mtdbat1l(0x70000000 | BATL_PP_10 | BATL_CACHEINHIBIT); |
||||||
|
mtdbat1u(0x70000000 | BATU_BL_256M | BATU_VS | BATU_VP); |
||||||
|
set_msr(msr); |
||||||
|
|
||||||
|
for (i = 0; i < CFG_MAX_FLASH_BANKS; i++) |
||||||
|
flash_info[i].flash_id = FLASH_UNKNOWN; |
||||||
|
size = cfi_init(FLASH_BASE0_PRELIM, &flash_info[0]); |
||||||
|
if (!size) |
||||||
|
size = jedec_init(FLASH_BASE0_PRELIM, &flash_info[0]); |
||||||
|
|
||||||
|
if (flash_info[0].flash_id == FLASH_UNKNOWN) |
||||||
|
printf ("# Unknown FLASH on Bank 1 - Size = 0x%08lx = %ld MB\n", |
||||||
|
size, size<<20); |
||||||
|
|
||||||
|
return size; |
||||||
|
} |
||||||
|
|
||||||
|
void flash_print_info (flash_info_t *flash) |
||||||
|
{ |
||||||
|
int i; |
||||||
|
int k; |
||||||
|
int size; |
||||||
|
int erased; |
||||||
|
volatile unsigned long *p; |
||||||
|
|
||||||
|
if (flash->flash_id == FLASH_UNKNOWN) { |
||||||
|
printf ("missing or unknown FLASH type\n"); |
||||||
|
flash_init(); |
||||||
|
} |
||||||
|
|
||||||
|
if (flash->flash_id == FLASH_UNKNOWN) { |
||||||
|
printf ("missing or unknown FLASH type\n"); |
||||||
|
return; |
||||||
|
} |
||||||
|
|
||||||
|
switch (((flash->flash_id) >> 16) & 0xff) { |
||||||
|
case 0x01: |
||||||
|
printf ("AMD "); |
||||||
|
break; |
||||||
|
case 0x04: |
||||||
|
printf("FUJITSU "); |
||||||
|
break; |
||||||
|
case 0x20: |
||||||
|
printf("STM "); |
||||||
|
break; |
||||||
|
case 0xBF: |
||||||
|
printf("SST "); |
||||||
|
break; |
||||||
|
case 0x89: |
||||||
|
case 0xB0: |
||||||
|
printf("INTEL "); |
||||||
|
break; |
||||||
|
default: |
||||||
|
printf ("Unknown Vendor "); |
||||||
|
break; |
||||||
|
} |
||||||
|
|
||||||
|
switch ((flash->flash_id) & 0xffff) { |
||||||
|
case (uint16_t)AMD_ID_LV800T: |
||||||
|
printf ("AM29LV800T\n"); |
||||||
|
break; |
||||||
|
case (uint16_t)AMD_ID_LV800B: |
||||||
|
printf ("AM29LV800B\n"); |
||||||
|
break; |
||||||
|
case (uint16_t)AMD_ID_LV160T: |
||||||
|
printf ("AM29LV160T\n"); |
||||||
|
break; |
||||||
|
case (uint16_t)AMD_ID_LV160B: |
||||||
|
printf ("AM29LV160B\n"); |
||||||
|
break; |
||||||
|
case (uint16_t)AMD_ID_LV320T: |
||||||
|
printf ("AM29LV320T\n"); |
||||||
|
break; |
||||||
|
case (uint16_t)AMD_ID_LV320B: |
||||||
|
printf ("AM29LV320B\n"); |
||||||
|
break; |
||||||
|
case (uint16_t)INTEL_ID_28F800C3T: |
||||||
|
printf ("28F800C3T\n"); |
||||||
|
break; |
||||||
|
case (uint16_t)INTEL_ID_28F800C3B: |
||||||
|
printf ("28F800C3B\n"); |
||||||
|
break; |
||||||
|
case (uint16_t)INTEL_ID_28F160C3T: |
||||||
|
printf ("28F160C3T\n"); |
||||||
|
break; |
||||||
|
case (uint16_t)INTEL_ID_28F160C3B: |
||||||
|
printf ("28F160C3B\n"); |
||||||
|
break; |
||||||
|
case (uint16_t)INTEL_ID_28F320C3T: |
||||||
|
printf ("28F320C3T\n"); |
||||||
|
break; |
||||||
|
case (uint16_t)INTEL_ID_28F320C3B: |
||||||
|
printf ("28F320C3B\n"); |
||||||
|
break; |
||||||
|
case (uint16_t)INTEL_ID_28F640C3T: |
||||||
|
printf ("28F640C3T\n"); |
||||||
|
break; |
||||||
|
case (uint16_t)INTEL_ID_28F640C3B: |
||||||
|
printf ("28F640C3B\n"); |
||||||
|
break; |
||||||
|
default: |
||||||
|
printf ("Unknown Chip Type\n"); |
||||||
|
break; |
||||||
|
} |
||||||
|
|
||||||
|
if (flash->size >= (1 << 20)) { |
||||||
|
printf (" Size: %ld MB in %d Sectors\n", |
||||||
|
flash->size >> 20, flash->sector_count); |
||||||
|
} else { |
||||||
|
printf (" Size: %ld kB in %d Sectors\n", |
||||||
|
flash->size >> 10, flash->sector_count); |
||||||
|
} |
||||||
|
|
||||||
|
printf (" Sector Start Addresses:"); |
||||||
|
for (i = 0; i < flash->sector_count; ++i) { |
||||||
|
/* Check if whole sector is erased*/ |
||||||
|
if (i != (flash->sector_count-1)) |
||||||
|
size = flash->start[i+1] - flash->start[i]; |
||||||
|
else |
||||||
|
size = flash->start[0] + flash->size - flash->start[i]; |
||||||
|
|
||||||
|
erased = 1; |
||||||
|
p = (volatile unsigned long *)flash->start[i]; |
||||||
|
size = size >> 2; /* divide by 4 for longword access */ |
||||||
|
for (k=0; k<size; k++) { |
||||||
|
if (*p++ != 0xffffffff) { |
||||||
|
erased = 0; |
||||||
|
break; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
if ((i % 5) == 0) |
||||||
|
printf ("\n "); |
||||||
|
|
||||||
|
printf (" %08lX%s%s", |
||||||
|
flash->start[i], |
||||||
|
erased ? " E" : " ", |
||||||
|
flash->protect[i] ? "RO " : " "); |
||||||
|
} |
||||||
|
printf ("\n"); |
||||||
|
} |
@ -0,0 +1,310 @@ |
|||||||
|
/*
|
||||||
|
* board/eva/phantom.c |
||||||
|
* |
||||||
|
* Phantom RTC device driver for EVA |
||||||
|
* |
||||||
|
* Author: Sangmoon Kim |
||||||
|
* dogoil@etinsys.com |
||||||
|
* |
||||||
|
* Copyright 2002 Etinsys Inc. |
||||||
|
* |
||||||
|
* This program is free software; you can redistribute it and/or modify it |
||||||
|
* under the terms of the GNU General Public License as published by the |
||||||
|
* Free Software Foundation; either version 2 of the License, or (at your |
||||||
|
* option) any later version. |
||||||
|
*/ |
||||||
|
|
||||||
|
#include <common.h> |
||||||
|
#include <command.h> |
||||||
|
#include <rtc.h> |
||||||
|
|
||||||
|
#if (CONFIG_COMMANDS & CFG_CMD_DATE) |
||||||
|
|
||||||
|
#define RTC_BASE (CFG_NVRAM_BASE_ADDR + 0x7fff8) |
||||||
|
|
||||||
|
#define RTC_YEAR ( RTC_BASE + 7 ) |
||||||
|
#define RTC_MONTH ( RTC_BASE + 6 ) |
||||||
|
#define RTC_DAY_OF_MONTH ( RTC_BASE + 5 ) |
||||||
|
#define RTC_DAY_OF_WEEK ( RTC_BASE + 4 ) |
||||||
|
#define RTC_HOURS ( RTC_BASE + 3 ) |
||||||
|
#define RTC_MINUTES ( RTC_BASE + 2 ) |
||||||
|
#define RTC_SECONDS ( RTC_BASE + 1 ) |
||||||
|
#define RTC_CENTURY ( RTC_BASE + 0 ) |
||||||
|
|
||||||
|
#define RTC_CONTROLA RTC_CENTURY |
||||||
|
#define RTC_CONTROLB RTC_SECONDS |
||||||
|
#define RTC_CONTROLC RTC_DAY_OF_WEEK |
||||||
|
|
||||||
|
#define RTC_CA_WRITE 0x80 |
||||||
|
#define RTC_CA_READ 0x40 |
||||||
|
|
||||||
|
#define RTC_CB_OSC_DISABLE 0x80 |
||||||
|
|
||||||
|
#define RTC_CC_BATTERY_FLAG 0x80 |
||||||
|
#define RTC_CC_FREQ_TEST 0x40 |
||||||
|
|
||||||
|
|
||||||
|
static int phantom_flag = -1; |
||||||
|
static int century_flag = -1; |
||||||
|
|
||||||
|
static uchar rtc_read(unsigned int addr) |
||||||
|
{ |
||||||
|
return *(volatile unsigned char *)(addr); |
||||||
|
} |
||||||
|
|
||||||
|
static void rtc_write(unsigned int addr, uchar val) |
||||||
|
{ |
||||||
|
*(volatile unsigned char *)(addr) = val; |
||||||
|
} |
||||||
|
|
||||||
|
static unsigned char phantom_rtc_sequence[] = { |
||||||
|
0xc5, 0x3a, 0xa3, 0x5c, 0xc5, 0x3a, 0xa3, 0x5c |
||||||
|
}; |
||||||
|
|
||||||
|
static unsigned char* phantom_rtc_read(int addr, unsigned char rtc[8]) |
||||||
|
{ |
||||||
|
int i, j; |
||||||
|
unsigned char v; |
||||||
|
unsigned char save = rtc_read(addr); |
||||||
|
|
||||||
|
for (j = 0; j < 8; j++) { |
||||||
|
v = phantom_rtc_sequence[j]; |
||||||
|
for (i = 0; i < 8; i++) { |
||||||
|
rtc_write(addr, v & 1); |
||||||
|
v >>= 1; |
||||||
|
} |
||||||
|
} |
||||||
|
for (j = 0; j < 8; j++) { |
||||||
|
v = 0; |
||||||
|
for (i = 0; i < 8; i++) { |
||||||
|
if(rtc_read(addr) & 1) |
||||||
|
v |= 1 << i; |
||||||
|
} |
||||||
|
rtc[j] = v; |
||||||
|
} |
||||||
|
rtc_write(addr, save); |
||||||
|
return rtc; |
||||||
|
} |
||||||
|
|
||||||
|
static void phantom_rtc_write(int addr, unsigned char rtc[8]) |
||||||
|
{ |
||||||
|
int i, j; |
||||||
|
unsigned char v; |
||||||
|
unsigned char save = rtc_read(addr); |
||||||
|
for (j = 0; j < 8; j++) { |
||||||
|
v = phantom_rtc_sequence[j]; |
||||||
|
for (i = 0; i < 8; i++) { |
||||||
|
rtc_write(addr, v & 1); |
||||||
|
v >>= 1; |
||||||
|
} |
||||||
|
} |
||||||
|
for (j = 0; j < 8; j++) { |
||||||
|
v = rtc[j]; |
||||||
|
for (i = 0; i < 8; i++) { |
||||||
|
rtc_write(addr, v & 1); |
||||||
|
v >>= 1; |
||||||
|
} |
||||||
|
} |
||||||
|
rtc_write(addr, save); |
||||||
|
} |
||||||
|
|
||||||
|
static int get_phantom_flag(void) |
||||||
|
{ |
||||||
|
int i; |
||||||
|
unsigned char rtc[8]; |
||||||
|
|
||||||
|
phantom_rtc_read(RTC_BASE, rtc); |
||||||
|
|
||||||
|
for(i = 1; i < 8; i++) { |
||||||
|
if (rtc[i] != rtc[0]) |
||||||
|
return 1; |
||||||
|
} |
||||||
|
return 0; |
||||||
|
} |
||||||
|
|
||||||
|
void rtc_reset(void) |
||||||
|
{ |
||||||
|
if (phantom_flag < 0) |
||||||
|
phantom_flag = get_phantom_flag(); |
||||||
|
|
||||||
|
if (phantom_flag) { |
||||||
|
unsigned char rtc[8]; |
||||||
|
phantom_rtc_read(RTC_BASE, rtc); |
||||||
|
if(rtc[4] & 0x30) { |
||||||
|
printf( "real-time-clock was stopped. Now starting...\n" ); |
||||||
|
rtc[4] &= 0x07; |
||||||
|
phantom_rtc_write(RTC_BASE, rtc); |
||||||
|
} |
||||||
|
} else { |
||||||
|
uchar reg_a, reg_b, reg_c; |
||||||
|
reg_a = rtc_read( RTC_CONTROLA ); |
||||||
|
reg_b = rtc_read( RTC_CONTROLB ); |
||||||
|
|
||||||
|
if ( reg_b & RTC_CB_OSC_DISABLE ) |
||||||
|
{ |
||||||
|
printf( "real-time-clock was stopped. Now starting...\n" ); |
||||||
|
reg_a |= RTC_CA_WRITE; |
||||||
|
reg_b &= ~RTC_CB_OSC_DISABLE; |
||||||
|
rtc_write( RTC_CONTROLA, reg_a ); |
||||||
|
rtc_write( RTC_CONTROLB, reg_b ); |
||||||
|
} |
||||||
|
|
||||||
|
/* make sure read/write clock register bits are cleared */ |
||||||
|
reg_a &= ~( RTC_CA_WRITE | RTC_CA_READ ); |
||||||
|
rtc_write( RTC_CONTROLA, reg_a ); |
||||||
|
|
||||||
|
reg_c = rtc_read( RTC_CONTROLC ); |
||||||
|
if (( reg_c & RTC_CC_BATTERY_FLAG ) == 0 ) |
||||||
|
printf( "RTC battery low. Clock setting may not be reliable.\n"); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
inline unsigned bcd2bin (uchar n) |
||||||
|
{ |
||||||
|
return ((((n >> 4) & 0x0F) * 10) + (n & 0x0F)); |
||||||
|
} |
||||||
|
|
||||||
|
inline unsigned char bin2bcd (unsigned int n) |
||||||
|
{ |
||||||
|
return (((n / 10) << 4) | (n % 10)); |
||||||
|
} |
||||||
|
|
||||||
|
static int get_century_flag(void) |
||||||
|
{ |
||||||
|
int flag = 0; |
||||||
|
int bcd, century; |
||||||
|
bcd = rtc_read( RTC_CENTURY ); |
||||||
|
century = bcd2bin( bcd & 0x3F ); |
||||||
|
rtc_write( RTC_CENTURY, bin2bcd(century+1)); |
||||||
|
if (bcd == rtc_read( RTC_CENTURY )) |
||||||
|
flag = 1; |
||||||
|
rtc_write( RTC_CENTURY, bcd); |
||||||
|
return flag; |
||||||
|
} |
||||||
|
|
||||||
|
void rtc_get( struct rtc_time *tmp) |
||||||
|
{ |
||||||
|
if (phantom_flag < 0) |
||||||
|
phantom_flag = get_phantom_flag(); |
||||||
|
|
||||||
|
if (phantom_flag) |
||||||
|
{ |
||||||
|
unsigned char rtc[8]; |
||||||
|
|
||||||
|
phantom_rtc_read(RTC_BASE, rtc); |
||||||
|
|
||||||
|
tmp->tm_sec = bcd2bin(rtc[1] & 0x7f); |
||||||
|
tmp->tm_min = bcd2bin(rtc[2] & 0x7f); |
||||||
|
tmp->tm_hour = bcd2bin(rtc[3] & 0x1f); |
||||||
|
tmp->tm_wday = bcd2bin(rtc[4] & 0x7); |
||||||
|
tmp->tm_mday = bcd2bin(rtc[5] & 0x3f); |
||||||
|
tmp->tm_mon = bcd2bin(rtc[6] & 0x1f); |
||||||
|
tmp->tm_year = bcd2bin(rtc[7]) + 1900; |
||||||
|
tmp->tm_yday = 0; |
||||||
|
tmp->tm_isdst = 0; |
||||||
|
|
||||||
|
if( (rtc[3] & 0x80) && (rtc[3] & 0x40) ) tmp->tm_hour += 12; |
||||||
|
if (tmp->tm_year < 1970) tmp->tm_year += 100; |
||||||
|
} else { |
||||||
|
uchar sec, min, hour; |
||||||
|
uchar mday, wday, mon, year; |
||||||
|
|
||||||
|
int century; |
||||||
|
|
||||||
|
uchar reg_a; |
||||||
|
|
||||||
|
if (century_flag < 0) |
||||||
|
century_flag = get_century_flag(); |
||||||
|
|
||||||
|
reg_a = rtc_read( RTC_CONTROLA ); |
||||||
|
/* lock clock registers for read */ |
||||||
|
rtc_write( RTC_CONTROLA, ( reg_a | RTC_CA_READ )); |
||||||
|
|
||||||
|
sec = rtc_read( RTC_SECONDS ); |
||||||
|
min = rtc_read( RTC_MINUTES ); |
||||||
|
hour = rtc_read( RTC_HOURS ); |
||||||
|
mday = rtc_read( RTC_DAY_OF_MONTH ); |
||||||
|
wday = rtc_read( RTC_DAY_OF_WEEK ); |
||||||
|
mon = rtc_read( RTC_MONTH ); |
||||||
|
year = rtc_read( RTC_YEAR ); |
||||||
|
century = rtc_read( RTC_CENTURY ); |
||||||
|
|
||||||
|
/* unlock clock registers after read */ |
||||||
|
rtc_write( RTC_CONTROLA, ( reg_a & ~RTC_CA_READ )); |
||||||
|
|
||||||
|
tmp->tm_sec = bcd2bin( sec & 0x7F ); |
||||||
|
tmp->tm_min = bcd2bin( min & 0x7F ); |
||||||
|
tmp->tm_hour = bcd2bin( hour & 0x3F ); |
||||||
|
tmp->tm_mday = bcd2bin( mday & 0x3F ); |
||||||
|
tmp->tm_mon = bcd2bin( mon & 0x1F ); |
||||||
|
tmp->tm_wday = bcd2bin( wday & 0x07 ); |
||||||
|
|
||||||
|
if (century_flag) { |
||||||
|
tmp->tm_year = bcd2bin( year ) + |
||||||
|
( bcd2bin( century & 0x3F ) * 100 ); |
||||||
|
} else { |
||||||
|
tmp->tm_year = bcd2bin( year ) + 1900; |
||||||
|
if (tmp->tm_year < 1970) tmp->tm_year += 100; |
||||||
|
} |
||||||
|
|
||||||
|
tmp->tm_yday = 0; |
||||||
|
tmp->tm_isdst= 0; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
void rtc_set( struct rtc_time *tmp ) |
||||||
|
{ |
||||||
|
if (phantom_flag < 0) |
||||||
|
phantom_flag = get_phantom_flag(); |
||||||
|
|
||||||
|
if (phantom_flag) { |
||||||
|
uint year; |
||||||
|
unsigned char rtc[8]; |
||||||
|
|
||||||
|
year = tmp->tm_year; |
||||||
|
year -= (year < 2000) ? 1900 : 2000; |
||||||
|
|
||||||
|
rtc[0] = bin2bcd(0); |
||||||
|
rtc[1] = bin2bcd(tmp->tm_sec); |
||||||
|
rtc[2] = bin2bcd(tmp->tm_min); |
||||||
|
rtc[3] = bin2bcd(tmp->tm_hour); |
||||||
|
rtc[4] = bin2bcd(tmp->tm_wday); |
||||||
|
rtc[5] = bin2bcd(tmp->tm_mday); |
||||||
|
rtc[6] = bin2bcd(tmp->tm_mon); |
||||||
|
rtc[7] = bin2bcd(year); |
||||||
|
|
||||||
|
phantom_rtc_write(RTC_BASE, rtc); |
||||||
|
} else { |
||||||
|
uchar reg_a; |
||||||
|
if (century_flag < 0) |
||||||
|
century_flag = get_century_flag(); |
||||||
|
|
||||||
|
/* lock clock registers for write */ |
||||||
|
reg_a = rtc_read( RTC_CONTROLA ); |
||||||
|
rtc_write( RTC_CONTROLA, ( reg_a | RTC_CA_WRITE )); |
||||||
|
|
||||||
|
rtc_write( RTC_MONTH, bin2bcd( tmp->tm_mon )); |
||||||
|
|
||||||
|
rtc_write( RTC_DAY_OF_WEEK, bin2bcd( tmp->tm_wday )); |
||||||
|
rtc_write( RTC_DAY_OF_MONTH, bin2bcd( tmp->tm_mday )); |
||||||
|
rtc_write( RTC_HOURS, bin2bcd( tmp->tm_hour )); |
||||||
|
rtc_write( RTC_MINUTES, bin2bcd( tmp->tm_min )); |
||||||
|
rtc_write( RTC_SECONDS, bin2bcd( tmp->tm_sec )); |
||||||
|
|
||||||
|
/* break year up into century and year in century */ |
||||||
|
if (century_flag) { |
||||||
|
rtc_write( RTC_YEAR, bin2bcd( tmp->tm_year % 100 )); |
||||||
|
rtc_write( RTC_CENTURY, bin2bcd( tmp->tm_year / 100 )); |
||||||
|
reg_a &= 0xc0; |
||||||
|
reg_a |= bin2bcd( tmp->tm_year / 100 ); |
||||||
|
} else { |
||||||
|
rtc_write(RTC_YEAR, bin2bcd(tmp->tm_year - |
||||||
|
((tmp->tm_year < 2000) ? 1900 : 2000))); |
||||||
|
} |
||||||
|
|
||||||
|
/* unlock clock registers after read */ |
||||||
|
rtc_write( RTC_CONTROLA, ( reg_a & ~RTC_CA_WRITE )); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
#endif |
@ -0,0 +1,54 @@ |
|||||||
|
/*
|
||||||
|
* (C) Copyright 2000 |
||||||
|
* Wolfgang Denk, DENX Software Engineering, wd@denx.de. |
||||||
|
* |
||||||
|
* See file CREDITS for list of people who contributed to this |
||||||
|
* project. |
||||||
|
* |
||||||
|
* This program is free software; you can redistribute it and/or |
||||||
|
* modify it under the terms of the GNU General Public License as |
||||||
|
* published by the Free Software Foundation; either version 2 of |
||||||
|
* the License, or (at your option) any later version. |
||||||
|
* |
||||||
|
* This program is distributed in the hope that it will be useful, |
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||||
|
* GNU General Public License for more details. |
||||||
|
* |
||||||
|
* You should have received a copy of the GNU General Public License |
||||||
|
* along with this program; if not, write to the Free Software |
||||||
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, |
||||||
|
* MA 02111-1307 USA |
||||||
|
*/ |
||||||
|
|
||||||
|
/*-----------------------------------------------------------------------
|
||||||
|
* Timer value for timer 2, ICLK = 10 |
||||||
|
* |
||||||
|
* SPEED_FCOUNT2 = GCLK / (16 * (TIMER_TMR_PS + 1)) |
||||||
|
* SPEED_TMR3_PS = (GCLK / (16 * SPEED_FCOUNT3)) - 1 |
||||||
|
* |
||||||
|
* SPEED_FCOUNT2 timer 2 counting frequency |
||||||
|
* GCLK CPU clock |
||||||
|
* SPEED_TMR2_PS prescaler |
||||||
|
*/ |
||||||
|
#define SPEED_TMR2_PS (250 - 1) /* divide by 250 */ |
||||||
|
|
||||||
|
/*-----------------------------------------------------------------------
|
||||||
|
* Timer value for PIT |
||||||
|
* |
||||||
|
* PIT_TIME = SPEED_PITC / PITRTCLK |
||||||
|
* PITRTCLK = 8192 |
||||||
|
*/ |
||||||
|
#define SPEED_PITC (82 << 16) /* start counting from 82 */ |
||||||
|
|
||||||
|
/*
|
||||||
|
* The new value for PTA is calculated from |
||||||
|
* |
||||||
|
* PTA = (gclk * Trefresh) / (2 ^ (2 * DFBRG) * PTP * NCS) |
||||||
|
* |
||||||
|
* gclk CPU clock (not bus clock !) |
||||||
|
* Trefresh Refresh cycle * 4 (four word bursts used) |
||||||
|
* DFBRG For normal mode (no clock reduction) always 0 |
||||||
|
* PTP Prescaler (already adjusted for no. of banks and 4K / 8K refresh) |
||||||
|
* NCS Number of SDRAM banks (chip selects) on this UPM. |
||||||
|
*/ |
@ -0,0 +1,128 @@ |
|||||||
|
/* |
||||||
|
* (C) Copyright 2001 |
||||||
|
* Wolfgang Denk, DENX Software Engineering, wd@denx.de. |
||||||
|
* |
||||||
|
* See file CREDITS for list of people who contributed to this |
||||||
|
* project. |
||||||
|
* |
||||||
|
* This program is free software; you can redistribute it and/or |
||||||
|
* modify it under the terms of the GNU General Public License as |
||||||
|
* published by the Free Software Foundation; either version 2 of |
||||||
|
* the License, or (at your option) any later version. |
||||||
|
* |
||||||
|
* This program is distributed in the hope that it will be useful, |
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||||
|
* GNU General Public License for more details. |
||||||
|
* |
||||||
|
* You should have received a copy of the GNU General Public License |
||||||
|
* along with this program; if not, write to the Free Software |
||||||
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, |
||||||
|
* MA 02111-1307 USA |
||||||
|
*/ |
||||||
|
|
||||||
|
OUTPUT_ARCH(powerpc) |
||||||
|
SEARCH_DIR(/lib); SEARCH_DIR(/usr/lib); SEARCH_DIR(/usr/local/lib); SEARCH_DIR(/usr/local/powerpc-any-elf/lib); |
||||||
|
/* Do we need any of these for elf? |
||||||
|
__DYNAMIC = 0; */ |
||||||
|
SECTIONS |
||||||
|
{ |
||||||
|
/* Read-only sections, merged into text segment: */ |
||||||
|
. = + SIZEOF_HEADERS; |
||||||
|
.interp : { *(.interp) } |
||||||
|
.hash : { *(.hash) } |
||||||
|
.dynsym : { *(.dynsym) } |
||||||
|
.dynstr : { *(.dynstr) } |
||||||
|
.rel.text : { *(.rel.text) } |
||||||
|
.rela.text : { *(.rela.text) } |
||||||
|
.rel.data : { *(.rel.data) } |
||||||
|
.rela.data : { *(.rela.data) } |
||||||
|
.rel.rodata : { *(.rel.rodata) } |
||||||
|
.rela.rodata : { *(.rela.rodata) } |
||||||
|
.rel.got : { *(.rel.got) } |
||||||
|
.rela.got : { *(.rela.got) } |
||||||
|
.rel.ctors : { *(.rel.ctors) } |
||||||
|
.rela.ctors : { *(.rela.ctors) } |
||||||
|
.rel.dtors : { *(.rel.dtors) } |
||||||
|
.rela.dtors : { *(.rela.dtors) } |
||||||
|
.rel.bss : { *(.rel.bss) } |
||||||
|
.rela.bss : { *(.rela.bss) } |
||||||
|
.rel.plt : { *(.rel.plt) } |
||||||
|
.rela.plt : { *(.rela.plt) } |
||||||
|
.init : { *(.init) } |
||||||
|
.plt : { *(.plt) } |
||||||
|
.text : |
||||||
|
{ |
||||||
|
cpu/mpc824x/start.o (.text) |
||||||
|
lib_ppc/board.o (.text) |
||||||
|
lib_ppc/ppcstring.o (.text) |
||||||
|
|
||||||
|
. = DEFINED(env_offset) ? env_offset : .; |
||||||
|
common/environment.o (.text) |
||||||
|
|
||||||
|
*(.text) |
||||||
|
|
||||||
|
*(.fixup) |
||||||
|
*(.got1) |
||||||
|
. = ALIGN(16); |
||||||
|
*(.rodata) |
||||||
|
*(.rodata1) |
||||||
|
} |
||||||
|
.fini : { *(.fini) } =0 |
||||||
|
.ctors : { *(.ctors) } |
||||||
|
.dtors : { *(.dtors) } |
||||||
|
|
||||||
|
/* Read-write section, merged into data segment: */ |
||||||
|
. = (. + 0x0FFF) & 0xFFFFF000; |
||||||
|
_erotext = .; |
||||||
|
PROVIDE (erotext = .); |
||||||
|
.reloc : |
||||||
|
{ |
||||||
|
*(.got) |
||||||
|
_GOT2_TABLE_ = .; |
||||||
|
*(.got2) |
||||||
|
_FIXUP_TABLE_ = .; |
||||||
|
*(.fixup) |
||||||
|
} |
||||||
|
__got2_entries = (_FIXUP_TABLE_ - _GOT2_TABLE_) >> 2; |
||||||
|
__fixup_entries = (. - _FIXUP_TABLE_) >> 2; |
||||||
|
|
||||||
|
.data : |
||||||
|
{ |
||||||
|
*(.data) |
||||||
|
*(.data1) |
||||||
|
*(.sdata) |
||||||
|
*(.sdata2) |
||||||
|
*(.dynamic) |
||||||
|
CONSTRUCTORS |
||||||
|
} |
||||||
|
_edata = .; |
||||||
|
PROVIDE (edata = .); |
||||||
|
|
||||||
|
__u_boot_cmd_start = .; |
||||||
|
.u_boot_cmd : { *(.u_boot_cmd) } |
||||||
|
__u_boot_cmd_end = .; |
||||||
|
|
||||||
|
__start___ex_table = .; |
||||||
|
__ex_table : { *(__ex_table) } |
||||||
|
__stop___ex_table = .; |
||||||
|
|
||||||
|
. = ALIGN(4096); |
||||||
|
__init_begin = .; |
||||||
|
.text.init : { *(.text.init) } |
||||||
|
.data.init : { *(.data.init) } |
||||||
|
. = ALIGN(4096); |
||||||
|
__init_end = .; |
||||||
|
|
||||||
|
__bss_start = .; |
||||||
|
.bss : |
||||||
|
{ |
||||||
|
*(.sbss) *(.scommon) |
||||||
|
*(.dynbss) |
||||||
|
*(.bss) |
||||||
|
*(COMMON) |
||||||
|
} |
||||||
|
|
||||||
|
_end = . ; |
||||||
|
PROVIDE (end = .); |
||||||
|
} |
@ -0,0 +1,439 @@ |
|||||||
|
/*
|
||||||
|
* (C) Copyright 2001, 2002 |
||||||
|
* Sangmoon Kim, Etin Systems, dogoil@etinsys.com. |
||||||
|
* |
||||||
|
* See file CREDITS for list of people who contributed to this |
||||||
|
* project. |
||||||
|
* |
||||||
|
* This program is free software; you can redistribute it and/or |
||||||
|
* modify it under the terms of the GNU General Public License as |
||||||
|
* published by the Free Software Foundation; either version 2 of |
||||||
|
* the License, or (at your option) any later version. |
||||||
|
* |
||||||
|
* This program is distributed in the hope that it will be useful, |
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||||
|
* GNU General Public License for more details. |
||||||
|
* |
||||||
|
* You should have received a copy of the GNU General Public License |
||||||
|
* along with this program; if not, write to the Free Software |
||||||
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, |
||||||
|
* MA 02111-1307 USA |
||||||
|
*/ |
||||||
|
|
||||||
|
/* ------------------------------------------------------------------------- */ |
||||||
|
|
||||||
|
/*
|
||||||
|
* board/config.h - configuration options, board specific |
||||||
|
*/ |
||||||
|
|
||||||
|
#ifndef __CONFIG_H |
||||||
|
#define __CONFIG_H |
||||||
|
|
||||||
|
/* Environments */ |
||||||
|
|
||||||
|
/* bootargs */ |
||||||
|
#define CONFIG_BOOTARGS \ |
||||||
|
"console=ttyS0,9600 init=/linuxrc " \
|
||||||
|
"root=/dev/nfs rw nfsroot=192.168.0.1:" \
|
||||||
|
"/tftpboot/target " \
|
||||||
|
"ip=192.168.0.2:192.168.0.1:192.168.0.1:" \
|
||||||
|
"255.255.255.0:debris:eth0:none " \
|
||||||
|
"mtdparts=phys:12m(root),-(kernel)" |
||||||
|
|
||||||
|
/* bootcmd */ |
||||||
|
#define CONFIG_BOOTCOMMAND \ |
||||||
|
"tftp 800000 pImage; " \
|
||||||
|
"setenv bootargs console=ttyS0,9600 init=/linuxrc " \
|
||||||
|
"root=/dev/nfs rw nfsroot=$(serverip):$(rootpath) " \
|
||||||
|
"ip=$(ipaddr):$(serverip):$(gatewayip):" \
|
||||||
|
"$(netmask):$(hostname):eth0:none " \
|
||||||
|
"mtdparts=phys:12m(root),-(kernel); " \
|
||||||
|
"bootm 800000" |
||||||
|
|
||||||
|
/* bootdelay */ |
||||||
|
#define CONFIG_BOOTDELAY 5 /* autoboot 5s */ |
||||||
|
|
||||||
|
/* baudrate */ |
||||||
|
#define CONFIG_BAUDRATE 9600 /* console baudrate = 9600bps */ |
||||||
|
|
||||||
|
/* loads_echo */ |
||||||
|
#define CONFIG_LOADS_ECHO 0 /* echo off for serial download */ |
||||||
|
|
||||||
|
/* ethaddr */ |
||||||
|
#undef CONFIG_ETHADDR |
||||||
|
|
||||||
|
/* eth2addr */ |
||||||
|
#undef CONFIG_ETH2ADDR |
||||||
|
|
||||||
|
/* eth3addr */ |
||||||
|
#undef CONFIG_ETH3ADDR |
||||||
|
|
||||||
|
/* ipaddr */ |
||||||
|
#define CONFIG_IPADDR 192.168.0.2 |
||||||
|
|
||||||
|
/* serverip */ |
||||||
|
#define CONFIG_SERVERIP 192.168.0.1 |
||||||
|
|
||||||
|
/* autoload */ |
||||||
|
#undef CFG_AUTOLOAD |
||||||
|
|
||||||
|
/* rootpath */ |
||||||
|
#define CONFIG_ROOTPATH /tftpboot/target |
||||||
|
|
||||||
|
/* gatewayip */ |
||||||
|
#define CONFIG_GATEWAYIP 192.168.0.1 |
||||||
|
|
||||||
|
/* netmask */ |
||||||
|
#define CONFIG_NETMASK 255.255.255.0 |
||||||
|
|
||||||
|
/* hostname */ |
||||||
|
#define CONFIG_HOSTNAME debris |
||||||
|
|
||||||
|
/* bootfile */ |
||||||
|
#define CONFIG_BOOTFILE pImage |
||||||
|
|
||||||
|
/* loadaddr */ |
||||||
|
#define CONFIG_LOADADDR 800000 |
||||||
|
|
||||||
|
/* preboot */ |
||||||
|
#undef CONFIG_PREBOOT |
||||||
|
|
||||||
|
/* clocks_in_mhz */ |
||||||
|
#undef CONFIG_CLOCKS_IN_MHZ |
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* High Level Configuration Options |
||||||
|
* (easy to change) |
||||||
|
*/ |
||||||
|
|
||||||
|
#define CONFIG_MPC824X 1 |
||||||
|
#define CONFIG_MPC8245 1 |
||||||
|
#define CONFIG_DEBRIS 1 |
||||||
|
|
||||||
|
#if 0 |
||||||
|
#define USE_DINK32 1 |
||||||
|
#else |
||||||
|
#undef USE_DINK32 |
||||||
|
#endif |
||||||
|
|
||||||
|
#define CONFIG_CONS_INDEX 1 |
||||||
|
#define CONFIG_BAUDRATE 9600 |
||||||
|
#define CONFIG_DRAM_SPEED 100 /* MHz */ |
||||||
|
|
||||||
|
#define CONFIG_COMMANDS ( CONFIG_CMD_DFL | \ |
||||||
|
CFG_CMD_ASKENV | \
|
||||||
|
CFG_CMD_CACHE | \
|
||||||
|
CFG_CMD_DATE | \
|
||||||
|
CFG_CMD_DHCP | \
|
||||||
|
CFG_CMD_DIAG | \
|
||||||
|
CFG_CMD_EEPROM | \
|
||||||
|
CFG_CMD_ELF | \
|
||||||
|
CFG_CMD_I2C | \
|
||||||
|
CFG_CMD_JFFS2 | \
|
||||||
|
CFG_CMD_KGBD | \
|
||||||
|
CFG_CMD_PCI | \
|
||||||
|
CFG_CMD_PING | \
|
||||||
|
CFG_CMD_SAVES | \
|
||||||
|
CFG_CMD_SDRAM) |
||||||
|
/* this must be included AFTER the definition of CONFIG_COMMANDS (if any) */ |
||||||
|
#include <cmd_confdefs.h> |
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Miscellaneous configurable options |
||||||
|
*/ |
||||||
|
#define CFG_LONGHELP 1 /* undef to save memory */ |
||||||
|
#define CFG_PROMPT "=> " /* Monitor Command Prompt */ |
||||||
|
#define CFG_CBSIZE 256 /* Console I/O Buffer Size */ |
||||||
|
#define CFG_PBSIZE (CFG_CBSIZE+sizeof(CFG_PROMPT)+16) /* Print Buffer Size */ |
||||||
|
#define CFG_MAXARGS 16 /* max number of command args */ |
||||||
|
#define CFG_BARGSIZE CFG_CBSIZE /* Boot Argument Buffer Size */ |
||||||
|
#define CFG_LOAD_ADDR 0x00100000 /* default load address */ |
||||||
|
#define CFG_HZ 1000 /* decrementer freq: 1 ms ticks */ |
||||||
|
|
||||||
|
/*-----------------------------------------------------------------------
|
||||||
|
* PCI stuff |
||||||
|
*----------------------------------------------------------------------- |
||||||
|
*/ |
||||||
|
#define CONFIG_PCI /* include pci support */ |
||||||
|
#define CONFIG_PCI_PNP |
||||||
|
|
||||||
|
#define CONFIG_NET_MULTI /* Multi ethernet cards support */ |
||||||
|
#define CONFIG_EEPRO100 |
||||||
|
#define CFG_RX_ETH_BUFFER 8 /* use 8 rx buffer on eepro100 */ |
||||||
|
#define CONFIG_EEPRO100_SROM_WRITE |
||||||
|
|
||||||
|
#define PCI_ENET0_IOADDR 0x80000000 |
||||||
|
#define PCI_ENET0_MEMADDR 0x80000000 |
||||||
|
#define PCI_ENET1_IOADDR 0x81000000 |
||||||
|
#define PCI_ENET1_MEMADDR 0x81000000 |
||||||
|
/*-----------------------------------------------------------------------
|
||||||
|
* Start addresses for the final memory configuration |
||||||
|
* (Set up by the startup code) |
||||||
|
* Please note that CFG_SDRAM_BASE _must_ start at 0 |
||||||
|
*/ |
||||||
|
#define CFG_SDRAM_BASE 0x00000000 |
||||||
|
#define CFG_MAX_RAM_SIZE 0x10000000 |
||||||
|
|
||||||
|
#define CFG_RESET_ADDRESS 0xFFF00100 |
||||||
|
|
||||||
|
#if defined (USE_DINK32) |
||||||
|
#define CFG_MONITOR_LEN 0x00040000 |
||||||
|
#define CFG_MONITOR_BASE 0x00090000 |
||||||
|
#define CFG_RAMBOOT 1 |
||||||
|
#define CFG_INIT_RAM_ADDR (CFG_MONITOR_BASE + CFG_MONITOR_LEN) |
||||||
|
#define CFG_INIT_RAM_END 0x10000 |
||||||
|
#define CFG_GBL_DATA_SIZE 256 /* size in bytes reserved for initial data */ |
||||||
|
#define CFG_GBL_DATA_OFFSET (CFG_INIT_RAM_END - CFG_GBL_DATA_SIZE) |
||||||
|
#define CFG_INIT_SP_OFFSET CFG_GBL_DATA_OFFSET |
||||||
|
#else |
||||||
|
#undef CFG_RAMBOOT |
||||||
|
#define CFG_MONITOR_LEN 0x00040000 |
||||||
|
#define CFG_MONITOR_BASE TEXT_BASE |
||||||
|
|
||||||
|
/*#define CFG_GBL_DATA_SIZE 256*/ |
||||||
|
#define CFG_GBL_DATA_SIZE 128 |
||||||
|
|
||||||
|
#define CFG_INIT_RAM_ADDR 0x40000000 |
||||||
|
#define CFG_INIT_RAM_END 0x1000 |
||||||
|
#define CFG_GBL_DATA_OFFSET (CFG_INIT_RAM_END - CFG_GBL_DATA_SIZE) |
||||||
|
|
||||||
|
#endif |
||||||
|
|
||||||
|
#define CFG_FLASH_BASE 0x7C000000 |
||||||
|
#define CFG_FLASH_SIZE (16*1024*1024) /* debris has tiny eeprom */ |
||||||
|
|
||||||
|
#define CFG_MALLOC_LEN (512 << 10) /* Reserve 512 kB for malloc() */ |
||||||
|
|
||||||
|
#define CFG_MEMTEST_START 0x00000000 /* memtest works on */ |
||||||
|
#define CFG_MEMTEST_END 0x04000000 /* 0 ... 32 MB in DRAM */ |
||||||
|
|
||||||
|
#define CFG_EUMB_ADDR 0xFC000000 |
||||||
|
|
||||||
|
#define CFG_FLASH_RANGE_BASE 0xFF000000 /* flash memory address range */ |
||||||
|
#define CFG_FLASH_RANGE_SIZE 0x01000000 |
||||||
|
#define FLASH_BASE0_PRELIM 0x7C000000 /* debris flash */ |
||||||
|
|
||||||
|
#define CFG_JFFS2_FIRST_BANK 0 /* use for JFFS2 */ |
||||||
|
#define CFG_JFFS2_NUM_BANKS 1 |
||||||
|
|
||||||
|
#define CFG_ENV_IS_IN_NVRAM 1 |
||||||
|
#define CONFIG_ENV_OVERWRITE 1 |
||||||
|
#define CFG_NVRAM_ACCESS_ROUTINE 1 |
||||||
|
#define CFG_ENV_ADDR 0xFF000000 /* right at the start of NVRAM */ |
||||||
|
#define CFG_ENV_SIZE 0x400 /* Size of the Environment - 8K */ |
||||||
|
#define CFG_ENV_OFFSET 0 /* starting right at the beginning */ |
||||||
|
|
||||||
|
#define CFG_NVRAM_BASE_ADDR 0xff000000 |
||||||
|
|
||||||
|
/*
|
||||||
|
* CFG_NVRAM_BASE_ADDR + CFG_NVRAM_VXWORKS_OFFS = |
||||||
|
* NV_RAM_ADDRS + NV_BOOT_OFFSET + NV_ENET_OFFSET |
||||||
|
*/ |
||||||
|
#define CFG_NVRAM_VXWORKS_OFFS 0x6900 |
||||||
|
|
||||||
|
/*
|
||||||
|
* select i2c support configuration |
||||||
|
* |
||||||
|
* Supported configurations are {none, software, hardware} drivers. |
||||||
|
* If the software driver is chosen, there are some additional |
||||||
|
* configuration items that the driver uses to drive the port pins. |
||||||
|
*/ |
||||||
|
#define CONFIG_HARD_I2C 1 /* To enable I2C support */ |
||||||
|
#undef CONFIG_SOFT_I2C /* I2C bit-banged */ |
||||||
|
#define CFG_I2C_SPEED 400000 /* I2C speed and slave address */ |
||||||
|
#define CFG_I2C_SLAVE 0x7F |
||||||
|
|
||||||
|
#ifdef CONFIG_SOFT_I2C |
||||||
|
#error "Soft I2C is not configured properly. Please review!" |
||||||
|
#define I2C_PORT 3 /* Port A=0, B=1, C=2, D=3 */ |
||||||
|
#define I2C_ACTIVE (iop->pdir |= 0x00010000) |
||||||
|
#define I2C_TRISTATE (iop->pdir &= ~0x00010000) |
||||||
|
#define I2C_READ ((iop->pdat & 0x00010000) != 0) |
||||||
|
#define I2C_SDA(bit) if(bit) iop->pdat |= 0x00010000; \ |
||||||
|
else iop->pdat &= ~0x00010000 |
||||||
|
#define I2C_SCL(bit) if(bit) iop->pdat |= 0x00020000; \ |
||||||
|
else iop->pdat &= ~0x00020000 |
||||||
|
#define I2C_DELAY udelay(5) /* 1/4 I2C clock duration */ |
||||||
|
#endif /* CONFIG_SOFT_I2C */ |
||||||
|
|
||||||
|
#define CFG_I2C_EEPROM_ADDR 0x57 /* EEPROM IS24C02 */ |
||||||
|
#define CFG_I2C_EEPROM_ADDR_LEN 1 /* Bytes of address */ |
||||||
|
#define CFG_EEPROM_PAGE_WRITE_BITS 3 |
||||||
|
#define CFG_EEPROM_PAGE_WRITE_DELAY_MS 10 /* and takes up to 10 msec */ |
||||||
|
|
||||||
|
#define CFG_BAUDRATE_TABLE { 9600, 19200, 38400, 57600, 115200 } |
||||||
|
#define CFG_FLASH_BANKS { FLASH_BASE0_PRELIM } |
||||||
|
|
||||||
|
/*-----------------------------------------------------------------------
|
||||||
|
* Definitions for initial stack pointer and data area (in DPRAM) |
||||||
|
*/ |
||||||
|
|
||||||
|
/*
|
||||||
|
* NS16550 Configuration |
||||||
|
*/ |
||||||
|
#define CFG_NS16550 |
||||||
|
#define CFG_NS16550_SERIAL |
||||||
|
|
||||||
|
#define CFG_NS16550_REG_SIZE 1 |
||||||
|
|
||||||
|
#define CFG_NS16550_CLK 7372800 |
||||||
|
|
||||||
|
#define CFG_NS16550_COM1 0xFF080000 |
||||||
|
#define CFG_NS16550_COM2 (CFG_NS16550_COM1 + 8) |
||||||
|
#define CFG_NS16550_COM3 (CFG_NS16550_COM1 + 16) |
||||||
|
#define CFG_NS16550_COM4 (CFG_NS16550_COM1 + 24) |
||||||
|
|
||||||
|
/*
|
||||||
|
* Low Level Configuration Settings |
||||||
|
* (address mappings, register initial values, etc.) |
||||||
|
* You should know what you are doing if you make changes here. |
||||||
|
*/ |
||||||
|
|
||||||
|
#define CONFIG_SYS_CLK_FREQ 33333333 /* external frequency to pll */ |
||||||
|
#define CONFIG_PLL_PCI_TO_MEM_MULTIPLIER 3 |
||||||
|
|
||||||
|
#define CFG_DLL_EXTEND 0x00 |
||||||
|
#define CFG_PCI_HOLD_DEL 0x20 |
||||||
|
|
||||||
|
#define CFG_ROMNAL 15 /* rom/flash next access time */ |
||||||
|
#define CFG_ROMFAL 31 /* rom/flash access time */ |
||||||
|
|
||||||
|
#define CFG_REFINT 430 /* # of clocks between CBR refresh cycles */ |
||||||
|
|
||||||
|
#define CFG_DBUS_SIZE2 1 /* set for 8-bit RCS1, clear for 32,64 */ |
||||||
|
|
||||||
|
/* the following are for SDRAM only*/ |
||||||
|
#define CFG_BSTOPRE 121 /* Burst To Precharge, sets open page interval */ |
||||||
|
#define CFG_REFREC 8 /* Refresh to activate interval */ |
||||||
|
#define CFG_RDLAT 4 /* data latency from read command */ |
||||||
|
#define CFG_PRETOACT 3 /* Precharge to activate interval */ |
||||||
|
#define CFG_ACTTOPRE 5 /* Activate to Precharge interval */ |
||||||
|
#define CFG_ACTORW 3 /* Activate to R/W */ |
||||||
|
#define CFG_SDMODE_CAS_LAT 3 /* SDMODE CAS latency */ |
||||||
|
#define CFG_SDMODE_WRAP 0 /* SDMODE wrap type */ |
||||||
|
#if 0 |
||||||
|
#define CFG_SDMODE_BURSTLEN 2 /* OBSOLETE! SDMODE Burst length 2=4, 3=8 */ |
||||||
|
#endif |
||||||
|
|
||||||
|
#define CFG_REGISTERD_TYPE_BUFFER 1 |
||||||
|
#define CFG_EXTROM 1 |
||||||
|
#define CFG_REGDIMM 0 |
||||||
|
|
||||||
|
|
||||||
|
/* memory bank settings*/ |
||||||
|
/*
|
||||||
|
* only bits 20-29 are actually used from these vales to set the |
||||||
|
* start/end address the upper two bits will be 0, and the lower 20 |
||||||
|
* bits will be set to 0x00000 for a start address, or 0xfffff for an |
||||||
|
* end address |
||||||
|
*/ |
||||||
|
#define CFG_BANK0_START 0x00000000 |
||||||
|
#define CFG_BANK0_END (0x4000000 - 1) |
||||||
|
#define CFG_BANK0_ENABLE 1 |
||||||
|
#define CFG_BANK1_START 0x04000000 |
||||||
|
#define CFG_BANK1_END (0x8000000 - 1) |
||||||
|
#define CFG_BANK1_ENABLE 1 |
||||||
|
#define CFG_BANK2_START 0x3ff00000 |
||||||
|
#define CFG_BANK2_END 0x3fffffff |
||||||
|
#define CFG_BANK2_ENABLE 0 |
||||||
|
#define CFG_BANK3_START 0x3ff00000 |
||||||
|
#define CFG_BANK3_END 0x3fffffff |
||||||
|
#define CFG_BANK3_ENABLE 0 |
||||||
|
#define CFG_BANK4_START 0x00000000 |
||||||
|
#define CFG_BANK4_END 0x00000000 |
||||||
|
#define CFG_BANK4_ENABLE 0 |
||||||
|
#define CFG_BANK5_START 0x00000000 |
||||||
|
#define CFG_BANK5_END 0x00000000 |
||||||
|
#define CFG_BANK5_ENABLE 0 |
||||||
|
#define CFG_BANK6_START 0x00000000 |
||||||
|
#define CFG_BANK6_END 0x00000000 |
||||||
|
#define CFG_BANK6_ENABLE 0 |
||||||
|
#define CFG_BANK7_START 0x00000000 |
||||||
|
#define CFG_BANK7_END 0x00000000 |
||||||
|
#define CFG_BANK7_ENABLE 0 |
||||||
|
/*
|
||||||
|
* Memory bank enable bitmask, specifying which of the banks defined above |
||||||
|
are actually present. MSB is for bank #7, LSB is for bank #0. |
||||||
|
*/ |
||||||
|
#define CFG_BANK_ENABLE 0x01 |
||||||
|
|
||||||
|
#define CFG_ODCR 0x75 /* configures line driver impedances, */ |
||||||
|
/* see 8240 book for bit definitions */ |
||||||
|
#define CFG_PGMAX 0x32 /* how long the 8240 retains the */ |
||||||
|
/* currently accessed page in memory */ |
||||||
|
/* see 8240 book for details */ |
||||||
|
|
||||||
|
/* SDRAM 0 - 256MB */ |
||||||
|
#define CFG_IBAT0L (CFG_SDRAM_BASE | BATL_PP_10 | BATL_MEMCOHERENCE) |
||||||
|
#define CFG_IBAT0U (CFG_SDRAM_BASE | BATU_BL_256M | BATU_VS | BATU_VP) |
||||||
|
|
||||||
|
/* stack in DCACHE @ 1GB (no backing mem) */ |
||||||
|
#if defined(USE_DINK32) |
||||||
|
#define CFG_IBAT1L (0x40000000 | BATL_PP_00 ) |
||||||
|
#define CFG_IBAT1U (0x40000000 | BATU_BL_128K ) |
||||||
|
#else |
||||||
|
#define CFG_IBAT1L (CFG_INIT_RAM_ADDR | BATL_PP_10 | BATL_MEMCOHERENCE) |
||||||
|
#define CFG_IBAT1U (CFG_INIT_RAM_ADDR | BATU_BL_128K | BATU_VS | BATU_VP) |
||||||
|
#endif |
||||||
|
|
||||||
|
/* PCI memory */ |
||||||
|
#define CFG_IBAT2L (0x80000000 | BATL_PP_10 | BATL_CACHEINHIBIT) |
||||||
|
#define CFG_IBAT2U (0x80000000 | BATU_BL_256M | BATU_VS | BATU_VP) |
||||||
|
|
||||||
|
/* Flash, config addrs, etc */ |
||||||
|
#define CFG_IBAT3L (0xF0000000 | BATL_PP_10 | BATL_CACHEINHIBIT) |
||||||
|
#define CFG_IBAT3U (0xF0000000 | BATU_BL_256M | BATU_VS | BATU_VP) |
||||||
|
|
||||||
|
#define CFG_DBAT0L CFG_IBAT0L |
||||||
|
#define CFG_DBAT0U CFG_IBAT0U |
||||||
|
#define CFG_DBAT1L CFG_IBAT1L |
||||||
|
#define CFG_DBAT1U CFG_IBAT1U |
||||||
|
#define CFG_DBAT2L CFG_IBAT2L |
||||||
|
#define CFG_DBAT2U CFG_IBAT2U |
||||||
|
#define CFG_DBAT3L CFG_IBAT3L |
||||||
|
#define CFG_DBAT3U CFG_IBAT3U |
||||||
|
|
||||||
|
/*
|
||||||
|
* For booting Linux, the board info and command line data |
||||||
|
* have to be in the first 8 MB of memory, since this is |
||||||
|
* the maximum mapped by the Linux kernel during initialization. |
||||||
|
*/ |
||||||
|
#define CFG_BOOTMAPSZ (8 << 20) /* Initial Memory map for Linux */ |
||||||
|
/*-----------------------------------------------------------------------
|
||||||
|
* FLASH organization |
||||||
|
*/ |
||||||
|
#define CFG_MAX_FLASH_BANKS 1 /* max number of memory banks */ |
||||||
|
#define CFG_MAX_FLASH_SECT 256 /* max number of sectors on one chip */ |
||||||
|
|
||||||
|
#define CFG_FLASH_ERASE_TOUT 120000 /* Timeout for Flash Erase (in ms) */ |
||||||
|
#define CFG_FLASH_WRITE_TOUT 500 /* Timeout for Flash Write (in ms) */ |
||||||
|
|
||||||
|
/*-----------------------------------------------------------------------
|
||||||
|
* Cache Configuration |
||||||
|
*/ |
||||||
|
#define CFG_CACHELINE_SIZE 32 /* For MPC8240 CPU */ |
||||||
|
#if (CONFIG_COMMANDS & CFG_CMD_KGDB) |
||||||
|
# define CFG_CACHELINE_SHIFT 5 /* log base 2 of the above value */ |
||||||
|
#endif |
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Internal Definitions |
||||||
|
* |
||||||
|
* Boot Flags |
||||||
|
*/ |
||||||
|
#define BOOTFLAG_COLD 0x01 /* Normal Power-On: Boot from FLASH */ |
||||||
|
#define BOOTFLAG_WARM 0x02 /* Software reboot */ |
||||||
|
|
||||||
|
|
||||||
|
/* values according to the manual */ |
||||||
|
|
||||||
|
#define CONFIG_DRAM_50MHZ 1 |
||||||
|
#define CONFIG_SDRAM_50MHZ |
||||||
|
|
||||||
|
#define CONFIG_DISK_SPINUP_TIME 1000000 |
||||||
|
|
||||||
|
#endif /* __CONFIG_H */ |
Loading…
Reference in new issue