* Patch by Hans-Joerg Frieden, 06 Dec 2002

Fix misc problems with AmigaOne support

* Patch by Chris Hallinan, 3 Dec 2002:
  minor cleanup to the MPC8245 EPIC driver

* Patch by Pierre Aubert , 28 Nov 2002
  Add support for external (SIU) interrupts on MPC8xx

* Patch by Pierre Aubert , 28 Nov 2002
  Fix nested syscalls bug in standalone applications

* Patch by David Mller, 27 Nov 2002:
  fix output of "pciinfo" command for CardBus bridge devices.

* Fix bug in TQM8260 board detection - boards got stuck when board ID
  was not readable
master
wdenk 22 years ago
parent 1f53a41603
commit 7c7a23bd5a
  1. 18
      CHANGELOG
  2. 9
      board/MAI/AmigaOneG3SE/AmigaOneG3SE.c
  3. 13
      board/MAI/AmigaOneG3SE/Makefile
  4. 5
      board/MAI/AmigaOneG3SE/articiaS.c
  5. 10
      board/MAI/AmigaOneG3SE/articiaS_pci.c
  6. 2
      board/MAI/AmigaOneG3SE/config.mk
  7. 6
      board/MAI/AmigaOneG3SE/video.c
  8. 54
      board/MAI/bios_emulator/glue.c
  9. 80
      board/MAI/bios_emulator/scitech/src/x86emu/makefile.uboot
  10. 7
      board/MAI/bios_emulator/x86interface.c
  11. 2
      board/MAI/menu/cmd_menu.c
  12. 10
      board/hermes/u-boot.lds
  13. 2
      board/tqm8260/tqm8260.c
  14. 2
      board/trab/vfd.c
  15. 68
      common/cmd_pci.c
  16. 16
      common/env_common.c
  17. 35
      common/env_nvram.c
  18. 21
      cpu/74xx_7xx/start.S
  19. 3
      cpu/mpc824x/drivers/epic/epic.h
  20. 19
      cpu/mpc824x/drivers/epic/epic1.c
  21. 2
      cpu/mpc824x/interrupts.c
  22. 18
      cpu/mpc824x/start.S
  23. 18
      cpu/mpc8260/start.S
  24. 241
      cpu/mpc8xx/interrupts.c
  25. 18
      cpu/mpc8xx/start.S
  26. 18
      cpu/ppc4xx/start.S
  27. 10
      examples/timer.c
  28. 105
      include/commproc.h
  29. 34
      include/configs/AmigaOneG3SE.h
  30. 5
      lib_ppc/board.c

@ -2,6 +2,24 @@
Changes since for U-Boot 0.1.0: Changes since for U-Boot 0.1.0:
====================================================================== ======================================================================
* Patch by Hans-Joerg Frieden, 06 Dec 2002
Fix misc problems with AmigaOne support
* Patch by Chris Hallinan, 3 Dec 2002:
minor cleanup to the MPC8245 EPIC driver
* Patch by Pierre Aubert , 28 Nov 2002
Add support for external (SIU) interrupts on MPC8xx
* Patch by Pierre Aubert , 28 Nov 2002
Fix nested syscalls bug in standalone applications
* Patch by David Müller, 27 Nov 2002:
fix output of "pciinfo" command for CardBus bridge devices.
* Fix bug in TQM8260 board detection - boards got stuck when board ID
was not readable
* Add LED indication for IDE activity on KUP4K board * Add LED indication for IDE activity on KUP4K board
* Fix startup problems with VFD display on TRAB * Fix startup problems with VFD display on TRAB

@ -76,9 +76,8 @@ __asm(" .globl send_kb \n
int checkboard (void) int checkboard (void)
{ {
printf ("AmigaOneG3SE\n"); printf ("Board: AmigaOneG3SE\n");
return 0;
return 1;
} }
long initdram (int board_type) long initdram (int board_type)
@ -88,9 +87,9 @@ long initdram (int board_type)
void after_reloc (ulong dest_addr) void after_reloc (ulong dest_addr, gd_t *gd)
{ {
DECLARE_GLOBAL_DATA_PTR; /* HJF: DECLARE_GLOBAL_DATA_PTR; */
board_init_r (gd, dest_addr); board_init_r (gd, dest_addr);
} }

@ -35,13 +35,16 @@ AOBJS = board_asm_init.o memio.o
OBJS = $(COBJS) $(AOBJS) OBJS = $(COBJS) $(AOBJS)
## FIXME !!! EMUDIR = ../bios_emulator/scitech/src/x86emu/
# EMUOBJS = ../bios_emulator/scitech/src/x86emu/*.o EMUOBJ = $(EMUDIR)decode.o $(EMUDIR)ops2.o $(EMUDIR)fpu.o $(EMUDIR)prim_ops.o \
$(EMUDIR)ops.o $(EMUDIR)sys.o
EMUSRC = $(EMUOBJ:.o=.c)
$(LIB): .depend $(OBJS) $(EMUSRC)
$(LIB): .depend $(OBJS) $(EMUOBJS) make libx86emu.a -C ../bios_emulator/scitech/src/x86emu -f makefile.uboot CROSS_COMPILE=$(CROSS_COMPILE)
-rm $(LIB) -rm $(LIB)
$(AR) crv $@ $(OBJS) $(EMUOBJS) $(AR) crv $@ $(OBJS) $(EMUOBJ)
######################################################################### #########################################################################

@ -82,8 +82,9 @@ static inline unsigned short NSto10PS (unsigned char spd_byte)
long detect_sdram (uint8 * rom, int dimmNum, struct dimm_bank *banks) long detect_sdram (uint8 * rom, int dimmNum, struct dimm_bank *banks)
{ {
DECLARE_GLOBAL_DATA_PTR;
int dimm_address = (dimmNum == 0) ? SM_DIMM0_ADDR : SM_DIMM1_ADDR; int dimm_address = (dimmNum == 0) ? SM_DIMM0_ADDR : SM_DIMM1_ADDR;
uint32 busclock = get_bus_freq (0); uint32 busclock = gd->bus_clk;
uint32 memclock = busclock; uint32 memclock = busclock;
uint32 tmemclock = 1000000000 / (memclock / 100); uint32 tmemclock = 1000000000 / (memclock / 100);
uint32 datawidth; uint32 datawidth;
@ -404,7 +405,7 @@ long articiaS_ram_init (void)
uint32 total_ram = 0; uint32 total_ram = 0;
struct dimm_bank banks[4]; /* FIXME: Move to initram */ struct dimm_bank banks[4]; /* FIXME: Move to initram */
uint32 busclock = get_bus_freq (0); uint32 busclock = gd->bus_clk;
uint32 memclock = busclock; uint32 memclock = busclock;
uint32 reg32; uint32 reg32;
uint32 refresh_clocks; uint32 refresh_clocks;

@ -26,7 +26,7 @@
#include "memio.h" #include "memio.h"
#include "articiaS.h" #include "articiaS.h"
//#define ARTICIA_PCI_DEBUG #undef ARTICIA_PCI_DEBUG
#ifdef ARTICIA_PCI_DEBUG #ifdef ARTICIA_PCI_DEBUG
#define PRINTF(fmt,args...) printf (fmt ,##args) #define PRINTF(fmt,args...) printf (fmt ,##args)
@ -512,7 +512,11 @@ int articiaS_init_vga (void)
PRINTF("Searching for class 0x%x on bus %d\n", classes[classnr], busnr); PRINTF("Searching for class 0x%x on bus %d\n", classes[classnr], busnr);
/* Find the first of this class on this bus */ /* Find the first of this class on this bus */
dev = pci_hose_find_class(&articiaS_hose, busnr, classes[classnr], 0); dev = pci_hose_find_class(&articiaS_hose, busnr, classes[classnr], 0);
if (dev != ~0) break; if (dev != ~0)
{
PRINTF("Found VGA Card at %02x:%02x:%02x\n", PCI_BUS(dev), PCI_DEV(dev), PCI_FUNC(dev));
break;
}
busnr++; busnr++;
if (busnr > articiaS_hose.last_busno) if (busnr > articiaS_hose.last_busno)
{ {
@ -552,7 +556,7 @@ int articiaS_init_vga (void)
/* /*
* Now try to run the bios * Now try to run the bios
*/ */
PRINTF("Trying to run bios now\n");
if (execute_bios(dev, gd->relocaddr)) if (execute_bios(dev, gd->relocaddr))
{ {
printf("OK\n"); printf("OK\n");

@ -29,5 +29,5 @@ X86EMU = -I../bios_emulator/scitech/include -I../bios_emulator/scitech/src/x86e
TEXT_BASE = 0xfff00000 TEXT_BASE = 0xfff00000
PLATFORM_CPPFLAGS += -DTEXT_BASE=$(TEXT_BASE) -Wa,-mregnames -DEASTEREGG $(X86EMU) #-DDEBUG PLATFORM_CPPFLAGS += -DTEXT_BASE=$(TEXT_BASE) -Wa,-mregnames -DEASTEREGG $(X86EMU) -Dprintk=printf #-DDEBUG

@ -474,13 +474,13 @@ void video_easteregg(void)
} }
#endif #endif
extern bd_t *bd_global;
extern block_dev_desc_t * ide_get_dev(int dev); extern block_dev_desc_t * ide_get_dev(int dev);
extern char version_string[]; extern char version_string[];
void video_banner(void) void video_banner(void)
{ {
block_dev_desc_t *ide; block_dev_desc_t *ide;
DECLARE_GLOBAL_DATA_PTR;
int i; int i;
char *s; char *s;
int maxdev; int maxdev;
@ -513,8 +513,8 @@ void video_banner(void)
video_clear(); video_clear();
printf("%s\n\nCPU: ", version_string); printf("%s\n\nCPU: ", version_string);
checkcpu(); checkcpu();
printf("DRAM: %ld MB\n", bd_global->bi_memsize/(1024*1024)); printf("DRAM: %ld MB\n", gd->bd->bi_memsize/(1024*1024));
printf("FSB: %ld MHz\n", bd_global->bi_busfreq/1000000); printf("FSB: %ld MHz\n", gd->bd->bi_busfreq/1000000);
printf("\n---- Disk summary ----\n"); printf("\n---- Disk summary ----\n");
for (i = 0; i < maxdev; i++) for (i = 0; i < maxdev; i++)

@ -271,9 +271,9 @@ int attempt_map_rom(pci_dev_t dev, void *copy_address)
pci_write_config_dword(dev, PCI_ROM_ADDRESS, 0); pci_write_config_dword(dev, PCI_ROM_ADDRESS, 0);
pci_write_config_dword(dev, i, bar_backup); pci_write_config_dword(dev, i, bar_backup);
/* FIXME: */ /* FIXME: Shouldn't be needed anymore*/
bat_map(2, 0x80000000, 256*1024*1024); /* bat_map(2, 0x80000000, 256*1024*1024);
show_bat_mapping(); show_bat_mapping(); */
/* /*
* Since most cards can probably only do 16 bit IO addressing, we * Since most cards can probably only do 16 bit IO addressing, we
@ -436,7 +436,6 @@ int find_image(u32 rom_address, u32 rom_size, void **image, u32 *image_size)
void show_bat_mapping(void) void show_bat_mapping(void)
{ {
#ifdef DEBUG
u32 dbat0u, dbat0l, ibat0u, ibat0l; u32 dbat0u, dbat0l, ibat0u, ibat0l;
u32 dbat1u, dbat1l, ibat1u, ibat1l; u32 dbat1u, dbat1l, ibat1u, ibat1l;
u32 dbat2u, dbat2l, ibat2u, ibat2l; u32 dbat2u, dbat2l, ibat2u, ibat2l;
@ -477,7 +476,6 @@ void show_bat_mapping(void)
dbat3u, dbat3l, ibat3u, ibat3l); dbat3u, dbat3l, ibat3u, ibat3l);
printf("\nMSR: %08x HID0: %08x L2CR: %08x \n", msr,hid0, l2cr_reg); printf("\nMSR: %08x HID0: %08x L2CR: %08x \n", msr,hid0, l2cr_reg);
#endif
} }
@ -485,44 +483,34 @@ void show_bat_mapping(void)
void remove_init_data(void) void remove_init_data(void)
{ {
char *s; char *s;
u32 batl = ((CFG_SDRAM_BASE+0x100000) | BATL_PP_RW);
u32 batu =((CFG_SDRAM_BASE+0x100000) | BATU_BL_256M | BATU_VS | BATU_VP);
#if 0 /* already done in board_init_r() */
void *data = (void *)(CFG_INIT_RAM_ADDR+CFG_INIT_DATA_OFFSET);
unsigned char data2[CFG_INIT_DATA_SIZE];
/* Make a copy of the data */
memcpy(data2, data, CFG_INIT_DATA_SIZE);
#endif /* 0 */
/* Invalidate and disable data cache */ /* Invalidate and disable data cache */
invalidate_l1_data_cache(); invalidate_l1_data_cache();
dcache_disable(); dcache_disable();
#if 0
/* Copy to the real RAM address */
memcpy(data, data2, CFG_INIT_DATA_SIZE);
#endif
/*printf("Before ICache enable\n");
show_bat_mapping();*/
__asm volatile ("isync \n"
"mtdbatu 2,%2 \n"
"mtdbatl 2,%2 \n"
"mtdbatu 1,%0 \n"
"mtdbatl 1,%1 \n"
"sync \n"
"isync \n"
: : "r" (batu), "r" (batl), "r" (0));
/* show_bat_mapping(); */
s = getenv("x86_cache"); s = getenv("x86_cache");
if (!s || (s && strcmp(s, "on")==0)) if (!s)
{ {
icache_enable(); icache_enable();
dcache_enable(); dcache_enable();
} }
else if (s)
{
if (strcmp(s, "dcache")==0)
{
dcache_enable();
}
else if (strcmp(s, "icache") == 0)
{
icache_enable();
}
else if (strcmp(s, "on")== 0 || strcmp(s, "both") == 0)
{
dcache_enable();
icache_enable();
}
}
/* show_bat_mapping();*/
} }

@ -0,0 +1,80 @@
#############################################################################
#
# Realmode X86 Emulator Library
#
# Copyright (C) 1996-1999 SciTech Software, Inc.
#
# ========================================================================
#
# Permission to use, copy, modify, distribute, and sell this software and
# its documentation for any purpose is hereby granted without fee,
# provided that the above copyright notice appear in all copies and that
# both that copyright notice and this permission notice appear in
# supporting documentation, and that the name of the authors not be used
# in advertising or publicity pertaining to distribution of the software
# without specific, written prior permission. The authors makes no
# representations about the suitability of this software for any purpose.
# It is provided "as is" without express or implied warranty.
#
# THE AUTHORS DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
# INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
# EVENT SHALL THE AUTHORS BE LIABLE FOR ANY SPECIAL, INDIRECT OR
# CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF
# USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
# OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
# PERFORMANCE OF THIS SOFTWARE.
#
# ========================================================================
#
# Descripton: Linux specific makefile for the x86emu library.
#
#############################################################################
CC = $(CROSS_COMPILE)gcc
AR = $(CROSS_COMPILE)ar
TARGETLIB = libx86emu.a
TARGETDEBUGLIB =libx86emud.a
OBJS=\
decode.o \
fpu.o \
ops.o \
ops2.o \
prim_ops.o \
sys.o
DEBUGOBJS=debug.d \
decode.d \
fpu.d \
ops.d \
ops2.d \
prim_ops.d \
sys.d
.SUFFIXES: .d
all: $(TARGETLIB) $(TARGETDEBUGLIB)
$(TARGETLIB): $(OBJS)
$(AR) rv $(TARGETLIB) $(OBJS)
$(TARGETDEBUGLIB): $(DEBUGOBJS)
$(AR) rv $(TARGETDEBUGLIB) $(DEBUGOBJS)
INCS = -I. -Ix86emu -I../../include
CFLAGS = -D__DRIVER__ -DFORCE_POST -D_CEXPORT= -DNO_LONG_LONG -Dprintk=printf -fsigned-char -fomit-frame-pointer -mrelocatable -ffixed-r14 -meabi -mrelocatable -ffixed-r14 -meabi
CDEBUGFLAGS = -DDEBUG
.c.o:
$(CC) -g -O2 -Wall -c $(CFLAGS) $(INCS) $*.c
.c.d:
$(CC) -g -O2 -Wall -c -o$*.d $(CFLAGS) $(CDEBUGFLAGS) $(INCS) $*.c
.cpp.o:
$(CC) -c $(CFLAGS) $(INCS) $*.cpp
clean:
rm -f *.a *.o *.d
validate: validate.o libx86emu.a
$(CC) -o validate validate.o -lx86emu -L.

@ -398,9 +398,7 @@ int execute_bios(pci_dev_t gr_dev, void *reloc_addr)
u8 cfg; u8 cfg;
int i; int i;
char c; char c;
#ifdef DEBUG
char *s; char *s;
#endif
#ifdef EASTEREGG #ifdef EASTEREGG
int easteregg_active = 0; int easteregg_active = 0;
#endif #endif
@ -409,6 +407,7 @@ int execute_bios(pci_dev_t gr_dev, void *reloc_addr)
unsigned char *msg; unsigned char *msg;
unsigned char current_attr; unsigned char current_attr;
PRINTF("Trying to remove init data\n");
remove_init_data(); remove_init_data();
PRINTF("Removed init data from cache, now in RAM\n"); PRINTF("Removed init data from cache, now in RAM\n");
@ -438,7 +437,7 @@ int execute_bios(pci_dev_t gr_dev, void *reloc_addr)
return 0; return 0;
} }
#ifdef DEBUG #if 1 /*def DEBUG*/
s = getenv("x86_ask_start"); s = getenv("x86_ask_start");
if (s) if (s)
{ {
@ -646,7 +645,7 @@ int execute_bios(pci_dev_t gr_dev, void *reloc_addr)
if (getenv("x86_do_inout")) do_inout(); if (getenv("x86_do_inout")) do_inout();
#endif #endif
dcache_disable(); //FIXME: dcache_disable();
return 1; return 1;
} }

@ -2,7 +2,7 @@
#include <command.h> #include <command.h>
#include <cmd_menu.h> #include <cmd_menu.h>
int do_menu( cmd_tbl_t *cmdtp, bd_t *bd, int flag, int argc, char *argv[] ) int do_menu( cmd_tbl_t *cmdtp, /*bd_t *bd,*/ int flag, int argc, char *argv[] )
{ {
// printf("<NOT YET IMPLEMENTED>\n"); // printf("<NOT YET IMPLEMENTED>\n");
return 0; return 0;

@ -56,11 +56,13 @@ SECTIONS
/* WARNING - the following is hand-optimized to fit within */ /* WARNING - the following is hand-optimized to fit within */
/* the sector layout of our flash chips! XXX FIXME XXX */ /* the sector layout of our flash chips! XXX FIXME XXX */
cpu/mpc8xx/start.o (.text) cpu/mpc8xx/start.o (.text)
common/dlmalloc.o (.text) common/dlmalloc.o (.text)
lib_ppc/ppcstring.o (.text) cpu/mpc8xx/interrupts.o (.text)
cpu/mpc8xx/interrupts.o (.text)
lib_ppc/time.o (.text) lib_ppc/time.o (.text)
lib_ppc/ticks.o (.text)
lib_ppc/cache.o (.text)
lib_generic/crc32.o (.text)
. = env_offset; . = env_offset;
common/environment.o(.text) common/environment.o(.text)

@ -202,7 +202,7 @@ int checkboard (void)
if (!i || strncmp (str, "TQM8260", 7)) { if (!i || strncmp (str, "TQM8260", 7)) {
puts ("### No HW ID - assuming TQM8260\n"); puts ("### No HW ID - assuming TQM8260\n");
return (1); return (0);
} }
puts (str); puts (str);

@ -344,7 +344,7 @@ int drv_vfd_init(void)
DECLARE_GLOBAL_DATA_PTR; DECLARE_GLOBAL_DATA_PTR;
if (vfd_init_done != 0) if (vfd_init_done != 0)
return; return (0);
vfd_init_done = 1; vfd_init_done = 1;
vfdbase = gd->fb_base; vfdbase = gd->fb_base;

@ -205,9 +205,27 @@ void pci_header_show(pci_dev_t dev)
PRINT (" header type = 0x%.2x\n", byte, PCI_HEADER_TYPE); PRINT (" header type = 0x%.2x\n", byte, PCI_HEADER_TYPE);
PRINT (" BIST = 0x%.2x\n", byte, PCI_BIST); PRINT (" BIST = 0x%.2x\n", byte, PCI_BIST);
PRINT (" base address 0 = 0x%.8x\n", dword, PCI_BASE_ADDRESS_0); PRINT (" base address 0 = 0x%.8x\n", dword, PCI_BASE_ADDRESS_0);
PRINT (" base address 1 = 0x%.8x\n", dword, PCI_BASE_ADDRESS_1);
if (header_type & 0x01) { /* PCI-to-PCI bridge */ switch (header_type & 0x03) {
case PCI_HEADER_TYPE_NORMAL: /* "normal" PCI device */
PRINT (" base address 1 = 0x%.8x\n", dword, PCI_BASE_ADDRESS_1);
PRINT (" base address 2 = 0x%.8x\n", dword, PCI_BASE_ADDRESS_2);
PRINT (" base address 3 = 0x%.8x\n", dword, PCI_BASE_ADDRESS_3);
PRINT (" base address 4 = 0x%.8x\n", dword, PCI_BASE_ADDRESS_4);
PRINT (" base address 5 = 0x%.8x\n", dword, PCI_BASE_ADDRESS_5);
PRINT (" cardBus CIS pointer = 0x%.8x\n", dword, PCI_CARDBUS_CIS);
PRINT (" sub system vendor ID = 0x%.4x\n", word, PCI_SUBSYSTEM_VENDOR_ID);
PRINT (" sub system ID = 0x%.4x\n", word, PCI_SUBSYSTEM_ID);
PRINT (" expansion ROM base address = 0x%.8x\n", dword, PCI_ROM_ADDRESS);
PRINT (" interrupt line = 0x%.2x\n", byte, PCI_INTERRUPT_LINE);
PRINT (" interrupt pin = 0x%.2x\n", byte, PCI_INTERRUPT_PIN);
PRINT (" min Grant = 0x%.2x\n", byte, PCI_MIN_GNT);
PRINT (" max Latency = 0x%.2x\n", byte, PCI_MAX_LAT);
break;
case PCI_HEADER_TYPE_BRIDGE: /* PCI-to-PCI bridge */
PRINT (" base address 1 = 0x%.8x\n", dword, PCI_BASE_ADDRESS_1);
PRINT (" primary bus number = 0x%.2x\n", byte, PCI_PRIMARY_BUS); PRINT (" primary bus number = 0x%.2x\n", byte, PCI_PRIMARY_BUS);
PRINT (" secondary bus number = 0x%.2x\n", byte, PCI_SECONDARY_BUS); PRINT (" secondary bus number = 0x%.2x\n", byte, PCI_SECONDARY_BUS);
PRINT (" subordinate bus number = 0x%.2x\n", byte, PCI_SUBORDINATE_BUS); PRINT (" subordinate bus number = 0x%.2x\n", byte, PCI_SUBORDINATE_BUS);
@ -227,19 +245,39 @@ void pci_header_show(pci_dev_t dev)
PRINT (" interrupt line = 0x%.2x\n", byte, PCI_INTERRUPT_LINE); PRINT (" interrupt line = 0x%.2x\n", byte, PCI_INTERRUPT_LINE);
PRINT (" interrupt pin = 0x%.2x\n", byte, PCI_INTERRUPT_PIN); PRINT (" interrupt pin = 0x%.2x\n", byte, PCI_INTERRUPT_PIN);
PRINT (" bridge control = 0x%.4x\n", word, PCI_BRIDGE_CONTROL); PRINT (" bridge control = 0x%.4x\n", word, PCI_BRIDGE_CONTROL);
} else { /* PCI device */ break;
PRINT(" base address 2 = 0x%.8x\n", dword, PCI_BASE_ADDRESS_2);
PRINT(" base address 3 = 0x%.8x\n", dword, PCI_BASE_ADDRESS_3); case PCI_HEADER_TYPE_CARDBUS: /* PCI-to-CardBus bridge */
PRINT(" base address 4 = 0x%.8x\n", dword, PCI_BASE_ADDRESS_4);
PRINT(" base address 5 = 0x%.8x\n", dword, PCI_BASE_ADDRESS_5); PRINT (" capabilities = 0x%.2x\n", byte, PCI_CB_CAPABILITY_LIST);
PRINT(" cardBus CIS pointer = 0x%.8x\n", dword, PCI_CARDBUS_CIS); PRINT (" secondary status = 0x%.4x\n", word, PCI_CB_SEC_STATUS);
PRINT(" sub system vendor ID = 0x%.4x\n", word, PCI_SUBSYSTEM_VENDOR_ID); PRINT (" primary bus number = 0x%.2x\n", byte, PCI_CB_PRIMARY_BUS);
PRINT(" sub system ID = 0x%.4x\n", word, PCI_SUBSYSTEM_ID); PRINT (" CardBus number = 0x%.2x\n", byte, PCI_CB_CARD_BUS);
PRINT(" expansion ROM base address = 0x%.8x\n", dword, PCI_ROM_ADDRESS); PRINT (" subordinate bus number = 0x%.2x\n", byte, PCI_CB_SUBORDINATE_BUS);
PRINT(" interrupt line = 0x%.2x\n", byte, PCI_INTERRUPT_LINE); PRINT (" CardBus latency timer = 0x%.2x\n", byte, PCI_CB_LATENCY_TIMER);
PRINT(" interrupt pin = 0x%.2x\n", byte, PCI_INTERRUPT_PIN); PRINT (" CardBus memory base 0 = 0x%.8x\n", dword, PCI_CB_MEMORY_BASE_0);
PRINT(" min Grant = 0x%.2x\n", byte, PCI_MIN_GNT); PRINT (" CardBus memory limit 0 = 0x%.8x\n", dword, PCI_CB_MEMORY_LIMIT_0);
PRINT(" max Latency = 0x%.2x\n", byte, PCI_MAX_LAT); PRINT (" CardBus memory base 1 = 0x%.8x\n", dword, PCI_CB_MEMORY_BASE_1);
PRINT (" CardBus memory limit 1 = 0x%.8x\n", dword, PCI_CB_MEMORY_LIMIT_1);
PRINT (" CardBus IO base 0 = 0x%.4x\n", word, PCI_CB_IO_BASE_0);
PRINT (" CardBus IO base high 0 = 0x%.4x\n", word, PCI_CB_IO_BASE_0_HI);
PRINT (" CardBus IO limit 0 = 0x%.4x\n", word, PCI_CB_IO_LIMIT_0);
PRINT (" CardBus IO limit high 0 = 0x%.4x\n", word, PCI_CB_IO_LIMIT_0_HI);
PRINT (" CardBus IO base 1 = 0x%.4x\n", word, PCI_CB_IO_BASE_1);
PRINT (" CardBus IO base high 1 = 0x%.4x\n", word, PCI_CB_IO_BASE_1_HI);
PRINT (" CardBus IO limit 1 = 0x%.4x\n", word, PCI_CB_IO_LIMIT_1);
PRINT (" CardBus IO limit high 1 = 0x%.4x\n", word, PCI_CB_IO_LIMIT_1_HI);
PRINT (" interrupt line = 0x%.2x\n", byte, PCI_INTERRUPT_LINE);
PRINT (" interrupt pin = 0x%.2x\n", byte, PCI_INTERRUPT_PIN);
PRINT (" bridge control = 0x%.4x\n", word, PCI_CB_BRIDGE_CONTROL);
PRINT (" subvendor ID = 0x%.4x\n", word, PCI_CB_SUBSYSTEM_VENDOR_ID);
PRINT (" subdevice ID = 0x%.4x\n", word, PCI_CB_SUBSYSTEM_ID);
PRINT (" PC Card 16bit base address = 0x%.8x\n", dword, PCI_CB_LEGACY_MODE_BASE);
break;
default:
printf("unknown header\n");
break;
} }
#undef PRINT #undef PRINT

@ -156,6 +156,21 @@ static uchar env_get_char_init (int index)
return (c); return (c);
} }
#ifdef CONFIG_AMIGAONEG3SE
uchar env_get_char_memory (int index)
{
DECLARE_GLOBAL_DATA_PTR;
uchar retval;
enable_nvram();
if (gd->env_valid) {
retval = ( *((uchar *)(gd->env_addr + index)) );
} else {
retval = ( default_environment[index] );
}
disable_nvram();
return retval;
}
#else
uchar env_get_char_memory (int index) uchar env_get_char_memory (int index)
{ {
DECLARE_GLOBAL_DATA_PTR; DECLARE_GLOBAL_DATA_PTR;
@ -166,6 +181,7 @@ uchar env_get_char_memory (int index)
return ( default_environment[index] ); return ( default_environment[index] );
} }
} }
#endif
uchar *env_get_addr (int index) uchar *env_get_addr (int index)
{ {

@ -66,7 +66,25 @@ extern int default_environment_size;
extern uchar (*env_get_char)(int); extern uchar (*env_get_char)(int);
extern uchar env_get_char_memory (int index); extern uchar env_get_char_memory (int index);
#ifdef CONFIG_AMIGAONEG3SE
uchar env_get_char_spec (int index)
{
#ifdef CFG_NVRAM_ACCESS_ROUTINE
uchar c;
nvram_read(&c, CFG_ENV_ADDR+index, 1);
return c;
#else
DECLARE_GLOBAL_DATA_PTR;
uchar retval;
enable_nvram();
retval = *((uchar *)(gd->env_addr + index));
disable_nvram();
return retval;
#endif
}
#else
uchar env_get_char_spec (int index) uchar env_get_char_spec (int index)
{ {
#ifdef CFG_NVRAM_ACCESS_ROUTINE #ifdef CFG_NVRAM_ACCESS_ROUTINE
@ -81,6 +99,7 @@ uchar env_get_char_spec (int index)
return *((uchar *)(gd->env_addr + index)); return *((uchar *)(gd->env_addr + index));
#endif #endif
} }
#endif
void env_relocate_spec (void) void env_relocate_spec (void)
{ {
@ -94,13 +113,19 @@ void env_relocate_spec (void)
int saveenv (void) int saveenv (void)
{ {
int rcode = 0; int rcode = 0;
#ifdef CONFIG_AMIGAONEG3SE
enable_nvram();
#endif
#ifdef CFG_NVRAM_ACCESS_ROUTINE #ifdef CFG_NVRAM_ACCESS_ROUTINE
nvram_write(CFG_ENV_ADDR, env_ptr, CFG_ENV_SIZE); nvram_write(CFG_ENV_ADDR, env_ptr, CFG_ENV_SIZE);
#else #else
if (memcpy ((char *)CFG_ENV_ADDR, env_ptr, CFG_ENV_SIZE) == NULL) if (memcpy ((char *)CFG_ENV_ADDR, env_ptr, CFG_ENV_SIZE) == NULL)
rcode = 1 ; rcode = 1 ;
#endif #endif
#ifdef CONFIG_AMIGAONEG3SE
udelay(10000);
disable_nvram();
#endif
return rcode; return rcode;
} }
@ -113,7 +138,9 @@ int saveenv (void)
int env_init (void) int env_init (void)
{ {
DECLARE_GLOBAL_DATA_PTR; DECLARE_GLOBAL_DATA_PTR;
#ifdef CONFIG_AMIGAONEG3SE
enable_nvram();
#endif
#if defined(CFG_NVRAM_ACCESS_ROUTINE) #if defined(CFG_NVRAM_ACCESS_ROUTINE)
ulong crc; ulong crc;
uchar data[ENV_SIZE]; uchar data[ENV_SIZE];
@ -131,7 +158,9 @@ int env_init (void)
gd->env_addr = (ulong)&default_environment[0]; gd->env_addr = (ulong)&default_environment[0];
gd->env_valid = 0; gd->env_valid = 0;
} }
#ifdef CONFIG_AMIGAONEG3SE
disable_nvram();
#endif
return (0); return (0);
} }

@ -177,7 +177,14 @@ SystemCall:
add r11,r11,r0 add r11,r11,r0
lwz r11,0(r11) lwz r11,0(r11)
li r12,0xd00-4*3 /* save LR & SRRx */ li r20,0xd00-4 /* Get stack pointer */
lwz r12,0(r20)
subi r12,r12,12 /* Adjust stack pointer */
li r0,0xc00+_end_back-SystemCall
cmplw 0, r0, r12 /* Check stack overflow */
bgt 1f
stw r12,0(r20)
mflr r0 mflr r0
stw r0,0(r12) stw r0,0(r12)
mfspr r0,SRR0 mfspr r0,SRR0
@ -202,7 +209,9 @@ _back:
mtmsr r11 mtmsr r11
SYNC SYNC
li r12,0xd00-4*3 /* restore regs */ li r12,0xd00-4 /* restore regs */
lwz r12,0(r12)
lwz r11,0(r12) lwz r11,0(r12)
mtlr r11 mtlr r11
lwz r11,4(r12) lwz r11,4(r12)
@ -210,8 +219,13 @@ _back:
lwz r11,8(r12) lwz r11,8(r12)
mtspr SRR1,r11 mtspr SRR1,r11
addi r12,r12,12 /* Adjust stack pointer */
li r20,0xd00-4
stw r12,0(r20)
SYNC SYNC
rfi rfi
_end_back:
STD_EXCEPTION(0xd00, SingleStep, UnknownException) STD_EXCEPTION(0xd00, SingleStep, UnknownException)
@ -716,6 +730,9 @@ in_ram:
bne 5b bne 5b
6: 6:
mr r3, r10 /* Destination Address */ mr r3, r10 /* Destination Address */
#ifdef CONFIG_AMIGAONEG3SE
mr r4, r9 /* Use RAM copy of the global data */
#endif
bl after_reloc bl after_reloc
/* not reached - end relocate_code */ /* not reached - end relocate_code */

@ -108,6 +108,9 @@
#define EPIC_PROC_INT_ACK_REG (EPIC_EUMBBAR + 0x200a0)/* Int. acknowledge */ #define EPIC_PROC_INT_ACK_REG (EPIC_EUMBBAR + 0x200a0)/* Int. acknowledge */
#define EPIC_PROC_EOI_REG (EPIC_EUMBBAR + 0x200b0)/* End of interrupt */ #define EPIC_PROC_EOI_REG (EPIC_EUMBBAR + 0x200b0)/* End of interrupt */
#define EPIC_VEC_PRI_MASK 0x80000000 /* Mask Interrupt bit in IVPR */
#define EPIC_VEC_PRI_DFLT_PRI 8 /* Interrupt Priority in IVPR */
/* Error code */ /* Error code */
#define OK 0 #define OK 0

@ -70,6 +70,10 @@ void epicInit
tmp = sysEUMBBARRead(EPIC_GLOBAL_REG); tmp = sysEUMBBARRead(EPIC_GLOBAL_REG);
tmp |= 0xa0000000; /* Set the Global Conf. register */ tmp |= 0xa0000000; /* Set the Global Conf. register */
sysEUMBBARWrite(EPIC_GLOBAL_REG, tmp); sysEUMBBARWrite(EPIC_GLOBAL_REG, tmp);
/*
* Wait for EPIC to reset - CLH
*/
while( (sysEUMBBARRead(EPIC_GLOBAL_REG) & 0x80000000) == 1);
sysEUMBBARWrite(EPIC_GLOBAL_REG, 0x20000000); sysEUMBBARWrite(EPIC_GLOBAL_REG, 0x20000000);
tmp = sysEUMBBARRead(EPIC_INT_CONF_REG); /* Read interrupt conf. reg */ tmp = sysEUMBBARRead(EPIC_INT_CONF_REG); /* Read interrupt conf. reg */
@ -81,7 +85,8 @@ void epicInit
sysEUMBBARWrite(EPIC_INT_CONF_REG, tmp); sysEUMBBARWrite(EPIC_INT_CONF_REG, tmp);
} }
while (epicIntAck() != 0xff); /* Clear all pending interrupts */ while (epicIntAck() != 0xff) /* Clear all pending interrupts */
epicEOI();
} }
/**************************************************************************** /****************************************************************************
@ -92,18 +97,18 @@ void epicInit
* *
* RETURNS: None * RETURNS: None
*/ */
void epicIntEnable void epicIntEnable(int intVec)
( {
int intVec /* Interrupt Vector Number */
)
{
ULONG tmp; ULONG tmp;
ULONG srAddr; ULONG srAddr;
srAddr = SrcVecTable[intVec].srcAddr; /* Retrieve src Vec/Prio register */ srAddr = SrcVecTable[intVec].srcAddr; /* Retrieve src Vec/Prio register */
tmp = sysEUMBBARRead(srAddr); tmp = sysEUMBBARRead(srAddr);
tmp &= 0x7fffffff; /* Clear the mask bit */ tmp &= ~EPIC_VEC_PRI_MASK; /* Clear the mask bit */
tmp |= (EPIC_VEC_PRI_DFLT_PRI << 16); /* Set priority to Default - CLH */
tmp |= intVec; /* Set Vector number */
sysEUMBBARWrite(srAddr, tmp); sysEUMBBARWrite(srAddr, tmp);
return; return;
} }

@ -92,6 +92,8 @@ int interrupt_init (void)
*/ */
epicInit (EPIC_DIRECT_IRQ, 0); epicInit (EPIC_DIRECT_IRQ, 0);
/* EPIC won't generate INT unless Current Task Pri < 15 */
epicCurTaskPrioSet(0);
set_dec (decrementer_count); set_dec (decrementer_count);

@ -278,7 +278,14 @@ SystemCall:
add r11,r11,r0 add r11,r11,r0
lwz r11,0(r11) lwz r11,0(r11)
li r12,0xd00-4*3 /* save LR & SRRx */ li r20,0xd00-4 /* Get stack pointer */
lwz r12,0(r20)
subi r12,r12,12 /* Adjust stack pointer */
li r0,0xc00+_end_back-SystemCall
cmplw 0, r0, r12 /* Check stack overflow */
bgt 1f
stw r12,0(r20)
mflr r0 mflr r0
stw r0,0(r12) stw r0,0(r12)
mfspr r0,SRR0 mfspr r0,SRR0
@ -303,7 +310,9 @@ _back:
mtmsr r11 mtmsr r11
SYNC SYNC
li r12,0xd00-4*3 /* restore regs */ li r12,0xd00-4 /* restore regs */
lwz r12,0(r12)
lwz r11,0(r12) lwz r11,0(r12)
mtlr r11 mtlr r11
lwz r11,4(r12) lwz r11,4(r12)
@ -311,8 +320,13 @@ _back:
lwz r11,8(r12) lwz r11,8(r12)
mtspr SRR1,r11 mtspr SRR1,r11
addi r12,r12,12 /* Adjust stack pointer */
li r20,0xd00-4
stw r12,0(r20)
SYNC SYNC
rfi rfi
_end_back:
STD_EXCEPTION(EXC_OFF_TRACE, SingleStep, UnknownException) STD_EXCEPTION(EXC_OFF_TRACE, SingleStep, UnknownException)

@ -324,7 +324,14 @@ SystemCall:
add r11,r11,r0 add r11,r11,r0
lwz r11,0(r11) lwz r11,0(r11)
li r12,0xd00-4*3 /* save LR & SRRx */ li r20,0xd00-4 /* Get stack pointer */
lwz r12,0(r20)
subi r12,r12,12 /* Adjust stack pointer */
li r0,0xc00+_end_back-SystemCall
cmplw 0, r0, r12 /* Check stack overflow */
bgt 1f
stw r12,0(r20)
mflr r0 mflr r0
stw r0,0(r12) stw r0,0(r12)
mfspr r0,SRR0 mfspr r0,SRR0
@ -349,7 +356,9 @@ _back:
mtmsr r11 mtmsr r11
SYNC SYNC
li r12,0xd00-4*3 /* restore regs */ li r12,0xd00-4 /* restore regs */
lwz r12,0(r12)
lwz r11,0(r12) lwz r11,0(r12)
mtlr r11 mtlr r11
lwz r11,4(r12) lwz r11,4(r12)
@ -357,8 +366,13 @@ _back:
lwz r11,8(r12) lwz r11,8(r12)
mtspr SRR1,r11 mtspr SRR1,r11
addi r12,r12,12 /* Adjust stack pointer */
li r20,0xd00-4
stw r12,0(r20)
SYNC SYNC
rfi rfi
_end_back:
STD_EXCEPTION(0xd00, SingleStep, UnknownException) STD_EXCEPTION(0xd00, SingleStep, UnknownException)

@ -28,99 +28,104 @@
#include <asm/processor.h> #include <asm/processor.h>
#include <commproc.h> #include <commproc.h>
/****************************************************************************/ /************************************************************************/
unsigned decrementer_count; /* count value for 1e6/HZ microseconds */ unsigned decrementer_count; /* count value for 1e6/HZ microseconds */
/****************************************************************************/ /************************************************************************/
/* /*
* CPM interrupt vector functions. * CPM interrupt vector functions.
*/ */
struct cpm_action { struct interrupt_action {
interrupt_handler_t *handler; interrupt_handler_t *handler;
void *arg; void *arg;
}; };
static struct cpm_action cpm_vecs[CPMVEC_NR]; static struct interrupt_action cpm_vecs[CPMVEC_NR];
static struct interrupt_action irq_vecs[NR_IRQS];
static void cpm_interrupt_init (void); static void cpm_interrupt_init (void);
static void cpm_interrupt(int irq, struct pt_regs * regs); static void cpm_interrupt (void *regs);
/****************************************************************************/ /************************************************************************/
static __inline__ unsigned long get_msr(void) static __inline__ unsigned long get_msr (void)
{ {
unsigned long msr; unsigned long msr;
asm volatile("mfmsr %0" : "=r" (msr) :); asm volatile ("mfmsr %0":"=r" (msr):);
return msr;
return msr;
} }
static __inline__ void set_msr(unsigned long msr) static __inline__ void set_msr (unsigned long msr)
{ {
asm volatile("mtmsr %0" : : "r" (msr)); asm volatile ("mtmsr %0"::"r" (msr));
} }
static __inline__ unsigned long get_dec(void) static __inline__ unsigned long get_dec (void)
{ {
unsigned long val; unsigned long val;
asm volatile ("mfdec %0":"=r" (val):);
asm volatile("mfdec %0" : "=r" (val) :); return val;
return val;
} }
static __inline__ void set_dec(unsigned long val) static __inline__ void set_dec (unsigned long val)
{ {
asm volatile("mtdec %0" : : "r" (val)); asm volatile ("mtdec %0"::"r" (val));
} }
void enable_interrupts (void) void enable_interrupts (void)
{ {
set_msr (get_msr() | MSR_EE); set_msr (get_msr () | MSR_EE);
} }
/* returns flag if MSR_EE was set before */ /* returns flag if MSR_EE was set before */
int disable_interrupts (void) int disable_interrupts (void)
{ {
ulong msr = get_msr(); ulong msr = get_msr ();
set_msr (msr & ~MSR_EE); set_msr (msr & ~MSR_EE);
return ((msr & MSR_EE) != 0); return ((msr & MSR_EE) != 0);
} }
/****************************************************************************/ /************************************************************************/
int interrupt_init(void) int interrupt_init (void)
{ {
volatile immap_t *immr = (immap_t *)CFG_IMMR; volatile immap_t *immr = (immap_t *) CFG_IMMR;
decrementer_count = get_tbclk() / CFG_HZ; decrementer_count = get_tbclk () / CFG_HZ;
cpm_interrupt_init(); /* disable all interrupts */
immr->im_siu_conf.sc_simask = 0;
/* disable all interrupts except for the CPM interrupt */ /* Configure CPM interrupts */
immr->im_siu_conf.sc_simask = 1 << (31-CPM_INTERRUPT); cpm_interrupt_init ();
set_dec (decrementer_count); set_dec (decrementer_count);
set_msr (get_msr() | MSR_EE); set_msr (get_msr () | MSR_EE);
return (0); return (0);
} }
/****************************************************************************/ /************************************************************************/
/* /*
* Handle external interrupts * Handle external interrupts
*/ */
void external_interrupt(struct pt_regs *regs) void external_interrupt (struct pt_regs *regs)
{ {
volatile immap_t *immr = (immap_t *)CFG_IMMR; volatile immap_t *immr = (immap_t *) CFG_IMMR;
int irq; int irq;
ulong simask, newmask; ulong simask, newmask;
ulong vec, v_bit; ulong vec, v_bit;
/* /*
* read the SIVEC register and shift the bits down * read the SIVEC register and shift the bits down
@ -137,14 +142,15 @@ void external_interrupt(struct pt_regs *regs)
newmask = simask & (~(0xFFFF0000 >> irq)); newmask = simask & (~(0xFFFF0000 >> irq));
immr->im_siu_conf.sc_simask = newmask; immr->im_siu_conf.sc_simask = newmask;
if (!(irq & 0x1)) { /* External Interrupt ? */ if (!(irq & 0x1)) { /* External Interrupt ? */
ulong siel; ulong siel;
/* /*
* Read Interrupt Edge/Level Register * Read Interrupt Edge/Level Register
*/ */
siel = immr->im_siu_conf.sc_siel; siel = immr->im_siu_conf.sc_siel;
if (siel & v_bit) { /* edge triggered interrupt ? */ if (siel & v_bit) { /* edge triggered interrupt ? */
/* /*
* Rewrite SIPEND Register to clear interrupt * Rewrite SIPEND Register to clear interrupt
*/ */
@ -152,34 +158,29 @@ void external_interrupt(struct pt_regs *regs)
} }
} }
switch (irq) { if (irq_vecs[irq].handler != NULL) {
case CPM_INTERRUPT: irq_vecs[irq].handler (irq_vecs[irq].arg);
cpm_interrupt (irq, regs); } else {
break;
default:
printf ("\nBogus External Interrupt IRQ %d Vector %ld\n", printf ("\nBogus External Interrupt IRQ %d Vector %ld\n",
irq, vec); irq, vec);
/* turn off the bogus interrupt to avoid it from now */ /* turn off the bogus interrupt to avoid it from now */
simask &= ~v_bit; simask &= ~v_bit;
break;
} }
/* /*
* Re-Enable old Interrupt Mask * Re-Enable old Interrupt Mask
*/ */
immr->im_siu_conf.sc_simask = simask; immr->im_siu_conf.sc_simask = simask;
} }
/****************************************************************************/ /************************************************************************/
/* /*
* CPM interrupt handler * CPM interrupt handler
*/ */
static void static void cpm_interrupt (void *regs)
cpm_interrupt(int irq, struct pt_regs * regs)
{ {
volatile immap_t *immr = (immap_t *)CFG_IMMR; volatile immap_t *immr = (immap_t *) CFG_IMMR;
uint vec; uint vec;
/* /*
* Get the vector by setting the ACK bit * Get the vector by setting the ACK bit
@ -190,13 +191,14 @@ cpm_interrupt(int irq, struct pt_regs * regs)
vec >>= 11; vec >>= 11;
if (cpm_vecs[vec].handler != NULL) { if (cpm_vecs[vec].handler != NULL) {
(*cpm_vecs[vec].handler)(cpm_vecs[vec].arg); (*cpm_vecs[vec].handler) (cpm_vecs[vec].arg);
} else { } else {
immr->im_cpic.cpic_cimr &= ~(1 << vec); immr->im_cpic.cpic_cimr &= ~(1 << vec);
printf ("Masking bogus CPM interrupt vector 0x%x\n", vec); printf ("Masking bogus CPM interrupt vector 0x%x\n", vec);
} }
/* /*
* After servicing the interrupt, we have to remove the status indicator. * After servicing the interrupt,
* we have to remove the status indicator.
*/ */
immr->im_cpic.cpic_cisr |= (1 << vec); immr->im_cpic.cpic_cisr |= (1 << vec);
} }
@ -207,75 +209,110 @@ cpm_interrupt(int irq, struct pt_regs * regs)
* to do is ACK it and return. This is a no-op function so we don't * to do is ACK it and return. This is a no-op function so we don't
* need any special tests in the interrupt handler. * need any special tests in the interrupt handler.
*/ */
static void static void cpm_error_interrupt (void *dummy)
cpm_error_interrupt (void *dummy)
{ {
} }
/****************************************************************************/ /************************************************************************/
/* /*
* Install and free a CPM interrupt handler. * Install and free an interrupt handler
*/ */
void irq_install_handler (int vec, interrupt_handler_t * handler,
void void *arg)
irq_install_handler(int vec, interrupt_handler_t *handler, void *arg)
{ {
volatile immap_t *immr = (immap_t *)CFG_IMMR; volatile immap_t *immr = (immap_t *) CFG_IMMR;
if (cpm_vecs[vec].handler != NULL) { if ((vec & CPMVEC_OFFSET) != 0) {
printf ("CPM interrupt 0x%x replacing 0x%x\n", /* CPM interrupt */
(uint)handler, (uint)cpm_vecs[vec].handler); vec &= 0xffff;
} if (cpm_vecs[vec].handler != NULL) {
cpm_vecs[vec].handler = handler; printf ("CPM interrupt 0x%x replacing 0x%x\n",
cpm_vecs[vec].arg = arg; (uint) handler,
immr->im_cpic.cpic_cimr |= (1 << vec); (uint) cpm_vecs[vec].handler);
}
cpm_vecs[vec].handler = handler;
cpm_vecs[vec].arg = arg;
immr->im_cpic.cpic_cimr |= (1 << vec);
#if 0
printf ("Install CPM interrupt for vector %d ==> %p\n",
vec, handler);
#endif
} else {
/* SIU interrupt */
if (irq_vecs[vec].handler != NULL) {
printf ("SIU interrupt %d 0x%x replacing 0x%x\n",
vec,
(uint) handler,
(uint) cpm_vecs[vec].handler);
}
irq_vecs[vec].handler = handler;
irq_vecs[vec].arg = arg;
immr->im_siu_conf.sc_simask |= 1 << (31 - vec);
#if 0 #if 0
printf ("Install CPM interrupt for vector %d ==> %p\n", vec, handler); printf ("Install SIU interrupt for vector %d ==> %p\n",
vec, handler);
#endif #endif
}
} }
void void irq_free_handler (int vec)
irq_free_handler(int vec)
{ {
volatile immap_t *immr = (immap_t *)CFG_IMMR; volatile immap_t *immr = (immap_t *) CFG_IMMR;
if ((vec & CPMVEC_OFFSET) != 0) {
/* CPM interrupt */
vec &= 0xffff;
#if 0
printf ("Free CPM interrupt for vector %d ==> %p\n",
vec, cpm_vecs[vec].handler);
#endif
immr->im_cpic.cpic_cimr &= ~(1 << vec);
cpm_vecs[vec].handler = NULL;
cpm_vecs[vec].arg = NULL;
} else {
/* SIU interrupt */
#if 0 #if 0
printf ("Free CPM interrupt for vector %d ==> %p\n", printf ("Free CPM interrupt for vector %d ==> %p\n",
vec, cpm_vecs[vec].handler); vec, cpm_vecs[vec].handler);
#endif #endif
immr->im_cpic.cpic_cimr &= ~(1 << vec); immr->im_siu_conf.sc_simask &= ~(1 << (31 - vec));
cpm_vecs[vec].handler = NULL; irq_vecs[vec].handler = NULL;
cpm_vecs[vec].arg = NULL; irq_vecs[vec].arg = NULL;
}
} }
/****************************************************************************/ /************************************************************************/
static void static void cpm_interrupt_init (void)
cpm_interrupt_init (void)
{ {
volatile immap_t *immr = (immap_t *)CFG_IMMR; volatile immap_t *immr = (immap_t *) CFG_IMMR;
/* /*
* Initialize the CPM interrupt controller. * Initialize the CPM interrupt controller.
*/ */
immr->im_cpic.cpic_cicr = immr->im_cpic.cpic_cicr =
( CICR_SCD_SCC4 | (CICR_SCD_SCC4 |
CICR_SCC_SCC3 | CICR_SCC_SCC3 |
CICR_SCB_SCC2 | CICR_SCB_SCC2 |
CICR_SCA_SCC1 ) | ((CPM_INTERRUPT/2) << 13) | CICR_HP_MASK; CICR_SCA_SCC1) | ((CPM_INTERRUPT / 2) << 13) | CICR_HP_MASK;
immr->im_cpic.cpic_cimr = 0; immr->im_cpic.cpic_cimr = 0;
/* /*
* Install the error handler. * Install the error handler.
*/ */
irq_install_handler(CPMVEC_ERROR, cpm_error_interrupt, NULL); irq_install_handler (CPMVEC_ERROR, cpm_error_interrupt, NULL);
immr->im_cpic.cpic_cicr |= CICR_IEN; immr->im_cpic.cpic_cicr |= CICR_IEN;
/*
* Install the cpm interrupt handler
*/
irq_install_handler (CPM_INTERRUPT, cpm_interrupt, NULL);
} }
/****************************************************************************/ /************************************************************************/
volatile ulong timestamp = 0; volatile ulong timestamp = 0;
@ -284,18 +321,19 @@ volatile ulong timestamp = 0;
* with interrupts disabled. * with interrupts disabled.
* Trivial implementation - no need to be really accurate. * Trivial implementation - no need to be really accurate.
*/ */
void timer_interrupt(struct pt_regs *regs) void timer_interrupt (struct pt_regs *regs)
{ {
volatile immap_t *immr = (immap_t *)CFG_IMMR; volatile immap_t *immr = (immap_t *) CFG_IMMR;
#ifdef CONFIG_STATUS_LED #ifdef CONFIG_STATUS_LED
extern void status_led_tick (ulong); extern void status_led_tick (ulong);
#endif #endif
#if 0 #if 0
printf ("*** Timer Interrupt *** "); printf ("*** Timer Interrupt *** ");
#endif #endif
/* Reset Timer Expired and Timers Interrupt Status */ /* Reset Timer Expired and Timers Interrupt Status */
immr->im_clkrstk.cark_plprcrk = KAPWR_KEY; immr->im_clkrstk.cark_plprcrk = KAPWR_KEY;
__asm__("nop"); __asm__ ("nop");
immr->im_clkrst.car_plprcr |= PLPRCR_TEXPS | PLPRCR_TMIST; immr->im_clkrst.car_plprcr |= PLPRCR_TEXPS | PLPRCR_TMIST;
/* Restore Decrementer Count */ /* Restore Decrementer Count */
set_dec (decrementer_count); set_dec (decrementer_count);
@ -304,11 +342,10 @@ void timer_interrupt(struct pt_regs *regs)
#ifdef CONFIG_STATUS_LED #ifdef CONFIG_STATUS_LED
status_led_tick (timestamp); status_led_tick (timestamp);
#endif /* CONFIG_STATUS_LED */ #endif /* CONFIG_STATUS_LED */
#if defined(CONFIG_WATCHDOG) || defined(CFG_CMA_LCD_HEARTBEAT) #if defined(CONFIG_WATCHDOG) || defined(CFG_CMA_LCD_HEARTBEAT)
/* /*
* The shortest watchdog period of all boards (except LWMON) * The shortest watchdog period of all boards (except LWMON)
* is approx. 1 sec, thus re-trigger watchdog at least * is approx. 1 sec, thus re-trigger watchdog at least
@ -321,20 +358,20 @@ void timer_interrupt(struct pt_regs *regs)
#endif #endif
#if defined(CFG_CMA_LCD_HEARTBEAT) #if defined(CFG_CMA_LCD_HEARTBEAT)
extern void lcd_heartbeat(void); extern void lcd_heartbeat (void);
lcd_heartbeat();
lcd_heartbeat ();
#endif /* CFG_CMA_LCD_HEARTBEAT */ #endif /* CFG_CMA_LCD_HEARTBEAT */
#if defined(CONFIG_WATCHDOG) #if defined(CONFIG_WATCHDOG)
reset_8xx_watchdog(immr); reset_8xx_watchdog (immr);
#endif /* CONFIG_WATCHDOG */ #endif /* CONFIG_WATCHDOG */
} }
#endif /* CONFIG_WATCHDOG || CFG_CMA_LCD_HEARTBEAT */ #endif /* CONFIG_WATCHDOG || CFG_CMA_LCD_HEARTBEAT */
} }
/****************************************************************************/ /************************************************************************/
void reset_timer (void) void reset_timer (void)
{ {
@ -351,4 +388,4 @@ void set_timer (ulong t)
timestamp = t; timestamp = t;
} }
/****************************************************************************/ /************************************************************************/

@ -285,7 +285,14 @@ SystemCall:
add r11,r11,r0 add r11,r11,r0
lwz r11,0(r11) lwz r11,0(r11)
li r12,0xd00-4*3 /* save LR & SRRx */ li r20,0xd00-4 /* Get stack pointer */
lwz r12,0(r20)
subi r12,r12,12 /* Adjust stack pointer */
li r0,0xc00+_end_back-SystemCall
cmplw 0, r0, r12 /* Check stack overflow */
bgt 1f
stw r12,0(r20)
mflr r0 mflr r0
stw r0,0(r12) stw r0,0(r12)
mfspr r0,SRR0 mfspr r0,SRR0
@ -310,7 +317,9 @@ _back:
mtmsr r11 mtmsr r11
SYNC SYNC
li r12,0xd00-4*3 /* restore regs */ li r12,0xd00-4 /* restore regs */
lwz r12,0(r12)
lwz r11,0(r12) lwz r11,0(r12)
mtlr r11 mtlr r11
lwz r11,4(r12) lwz r11,4(r12)
@ -318,8 +327,13 @@ _back:
lwz r11,8(r12) lwz r11,8(r12)
mtspr SRR1,r11 mtspr SRR1,r11
addi r12,r12,12 /* Adjust stack pointer */
li r20,0xd00-4
stw r12,0(r20)
SYNC SYNC
rfi rfi
_end_back:
STD_EXCEPTION(0xd00, SingleStep, UnknownException) STD_EXCEPTION(0xd00, SingleStep, UnknownException)

@ -775,7 +775,14 @@ SystemCall:
add r11,r11,r0 add r11,r11,r0
lwz r11,0(r11) lwz r11,0(r11)
li r12,0xd00-4*3 /* save LR & SRRx */ li r20,0xd00-4 /* Get stack pointer */
lwz r12,0(r20)
subi r12,r12,12 /* Adjust stack pointer */
li r0,0xc00+_end_back-SystemCall
cmplw 0, r0, r12 /* Check stack overflow */
bgt 1f
stw r12,0(r20)
mflr r0 mflr r0
stw r0,0(r12) stw r0,0(r12)
mfspr r0,SRR0 mfspr r0,SRR0
@ -800,7 +807,9 @@ _back:
mtmsr r11 mtmsr r11
SYNC SYNC
li r12,0xd00-4*3 /* restore regs */ li r12,0xd00-4 /* restore regs */
lwz r12,0(r12)
lwz r11,0(r12) lwz r11,0(r12)
mtlr r11 mtlr r11
lwz r11,4(r12) lwz r11,4(r12)
@ -808,8 +817,13 @@ _back:
lwz r11,8(r12) lwz r11,8(r12)
mtspr SRR1,r11 mtspr SRR1,r11
addi r12,r12,12 /* Adjust stack pointer */
li r20,0xd00-4
stw r12,0(r20)
SYNC SYNC
rfi rfi
_end_back:
STD_EXCEPTION(0xd00, SingleStep, UnknownException) STD_EXCEPTION(0xd00, SingleStep, UnknownException)

@ -122,6 +122,7 @@ int timer (int argc, char *argv[])
tid_8xx_cpmtimer_t hw; tid_8xx_cpmtimer_t hw;
tid_8xx_cpmtimer_t *hwp = &hw; tid_8xx_cpmtimer_t *hwp = &hw;
int c; int c;
int running;
/* Pointer to CPM Timer structure */ /* Pointer to CPM Timer structure */
cpmtimerp = &((immap_t *) gd->bd->bi_immr_base)->im_cpmtimer; cpmtimerp = &((immap_t *) gd->bd->bi_immr_base)->im_cpmtimer;
@ -185,6 +186,7 @@ int timer (int argc, char *argv[])
*hwp->terp = (CPMT_EVENT_CAP | CPMT_EVENT_REF); *hwp->terp = (CPMT_EVENT_CAP | CPMT_EVENT_REF);
mon_printf (usage); mon_printf (usage);
running = 0;
while ((c = mon_getc()) != 'q') { while ((c = mon_getc()) != 'q') {
if (c == 'b') { if (c == 'b') {
@ -197,6 +199,7 @@ int timer (int argc, char *argv[])
/* enable timer */ /* enable timer */
*hwp->tgcrp |= (CPMT_GCR_RST << TID_TIMER_ID); *hwp->tgcrp |= (CPMT_GCR_RST << TID_TIMER_ID);
running = 1;
#ifdef DEBUG #ifdef DEBUG
mon_printf ("tgcr=0x%x, tmr=0x%x, trr=0x%x," mon_printf ("tgcr=0x%x, tmr=0x%x, trr=0x%x,"
@ -210,6 +213,7 @@ int timer (int argc, char *argv[])
mon_printf ("Stopping timer\n"); mon_printf ("Stopping timer\n");
*hwp->tgcrp &= ~(CPMT_GCR_MASK << TID_TIMER_ID); *hwp->tgcrp &= ~(CPMT_GCR_MASK << TID_TIMER_ID);
running = 0;
#ifdef DEBUG #ifdef DEBUG
mon_printf ("tgcr=0x%x, tmr=0x%x, trr=0x%x," mon_printf ("tgcr=0x%x, tmr=0x%x, trr=0x%x,"
@ -252,6 +256,12 @@ int timer (int argc, char *argv[])
} }
mon_printf (usage); mon_printf (usage);
} }
if (running) {
mon_printf ("Stopping timer\n");
*hwp->tgcrp &= ~(CPMT_GCR_MASK << TID_TIMER_ID);
mon_free_hdlr (hwp->cpm_vec);
}
return (0); return (0);
} }

@ -22,10 +22,10 @@
/* CPM Command register. /* CPM Command register.
*/ */
#define CPM_CR_RST ((ushort)0x8000) #define CPM_CR_RST ((ushort)0x8000)
#define CPM_CR_OPCODE ((ushort)0x0f00) #define CPM_CR_OPCODE ((ushort)0x0f00)
#define CPM_CR_CHAN ((ushort)0x00f0) #define CPM_CR_CHAN ((ushort)0x00f0)
#define CPM_CR_FLG ((ushort)0x0001) #define CPM_CR_FLG ((ushort)0x0001)
/* Some commands (there are more...later) /* Some commands (there are more...later)
*/ */
@ -39,14 +39,14 @@
/* Channel numbers. /* Channel numbers.
*/ */
#define CPM_CR_CH_SCC1 ((ushort)0x0000) #define CPM_CR_CH_SCC1 ((ushort)0x0000)
#define CPM_CR_CH_I2C ((ushort)0x0001) /* I2C and IDMA1 */ #define CPM_CR_CH_I2C ((ushort)0x0001) /* I2C and IDMA1 */
#define CPM_CR_CH_SCC2 ((ushort)0x0004) #define CPM_CR_CH_SCC2 ((ushort)0x0004)
#define CPM_CR_CH_SPI ((ushort)0x0005) /* SPI / IDMA2 / Timers */ #define CPM_CR_CH_SPI ((ushort)0x0005) /* SPI/IDMA2/Timers */
#define CPM_CR_CH_SCC3 ((ushort)0x0008) #define CPM_CR_CH_SCC3 ((ushort)0x0008)
#define CPM_CR_CH_SMC1 ((ushort)0x0009) /* SMC1 / DSP1 */ #define CPM_CR_CH_SMC1 ((ushort)0x0009) /* SMC1 / DSP1 */
#define CPM_CR_CH_SCC4 ((ushort)0x000c) #define CPM_CR_CH_SCC4 ((ushort)0x000c)
#define CPM_CR_CH_SMC2 ((ushort)0x000d) /* SMC2 / DSP2 */ #define CPM_CR_CH_SMC2 ((ushort)0x000d) /* SMC2 / DSP2 */
#define mk_cr_cmd(CH, CMD) ((CMD << 8) | (CH << 4)) #define mk_cr_cmd(CH, CMD) ((CMD << 8) | (CH << 4))
@ -523,8 +523,8 @@ typedef struct scc_enet {
#define PROFF_ENET PROFF_SCC2 #define PROFF_ENET PROFF_SCC2
#define CPM_CR_ENET CPM_CR_CH_SCC2 #define CPM_CR_ENET CPM_CR_CH_SCC2
#define SCC_ENET 1 #define SCC_ENET 1
#define PA_ENET_RXD ((ushort)0x0004) #define PA_ENET_RXD ((ushort)0x0004)
#define PA_ENET_TXD ((ushort)0x0008) #define PA_ENET_TXD ((ushort)0x0008)
#define PA_ENET_TCLK ((ushort)0x0100) #define PA_ENET_TCLK ((ushort)0x0100)
#define PA_ENET_RCLK ((ushort)0x0400) #define PA_ENET_RCLK ((ushort)0x0400)
#define PB_ENET_TENA ((uint)0x00002000) #define PB_ENET_TENA ((uint)0x00002000)
@ -1034,21 +1034,21 @@ typedef struct scc_enet {
#define PROFF_ENET PROFF_SCC2 #define PROFF_ENET PROFF_SCC2
#define CPM_CR_ENET CPM_CR_CH_SCC2 #define CPM_CR_ENET CPM_CR_CH_SCC2
#define SCC_ENET 1 #define SCC_ENET 1
#define PA_ENET_RXD ((ushort)0x0004) /* PA 13 */ #define PA_ENET_RXD ((ushort)0x0004) /* PA 13 */
#define PA_ENET_TXD ((ushort)0x0008) /* PA 12 */ #define PA_ENET_TXD ((ushort)0x0008) /* PA 12 */
#define PA_ENET_RCLK ((ushort)0x0200) /* PA 6 */ #define PA_ENET_RCLK ((ushort)0x0200) /* PA 6 */
#define PA_ENET_TCLK ((ushort)0x0800) /* PA 4 */ #define PA_ENET_TCLK ((ushort)0x0800) /* PA 4 */
#define PB_ENET_TENA ((uint)0x00002000) /* PB 18 */ #define PB_ENET_TENA ((uint)0x00002000) /* PB 18 */
#define PC_ENET_CLSN ((ushort)0x0040) /* PC 9 */ #define PC_ENET_CLSN ((ushort)0x0040) /* PC 9 */
#define PC_ENET_RENA ((ushort)0x0080) /* PC 8 */ #define PC_ENET_RENA ((ushort)0x0080) /* PC 8 */
/* Control bits in the SICR to route TCLK (CLK3) and RCLK (CLK1) to /* Control bits in the SICR to route TCLK (CLK3) and RCLK (CLK1) to
* SCC2. Also, make sure GR2 (bit 16) and SC2 (bit 17) are zero. * SCC2. Also, make sure GR2 (bit 16) and SC2 (bit 17) are zero.
*/ */
#define SICR_ENET_MASK ((uint)0x0000ff00) #define SICR_ENET_MASK ((uint)0x0000ff00)
#define SICR_ENET_CLKRT ((uint)0x00002f00) #define SICR_ENET_CLKRT ((uint)0x00002f00)
#endif /* CONFIG_NX823 */ #endif /* CONFIG_NX823 */
@ -1583,35 +1583,36 @@ typedef struct hdlc_pram_s {
* priority and SCC1 == SCCa, etc...). * priority and SCC1 == SCCa, etc...).
*/ */
#define CPMVEC_NR 32 #define CPMVEC_NR 32
#define CPMVEC_PIO_PC15 ((ushort)0x1f) #define CPMVEC_OFFSET 0x00010000
#define CPMVEC_SCC1 ((ushort)0x1e) #define CPMVEC_PIO_PC15 ((ushort)0x1f | CPMVEC_OFFSET)
#define CPMVEC_SCC2 ((ushort)0x1d) #define CPMVEC_SCC1 ((ushort)0x1e | CPMVEC_OFFSET)
#define CPMVEC_SCC3 ((ushort)0x1c) #define CPMVEC_SCC2 ((ushort)0x1d | CPMVEC_OFFSET)
#define CPMVEC_SCC4 ((ushort)0x1b) #define CPMVEC_SCC3 ((ushort)0x1c | CPMVEC_OFFSET)
#define CPMVEC_PIO_PC14 ((ushort)0x1a) #define CPMVEC_SCC4 ((ushort)0x1b | CPMVEC_OFFSET)
#define CPMVEC_TIMER1 ((ushort)0x19) #define CPMVEC_PIO_PC14 ((ushort)0x1a | CPMVEC_OFFSET)
#define CPMVEC_PIO_PC13 ((ushort)0x18) #define CPMVEC_TIMER1 ((ushort)0x19 | CPMVEC_OFFSET)
#define CPMVEC_PIO_PC12 ((ushort)0x17) #define CPMVEC_PIO_PC13 ((ushort)0x18 | CPMVEC_OFFSET)
#define CPMVEC_SDMA_CB_ERR ((ushort)0x16) #define CPMVEC_PIO_PC12 ((ushort)0x17 | CPMVEC_OFFSET)
#define CPMVEC_IDMA1 ((ushort)0x15) #define CPMVEC_SDMA_CB_ERR ((ushort)0x16 | CPMVEC_OFFSET)
#define CPMVEC_IDMA2 ((ushort)0x14) #define CPMVEC_IDMA1 ((ushort)0x15 | CPMVEC_OFFSET)
#define CPMVEC_TIMER2 ((ushort)0x12) #define CPMVEC_IDMA2 ((ushort)0x14 | CPMVEC_OFFSET)
#define CPMVEC_RISCTIMER ((ushort)0x11) #define CPMVEC_TIMER2 ((ushort)0x12 | CPMVEC_OFFSET)
#define CPMVEC_I2C ((ushort)0x10) #define CPMVEC_RISCTIMER ((ushort)0x11 | CPMVEC_OFFSET)
#define CPMVEC_PIO_PC11 ((ushort)0x0f) #define CPMVEC_I2C ((ushort)0x10 | CPMVEC_OFFSET)
#define CPMVEC_PIO_PC10 ((ushort)0x0e) #define CPMVEC_PIO_PC11 ((ushort)0x0f | CPMVEC_OFFSET)
#define CPMVEC_TIMER3 ((ushort)0x0c) #define CPMVEC_PIO_PC10 ((ushort)0x0e | CPMVEC_OFFSET)
#define CPMVEC_PIO_PC9 ((ushort)0x0b) #define CPMVEC_TIMER3 ((ushort)0x0c | CPMVEC_OFFSET)
#define CPMVEC_PIO_PC8 ((ushort)0x0a) #define CPMVEC_PIO_PC9 ((ushort)0x0b | CPMVEC_OFFSET)
#define CPMVEC_PIO_PC7 ((ushort)0x09) #define CPMVEC_PIO_PC8 ((ushort)0x0a | CPMVEC_OFFSET)
#define CPMVEC_TIMER4 ((ushort)0x07) #define CPMVEC_PIO_PC7 ((ushort)0x09 | CPMVEC_OFFSET)
#define CPMVEC_PIO_PC6 ((ushort)0x06) #define CPMVEC_TIMER4 ((ushort)0x07 | CPMVEC_OFFSET)
#define CPMVEC_SPI ((ushort)0x05) #define CPMVEC_PIO_PC6 ((ushort)0x06 | CPMVEC_OFFSET)
#define CPMVEC_SMC1 ((ushort)0x04) #define CPMVEC_SPI ((ushort)0x05 | CPMVEC_OFFSET)
#define CPMVEC_SMC2 ((ushort)0x03) #define CPMVEC_SMC1 ((ushort)0x04 | CPMVEC_OFFSET)
#define CPMVEC_PIO_PC5 ((ushort)0x02) #define CPMVEC_SMC2 ((ushort)0x03 | CPMVEC_OFFSET)
#define CPMVEC_PIO_PC4 ((ushort)0x01) #define CPMVEC_PIO_PC5 ((ushort)0x02 | CPMVEC_OFFSET)
#define CPMVEC_ERROR ((ushort)0x00) #define CPMVEC_PIO_PC4 ((ushort)0x01 | CPMVEC_OFFSET)
#define CPMVEC_ERROR ((ushort)0x00 | CPMVEC_OFFSET)
extern void irq_install_handler(int vec, void (*handler)(void *), void *dev_id); extern void irq_install_handler(int vec, void (*handler)(void *), void *dev_id);

@ -93,7 +93,7 @@
* Miscellaneous configurable options * Miscellaneous configurable options
*/ */
#define CFG_LONGHELP /* undef to save memory */ #define CFG_LONGHELP /* undef to save memory */
#define CFG_PROMPT "=> " /* Monitor Command Prompt */ #define CFG_PROMPT "] " /* Monitor Command Prompt */
#define CFG_HUSH_PARSER 1 /* use "hush" command parser */ #define CFG_HUSH_PARSER 1 /* use "hush" command parser */
/* #undef CFG_HUSH_PARSER */ /* #undef CFG_HUSH_PARSER */
@ -145,7 +145,8 @@
/* Size in bytes reserved for initial data /* Size in bytes reserved for initial data
*/ */
#define CFG_INIT_RAM_ADDR 0x400000 /* HJF: used to be 0x400000 */
#define CFG_INIT_RAM_ADDR 0x40000000
#define CFG_INIT_RAM_END 0x8000 #define CFG_INIT_RAM_END 0x8000
#define CFG_GBL_DATA_SIZE 128 #define CFG_GBL_DATA_SIZE 128
#define CFG_GBL_DATA_OFFSET (CFG_INIT_RAM_END - CFG_GBL_DATA_SIZE) #define CFG_GBL_DATA_OFFSET (CFG_INIT_RAM_END - CFG_GBL_DATA_SIZE)
@ -163,24 +164,37 @@
/* SDRAM 0 - 256MB /* SDRAM 0 - 256MB
*/ */
#define CFG_IBAT0L (CFG_SDRAM_BASE | BATL_PP_RW | BATL_CACHEINHIBIT) /*HJF: #define CFG_IBAT0L (CFG_SDRAM_BASE | BATL_PP_RW | BATL_CACHEINHIBIT)
#define CFG_IBAT0U (CFG_SDRAM_BASE | BATU_BL_4M | BATU_VS | BATU_VP) #define CFG_IBAT0U (CFG_SDRAM_BASE | BATU_BL_4M | BATU_VS | BATU_VP)
#define CFG_DBAT0L (CFG_SDRAM_BASE | BATL_PP_RW | BATL_CACHEINHIBIT) #define CFG_DBAT0L (CFG_SDRAM_BASE | BATL_PP_RW | BATL_CACHEINHIBIT)
#define CFG_DBAT0U CFG_IBAT0U #define CFG_DBAT0U CFG_IBAT0U*/
/* SDRAM 1 - 256MB #define CFG_DBAT0L (CFG_SDRAM_BASE | BATL_PP_10 | BATL_MEMCOHERENCE)
#define CFG_DBAT0U (CFG_SDRAM_BASE | BATU_BL_256M | BATU_VS | BATU_VP)
#define CFG_IBAT0L (CFG_SDRAM_BASE | BATL_PP_10 | BATL_MEMCOHERENCE)
#define CFG_IBAT0U (CFG_SDRAM_BASE | BATU_BL_256M | BATU_VS | BATU_VP)
/* PCI Range
*/ */
#define CFG_IBAT1L ((CFG_SDRAM_BASE+CFG_INIT_RAM_ADDR) | BATL_PP_RW) /* | BATL_CACHEINHIBIT) */ #define CFG_DBAT1L (0x80000000 | BATL_PP_RW | BATL_CACHEINHIBIT | BATL_GUARDEDSTORAGE)
#define CFG_DBAT1U (0x80000000 | BATU_BL_256M | BATU_VS | BATU_VP)
#define CFG_IBAT1L (0x80000000 | BATL_PP_RW | BATL_CACHEINHIBIT)
#define CFG_IBAT1U (0x80000000 | BATU_BL_256M | BATU_VS | BATU_VP)
/* HJF:
#define CFG_IBAT1L ((CFG_SDRAM_BASE+CFG_INIT_RAM_ADDR) | BATL_PP_RW)
#define CFG_IBAT1U ((CFG_SDRAM_BASE+CFG_INIT_RAM_ADDR) | BATU_BL_256M | BATU_VS | BATU_VP) #define CFG_IBAT1U ((CFG_SDRAM_BASE+CFG_INIT_RAM_ADDR) | BATU_BL_256M | BATU_VS | BATU_VP)
#define CFG_DBAT1L ((CFG_SDRAM_BASE+CFG_INIT_RAM_ADDR + 0x20000) | BATL_PP_RW ) /* | BATL_CACHEINHIBIT) */ #define CFG_DBAT1L ((CFG_SDRAM_BASE+CFG_INIT_RAM_ADDR + 0x20000) | BATL_PP_RW )
#define CFG_DBAT1U ((CFG_SDRAM_BASE+CFG_INIT_RAM_ADDR + 0x20000) | BATU_BL_256M | BATU_VS | BATU_VP) #define CFG_DBAT1U ((CFG_SDRAM_BASE+CFG_INIT_RAM_ADDR + 0x20000) | BATU_BL_256M | BATU_VS | BATU_VP)
*/
/* Init RAM in the CPU DCache (no backing memory) /* Init RAM in the CPU DCache (no backing memory)
*/ */
#define CFG_DBAT2L (CFG_INIT_RAM_ADDR | BATL_PP_RW | BATL_MEMCOHERENCE) #define CFG_DBAT2L (CFG_INIT_RAM_ADDR | BATL_PP_RW | BATL_MEMCOHERENCE)
#define CFG_DBAT2U (CFG_INIT_RAM_ADDR | BATU_BL_128K | BATU_VS | BATU_VP) #define CFG_DBAT2U (CFG_INIT_RAM_ADDR | BATU_BL_128K | BATU_VS | BATU_VP)
#define CFG_IBAT2L 0 /* CFG_DBAT2L */ /* This used to be commented out */
#define CFG_IBAT2U 0 /* CFG_DBAT2U */ #define CFG_IBAT2L CFG_DBAT2L
/* This here too */
#define CFG_IBAT2U CFG_DBAT2U
/* I/O and PCI memory at 0xf0000000 /* I/O and PCI memory at 0xf0000000
*/ */
@ -372,7 +386,7 @@
"pci_irqb_select=edge\0" \ "pci_irqb_select=edge\0" \
"pci_irqc=11\0" \ "pci_irqc=11\0" \
"pci_irqc_select=edge\0" \ "pci_irqc_select=edge\0" \
"pci_irqd=12\0" \ "pci_irqd=7\0" \
"pci_irqd_select=edge\0" "pci_irqd_select=edge\0"

@ -161,6 +161,11 @@ static void syscalls_init (void)
*addr++ |= NR_SYSCALLS & 0xFFFF; *addr++ |= NR_SYSCALLS & 0xFFFF;
flush_cache (0x0C00, 0x10); flush_cache (0x0C00, 0x10);
/* Initialize syscalls stack pointer */
addr = (ulong *) 0xCFC;
*addr = (ulong)addr;
flush_cache ((ulong)addr, 0x10);
} }
/* /*

Loading…
Cancel
Save