Commit 051063b5 authored by Linus Torvalds's avatar Linus Torvalds

Merge bk://linux-scsi.bkbits.net/scsi-for-linus-2.6

into home.osdl.org:/home/torvalds/v2.5/linux
parents 9430d91b 3b728486
...@@ -48,20 +48,24 @@ menu "Processor type and features" ...@@ -48,20 +48,24 @@ menu "Processor type and features"
choice choice
prompt "Platform" prompt "Platform"
default GDB default GDB
config V850E_SIM
bool "GDB"
config RTE_CB_MA1 config RTE_CB_MA1
bool "RTE-V850E/MA1-CB" bool "RTE-V850E/MA1-CB"
config RTE_CB_NB85E config RTE_CB_NB85E
bool "RTE-V850E/NB85E-CB" bool "RTE-V850E/NB85E-CB"
config V850E_SIM config RTE_CB_ME2
bool "GDB" bool "RTE-V850E/ME2-CB"
config V850E_AS85EP1
bool "AS85EP1"
config V850E2_SIM85E2C config V850E2_SIM85E2C
bool "sim85e2c" bool "sim85e2c"
config V850E2_SIM85E2S
bool "sim85e2s"
config V850E2_FPGA85E2C config V850E2_FPGA85E2C
bool "NA85E2C-FPGA" bool "NA85E2C-FPGA"
config V850E2_ANNA config V850E2_ANNA
bool "Anna" bool "Anna"
config V850E_AS85EP1
bool "AS85EP1"
endchoice endchoice
...@@ -78,41 +82,32 @@ menu "Processor type and features" ...@@ -78,41 +82,32 @@ menu "Processor type and features"
bool bool
depends RTE_CB_MA1 depends RTE_CB_MA1
default y default y
# Similarly for the RTE-V850E/MA1-CB - V850E/TEG # Similarly for the RTE-V850E/NB85E-CB - V850E/TEG
config V850E_TEG config V850E_TEG
bool bool
depends RTE_CB_NB85E depends RTE_CB_NB85E
default y default y
# ... and the RTE-V850E/ME2-CB - V850E/ME2
# NB85E processor core config V850E_ME2
config V850E_NB85E
bool bool
depends V850E_MA1 || V850E_TEG depends RTE_CB_ME2
default y default y
config V850E_MA1_HIGHRES_TIMER
bool "High resolution timer support"
depends V850E_MA1
#### sim85e2-specific config
#### V850E2 processor-specific config config V850E2_SIM85E2
# V850E2 processors
config V850E2
bool bool
depends V850E2_SIM85E2C || V850E2_FPGA85E2C || V850E2_ANNA depends V850E2_SIM85E2C || V850E2_SIM85E2S
default y default y
# Processors based on the NA85E2A core
config V850E2_NA85E2A
bool
depends V850E2_ANNA
default y
# Processors based on the NA85E2C core #### V850E2 processor-specific config
config V850E2_NA85E2C
# V850E2 processors
config V850E2
bool bool
depends V850E2_SIM85E2C || V850E2_FPGA85E2C depends V850E2_SIM85E2 || V850E2_FPGA85E2C || V850E2_ANNA
default y default y
...@@ -121,7 +116,7 @@ menu "Processor type and features" ...@@ -121,7 +116,7 @@ menu "Processor type and features"
# Boards in the RTE-x-CB series # Boards in the RTE-x-CB series
config RTE_CB config RTE_CB
bool bool
depends RTE_CB_MA1 || RTE_CB_NB85E depends RTE_CB_MA1 || RTE_CB_NB85E || RTE_CB_ME2
default y default y
config RTE_CB_MULTI config RTE_CB_MULTI
...@@ -129,7 +124,7 @@ menu "Processor type and features" ...@@ -129,7 +124,7 @@ menu "Processor type and features"
# RTE_CB_NB85E can either have multi ROM support or not, but # RTE_CB_NB85E can either have multi ROM support or not, but
# other platforms (currently only RTE_CB_MA1) require it. # other platforms (currently only RTE_CB_MA1) require it.
prompt "Multi monitor ROM support" if RTE_CB_NB85E prompt "Multi monitor ROM support" if RTE_CB_NB85E
depends RTE_CB depends RTE_CB_MA1 || RTE_CB_NB85E
default y default y
config RTE_CB_MULTI_DBTRAP config RTE_CB_MULTI_DBTRAP
...@@ -156,14 +151,42 @@ menu "Processor type and features" ...@@ -156,14 +151,42 @@ menu "Processor type and features"
# The only PCI bus we support is on the RTE-MOTHER-A board # The only PCI bus we support is on the RTE-MOTHER-A board
config PCI config PCI
bool bool
default y if RTE_MB_A_PCI default RTE_MB_A_PCI
#### Some feature-specific configs
# Everything except for the GDB simulator uses the same interrupt controller
config V850E_INTC
bool
default !V850E_SIM
# Everything except for the various simulators uses the "Timer D" unit
config V850E_TIMER_D
bool
default !V850E_SIM && !V850E2_SIM85E2
# Cache control used on some v850e1 processors
config V850E_CACHE
bool
default V850E_TEG || V850E_ME2
# Cache control used on v850e2 processors; I think this should
# actually apply to more, but currently only the SIM85E2S uses it
config V850E2_CACHE
bool
default V850E2_SIM85E2S
config NO_CACHE
bool
default !V850E_CACHE && !V850E2_CACHE
#### Misc config #### Misc config
config ROM_KERNEL config ROM_KERNEL
bool "Kernel in ROM" bool "Kernel in ROM"
depends V850E2_ANNA || (RTE_CB && !RTE_CB_MULTI) depends V850E2_ANNA || V850E_AS85EP1 || RTE_CB_ME2
# Some platforms pre-zero memory, in which case the kernel doesn't need to # Some platforms pre-zero memory, in which case the kernel doesn't need to
config ZERO_BSS config ZERO_BSS
...@@ -177,9 +200,12 @@ menu "Processor type and features" ...@@ -177,9 +200,12 @@ menu "Processor type and features"
int int
default 8 if V850E2_SIM85E2C || V850E2_FPGA85E2C default 8 if V850E2_SIM85E2C || V850E2_FPGA85E2C
config V850E_HIGHRES_TIMER
bool "High resolution timer support"
depends V850E_TIMER_D
config TIME_BOOTUP config TIME_BOOTUP
bool "Time bootup" bool "Time bootup"
depends V850E_MA1_HIGHRES_TIMER depends V850E_HIGHRES_TIMER
config RESET_GUARD config RESET_GUARD
bool "Reset Guard" bool "Reset Guard"
...@@ -241,6 +267,7 @@ config KCORE_AOUT ...@@ -241,6 +267,7 @@ config KCORE_AOUT
default y default y
config KCORE_ELF config KCORE_ELF
bool
default y default y
source "fs/Kconfig.binfmt" source "fs/Kconfig.binfmt"
......
...@@ -15,24 +15,26 @@ obj-y += intv.o entry.o process.o syscalls.o time.o semaphore.o setup.o \ ...@@ -15,24 +15,26 @@ obj-y += intv.o entry.o process.o syscalls.o time.o semaphore.o setup.o \
signal.o irq.o mach.o ptrace.o bug.o signal.o irq.o mach.o ptrace.o bug.o
obj-$(CONFIG_MODULES) += module.o v850_ksyms.o obj-$(CONFIG_MODULES) += module.o v850_ksyms.o
# chip-specific code # chip-specific code
obj-$(CONFIG_V850E_NB85E) += nb85e_intc.o obj-$(CONFIG_V850E_MA1) += ma.o
obj-$(CONFIG_V850E_MA1) += ma.o nb85e_utils.o nb85e_timer_d.o obj-$(CONFIG_V850E_ME2) += me2.o
obj-$(CONFIG_V850E_TEG) += teg.o nb85e_utils.o nb85e_cache.o \ obj-$(CONFIG_V850E_TEG) += teg.o
nb85e_timer_d.o obj-$(CONFIG_V850E_AS85EP1) += as85ep1.o
obj-$(CONFIG_V850E2_ANNA) += anna.o nb85e_intc.o nb85e_utils.o \ obj-$(CONFIG_V850E2_ANNA) += anna.o
nb85e_timer_d.o
obj-$(CONFIG_V850E_AS85EP1) += as85ep1.o nb85e_intc.o nb85e_utils.o \
nb85e_timer_d.o
# platform-specific code # platform-specific code
obj-$(CONFIG_V850E_SIM) += sim.o simcons.o obj-$(CONFIG_V850E_SIM) += sim.o simcons.o
obj-$(CONFIG_V850E2_SIM85E2C) += sim85e2c.o nb85e_intc.o memcons.o obj-$(CONFIG_V850E2_SIM85E2) += sim85e2.o memcons.o
obj-$(CONFIG_V850E2_FPGA85E2C) += fpga85e2c.o nb85e_intc.o memcons.o obj-$(CONFIG_V850E2_FPGA85E2C) += fpga85e2c.o memcons.o
obj-$(CONFIG_RTE_CB) += rte_cb.o rte_cb_leds.o obj-$(CONFIG_RTE_CB) += rte_cb.o rte_cb_leds.o
obj-$(CONFIG_RTE_CB_MA1) += rte_ma1_cb.o obj-$(CONFIG_RTE_CB_MA1) += rte_ma1_cb.o
obj-$(CONFIG_RTE_CB_ME2) += rte_me2_cb.o
obj-$(CONFIG_RTE_CB_NB85E) += rte_nb85e_cb.o obj-$(CONFIG_RTE_CB_NB85E) += rte_nb85e_cb.o
obj-$(CONFIG_RTE_CB_MULTI) += rte_cb_multi.o obj-$(CONFIG_RTE_CB_MULTI) += rte_cb_multi.o
obj-$(CONFIG_RTE_MB_A_PCI) += rte_mb_a_pci.o obj-$(CONFIG_RTE_MB_A_PCI) += rte_mb_a_pci.o
obj-$(CONFIG_RTE_GBUS_INT) += gbus_int.o obj-$(CONFIG_RTE_GBUS_INT) += gbus_int.o
# feature-specific code # feature-specific code
obj-$(CONFIG_V850E_MA1_HIGHRES_TIMER) += highres_timer.o obj-$(CONFIG_V850E_INTC) += v850e_intc.o
obj-$(CONFIG_V850E_TIMER_D) += v850e_timer_d.o v850e_utils.o
obj-$(CONFIG_V850E_CACHE) += v850e_cache.o
obj-$(CONFIG_V850E2_CACHE) += v850e2_cache.o
obj-$(CONFIG_V850E_HIGHRES_TIMER) += highres_timer.o
obj-$(CONFIG_PROC_FS) += procfs.o obj-$(CONFIG_PROC_FS) += procfs.o
/* /*
* arch/v850/kernel/anna.c -- Anna V850E2 evaluation chip/board * arch/v850/kernel/anna.c -- Anna V850E2 evaluation chip/board
* *
* Copyright (C) 2002 NEC Corporation * Copyright (C) 2002,03 NEC Electronics Corporation
* Copyright (C) 2002 Miles Bader <miles@gnu.org> * Copyright (C) 2002,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -21,8 +21,8 @@ ...@@ -21,8 +21,8 @@
#include <asm/machdep.h> #include <asm/machdep.h>
#include <asm/atomic.h> #include <asm/atomic.h>
#include <asm/page.h> #include <asm/page.h>
#include <asm/nb85e_timer_d.h> #include <asm/v850e_timer_d.h>
#include <asm/nb85e_uart.h> #include <asm/v850e_uart.h>
#include "mach.h" #include "mach.h"
...@@ -42,31 +42,33 @@ static void anna_led_tick (void); ...@@ -42,31 +42,33 @@ static void anna_led_tick (void);
void __init mach_early_init (void) void __init mach_early_init (void)
{ {
ANNA_ILBEN = 0; ANNA_ILBEN = 0;
ANNA_CSC(0) = 0x402F;
ANNA_CSC(1) = 0x4000; V850E2_CSC(0) = 0x402F;
ANNA_BPC = 0; V850E2_CSC(1) = 0x4000;
ANNA_BSC = 0xAAAA; V850E2_BPC = 0;
ANNA_BEC = 0; V850E2_BSC = 0xAAAA;
ANNA_BHC = 0xFFFF; /* icache all memory, dcache all */ V850E2_BEC = 0;
ANNA_BCT(0) = 0xB088;
ANNA_BCT(1) = 0x0008; #if 0
ANNA_DWC(0) = 0x0027; V850E2_BHC = 0xFFFF; /* icache all memory, dcache all */
ANNA_DWC(1) = 0; #else
ANNA_BCC = 0x0006; V850E2_BHC = 0; /* cache no memory */
ANNA_ASC = 0; #endif
ANNA_LBS = 0x0089; V850E2_BCT(0) = 0xB088;
ANNA_SCR3 = 0x21A9; V850E2_BCT(1) = 0x0008;
ANNA_RFS3 = 0x8121; V850E2_DWC(0) = 0x0027;
V850E2_DWC(1) = 0;
nb85e_intc_disable_irqs (); V850E2_BCC = 0x0006;
V850E2_ASC = 0;
V850E2_LBS = 0x0089;
V850E2_SCR(3) = 0x21A9;
V850E2_RFS(3) = 0x8121;
v850e_intc_disable_irqs ();
} }
void __init mach_setup (char **cmdline) void __init mach_setup (char **cmdline)
{ {
#ifdef CONFIG_V850E_NB85E_UART_CONSOLE
nb85e_uart_cons_init (1);
#endif
ANNA_PORT_PM (LEDS_PORT) = 0; /* Make all LED pins output pins. */ ANNA_PORT_PM (LEDS_PORT) = 0; /* Make all LED pins output pins. */
mach_tick = anna_led_tick; mach_tick = anna_led_tick;
} }
...@@ -95,12 +97,12 @@ void mach_gettimeofday (struct timespec *tv) ...@@ -95,12 +97,12 @@ void mach_gettimeofday (struct timespec *tv)
void __init mach_sched_init (struct irqaction *timer_action) void __init mach_sched_init (struct irqaction *timer_action)
{ {
/* Start hardware timer. */ /* Start hardware timer. */
nb85e_timer_d_configure (0, HZ); v850e_timer_d_configure (0, HZ);
/* Install timer interrupt handler. */ /* Install timer interrupt handler. */
setup_irq (IRQ_INTCMD(0), timer_action); setup_irq (IRQ_INTCMD(0), timer_action);
} }
static struct nb85e_intc_irq_init irq_inits[] = { static struct v850e_intc_irq_init irq_inits[] = {
{ "IRQ", 0, NUM_MACH_IRQS, 1, 7 }, { "IRQ", 0, NUM_MACH_IRQS, 1, 7 },
{ "PIN", IRQ_INTP(0), IRQ_INTP_NUM, 1, 4 }, { "PIN", IRQ_INTP(0), IRQ_INTP_NUM, 1, 4 },
{ "CCC", IRQ_INTCCC(0), IRQ_INTCCC_NUM, 1, 5 }, { "CCC", IRQ_INTCCC(0), IRQ_INTCCC_NUM, 1, 5 },
...@@ -118,7 +120,7 @@ static struct hw_interrupt_type hw_itypes[NUM_IRQ_INITS]; ...@@ -118,7 +120,7 @@ static struct hw_interrupt_type hw_itypes[NUM_IRQ_INITS];
void __init mach_init_irqs (void) void __init mach_init_irqs (void)
{ {
nb85e_intc_init_irq_types (irq_inits, hw_itypes); v850e_intc_init_irq_types (irq_inits, hw_itypes);
} }
void machine_restart (char *__unused) void machine_restart (char *__unused)
......
/* /*
* arch/v850/kernel/as85ep1.c -- AS85EP1 V850E evaluation chip/board * arch/v850/kernel/as85ep1.c -- AS85EP1 V850E evaluation chip/board
* *
* Copyright (C) 2002 NEC Corporation * Copyright (C) 2002,03 NEC Electronics Corporation
* Copyright (C) 2002 Miles Bader <miles@gnu.org> * Copyright (C) 2002,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -21,8 +21,8 @@ ...@@ -21,8 +21,8 @@
#include <asm/machdep.h> #include <asm/machdep.h>
#include <asm/atomic.h> #include <asm/atomic.h>
#include <asm/page.h> #include <asm/page.h>
#include <asm/nb85e_timer_d.h> #include <asm/v850e_timer_d.h>
#include <asm/nb85e_uart.h> #include <asm/v850e_uart.h>
#include "mach.h" #include "mach.h"
...@@ -90,20 +90,14 @@ void __init mach_early_init (void) ...@@ -90,20 +90,14 @@ void __init mach_early_init (void)
AS85EP1_IRAMM = 0x0; /* $BFbB"L?Na(BRAM$B$O!V(Bread-mode$B!W$K$J$j$^$9(B */ AS85EP1_IRAMM = 0x0; /* $BFbB"L?Na(BRAM$B$O!V(Bread-mode$B!W$K$J$j$^$9(B */
#endif /* !CONFIG_ROM_KERNEL */ #endif /* !CONFIG_ROM_KERNEL */
nb85e_intc_disable_irqs (); v850e_intc_disable_irqs ();
} }
void __init mach_setup (char **cmdline) void __init mach_setup (char **cmdline)
{ {
#ifdef CONFIG_V850E_NB85E_UART_CONSOLE
nb85e_uart_cons_init (1);
#endif
AS85EP1_PORT_PMC (LEDS_PORT) = 0; /* Make the LEDs port an I/O port. */ AS85EP1_PORT_PMC (LEDS_PORT) = 0; /* Make the LEDs port an I/O port. */
AS85EP1_PORT_PM (LEDS_PORT) = 0; /* Make all the bits output pins. */ AS85EP1_PORT_PM (LEDS_PORT) = 0; /* Make all the bits output pins. */
mach_tick = as85ep1_led_tick; mach_tick = as85ep1_led_tick;
ROOT_DEV = MKDEV (BLKMEM_MAJOR, 0);
} }
void __init mach_get_physical_ram (unsigned long *ram_start, void __init mach_get_physical_ram (unsigned long *ram_start,
...@@ -137,21 +131,21 @@ void __init mach_reserve_bootmem () ...@@ -137,21 +131,21 @@ void __init mach_reserve_bootmem ()
root_fs_image_end - root_fs_image_start); root_fs_image_end - root_fs_image_start);
} }
void mach_gettimeofday (struct timeval *tv) void mach_gettimeofday (struct timespec *tv)
{ {
tv->tv_sec = 0; tv->tv_sec = 0;
tv->tv_usec = 0; tv->tv_nsec = 0;
} }
void __init mach_sched_init (struct irqaction *timer_action) void __init mach_sched_init (struct irqaction *timer_action)
{ {
/* Start hardware timer. */ /* Start hardware timer. */
nb85e_timer_d_configure (0, HZ); v850e_timer_d_configure (0, HZ);
/* Install timer interrupt handler. */ /* Install timer interrupt handler. */
setup_irq (IRQ_INTCMD(0), timer_action); setup_irq (IRQ_INTCMD(0), timer_action);
} }
static struct nb85e_intc_irq_init irq_inits[] = { static struct v850e_intc_irq_init irq_inits[] = {
{ "IRQ", 0, NUM_MACH_IRQS, 1, 7 }, { "IRQ", 0, NUM_MACH_IRQS, 1, 7 },
{ "CCC", IRQ_INTCCC(0), IRQ_INTCCC_NUM, 1, 5 }, { "CCC", IRQ_INTCCC(0), IRQ_INTCCC_NUM, 1, 5 },
{ "CMD", IRQ_INTCMD(0), IRQ_INTCMD_NUM, 1, 5 }, { "CMD", IRQ_INTCMD(0), IRQ_INTCMD_NUM, 1, 5 },
...@@ -166,7 +160,7 @@ static struct hw_interrupt_type hw_itypes[NUM_IRQ_INITS]; ...@@ -166,7 +160,7 @@ static struct hw_interrupt_type hw_itypes[NUM_IRQ_INITS];
void __init mach_init_irqs (void) void __init mach_init_irqs (void)
{ {
nb85e_intc_init_irq_types (irq_inits, hw_itypes); v850e_intc_init_irq_types (irq_inits, hw_itypes);
} }
void machine_restart (char *__unused) void machine_restart (char *__unused)
......
...@@ -2,8 +2,8 @@ ...@@ -2,8 +2,8 @@
* arch/v850/kernel/fpga85e2c.h -- Machine-dependent defs for * arch/v850/kernel/fpga85e2c.h -- Machine-dependent defs for
* FPGA implementation of V850E2/NA85E2C * FPGA implementation of V850E2/NA85E2C
* *
* Copyright (C) 2002 NEC Corporation * Copyright (C) 2002,03 NEC Electronics Corporation
* Copyright (C) 2002 Miles Bader <miles@gnu.org> * Copyright (C) 2002,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -46,7 +46,7 @@ void __init mach_early_init (void) ...@@ -46,7 +46,7 @@ void __init mach_early_init (void)
/* Set bus sizes: CS0 32-bit, CS1 16-bit, CS7 8-bit, /* Set bus sizes: CS0 32-bit, CS1 16-bit, CS7 8-bit,
everything else 32-bit. */ everything else 32-bit. */
BSC = 0x2AA6; V850E2_BSC = 0x2AA6;
for (i = 2; i <= 6; i++) for (i = 2; i <= 6; i++)
CSDEV(i) = 0; /* 32 bit */ CSDEV(i) = 0; /* 32 bit */
...@@ -134,7 +134,7 @@ void machine_power_off (void) ...@@ -134,7 +134,7 @@ void machine_power_off (void)
/* Interrupts */ /* Interrupts */
struct nb85e_intc_irq_init irq_inits[] = { struct v850e_intc_irq_init irq_inits[] = {
{ "IRQ", 0, NUM_MACH_IRQS, 1, 7 }, { "IRQ", 0, NUM_MACH_IRQS, 1, 7 },
{ "RPU", IRQ_RPU(0), IRQ_RPU_NUM, 1, 6 }, { "RPU", IRQ_RPU(0), IRQ_RPU_NUM, 1, 6 },
{ 0 } { 0 }
...@@ -146,7 +146,7 @@ struct hw_interrupt_type hw_itypes[NUM_IRQ_INITS]; ...@@ -146,7 +146,7 @@ struct hw_interrupt_type hw_itypes[NUM_IRQ_INITS];
/* Initialize interrupts. */ /* Initialize interrupts. */
void __init mach_init_irqs (void) void __init mach_init_irqs (void)
{ {
nb85e_intc_init_irq_types (irq_inits, hw_itypes); v850e_intc_init_irq_types (irq_inits, hw_itypes);
} }
......
...@@ -113,9 +113,7 @@ static irqreturn_t gbus_int_handle_irq (int irq, void *dev_id, ...@@ -113,9 +113,7 @@ static irqreturn_t gbus_int_handle_irq (int irq, void *dev_id,
/* Only pay attention to enabled interrupts. */ /* Only pay attention to enabled interrupts. */
status &= enable; status &= enable;
if (status) { if (status) {
unsigned base_irq irq = IRQ_GBUS_INT (w * GBUS_INT_BITS_PER_WORD);
= IRQ_GBUS_INT (w * GBUS_INT_BITS_PER_WORD);
irq = base_irq;
do { do {
/* There's an active interrupt in word /* There's an active interrupt in word
W, find out which one, and call its W, find out which one, and call its
...@@ -247,7 +245,7 @@ void __init gbus_int_init_irqs (void) ...@@ -247,7 +245,7 @@ void __init gbus_int_init_irqs (void)
/* First initialize the shared gint interrupts. */ /* First initialize the shared gint interrupts. */
for (i = 0; i < NUM_USED_GINTS; i++) { for (i = 0; i < NUM_USED_GINTS; i++) {
unsigned gint = used_gint[i].gint; unsigned gint = used_gint[i].gint;
struct nb85e_intc_irq_init gint_irq_init[2]; struct v850e_intc_irq_init gint_irq_init[2];
/* We initialize one GINT interrupt at a time. */ /* We initialize one GINT interrupt at a time. */
gint_irq_init[0].name = "GINT"; gint_irq_init[0].name = "GINT";
...@@ -258,7 +256,7 @@ void __init gbus_int_init_irqs (void) ...@@ -258,7 +256,7 @@ void __init gbus_int_init_irqs (void)
gint_irq_init[1].name = 0; /* Terminate the vector. */ gint_irq_init[1].name = 0; /* Terminate the vector. */
nb85e_intc_init_irq_types (gint_irq_init, gint_hw_itypes); v850e_intc_init_irq_types (gint_irq_init, gint_hw_itypes);
} }
/* Then the GBUS interrupts. */ /* Then the GBUS interrupts. */
......
/* /*
* arch/v850/kernel/head.S -- Lowest-level startup code * arch/v850/kernel/head.S -- Lowest-level startup code
* *
* Copyright (C) 2001,02 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -115,7 +115,14 @@ C_ENTRY(start): ...@@ -115,7 +115,14 @@ C_ENTRY(start):
jarl CSYM(memset), lp jarl CSYM(memset), lp
#endif #endif
// Start Linux kernel. // What happens if the main kernel function returns (it shouldn't)
mov hilo(CSYM(machine_halt)), lp mov hilo(CSYM(machine_halt)), lp
jr CSYM(start_kernel)
// Start the linux kernel. We use an indirect jump to get extra
// range, because on some platforms this initial startup code
// (and the associated platform-specific code in mach_early_init)
// are located far away from the main kernel, e.g. so that they
// can initialize RAM first and copy the kernel or something.
mov hilo(CSYM(start_kernel)), r12
jmp [r12]
C_END(start) C_END(start)
/* /*
* arch/v850/kernel/highres_timer.c -- High resolution timing routines * arch/v850/kernel/highres_timer.c -- High resolution timing routines
* *
* Copyright (C) 2001,02 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
*/ */
#include <asm/system.h> #include <asm/system.h>
#include <asm/nb85e_timer_d.h> #include <asm/v850e_timer_d.h>
#include <asm/highres_timer.h> #include <asm/highres_timer.h>
#define HIGHRES_TIMER_USEC_SHIFT 12 #define HIGHRES_TIMER_USEC_SHIFT 12
...@@ -42,7 +42,7 @@ void highres_timer_slow_tick_irq (void) ...@@ -42,7 +42,7 @@ void highres_timer_slow_tick_irq (void)
void highres_timer_reset (void) void highres_timer_reset (void)
{ {
NB85E_TIMER_D_TMD (HIGHRES_TIMER_TIMER_D_UNIT) = 0; V850E_TIMER_D_TMD (HIGHRES_TIMER_TIMER_D_UNIT) = 0;
HIGHRES_TIMER_SLOW_TICKS = 0; HIGHRES_TIMER_SLOW_TICKS = 0;
} }
...@@ -51,12 +51,12 @@ void highres_timer_start (void) ...@@ -51,12 +51,12 @@ void highres_timer_start (void)
u32 fast_tick_rate; u32 fast_tick_rate;
/* Start hardware timer. */ /* Start hardware timer. */
nb85e_timer_d_configure (HIGHRES_TIMER_TIMER_D_UNIT, v850e_timer_d_configure (HIGHRES_TIMER_TIMER_D_UNIT,
HIGHRES_TIMER_SLOW_TICK_RATE); HIGHRES_TIMER_SLOW_TICK_RATE);
fast_tick_rate = fast_tick_rate =
(NB85E_TIMER_D_BASE_FREQ (V850E_TIMER_D_BASE_FREQ
>> NB85E_TIMER_D_DIVLOG2 (HIGHRES_TIMER_TIMER_D_UNIT)); >> V850E_TIMER_D_DIVLOG2 (HIGHRES_TIMER_TIMER_D_UNIT));
/* The obvious way of calculating microseconds from fast ticks /* The obvious way of calculating microseconds from fast ticks
is to do: is to do:
...@@ -77,16 +77,16 @@ void highres_timer_start (void) ...@@ -77,16 +77,16 @@ void highres_timer_start (void)
/* Enable the interrupt (which is hardwired to this use), and /* Enable the interrupt (which is hardwired to this use), and
give it the highest priority. */ give it the highest priority. */
NB85E_INTC_IC (IRQ_INTCMD (HIGHRES_TIMER_TIMER_D_UNIT)) = 0; V850E_INTC_IC (IRQ_INTCMD (HIGHRES_TIMER_TIMER_D_UNIT)) = 0;
} }
void highres_timer_stop (void) void highres_timer_stop (void)
{ {
/* Stop the timer. */ /* Stop the timer. */
NB85E_TIMER_D_TMCD (HIGHRES_TIMER_TIMER_D_UNIT) = V850E_TIMER_D_TMCD (HIGHRES_TIMER_TIMER_D_UNIT) =
NB85E_TIMER_D_TMCD_CAE; V850E_TIMER_D_TMCD_CAE;
/* Disable its interrupt, just in case. */ /* Disable its interrupt, just in case. */
nb85e_intc_disable_irq (IRQ_INTCMD (HIGHRES_TIMER_TIMER_D_UNIT)); v850e_intc_disable_irq (IRQ_INTCMD (HIGHRES_TIMER_TIMER_D_UNIT));
} }
inline void highres_timer_read_ticks (u32 *slow_ticks, u32 *fast_ticks) inline void highres_timer_read_ticks (u32 *slow_ticks, u32 *fast_ticks)
...@@ -95,9 +95,9 @@ inline void highres_timer_read_ticks (u32 *slow_ticks, u32 *fast_ticks) ...@@ -95,9 +95,9 @@ inline void highres_timer_read_ticks (u32 *slow_ticks, u32 *fast_ticks)
u32 fast_ticks_1, fast_ticks_2, _slow_ticks; u32 fast_ticks_1, fast_ticks_2, _slow_ticks;
local_irq_save (flags); local_irq_save (flags);
fast_ticks_1 = NB85E_TIMER_D_TMD (HIGHRES_TIMER_TIMER_D_UNIT); fast_ticks_1 = V850E_TIMER_D_TMD (HIGHRES_TIMER_TIMER_D_UNIT);
_slow_ticks = HIGHRES_TIMER_SLOW_TICKS; _slow_ticks = HIGHRES_TIMER_SLOW_TICKS;
fast_ticks_2 = NB85E_TIMER_D_TMD (HIGHRES_TIMER_TIMER_D_UNIT); fast_ticks_2 = V850E_TIMER_D_TMD (HIGHRES_TIMER_TIMER_D_UNIT);
local_irq_restore (flags); local_irq_restore (flags);
if (fast_ticks_2 < fast_ticks_1) if (fast_ticks_2 < fast_ticks_1)
......
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
#include <asm/machdep.h> #include <asm/machdep.h>
#include <asm/entry.h> #include <asm/entry.h>
#ifdef CONFIG_V850E_MA1_HIGHRES_TIMER #ifdef CONFIG_V850E_HIGHRES_TIMER
#include <asm/highres_timer.h> #include <asm/highres_timer.h>
#endif #endif
...@@ -59,7 +59,7 @@ ...@@ -59,7 +59,7 @@
.section .intv.mach, "ax" .section .intv.mach, "ax"
.org 0x0 .org 0x0
#if defined (CONFIG_V850E_MA1_HIGHRES_TIMER) && defined (IRQ_INTCMD) #if defined (CONFIG_V850E_HIGHRES_TIMER) && defined (IRQ_INTCMD)
/* Interrupts before the highres timer interrupt. */ /* Interrupts before the highres timer interrupt. */
.rept IRQ_INTCMD (HIGHRES_TIMER_TIMER_D_UNIT) .rept IRQ_INTCMD (HIGHRES_TIMER_TIMER_D_UNIT)
......
...@@ -22,19 +22,19 @@ ...@@ -22,19 +22,19 @@
#include <asm/atomic.h> #include <asm/atomic.h>
#include <asm/page.h> #include <asm/page.h>
#include <asm/machdep.h> #include <asm/machdep.h>
#include <asm/nb85e_timer_d.h> #include <asm/v850e_timer_d.h>
#include "mach.h" #include "mach.h"
void __init mach_sched_init (struct irqaction *timer_action) void __init mach_sched_init (struct irqaction *timer_action)
{ {
/* Start hardware timer. */ /* Start hardware timer. */
nb85e_timer_d_configure (0, HZ); v850e_timer_d_configure (0, HZ);
/* Install timer interrupt handler. */ /* Install timer interrupt handler. */
setup_irq (IRQ_INTCMD(0), timer_action); setup_irq (IRQ_INTCMD(0), timer_action);
} }
static struct nb85e_intc_irq_init irq_inits[] = { static struct v850e_intc_irq_init irq_inits[] = {
{ "IRQ", 0, NUM_MACH_IRQS, 1, 7 }, { "IRQ", 0, NUM_MACH_IRQS, 1, 7 },
{ "CMD", IRQ_INTCMD(0), IRQ_INTCMD_NUM, 1, 5 }, { "CMD", IRQ_INTCMD(0), IRQ_INTCMD_NUM, 1, 5 },
{ "DMA", IRQ_INTDMA(0), IRQ_INTDMA_NUM, 1, 2 }, { "DMA", IRQ_INTDMA(0), IRQ_INTDMA_NUM, 1, 2 },
...@@ -51,7 +51,7 @@ static struct hw_interrupt_type hw_itypes[NUM_IRQ_INITS]; ...@@ -51,7 +51,7 @@ static struct hw_interrupt_type hw_itypes[NUM_IRQ_INITS];
/* Initialize MA chip interrupts. */ /* Initialize MA chip interrupts. */
void __init ma_init_irqs (void) void __init ma_init_irqs (void)
{ {
nb85e_intc_init_irq_types (irq_inits, hw_itypes); v850e_intc_init_irq_types (irq_inits, hw_itypes);
} }
/* Called before configuring an on-chip UART. */ /* Called before configuring an on-chip UART. */
......
/*
* arch/v850/kernel/me2.c -- V850E/ME2 chip-specific support
*
* Copyright (C) 2003 NEC Corporation
* Copyright (C) 2003 Miles Bader <miles@gnu.org>
*
* This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this
* archive for more details.
*
* Written by Miles Bader <miles@gnu.org>
*/
#include <linux/config.h>
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/mm.h>
#include <linux/swap.h>
#include <linux/bootmem.h>
#include <linux/irq.h>
#include <asm/atomic.h>
#include <asm/page.h>
#include <asm/machdep.h>
#include <asm/v850e_timer_d.h>
#include "mach.h"
void __init mach_sched_init (struct irqaction *timer_action)
{
/* Start hardware timer. */
v850e_timer_d_configure (0, HZ);
/* Install timer interrupt handler. */
setup_irq (IRQ_INTCMD(0), timer_action);
}
static struct v850e_intc_irq_init irq_inits[] = {
{ "IRQ", 0, NUM_CPU_IRQS, 1, 7 },
{ "INTP", IRQ_INTP(0), IRQ_INTP_NUM, 1, 5 },
{ "CMD", IRQ_INTCMD(0), IRQ_INTCMD_NUM, 1, 3 },
{ "UBTIRE", IRQ_INTUBTIRE(0), IRQ_INTUBTIRE_NUM, 5, 4 },
{ "UBTIR", IRQ_INTUBTIR(0), IRQ_INTUBTIR_NUM, 5, 4 },
{ "UBTIT", IRQ_INTUBTIT(0), IRQ_INTUBTIT_NUM, 5, 4 },
{ "UBTIF", IRQ_INTUBTIF(0), IRQ_INTUBTIF_NUM, 5, 4 },
{ "UBTITO", IRQ_INTUBTITO(0), IRQ_INTUBTITO_NUM, 5, 4 },
{ 0 }
};
#define NUM_IRQ_INITS ((sizeof irq_inits / sizeof irq_inits[0]) - 1)
static struct hw_interrupt_type hw_itypes[NUM_IRQ_INITS];
/* Initialize V850E/ME2 chip interrupts. */
void __init me2_init_irqs (void)
{
v850e_intc_init_irq_types (irq_inits, hw_itypes);
}
/* Called before configuring an on-chip UART. */
void me2_uart_pre_configure (unsigned chan, unsigned cflags, unsigned baud)
{
if (chan == 0) {
/* Specify that the relevent pins on the chip should do
serial I/O, not direct I/O. */
ME2_PORT1_PMC |= 0xC;
/* Specify that we're using the UART, not the CSI device. */
ME2_PORT1_PFC |= 0xC;
} else if (chan == 1) {
/* Specify that the relevent pins on the chip should do
serial I/O, not direct I/O. */
ME2_PORT2_PMC |= 0x6;
/* Specify that we're using the UART, not the CSI device. */
ME2_PORT2_PFC |= 0x6;
}
}
...@@ -17,7 +17,7 @@ ...@@ -17,7 +17,7 @@
#include <linux/fs.h> #include <linux/fs.h>
#include <asm/machdep.h> #include <asm/machdep.h>
#include <asm/nb85e_uart.h> #include <asm/v850e_uart.h>
#include "mach.h" #include "mach.h"
...@@ -34,7 +34,7 @@ extern void multi_init (void); ...@@ -34,7 +34,7 @@ extern void multi_init (void);
void __init rte_cb_early_init (void) void __init rte_cb_early_init (void)
{ {
nb85e_intc_disable_irqs (); v850e_intc_disable_irqs ();
#ifdef CONFIG_RTE_CB_MULTI #ifdef CONFIG_RTE_CB_MULTI
multi_init (); multi_init ();
...@@ -43,6 +43,7 @@ void __init rte_cb_early_init (void) ...@@ -43,6 +43,7 @@ void __init rte_cb_early_init (void)
void __init mach_setup (char **cmdline) void __init mach_setup (char **cmdline)
{ {
#ifdef CONFIG_RTE_MB_A_PCI
/* Probe for Mother-A, and print a message if we find it. */ /* Probe for Mother-A, and print a message if we find it. */
*(volatile unsigned long *)MB_A_SRAM_ADDR = 0xDEADBEEF; *(volatile unsigned long *)MB_A_SRAM_ADDR = 0xDEADBEEF;
if (*(volatile unsigned long *)MB_A_SRAM_ADDR == 0xDEADBEEF) { if (*(volatile unsigned long *)MB_A_SRAM_ADDR == 0xDEADBEEF) {
...@@ -52,23 +53,11 @@ void __init mach_setup (char **cmdline) ...@@ -52,23 +53,11 @@ void __init mach_setup (char **cmdline)
" NEC SolutionGear/Midas lab" " NEC SolutionGear/Midas lab"
" RTE-MOTHER-A motherboard\n"); " RTE-MOTHER-A motherboard\n");
} }
#endif /* CONFIG_RTE_MB_A_PCI */
#if defined (CONFIG_V850E_NB85E_UART_CONSOLE) && !defined (CONFIG_TIME_BOOTUP)
nb85e_uart_cons_init (0);
#endif
mach_tick = led_tick; mach_tick = led_tick;
} }
#ifdef CONFIG_TIME_BOOTUP
void initial_boot_done (void)
{
#ifdef CONFIG_V850E_NB85E_UART_CONSOLE
nb85e_uart_cons_init (0);
#endif
}
#endif
void machine_restart (char *__unused) void machine_restart (char *__unused)
{ {
#ifdef CONFIG_RESET_GUARD #ifdef CONFIG_RESET_GUARD
...@@ -194,6 +183,7 @@ static struct hw_interrupt_type gbus_hw_itypes[NUM_GBUS_IRQ_INITS]; ...@@ -194,6 +183,7 @@ static struct hw_interrupt_type gbus_hw_itypes[NUM_GBUS_IRQ_INITS];
#endif /* CONFIG_RTE_GBUS_INT */ #endif /* CONFIG_RTE_GBUS_INT */
void __init rte_cb_init_irqs (void) void __init rte_cb_init_irqs (void)
{ {
#ifdef CONFIG_RTE_GBUS_INT #ifdef CONFIG_RTE_GBUS_INT
......
...@@ -20,7 +20,7 @@ ...@@ -20,7 +20,7 @@
#include <asm/page.h> #include <asm/page.h>
#include <asm/ma1.h> #include <asm/ma1.h>
#include <asm/rte_ma1_cb.h> #include <asm/rte_ma1_cb.h>
#include <asm/nb85e_timer_c.h> #include <asm/v850e_timer_c.h>
#include "mach.h" #include "mach.h"
...@@ -89,14 +89,14 @@ void __init mach_init_irqs (void) ...@@ -89,14 +89,14 @@ void __init mach_init_irqs (void)
rte_cb_init_irqs (); rte_cb_init_irqs ();
/* Use falling-edge-sensitivity for interrupts . */ /* Use falling-edge-sensitivity for interrupts . */
NB85E_TIMER_C_SESC (0) &= ~0xC; V850E_TIMER_C_SESC (0) &= ~0xC;
NB85E_TIMER_C_SESC (1) &= ~0xF; V850E_TIMER_C_SESC (1) &= ~0xF;
/* INTP000-INTP011 are shared with `Timer C', so we have to set /* INTP000-INTP011 are shared with `Timer C', so we have to set
up Timer C to pass them through as raw interrupts. */ up Timer C to pass them through as raw interrupts. */
for (tc = 0; tc < 2; tc++) for (tc = 0; tc < 2; tc++)
/* Turn on the timer. */ /* Turn on the timer. */
NB85E_TIMER_C_TMCC0 (tc) |= NB85E_TIMER_C_TMCC0_CAE; V850E_TIMER_C_TMCC0 (tc) |= V850E_TIMER_C_TMCC0_CAE;
/* Make sure the relevant port0/port1 pins are assigned /* Make sure the relevant port0/port1 pins are assigned
interrupt duty. We used INTP001-INTP011 (don't screw with interrupt duty. We used INTP001-INTP011 (don't screw with
......
/*
* arch/v850/kernel/rte_me2_cb.c -- Midas labs RTE-V850E/ME2-CB board
*
* Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
*
* This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this
* archive for more details.
*
* Written by Miles Bader <miles@gnu.org>
*/
#include <linux/config.h>
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/bootmem.h>
#include <linux/irq.h>
#include <linux/fs.h>
#include <linux/major.h>
#include <linux/sched.h>
#include <linux/delay.h>
#include <asm/atomic.h>
#include <asm/page.h>
#include <asm/me2.h>
#include <asm/rte_me2_cb.h>
#include <asm/machdep.h>
#include <asm/v850e_intc.h>
#include <asm/v850e_cache.h>
#include <asm/irq.h>
#include "mach.h"
extern unsigned long *_intv_start;
extern unsigned long *_intv_end;
/* LED access routines. */
extern unsigned read_leds (int pos, char *buf, int len);
extern unsigned write_leds (int pos, const char *buf, int len);
/* SDRAM are almost contiguous (with a small hole in between;
see mach_reserve_bootmem for details), so just use both as one big area. */
#define RAM_START SDRAM_ADDR
#define RAM_END (SDRAM_ADDR + SDRAM_SIZE)
void __init mach_get_physical_ram (unsigned long *ram_start,
unsigned long *ram_len)
{
*ram_start = RAM_START;
*ram_len = RAM_END - RAM_START;
}
void __init mach_reserve_bootmem ()
{
extern char _root_fs_image_start, _root_fs_image_end;
u32 root_fs_image_start = (u32)&_root_fs_image_start;
u32 root_fs_image_end = (u32)&_root_fs_image_end;
/* Reserve the memory used by the root filesystem image if it's
in RAM. */
if (root_fs_image_start >= RAM_START && root_fs_image_start < RAM_END)
reserve_bootmem (root_fs_image_start,
root_fs_image_end - root_fs_image_start);
}
void mach_gettimeofday (struct timespec *tv)
{
tv->tv_sec = 0;
tv->tv_nsec = 0;
}
/* Called before configuring an on-chip UART. */
void rte_me2_cb_uart_pre_configure (unsigned chan,
unsigned cflags, unsigned baud)
{
/* The RTE-V850E/ME2-CB connects some general-purpose I/O
pins on the CPU to the RTS/CTS lines of UARTB channel 0's
serial connection.
I/O pins P21 and P22 are RTS and CTS respectively. */
if (chan == 0) {
/* Put P21 & P22 in I/O port mode. */
ME2_PORT2_PMC &= ~0x6;
/* Make P21 and output, and P22 an input. */
ME2_PORT2_PM = (ME2_PORT2_PM & ~0xC) | 0x4;
}
me2_uart_pre_configure (chan, cflags, baud);
}
void __init mach_init_irqs (void)
{
/* Initialize interrupts. */
me2_init_irqs ();
rte_me2_cb_init_irqs ();
}
#ifdef CONFIG_ROM_KERNEL
/* Initialization for kernel in ROM. */
static inline rom_kernel_init (void)
{
/* If the kernel is in ROM, we have to copy any initialized data
from ROM into RAM. */
extern unsigned long _data_load_start, _sdata, _edata;
register unsigned long *src = &_data_load_start;
register unsigned long *dst = &_sdata, *end = &_edata;
while (dst != end)
*dst++ = *src++;
}
#endif /* CONFIG_ROM_KERNEL */
static void install_interrupt_vectors (void)
{
unsigned long *p1, *p2;
ME2_IRAMM = 0x03; /* V850E/ME2 iRAM write mode */
/* vector copy to iRAM */
p1 = (unsigned long *)0; /* v85x vector start */
p2 = (unsigned long *)&_intv_start;
while (p2 < (unsigned long *)&_intv_end)
*p1++ = *p2++;
ME2_IRAMM = 0x00; /* V850E/ME2 iRAM read mode */
}
/* CompactFlash */
static void cf_power_on (void)
{
/* CF card detected? */
if (CB_CF_STS0 & 0x0030)
return;
CB_CF_REG0 = 0x0002; /* reest on */
mdelay (10);
CB_CF_REG0 = 0x0003; /* power on */
mdelay (10);
CB_CF_REG0 = 0x0001; /* reset off */
mdelay (10);
}
static void cf_power_off (void)
{
CB_CF_REG0 = 0x0003; /* power on */
mdelay (10);
CB_CF_REG0 = 0x0002; /* reest on */
mdelay (10);
}
void __init mach_early_init (void)
{
install_interrupt_vectors ();
/* CS1 SDRAM instruction cache enable */
v850e_cache_enable (0x04, 0x03, 0);
rte_cb_early_init ();
/* CompactFlash power on */
cf_power_on ();
#if defined (CONFIG_ROM_KERNEL)
rom_kernel_init ();
#endif
}
/* RTE-V850E/ME2-CB Programmable Interrupt Controller. */
static struct cb_pic_irq_init cb_pic_irq_inits[] = {
{ "CB_EXTTM0", IRQ_CB_EXTTM0, 1, 1, 6 },
{ "CB_EXTSIO", IRQ_CB_EXTSIO, 1, 1, 6 },
{ "CB_TOVER", IRQ_CB_TOVER, 1, 1, 6 },
{ "CB_GINT0", IRQ_CB_GINT0, 1, 1, 6 },
{ "CB_USB", IRQ_CB_USB, 1, 1, 6 },
{ "CB_LANC", IRQ_CB_LANC, 1, 1, 6 },
{ "CB_USB_VBUS_ON", IRQ_CB_USB_VBUS_ON, 1, 1, 6 },
{ "CB_USB_VBUS_OFF", IRQ_CB_USB_VBUS_OFF, 1, 1, 6 },
{ "CB_EXTTM1", IRQ_CB_EXTTM1, 1, 1, 6 },
{ "CB_EXTTM2", IRQ_CB_EXTTM2, 1, 1, 6 },
{ 0 }
};
#define NUM_CB_PIC_IRQ_INITS \
((sizeof cb_pic_irq_inits / sizeof cb_pic_irq_inits[0]) - 1)
static struct hw_interrupt_type cb_pic_hw_itypes[NUM_CB_PIC_IRQ_INITS];
static unsigned char cb_pic_active_irqs = 0;
void __init rte_me2_cb_init_irqs (void)
{
cb_pic_init_irq_types (cb_pic_irq_inits, cb_pic_hw_itypes);
/* Initalize on board PIC1 (not PIC0) enable */
CB_PIC_INT0M = 0x0000;
CB_PIC_INT1M = 0x0000;
CB_PIC_INTR = 0x0000;
CB_PIC_INTEN |= CB_PIC_INT1EN;
ME2_PORT2_PMC |= 0x08; /* INTP23/SCK1 mode */
ME2_PORT2_PFC &= ~0x08; /* INTP23 mode */
ME2_INTR(2) &= ~0x08; /* INTP23 falling-edge detect */
ME2_INTF(2) &= ~0x08; /* " */
rte_cb_init_irqs (); /* gbus &c */
}
/* Enable interrupt handling for interrupt IRQ. */
void cb_pic_enable_irq (unsigned irq)
{
CB_PIC_INT1M |= 1 << (irq - CB_PIC_BASE_IRQ);
}
void cb_pic_disable_irq (unsigned irq)
{
CB_PIC_INT1M &= ~(1 << (irq - CB_PIC_BASE_IRQ));
}
void cb_pic_shutdown_irq (unsigned irq)
{
cb_pic_disable_irq (irq);
if (--cb_pic_active_irqs == 0)
free_irq (IRQ_CB_PIC, 0);
CB_PIC_INT1M &= ~(1 << (irq - CB_PIC_BASE_IRQ));
}
static void cb_pic_handle_irq (int irq, void *dev_id, struct pt_regs *regs)
{
unsigned status = CB_PIC_INTR;
unsigned enable = CB_PIC_INT1M;
/* Only pay attention to enabled interrupts. */
status &= enable;
CB_PIC_INTEN &= ~CB_PIC_INT1EN;
if (status) {
unsigned mask = 1;
irq = CB_PIC_BASE_IRQ;
do {
/* There's an active interrupt, find out which one,
and call its handler. */
while (! (status & mask)) {
irq++;
mask <<= 1;
}
status &= ~mask;
CB_PIC_INTR = mask;
/* Recursively call handle_irq to handle it. */
handle_irq (irq, regs);
} while (status);
}
CB_PIC_INTEN |= CB_PIC_INT1EN;
}
static void irq_nop (unsigned irq) { }
static unsigned cb_pic_startup_irq (unsigned irq)
{
int rval;
if (cb_pic_active_irqs == 0) {
rval = request_irq (IRQ_CB_PIC, cb_pic_handle_irq,
SA_INTERRUPT, "cb_pic_handler", 0);
if (rval != 0)
return rval;
}
cb_pic_active_irqs++;
cb_pic_enable_irq (irq);
return 0;
}
/* Initialize HW_IRQ_TYPES for INTC-controlled irqs described in array
INITS (which is terminated by an entry with the name field == 0). */
void __init cb_pic_init_irq_types (struct cb_pic_irq_init *inits,
struct hw_interrupt_type *hw_irq_types)
{
struct cb_pic_irq_init *init;
for (init = inits; init->name; init++) {
struct hw_interrupt_type *hwit = hw_irq_types++;
hwit->typename = init->name;
hwit->startup = cb_pic_startup_irq;
hwit->shutdown = cb_pic_shutdown_irq;
hwit->enable = cb_pic_enable_irq;
hwit->disable = cb_pic_disable_irq;
hwit->ack = irq_nop;
hwit->end = irq_nop;
/* Initialize kernel IRQ infrastructure for this interrupt. */
init_irq_handlers(init->base, init->num, init->interval, hwit);
}
}
...@@ -21,7 +21,7 @@ ...@@ -21,7 +21,7 @@
#include <asm/atomic.h> #include <asm/atomic.h>
#include <asm/page.h> #include <asm/page.h>
#include <asm/nb85e.h> #include <asm/v850e.h>
#include <asm/rte_nb85e_cb.h> #include <asm/rte_nb85e_cb.h>
#include "mach.h" #include "mach.h"
...@@ -41,7 +41,7 @@ void __init mach_early_init (void) ...@@ -41,7 +41,7 @@ void __init mach_early_init (void)
Unfortunately, the dcache seems to be buggy, so we only use the Unfortunately, the dcache seems to be buggy, so we only use the
icache for now. */ icache for now. */
nb85e_cache_enable (0x0040 /* BHC */, 0x0000 /* DCC */); v850e_cache_enable (0x0040 /*BHC*/, 0x0003 /*ICC*/, 0x0000 /*DCC*/);
rte_cb_early_init (); rte_cb_early_init ();
} }
......
/* /*
* arch/v850/kernel/sim85e2c.c -- Machine-specific stuff for * arch/v850/kernel/sim85e2.c -- Machine-specific stuff for
* V850E2 RTL simulator * V850E2 RTL simulator
* *
* Copyright (C) 2002 NEC Corporation * Copyright (C) 2002,03 NEC Electronics Corporation
* Copyright (C) 2002 Miles Bader <miles@gnu.org> * Copyright (C) 2002,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -26,17 +26,47 @@ ...@@ -26,17 +26,47 @@
#include "mach.h" #include "mach.h"
/* There are 4 possible areas we can use:
IRAM (1MB) is fast for instruction fetches, but slow for data
DRAM (1020KB) is fast for data, but slow for instructions
ERAM is cached, so should be fast for both insns and data
SDRAM is external DRAM, similar to ERAM
*/
#define INIT_MEMC_FOR_SDRAM
#define USE_SDRAM_AREA
#define KERNEL_IN_SDRAM_AREA
#define DCACHE_MODE V850E2_CACHE_BTSC_DCM_WT
/*#define DCACHE_MODE V850E2_CACHE_BTSC_DCM_WB_ALLOC*/
#ifdef USE_SDRAM_AREA
#define RAM_START SDRAM_ADDR
#define RAM_END (SDRAM_ADDR + SDRAM_SIZE)
#else
/* When we use DRAM, we need to account for the fact that the end of it is
used for R0_RAM. */
#define RAM_START DRAM_ADDR
#define RAM_END R0_RAM_ADDR
#endif
extern void memcons_setup (void); extern void memcons_setup (void);
void __init mach_early_init (void) #ifdef KERNEL_IN_SDRAM_AREA
#define EARLY_INIT_SECTION_ATTR __attribute__ ((section (".early.text")))
#else
#define EARLY_INIT_SECTION_ATTR __init
#endif
void EARLY_INIT_SECTION_ATTR mach_early_init (void)
{ {
extern int panic_timeout; extern int panic_timeout;
/* Don't stop the simulator at `halt' instructions. */ /* The sim85e2 simulator tracks `undefined' values, so to make
NOTHAL = 1;
/* The sim85e2c simulator tracks `undefined' values, so to make
debugging easier, we begin by zeroing out all otherwise debugging easier, we begin by zeroing out all otherwise
undefined registers. This is not strictly necessary. undefined registers. This is not strictly necessary.
...@@ -67,10 +97,41 @@ void __init mach_early_init (void) ...@@ -67,10 +97,41 @@ void __init mach_early_init (void)
asm volatile ("ldsr r0, 16; ldsr r0, 17; ldsr r0, 18; ldsr r0, 19"); asm volatile ("ldsr r0, 16; ldsr r0, 17; ldsr r0, 18; ldsr r0, 19");
asm volatile ("ldsr r0, 20"); asm volatile ("ldsr r0, 20");
#ifdef INIT_MEMC_FOR_SDRAM
/* Settings for SDRAM controller. */
V850E2_VSWC = 0x0042;
V850E2_BSC = 0x9286;
V850E2_BCT(0) = 0xb000; /* was: 0 */
V850E2_BCT(1) = 0x000b;
V850E2_ASC = 0;
V850E2_LBS = 0xa9aa; /* was: 0xaaaa */
V850E2_LBC(0) = 0;
V850E2_LBC(1) = 0; /* was: 0x3 */
V850E2_BCC = 0;
V850E2_RFS(4) = 0x800a; /* was: 0xf109 */
V850E2_SCR(4) = 0x2091; /* was: 0x20a1 */
V850E2_RFS(3) = 0x800c;
V850E2_SCR(3) = 0x20a1;
V850E2_DWC(0) = 0;
V850E2_DWC(1) = 0;
#endif
#if 0
#ifdef CONFIG_V850E2_SIM85E2S
/* Turn on the caches. */ /* Turn on the caches. */
NA85E2C_CACHE_BTSC V850E2_CACHE_BTSC = V850E2_CACHE_BTSC_ICM | DCACHE_MODE;
|= (NA85E2C_CACHE_BTSC_ICM | NA85E2C_CACHE_BTSC_DCM0); V850E2_BHC = 0x1010;
NA85E2C_BUSM_BHC = 0xFFFF; #elif CONFIG_V850E2_SIM85E2C
V850E2_CACHE_BTSC |= (V850E2_CACHE_BTSC_ICM | V850E2_CACHE_BTSC_DCM0);
V850E2_BUSM_BHC = 0xFFFF;
#endif
#else
V850E2_BHC = 0;
#endif
/* Don't stop the simulator at `halt' instructions. */
SIM85E2_NOTHAL = 1;
/* Ensure that the simulator halts on a panic, instead of going /* Ensure that the simulator halts on a panic, instead of going
into an infinite loop inside the panic function. */ into an infinite loop inside the panic function. */
...@@ -84,18 +145,23 @@ void __init mach_setup (char **cmdline) ...@@ -84,18 +145,23 @@ void __init mach_setup (char **cmdline)
void mach_get_physical_ram (unsigned long *ram_start, unsigned long *ram_len) void mach_get_physical_ram (unsigned long *ram_start, unsigned long *ram_len)
{ {
/* There are 3 possible areas we can use: *ram_start = RAM_START;
IRAM (1MB) is fast for instruction fetches, but slow for data *ram_len = RAM_END - RAM_START;
DRAM (1020KB) is fast for data, but slow for instructions }
ERAM is cached, so should be fast for both insns and data,
_but_ currently only supports write-through caching, so void __init mach_reserve_bootmem ()
writes are slow. {
Since there's really no area that's good for general kernel extern char _root_fs_image_start, _root_fs_image_end;
use, we use DRAM -- it won't be good for user programs u32 root_fs_image_start = (u32)&_root_fs_image_start;
(which will be loaded into kernel allocated memory), but u32 root_fs_image_end = (u32)&_root_fs_image_end;
currently we're more concerned with testing the kernel. */
*ram_start = DRAM_ADDR; /* Reserve the memory used by the root filesystem image if it's
*ram_len = R0_RAM_ADDR - DRAM_ADDR; in RAM. */
if (root_fs_image_end > root_fs_image_start
&& root_fs_image_start >= RAM_START
&& root_fs_image_start < RAM_END)
reserve_bootmem (root_fs_image_start,
root_fs_image_end - root_fs_image_start);
} }
void __init mach_sched_init (struct irqaction *timer_action) void __init mach_sched_init (struct irqaction *timer_action)
...@@ -114,7 +180,7 @@ void mach_gettimeofday (struct timespec *tv) ...@@ -114,7 +180,7 @@ void mach_gettimeofday (struct timespec *tv)
/* Interrupts */ /* Interrupts */
struct nb85e_intc_irq_init irq_inits[] = { struct v850e_intc_irq_init irq_inits[] = {
{ "IRQ", 0, NUM_MACH_IRQS, 1, 7 }, { "IRQ", 0, NUM_MACH_IRQS, 1, 7 },
{ 0 } { 0 }
}; };
...@@ -123,14 +189,14 @@ struct hw_interrupt_type hw_itypes[1]; ...@@ -123,14 +189,14 @@ struct hw_interrupt_type hw_itypes[1];
/* Initialize interrupts. */ /* Initialize interrupts. */
void __init mach_init_irqs (void) void __init mach_init_irqs (void)
{ {
nb85e_intc_init_irq_types (irq_inits, hw_itypes); v850e_intc_init_irq_types (irq_inits, hw_itypes);
} }
void machine_halt (void) __attribute__ ((noreturn)); void machine_halt (void) __attribute__ ((noreturn));
void machine_halt (void) void machine_halt (void)
{ {
SIMFIN = 0; /* Halt immediately. */ SIM85E2_SIMFIN = 0; /* Halt immediately. */
for (;;) {} for (;;) {}
} }
......
...@@ -22,7 +22,7 @@ ...@@ -22,7 +22,7 @@
#include <asm/atomic.h> #include <asm/atomic.h>
#include <asm/page.h> #include <asm/page.h>
#include <asm/machdep.h> #include <asm/machdep.h>
#include <asm/nb85e_timer_d.h> #include <asm/v850e_timer_d.h>
#include "mach.h" #include "mach.h"
...@@ -31,12 +31,12 @@ void __init mach_sched_init (struct irqaction *timer_action) ...@@ -31,12 +31,12 @@ void __init mach_sched_init (struct irqaction *timer_action)
/* Select timer interrupt instead of external pin. */ /* Select timer interrupt instead of external pin. */
TEG_ISS |= 0x1; TEG_ISS |= 0x1;
/* Start hardware timer. */ /* Start hardware timer. */
nb85e_timer_d_configure (0, HZ); v850e_timer_d_configure (0, HZ);
/* Install timer interrupt handler. */ /* Install timer interrupt handler. */
setup_irq (IRQ_INTCMD(0), timer_action); setup_irq (IRQ_INTCMD(0), timer_action);
} }
static struct nb85e_intc_irq_init irq_inits[] = { static struct v850e_intc_irq_init irq_inits[] = {
{ "IRQ", 0, NUM_CPU_IRQS, 1, 7 }, { "IRQ", 0, NUM_CPU_IRQS, 1, 7 },
{ "CMD", IRQ_INTCMD(0), IRQ_INTCMD_NUM, 1, 5 }, { "CMD", IRQ_INTCMD(0), IRQ_INTCMD_NUM, 1, 5 },
{ "SER", IRQ_INTSER(0), IRQ_INTSER_NUM, 1, 3 }, { "SER", IRQ_INTSER(0), IRQ_INTSER_NUM, 1, 3 },
...@@ -51,7 +51,7 @@ static struct hw_interrupt_type hw_itypes[NUM_IRQ_INITS]; ...@@ -51,7 +51,7 @@ static struct hw_interrupt_type hw_itypes[NUM_IRQ_INITS];
/* Initialize MA chip interrupts. */ /* Initialize MA chip interrupts. */
void __init teg_init_irqs (void) void __init teg_init_irqs (void)
{ {
nb85e_intc_init_irq_types (irq_inits, hw_itypes); v850e_intc_init_irq_types (irq_inits, hw_itypes);
} }
/* Called before configuring an on-chip UART. */ /* Called before configuring an on-chip UART. */
......
/*
* arch/v850/kernel/v850e2_cache.c -- Cache control for V850E2 cache
* memories
*
* Copyright (C) 2003 NEC Electronics Corporation
* Copyright (C) 2003 Miles Bader <miles@gnu.org>
*
* This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this
* archive for more details.
*
* Written by Miles Bader <miles@gnu.org>
*/
#include <linux/mm.h>
#include <asm/v850e2_cache.h>
/* Cache operations we can do. The encoding corresponds directly to the
value we need to write into the COPR register. */
enum cache_op {
OP_SYNC_IF_DIRTY = V850E2_CACHE_COPR_CFC(0), /* 000 */
OP_SYNC_IF_VALID = V850E2_CACHE_COPR_CFC(1), /* 001 */
OP_SYNC_IF_VALID_AND_CLEAR = V850E2_CACHE_COPR_CFC(3), /* 011 */
OP_WAY_CLEAR = V850E2_CACHE_COPR_CFC(4), /* 100 */
OP_FILL = V850E2_CACHE_COPR_CFC(5), /* 101 */
OP_CLEAR = V850E2_CACHE_COPR_CFC(6), /* 110 */
OP_CREATE_DIRTY = V850E2_CACHE_COPR_CFC(7) /* 111 */
};
/* Which cache to use. This encoding also corresponds directly to the
value we need to write into the COPR register. */
enum cache {
ICACHE = 0,
DCACHE = V850E2_CACHE_COPR_LBSL
};
/* Returns ADDR rounded down to the beginning of its cache-line. */
#define CACHE_LINE_ADDR(addr) \
((addr) & ~(V850E2_CACHE_LINE_SIZE - 1))
/* Returns END_ADDR rounded up to the `limit' of its cache-line. */
#define CACHE_LINE_END_ADDR(end_addr) \
CACHE_LINE_ADDR(end_addr + (V850E2_CACHE_LINE_SIZE - 1))
/* Low-level cache ops. */
/* Apply cache-op OP to all entries in CACHE. */
static inline void cache_op_all (enum cache_op op, enum cache cache)
{
int cmd = op | cache | V850E2_CACHE_COPR_WSLE | V850E2_CACHE_COPR_STRT;
if (op != OP_WAY_CLEAR) {
/* The WAY_CLEAR operation does the whole way, but other
ops take begin-index and count params; we just indicate
the entire cache. */
V850E2_CACHE_CADL = 0;
V850E2_CACHE_CADH = 0;
V850E2_CACHE_CCNT = V850E2_CACHE_WAY_SIZE - 1;
}
V850E2_CACHE_COPR = cmd | V850E2_CACHE_COPR_WSL(0); /* way 0 */
V850E2_CACHE_COPR = cmd | V850E2_CACHE_COPR_WSL(1); /* way 1 */
V850E2_CACHE_COPR = cmd | V850E2_CACHE_COPR_WSL(2); /* way 2 */
V850E2_CACHE_COPR = cmd | V850E2_CACHE_COPR_WSL(3); /* way 3 */
}
/* Apply cache-op OP to all entries in CACHE covering addresses ADDR
through ADDR+LEN. */
static inline void cache_op_range (enum cache_op op, u32 addr, u32 len,
enum cache cache)
{
u32 start = CACHE_LINE_ADDR (addr);
u32 end = CACHE_LINE_END_ADDR (addr + len);
u32 num_lines = (end - start) >> V850E2_CACHE_LINE_SIZE_BITS;
V850E2_CACHE_CADL = start & 0xFFFF;
V850E2_CACHE_CADH = start >> 16;
V850E2_CACHE_CCNT = num_lines - 1;
V850E2_CACHE_COPR = op | cache | V850E2_CACHE_COPR_STRT;
}
/* High-level ops. */
static void cache_exec_after_store_all (void)
{
cache_op_all (OP_SYNC_IF_DIRTY, DCACHE);
cache_op_all (OP_WAY_CLEAR, ICACHE);
}
static void cache_exec_after_store_range (u32 start, u32 len)
{
cache_op_range (OP_SYNC_IF_DIRTY, start, len, DCACHE);
cache_op_range (OP_CLEAR, start, len, ICACHE);
}
/* Exported functions. */
void flush_icache (void)
{
cache_exec_after_store_all ();
}
void flush_icache_range (unsigned long start, unsigned long end)
{
cache_exec_after_store_range (start, end - start);
}
void flush_icache_page (struct vm_area_struct *vma, struct page *page)
{
cache_exec_after_store_range (page_to_virt (page), PAGE_SIZE);
}
void flush_icache_user_range (struct vm_area_struct *vma, struct page *page,
unsigned long addr, int len)
{
cache_exec_after_store_range (addr, len);
}
void flush_cache_sigtramp (unsigned long addr)
{
/* For the exact size, see signal.c, but 16 bytes should be enough. */
cache_exec_after_store_range (addr, 16);
}
/* /*
* arch/v850/kernel/nb85e_cache.c -- Cache control for NB85E_CACHE212 and * arch/v850/kernel/v850e_cache.c -- Cache control for V850E cache memories
* NB85E_CACHE213 cache memories
* *
* Copyright (C) 2003 NEC Electronics Corporation * Copyright (C) 2003 NEC Electronics Corporation
* Copyright (C) 2003 Miles Bader <miles@gnu.org> * Copyright (C) 2003 Miles Bader <miles@gnu.org>
...@@ -12,19 +11,31 @@ ...@@ -12,19 +11,31 @@
* Written by Miles Bader <miles@gnu.org> * Written by Miles Bader <miles@gnu.org>
*/ */
/* This file implements cache control for the rather simple cache used on
some V850E CPUs, specifically the NB85E/TEG CPU-core and the V850E/ME2
CPU. V850E2 processors have their own (better) cache
implementation. */
#include <asm/entry.h> #include <asm/entry.h>
#include <asm/nb85e_cache.h> #include <asm/v850e_cache.h>
#define WAIT_UNTIL_CLEAR(value) while (value) {} #define WAIT_UNTIL_CLEAR(value) while (value) {}
/* Set caching params via the BHC and DCC registers. */ /* Set caching params via the BHC and DCC registers. */
void nb85e_cache_enable (u16 bhc, u16 dcc) void v850e_cache_enable (u16 bhc, u16 icc, u16 dcc)
{ {
unsigned long *r0_ram = (unsigned long *)R0_RAM_ADDR; unsigned long *r0_ram = (unsigned long *)R0_RAM_ADDR;
register u16 bhc_val asm ("r6") = bhc; register u16 bhc_val asm ("r6") = bhc;
/* Read the instruction cache control register (ICC) and confirm
that bits 0 and 1 (TCLR0, TCLR1) are all cleared. */
WAIT_UNTIL_CLEAR (V850E_CACHE_ICC & 0x3);
V850E_CACHE_ICC = icc;
#ifdef V850E_CACHE_DCC
/* Configure data-cache. */ /* Configure data-cache. */
NB85E_CACHE_DCC = dcc; V850E_CACHE_DCC = dcc;
#endif /* V850E_CACHE_DCC */
/* Configure caching for various memory regions by writing the BHC /* Configure caching for various memory regions by writing the BHC
register. The documentation says that an instruction _cannot_ register. The documentation says that an instruction _cannot_
...@@ -32,9 +43,12 @@ void nb85e_cache_enable (u16 bhc, u16 dcc) ...@@ -32,9 +43,12 @@ void nb85e_cache_enable (u16 bhc, u16 dcc)
instruction itself exists; to work around this, we store instruction itself exists; to work around this, we store
appropriate instructions into the on-chip RAM area (which is never appropriate instructions into the on-chip RAM area (which is never
cached), and briefly jump there to do the work. */ cached), and briefly jump there to do the work. */
r0_ram[0] = 0xf0720760; /* st.h r0, 0xfffff072[r0] */ #ifdef V850E_CACHE_WRITE_IBS
r0_ram[1] = 0xf06a3760; /* st.h r6, 0xfffff06a[r0] */ *r0_ram++ = 0xf0720760; /* st.h r0, 0xfffff072[r0] */
r0_ram[2] = 0x5640006b; /* jmp [r11] */ #endif
*r0_ram++ = 0xf06a3760; /* st.h r6, 0xfffff06a[r0] */
*r0_ram = 0x5640006b; /* jmp [r11] */
asm ("mov hilo(1f), r11; jmp [%1]; 1:;" asm ("mov hilo(1f), r11; jmp [%1]; 1:;"
:: "r" (bhc_val), "r" (R0_RAM_ADDR) : "r11"); :: "r" (bhc_val), "r" (R0_RAM_ADDR) : "r11");
} }
...@@ -43,11 +57,11 @@ static void clear_icache (void) ...@@ -43,11 +57,11 @@ static void clear_icache (void)
{ {
/* 1. Read the instruction cache control register (ICC) and confirm /* 1. Read the instruction cache control register (ICC) and confirm
that bits 0 and 1 (TCLR0, TCLR1) are all cleared. */ that bits 0 and 1 (TCLR0, TCLR1) are all cleared. */
WAIT_UNTIL_CLEAR (NB85E_CACHE_ICC & 0x3); WAIT_UNTIL_CLEAR (V850E_CACHE_ICC & 0x3);
/* 2. Read the ICC register and confirm that bit 12 (LOCK0) is /* 2. Read the ICC register and confirm that bit 12 (LOCK0) is
cleared. Bit 13 of the ICC register is always cleared. */ cleared. Bit 13 of the ICC register is always cleared. */
WAIT_UNTIL_CLEAR (NB85E_CACHE_ICC & 0x1000); WAIT_UNTIL_CLEAR (V850E_CACHE_ICC & 0x1000);
/* 3. Set the TCLR0 and TCLR1 bits of the ICC register as follows, /* 3. Set the TCLR0 and TCLR1 bits of the ICC register as follows,
when clearing way 0 and way 1 at the same time: when clearing way 0 and way 1 at the same time:
...@@ -55,13 +69,17 @@ static void clear_icache (void) ...@@ -55,13 +69,17 @@ static void clear_icache (void)
(b) Read the TCLR0 and TCLR1 bits to confirm that these bits (b) Read the TCLR0 and TCLR1 bits to confirm that these bits
are cleared. are cleared.
(c) Perform (a) and (b) above again. */ (c) Perform (a) and (b) above again. */
NB85E_CACHE_ICC |= 0x3; V850E_CACHE_ICC |= 0x3;
WAIT_UNTIL_CLEAR (NB85E_CACHE_ICC & 0x3); WAIT_UNTIL_CLEAR (V850E_CACHE_ICC & 0x3);
#ifdef V850E_CACHE_REPEAT_ICC_WRITE
/* Do it again. */ /* Do it again. */
NB85E_CACHE_ICC |= 0x3; V850E_CACHE_ICC |= 0x3;
WAIT_UNTIL_CLEAR (NB85E_CACHE_ICC & 0x3); WAIT_UNTIL_CLEAR (V850E_CACHE_ICC & 0x3);
#endif
} }
#ifdef V850E_CACHE_DCC
/* Flush or clear (or both) the data cache, depending on the value of FLAGS; /* Flush or clear (or both) the data cache, depending on the value of FLAGS;
the procedure is the same for both, just the control bits used differ (and the procedure is the same for both, just the control bits used differ (and
both may be performed simultaneously). */ both may be performed simultaneously). */
...@@ -69,47 +87,54 @@ static void dcache_op (unsigned short flags) ...@@ -69,47 +87,54 @@ static void dcache_op (unsigned short flags)
{ {
/* 1. Read the data cache control register (DCC) and confirm that bits /* 1. Read the data cache control register (DCC) and confirm that bits
0, 1, 4, and 5 (DC00, DC01, DC04, DC05) are all cleared. */ 0, 1, 4, and 5 (DC00, DC01, DC04, DC05) are all cleared. */
WAIT_UNTIL_CLEAR (NB85E_CACHE_DCC & 0x33); WAIT_UNTIL_CLEAR (V850E_CACHE_DCC & 0x33);
/* 2. Clear DCC register bit 12 (DC12), bit 13 (DC13), or both /* 2. Clear DCC register bit 12 (DC12), bit 13 (DC13), or both
depending on the way for which tags are to be cleared. */ depending on the way for which tags are to be cleared. */
NB85E_CACHE_DCC &= ~0xC000; V850E_CACHE_DCC &= ~0xC000;
/* 3. Set DCC register bit 0 (DC00), bit 1 (DC01) or both depending on /* 3. Set DCC register bit 0 (DC00), bit 1 (DC01) or both depending on
the way for which tags are to be cleared. the way for which tags are to be cleared.
... ...
Set DCC register bit 4 (DC04), bit 5 (DC05), or both depending Set DCC register bit 4 (DC04), bit 5 (DC05), or both depending
on the way to be data flushed. */ on the way to be data flushed. */
NB85E_CACHE_DCC |= flags; V850E_CACHE_DCC |= flags;
/* 4. Read DCC register bit DC00, DC01 [DC04, DC05], or both depending /* 4. Read DCC register bit DC00, DC01 [DC04, DC05], or both depending
on the way for which tags were cleared [flushed] and confirm on the way for which tags were cleared [flushed] and confirm
that that bit is cleared. */ that that bit is cleared. */
WAIT_UNTIL_CLEAR (NB85E_CACHE_DCC & flags); WAIT_UNTIL_CLEAR (V850E_CACHE_DCC & flags);
} }
#endif /* V850E_CACHE_DCC */
/* Flushes the contents of the dcache to memory. */ /* Flushes the contents of the dcache to memory. */
static inline void flush_dcache (void) static inline void flush_dcache (void)
{ {
#ifdef V850E_CACHE_DCC
/* We only need to do something if in write-back mode. */ /* We only need to do something if in write-back mode. */
if (NB85E_CACHE_DCC & 0x0400) if (V850E_CACHE_DCC & 0x0400)
dcache_op (0x30); dcache_op (0x30);
#endif /* V850E_CACHE_DCC */
} }
/* Flushes the contents of the dcache to memory, and then clears it. */ /* Flushes the contents of the dcache to memory, and then clears it. */
static inline void clear_dcache (void) static inline void clear_dcache (void)
{ {
#ifdef V850E_CACHE_DCC
/* We only need to do something if the dcache is enabled. */ /* We only need to do something if the dcache is enabled. */
if (NB85E_CACHE_DCC & 0x0C00) if (V850E_CACHE_DCC & 0x0C00)
dcache_op (0x33); dcache_op (0x33);
#endif /* V850E_CACHE_DCC */
} }
/* Clears the dcache without flushing to memory first. */ /* Clears the dcache without flushing to memory first. */
static inline void clear_dcache_no_flush (void) static inline void clear_dcache_no_flush (void)
{ {
#ifdef V850E_CACHE_DCC
/* We only need to do something if the dcache is enabled. */ /* We only need to do something if the dcache is enabled. */
if (NB85E_CACHE_DCC & 0x0C00) if (V850E_CACHE_DCC & 0x0C00)
dcache_op (0x3); dcache_op (0x3);
#endif /* V850E_CACHE_DCC */
} }
static inline void cache_exec_after_store (void) static inline void cache_exec_after_store (void)
...@@ -121,58 +146,28 @@ static inline void cache_exec_after_store (void) ...@@ -121,58 +146,28 @@ static inline void cache_exec_after_store (void)
/* Exported functions. */ /* Exported functions. */
void inline nb85e_cache_flush_all (void) void flush_icache (void)
{
clear_icache ();
clear_dcache ();
}
void nb85e_cache_flush_mm (struct mm_struct *mm)
{
/* nothing */
}
void nb85e_cache_flush_range (struct mm_struct *mm,
unsigned long start, unsigned long end)
{
/* nothing */
}
void nb85e_cache_flush_page (struct vm_area_struct *vma,
unsigned long page_addr)
{
/* nothing */
}
void nb85e_cache_flush_dcache_page (struct page *page)
{
/* nothing */
}
void nb85e_cache_flush_icache (void)
{ {
cache_exec_after_store (); cache_exec_after_store ();
} }
void nb85e_cache_flush_icache_range (unsigned long start, unsigned long end) void flush_icache_range (unsigned long start, unsigned long end)
{ {
cache_exec_after_store (); cache_exec_after_store ();
} }
void nb85e_cache_flush_icache_page (struct vm_area_struct *vma, void flush_icache_page (struct vm_area_struct *vma, struct page *page)
struct page *page)
{ {
cache_exec_after_store (); cache_exec_after_store ();
} }
void nb85e_cache_flush_icache_user_range (struct vm_area_struct *vma, void flush_icache_user_range (struct vm_area_struct *vma, struct page *page,
struct page *page,
unsigned long adr, int len) unsigned long adr, int len)
{ {
cache_exec_after_store (); cache_exec_after_store ();
} }
void nb85e_cache_flush_sigtramp (unsigned long addr) void flush_cache_sigtramp (unsigned long addr)
{ {
cache_exec_after_store (); cache_exec_after_store ();
} }
/* /*
* arch/v850/kernel/nb85e_intc.c -- NB85E cpu core interrupt controller (INTC) * arch/v850/kernel/v850e_intc.c -- V850E interrupt controller (INTC)
* *
* Copyright (C) 2001,02,03 NEC Electronics Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
...@@ -15,18 +15,18 @@ ...@@ -15,18 +15,18 @@
#include <linux/init.h> #include <linux/init.h>
#include <linux/irq.h> #include <linux/irq.h>
#include <asm/nb85e_intc.h> #include <asm/v850e_intc.h>
static void irq_nop (unsigned irq) { } static void irq_nop (unsigned irq) { }
static unsigned nb85e_intc_irq_startup (unsigned irq) static unsigned v850e_intc_irq_startup (unsigned irq)
{ {
nb85e_intc_clear_pending_irq (irq); v850e_intc_clear_pending_irq (irq);
nb85e_intc_enable_irq (irq); v850e_intc_enable_irq (irq);
return 0; return 0;
} }
static void nb85e_intc_end_irq (unsigned irq) static void v850e_intc_end_irq (unsigned irq)
{ {
unsigned long psw, temp; unsigned long psw, temp;
...@@ -64,22 +64,22 @@ static void nb85e_intc_end_irq (unsigned irq) ...@@ -64,22 +64,22 @@ static void nb85e_intc_end_irq (unsigned irq)
/* Initialize HW_IRQ_TYPES for INTC-controlled irqs described in array /* Initialize HW_IRQ_TYPES for INTC-controlled irqs described in array
INITS (which is terminated by an entry with the name field == 0). */ INITS (which is terminated by an entry with the name field == 0). */
void __init nb85e_intc_init_irq_types (struct nb85e_intc_irq_init *inits, void __init v850e_intc_init_irq_types (struct v850e_intc_irq_init *inits,
struct hw_interrupt_type *hw_irq_types) struct hw_interrupt_type *hw_irq_types)
{ {
struct nb85e_intc_irq_init *init; struct v850e_intc_irq_init *init;
for (init = inits; init->name; init++) { for (init = inits; init->name; init++) {
unsigned i; unsigned i;
struct hw_interrupt_type *hwit = hw_irq_types++; struct hw_interrupt_type *hwit = hw_irq_types++;
hwit->typename = init->name; hwit->typename = init->name;
hwit->startup = nb85e_intc_irq_startup; hwit->startup = v850e_intc_irq_startup;
hwit->shutdown = nb85e_intc_disable_irq; hwit->shutdown = v850e_intc_disable_irq;
hwit->enable = nb85e_intc_enable_irq; hwit->enable = v850e_intc_enable_irq;
hwit->disable = nb85e_intc_disable_irq; hwit->disable = v850e_intc_disable_irq;
hwit->ack = irq_nop; hwit->ack = irq_nop;
hwit->end = nb85e_intc_end_irq; hwit->end = v850e_intc_end_irq;
/* Initialize kernel IRQ infrastructure for this interrupt. */ /* Initialize kernel IRQ infrastructure for this interrupt. */
init_irq_handlers(init->base, init->num, init->interval, hwit); init_irq_handlers(init->base, init->num, init->interval, hwit);
...@@ -92,13 +92,13 @@ void __init nb85e_intc_init_irq_types (struct nb85e_intc_irq_init *inits, ...@@ -92,13 +92,13 @@ void __init nb85e_intc_init_irq_types (struct nb85e_intc_irq_init *inits,
interrupts are initially disabled), then interrupts are initially disabled), then
assume whoever enabled it has set things up assume whoever enabled it has set things up
properly, and avoid messing with it. */ properly, and avoid messing with it. */
if (! nb85e_intc_irq_enabled (irq)) if (! v850e_intc_irq_enabled (irq))
/* This write also (1) disables the /* This write also (1) disables the
interrupt, and (2) clears any pending interrupt, and (2) clears any pending
interrupts. */ interrupts. */
NB85E_INTC_IC (irq) V850E_INTC_IC (irq)
= (NB85E_INTC_IC_PR (init->priority) = (V850E_INTC_IC_PR (init->priority)
| NB85E_INTC_IC_MK); | V850E_INTC_IC_MK);
} }
} }
} }
/* /*
* include/asm-v850/nb85e_timer_d.c -- `Timer D' component often used * include/asm-v850/v850e_timer_d.c -- `Timer D' component often used
* with the NB85E cpu core * with V850E CPUs
* *
* Copyright (C) 2001,02 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -14,41 +14,41 @@ ...@@ -14,41 +14,41 @@
#include <linux/kernel.h> #include <linux/kernel.h>
#include <asm/nb85e_utils.h> #include <asm/v850e_utils.h>
#include <asm/nb85e_timer_d.h> #include <asm/v850e_timer_d.h>
/* Start interval timer TIMER (0-3). The timer will issue the /* Start interval timer TIMER (0-3). The timer will issue the
corresponding INTCMD interrupt RATE times per second. corresponding INTCMD interrupt RATE times per second.
This function does not enable the interrupt. */ This function does not enable the interrupt. */
void nb85e_timer_d_configure (unsigned timer, unsigned rate) void v850e_timer_d_configure (unsigned timer, unsigned rate)
{ {
unsigned divlog2, count; unsigned divlog2, count;
/* Calculate params for timer. */ /* Calculate params for timer. */
if (! calc_counter_params ( if (! calc_counter_params (
NB85E_TIMER_D_BASE_FREQ, rate, V850E_TIMER_D_BASE_FREQ, rate,
NB85E_TIMER_D_TMCD_CS_MIN, NB85E_TIMER_D_TMCD_CS_MAX, 16, V850E_TIMER_D_TMCD_CS_MIN, V850E_TIMER_D_TMCD_CS_MAX, 16,
&divlog2, &count)) &divlog2, &count))
printk (KERN_WARNING printk (KERN_WARNING
"Cannot find interval timer %d setting suitable" "Cannot find interval timer %d setting suitable"
" for rate of %dHz.\n" " for rate of %dHz.\n"
"Using rate of %dHz instead.\n", "Using rate of %dHz instead.\n",
timer, rate, timer, rate,
(NB85E_TIMER_D_BASE_FREQ >> divlog2) >> 16); (V850E_TIMER_D_BASE_FREQ >> divlog2) >> 16);
/* Do the actual hardware timer initialization: */ /* Do the actual hardware timer initialization: */
/* Enable timer. */ /* Enable timer. */
NB85E_TIMER_D_TMCD(timer) = NB85E_TIMER_D_TMCD_CAE; V850E_TIMER_D_TMCD(timer) = V850E_TIMER_D_TMCD_CAE;
/* Set clock divider. */ /* Set clock divider. */
NB85E_TIMER_D_TMCD(timer) V850E_TIMER_D_TMCD(timer)
= NB85E_TIMER_D_TMCD_CAE = V850E_TIMER_D_TMCD_CAE
| NB85E_TIMER_D_TMCD_CS(divlog2); | V850E_TIMER_D_TMCD_CS(divlog2);
/* Set timer compare register. */ /* Set timer compare register. */
NB85E_TIMER_D_CMD(timer) = count; V850E_TIMER_D_CMD(timer) = count;
/* Start counting. */ /* Start counting. */
NB85E_TIMER_D_TMCD(timer) V850E_TIMER_D_TMCD(timer)
= NB85E_TIMER_D_TMCD_CAE = V850E_TIMER_D_TMCD_CAE
| NB85E_TIMER_D_TMCD_CS(divlog2) | V850E_TIMER_D_TMCD_CS(divlog2)
| NB85E_TIMER_D_TMCD_CE; | V850E_TIMER_D_TMCD_CE;
} }
/* /*
* include/asm-v850/nb85e_utils.h -- Utility functions associated with * include/asm-v850/v850e_utils.h -- Utility functions associated with
* the NB85E cpu core * V850E CPUs
* *
* Copyright (C) 2001,02 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -12,10 +12,7 @@ ...@@ -12,10 +12,7 @@
* Written by Miles Bader <miles@gnu.org> * Written by Miles Bader <miles@gnu.org>
*/ */
/* Note: these functions are often associated with the N85E cpu core, #include <asm/v850e_utils.h>
but not always, which is why they're not in `nb85e.c'. */
#include <asm/nb85e_utils.h>
/* Calculate counter clock-divider and count values to attain the /* Calculate counter clock-divider and count values to attain the
desired frequency RATE from the base frequency BASE_FREQ. The desired frequency RATE from the base frequency BASE_FREQ. The
......
/* Linker script for the Midas labs RTE-V850E/ME2-CB evaluation board
(CONFIG_RTE_CB_ME2), with kernel in SDRAM. */
MEMORY {
/* 128Kbyte of IRAM */
IRAM : ORIGIN = 0x00000000, LENGTH = 0x00020000
/* 32MB of SDRAM. */
SDRAM : ORIGIN = 0x00800000, LENGTH = 0x02000000
}
#define KRAM SDRAM
SECTIONS {
.text : {
__kram_start = . ;
TEXT_CONTENTS
INTV_CONTENTS /* copy to iRAM (0x0-0x620) */
} > KRAM
.data : {
DATA_CONTENTS
BSS_CONTENTS
RAMK_INIT_CONTENTS
__kram_end = . ;
BOOTMAP_CONTENTS
} > KRAM
.root ALIGN (4096) : { ROOT_FS_CONTENTS } > SDRAM
}
...@@ -19,26 +19,26 @@ MEMORY { ...@@ -19,26 +19,26 @@ MEMORY {
/* `external ram' (CS1 area), comes after IRAM. /* `external ram' (CS1 area), comes after IRAM.
This should match ERAM_ADDR in "include/asm-v580/sim85e2c.h". */ This should match ERAM_ADDR in "include/asm-v580/sim85e2c.h". */
ERAM : ORIGIN = 0x00100000, LENGTH = 0x07f00000 ERAM : ORIGIN = 0x00100000, LENGTH = 0x07f00000
/* Dynamic RAM; uses memory controller. */
/* SDRAM : ORIGIN = 0x10000000, LENGTH = 0x01000000 */
SDRAM : ORIGIN = 0x10000000, LENGTH = 0x00200000/*use 2MB*/
} }
SECTIONS { SECTIONS {
.iram : { .iram : {
INTV_CONTENTS INTV_CONTENTS
TEXT_CONTENTS *arch/v850/kernel/head.o
RAMK_INIT_CONTENTS *(.early.text)
} > IRAM } > IRAM
.data : { .dram : {
__kram_start = . ;
DATA_CONTENTS
BSS_CONTENTS
ROOT_FS_CONTENTS
/* We stick console output into a buffer here. */
_memcons_output = . ; _memcons_output = . ;
. = . + 0x8000 ; . = . + 0x8000 ;
_memcons_output_end = . ; _memcons_output_end = . ;
} > DRAM
__kram_end = . ; .sdram : {
BOOTMAP_CONTENTS /* We stick console output into a buffer here. */
} > DRAM AT> DRAM_LOAD RAMK_KRAM_CONTENTS
ROOT_FS_CONTENTS
} > SDRAM
} }
...@@ -206,8 +206,8 @@ _jiffies = _jiffies_64 ; ...@@ -206,8 +206,8 @@ _jiffies = _jiffies_64 ;
# include "sim.ld" # include "sim.ld"
#endif #endif
#ifdef CONFIG_V850E2_SIM85E2C #ifdef CONFIG_V850E2_SIM85E2
# include "sim85e2c.ld" # include "sim85e2.ld"
#endif #endif
#ifdef CONFIG_V850E2_FPGA85E2C #ifdef CONFIG_V850E2_FPGA85E2C
...@@ -247,3 +247,8 @@ _jiffies = _jiffies_64 ; ...@@ -247,3 +247,8 @@ _jiffies = _jiffies_64 ;
# include "rte_nb85e_cb.ld" # include "rte_nb85e_cb.ld"
# endif # endif
#endif #endif
#ifdef CONFIG_RTE_CB_ME2
# include "rte_me2_cb.ld"
#endif
...@@ -404,14 +404,19 @@ config SERIAL_SUNSAB_CONSOLE ...@@ -404,14 +404,19 @@ config SERIAL_SUNSAB_CONSOLE
on your Sparc system as the console, you can do so by answering on your Sparc system as the console, you can do so by answering
Y to this option. Y to this option.
config V850E_NB85E_UART config V850E_UART
bool "NEC V850E on-chip UART support" bool "NEC V850E on-chip UART support"
depends on V850E_NB85E || V850E2_ANNA || V850E_AS85EP1 depends on V850E_MA1 || V850E_ME2 || V850E_TEG || V850E2_ANNA || V850E_AS85EP1
default y default y
config V850E_NB85E_UART_CONSOLE config V850E_UARTB
bool
depends V850E_UART && V850E_ME2
default y
config V850E_UART_CONSOLE
bool "Use NEC V850E on-chip UART for console" bool "Use NEC V850E on-chip UART for console"
depends on V850E_NB85E_UART depends on V850E_UART
config SERIAL98 config SERIAL98
tristate "PC-9800 8251-based primary serial port support" tristate "PC-9800 8251-based primary serial port support"
...@@ -426,12 +431,12 @@ config SERIAL98_CONSOLE ...@@ -426,12 +431,12 @@ config SERIAL98_CONSOLE
config SERIAL_CORE config SERIAL_CORE
tristate tristate
default m if SERIAL_AMBA!=y && SERIAL_CLPS711X!=y && SERIAL_21285!=y && !SERIAL_SA1100 && !SERIAL_ANAKIN && !SERIAL_UART00 && SERIAL_8250!=y && SERIAL_MUX!=y && !SERIAL_ROCKETPORT && !SERIAL_SUNCORE && !V850E_NB85E_UART && (SERIAL_AMBA=m || SERIAL_CLPS711X=m || SERIAL_21285=m || SERIAL_8250=m || SERIAL_MUX=m || SERIAL98=m) default m if SERIAL_AMBA!=y && SERIAL_CLPS711X!=y && SERIAL_21285!=y && !SERIAL_SA1100 && !SERIAL_ANAKIN && !SERIAL_UART00 && SERIAL_8250!=y && SERIAL_MUX!=y && !SERIAL_ROCKETPORT && !SERIAL_SUNCORE && !V850E_UART && (SERIAL_AMBA=m || SERIAL_CLPS711X=m || SERIAL_21285=m || SERIAL_8250=m || SERIAL_MUX=m || SERIAL98=m)
default y if SERIAL_AMBA=y || SERIAL_CLPS711X=y || SERIAL_21285=y || SERIAL_SA1100 || SERIAL_ANAKIN || SERIAL_UART00 || SERIAL_8250=y || SERIAL_MUX=y || SERIAL_ROCKETPORT || SERIAL_SUNCORE || V850E_NB85E_UART || SERIAL98=y default y if SERIAL_AMBA=y || SERIAL_CLPS711X=y || SERIAL_21285=y || SERIAL_SA1100 || SERIAL_ANAKIN || SERIAL_UART00 || SERIAL_8250=y || SERIAL_MUX=y || SERIAL_ROCKETPORT || SERIAL_SUNCORE || V850E_UART || SERIAL98=y
config SERIAL_CORE_CONSOLE config SERIAL_CORE_CONSOLE
bool bool
depends on SERIAL_AMBA_CONSOLE || SERIAL_CLPS711X_CONSOLE || SERIAL_21285_CONSOLE || SERIAL_SA1100_CONSOLE || SERIAL_ANAKIN_CONSOLE || SERIAL_UART00_CONSOLE || SERIAL_8250_CONSOLE || SERIAL_MUX_CONSOLE || SERIAL_SUNZILOG_CONSOLE || SERIAL_SUNSU_CONSOLE || SERIAL_SUNSAB_CONSOLE || V850E_NB85E_UART_CONSOLE || SERIAL98_CONSOLE depends on SERIAL_AMBA_CONSOLE || SERIAL_CLPS711X_CONSOLE || SERIAL_21285_CONSOLE || SERIAL_SA1100_CONSOLE || SERIAL_ANAKIN_CONSOLE || SERIAL_UART00_CONSOLE || SERIAL_8250_CONSOLE || SERIAL_MUX_CONSOLE || SERIAL_SUNZILOG_CONSOLE || SERIAL_SUNSU_CONSOLE || SERIAL_SUNSAB_CONSOLE || V850E_UART_CONSOLE || SERIAL98_CONSOLE
default y default y
config SERIAL_68328 config SERIAL_68328
......
...@@ -29,5 +29,5 @@ obj-$(CONFIG_SERIAL_MUX) += mux.o ...@@ -29,5 +29,5 @@ obj-$(CONFIG_SERIAL_MUX) += mux.o
obj-$(CONFIG_SERIAL_68328) += 68328serial.o obj-$(CONFIG_SERIAL_68328) += 68328serial.o
obj-$(CONFIG_SERIAL_68360) += 68360serial.o obj-$(CONFIG_SERIAL_68360) += 68360serial.o
obj-$(CONFIG_SERIAL_COLDFIRE) += mcfserial.o obj-$(CONFIG_SERIAL_COLDFIRE) += mcfserial.o
obj-$(CONFIG_V850E_NB85E_UART) += nb85e_uart.o obj-$(CONFIG_V850E_UART) += v850e_uart.o
obj-$(CONFIG_SERIAL98) += serial98.o obj-$(CONFIG_SERIAL98) += serial98.o
/* /*
* drivers/serial/nb85e_uart.c -- Serial I/O using V850E/NB85E on-chip UART * drivers/serial/v850e_uart.c -- Serial I/O using V850E on-chip UART or UARTB
* *
* Copyright (C) 2001,02,03 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
...@@ -11,6 +11,16 @@ ...@@ -11,6 +11,16 @@
* Written by Miles Bader <miles@gnu.org> * Written by Miles Bader <miles@gnu.org>
*/ */
/* This driver supports both the original V850E UART interface (called
merely `UART' in the docs) and the newer `UARTB' interface, which is
roughly a superset of the first one. The selection is made at
configure time -- if CONFIG_V850E_UARTB is defined, then UARTB is
presumed, otherwise the old UART -- as these are on-CPU UARTS, a system
can never have both.
The UARTB interface also has a 16-entry FIFO mode, which is not
yet supported by this driver. */
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/module.h> #include <linux/module.h>
...@@ -20,141 +30,64 @@ ...@@ -20,141 +30,64 @@
#include <linux/serial.h> #include <linux/serial.h>
#include <linux/serial_core.h> #include <linux/serial_core.h>
#include <asm/nb85e_uart.h> #include <asm/v850e_uart.h>
#include <asm/nb85e_utils.h>
/* Initial UART state. This may be overridden by machine-dependent headers. */ /* Initial UART state. This may be overridden by machine-dependent headers. */
#ifndef NB85E_UART_INIT_BAUD #ifndef V850E_UART_INIT_BAUD
#define NB85E_UART_INIT_BAUD 115200 #define V850E_UART_INIT_BAUD 115200
#endif #endif
#ifndef NB85E_UART_INIT_CFLAGS #ifndef V850E_UART_INIT_CFLAGS
#define NB85E_UART_INIT_CFLAGS (B115200 | CS8 | CREAD) #define V850E_UART_INIT_CFLAGS (B115200 | CS8 | CREAD)
#endif #endif
/* XXX This should be in a header file. */
#define NB85E_UART_BRGC_MIN 8
/* A string used for prefixing printed descriptions; since the same UART /* A string used for prefixing printed descriptions; since the same UART
macro is actually used on other chips than the V850E/NB85E. This must macro is actually used on other chips than the V850E. This must be a
be a constant string. */ constant string. */
#ifndef NB85E_UART_CHIP_NAME #ifndef V850E_UART_CHIP_NAME
#define NB85E_UART_CHIP_NAME "V850E/NB85E" #define V850E_UART_CHIP_NAME "V850E"
#endif #endif
#define V850E_UART_MINOR_BASE 64 /* First tty minor number */
/* Helper functions for doing baud-rate/frequency calculations. */
/* Calculate the minimum value for CKSR on this processor. */
static inline unsigned cksr_min (void)
{
int min = 0;
unsigned freq = NB85E_UART_BASE_FREQ;
while (freq > NB85E_UART_CKSR_MAX_FREQ) {
freq >>= 1;
min++;
}
return min;
}
/* Minimum baud rate possible. */
#define min_baud() \
((NB85E_UART_BASE_FREQ >> NB85E_UART_CKSR_MAX) / (2 * 255) + 1)
/* Maximum baud rate possible. The error is quite high at max, though. */
#define max_baud() \
((NB85E_UART_BASE_FREQ >> cksr_min()) / (2 * NB85E_UART_BRGC_MIN))
/* Low-level UART functions. */ /* Low-level UART functions. */
/* These masks define which control bits affect TX/RX modes, respectively. */
#define RX_BITS \
(NB85E_UART_ASIM_PS_MASK | NB85E_UART_ASIM_CL_8 | NB85E_UART_ASIM_ISRM)
#define TX_BITS \
(NB85E_UART_ASIM_PS_MASK | NB85E_UART_ASIM_CL_8 | NB85E_UART_ASIM_SL_2)
/* The UART require various delays after writing control registers. */
static inline void nb85e_uart_delay (unsigned cycles)
{
/* The loop takes 2 insns, so loop CYCLES / 2 times. */
register unsigned count = cycles >> 1;
while (--count != 0)
/* nothing */;
}
/* Configure and turn on uart channel CHAN, using the termios `control /* Configure and turn on uart channel CHAN, using the termios `control
modes' bits in CFLAGS, and a baud-rate of BAUD. */ modes' bits in CFLAGS, and a baud-rate of BAUD. */
void nb85e_uart_configure (unsigned chan, unsigned cflags, unsigned baud) void v850e_uart_configure (unsigned chan, unsigned cflags, unsigned baud)
{ {
int flags; int flags;
unsigned new_config = 0; /* What we'll write to the control reg. */ v850e_uart_speed_t old_speed;
unsigned new_clk_divlog2; /* New baud-rate generate clock divider. */ v850e_uart_config_t old_config;
unsigned new_brgen_count; /* New counter max for baud-rate generator.*/ v850e_uart_speed_t new_speed = v850e_uart_calc_speed (baud);
/* These are the current values corresponding to the above. */ v850e_uart_config_t new_config = v850e_uart_calc_config (cflags);
unsigned old_config, old_clk_divlog2, old_brgen_count;
/* Calculate new baud-rate generator config values. */
/* Calculate the log2 clock divider and baud-rate counter values
(note that the UART divides the resulting clock by 2, so
multiply BAUD by 2 here to compensate). */
calc_counter_params (NB85E_UART_BASE_FREQ, baud * 2,
cksr_min(), NB85E_UART_CKSR_MAX, 8/*bits*/,
&new_clk_divlog2, &new_brgen_count);
/* Figure out new configuration of control register. */
if (cflags & CSTOPB)
/* Number of stop bits, 1 or 2. */
new_config |= NB85E_UART_ASIM_SL_2;
if ((cflags & CSIZE) == CS8)
/* Number of data bits, 7 or 8. */
new_config |= NB85E_UART_ASIM_CL_8;
if (! (cflags & PARENB))
/* No parity check/generation. */
new_config |= NB85E_UART_ASIM_PS_NONE;
else if (cflags & PARODD)
/* Odd parity check/generation. */
new_config |= NB85E_UART_ASIM_PS_ODD;
else
/* Even parity check/generation. */
new_config |= NB85E_UART_ASIM_PS_EVEN;
if (cflags & CREAD)
/* Reading enabled. */
new_config |= NB85E_UART_ASIM_RXE;
new_config |= NB85E_UART_ASIM_TXE; /* Writing is always enabled. */
new_config |= NB85E_UART_ASIM_CAE;
new_config |= NB85E_UART_ASIM_ISRM; /* Errors generate a read-irq. */
/* Disable interrupts while we're twiddling the hardware. */ /* Disable interrupts while we're twiddling the hardware. */
local_irq_save (flags); local_irq_save (flags);
#ifdef NB85E_UART_PRE_CONFIGURE #ifdef V850E_UART_PRE_CONFIGURE
NB85E_UART_PRE_CONFIGURE (chan, cflags, baud); V850E_UART_PRE_CONFIGURE (chan, cflags, baud);
#endif #endif
old_config = NB85E_UART_ASIM (chan); old_config = V850E_UART_CONFIG (chan);
old_clk_divlog2 = NB85E_UART_CKSR (chan); old_speed = v850e_uart_speed (chan);
old_brgen_count = NB85E_UART_BRGC (chan);
if (new_clk_divlog2 != old_clk_divlog2 if (! v850e_uart_speed_eq (old_speed, new_speed)) {
|| new_brgen_count != old_brgen_count)
{
/* The baud rate has changed. First, disable the UART. */ /* The baud rate has changed. First, disable the UART. */
NB85E_UART_ASIM (chan) = 0; V850E_UART_CONFIG (chan) = V850E_UART_CONFIG_FINI;
old_config = 0; old_config = 0; /* Force the uart to be re-initialized. */
/* Reprogram the baud-rate generator. */ /* Reprogram the baud-rate generator. */
NB85E_UART_CKSR (chan) = new_clk_divlog2; v850e_uart_set_speed (chan, new_speed);
NB85E_UART_BRGC (chan) = new_brgen_count;
} }
if (! (old_config & NB85E_UART_ASIM_CAE)) { if (! (old_config & V850E_UART_CONFIG_ENABLED)) {
/* If we are enabling the uart for the first time, start /* If we are using the uart for the first time, start by
by turning on the enable bit, which must be done enabling it, which must be done before turning on any
before turning on any other bits. */ other bits. */
NB85E_UART_ASIM (chan) = NB85E_UART_ASIM_CAE; V850E_UART_CONFIG (chan) = V850E_UART_CONFIG_INIT;
/* Enabling the uart also resets it. */ /* See the initial state. */
old_config = NB85E_UART_ASIM_CAE; old_config = V850E_UART_CONFIG (chan);
} }
if (new_config != old_config) { if (new_config != old_config) {
...@@ -166,37 +99,34 @@ void nb85e_uart_configure (unsigned chan, unsigned cflags, unsigned baud) ...@@ -166,37 +99,34 @@ void nb85e_uart_configure (unsigned chan, unsigned cflags, unsigned baud)
unsigned changed_bits = new_config ^ old_config; unsigned changed_bits = new_config ^ old_config;
/* Which of RX/TX will be enabled in the new configuration. */ /* Which of RX/TX will be enabled in the new configuration. */
if (new_config & RX_BITS) if (new_config & V850E_UART_CONFIG_RX_BITS)
enable |= (new_config & NB85E_UART_ASIM_RXE); enable |= (new_config & V850E_UART_CONFIG_RX_ENABLE);
if (new_config & TX_BITS) if (new_config & V850E_UART_CONFIG_TX_BITS)
enable |= (new_config & NB85E_UART_ASIM_TXE); enable |= (new_config & V850E_UART_CONFIG_TX_ENABLE);
/* Figure out which of RX/TX needs to be disabled; note /* Figure out which of RX/TX needs to be disabled; note
that this will only happen if they're not already that this will only happen if they're not already
disabled. */ disabled. */
if (changed_bits & RX_BITS) if (changed_bits & V850E_UART_CONFIG_RX_BITS)
temp_disable |= (old_config & NB85E_UART_ASIM_RXE); temp_disable
if (changed_bits & TX_BITS) |= (old_config & V850E_UART_CONFIG_RX_ENABLE);
temp_disable |= (old_config & NB85E_UART_ASIM_TXE); if (changed_bits & V850E_UART_CONFIG_TX_BITS)
temp_disable
|= (old_config & V850E_UART_CONFIG_TX_ENABLE);
/* We have to turn off RX and/or TX mode before changing /* We have to turn off RX and/or TX mode before changing
any associated control bits. */ any associated control bits. */
if (temp_disable) if (temp_disable)
NB85E_UART_ASIM (chan) = old_config & ~temp_disable; V850E_UART_CONFIG (chan) = old_config & ~temp_disable;
/* Write the new control bits, while RX/TX are disabled. */ /* Write the new control bits, while RX/TX are disabled. */
if (changed_bits & ~enable) if (changed_bits & ~enable)
NB85E_UART_ASIM (chan) = new_config & ~enable; V850E_UART_CONFIG (chan) = new_config & ~enable;
/* The UART may not be reset properly unless we v850e_uart_config_delay (new_config, new_speed);
wait at least 2 `basic-clocks' until turning
on the TXE/RXE bits again. A `basic clock'
is the clock used by the baud-rate generator, i.e.,
the cpu clock divided by the 2^new_clk_divlog2. */
nb85e_uart_delay (1 << (new_clk_divlog2 + 1));
/* Write the final version, with enable bits turned on. */ /* Write the final version, with enable bits turned on. */
NB85E_UART_ASIM (chan) = new_config; V850E_UART_CONFIG (chan) = new_config;
} }
local_irq_restore (flags); local_irq_restore (flags);
...@@ -205,35 +135,35 @@ void nb85e_uart_configure (unsigned chan, unsigned cflags, unsigned baud) ...@@ -205,35 +135,35 @@ void nb85e_uart_configure (unsigned chan, unsigned cflags, unsigned baud)
/* Low-level console. */ /* Low-level console. */
#ifdef CONFIG_V850E_NB85E_UART_CONSOLE #ifdef CONFIG_V850E_UART_CONSOLE
static void nb85e_uart_cons_write (struct console *co, static void v850e_uart_cons_write (struct console *co,
const char *s, unsigned count) const char *s, unsigned count)
{ {
if (count > 0) { if (count > 0) {
unsigned chan = co->index; unsigned chan = co->index;
unsigned irq = IRQ_INTST (chan); unsigned irq = V850E_UART_TX_IRQ (chan);
int irq_was_enabled, irq_was_pending, flags; int irq_was_enabled, irq_was_pending, flags;
/* We don't want to get `transmission completed' (INTST) /* We don't want to get `transmission completed'
interrupts, since we're busy-waiting, so we disable interrupts, since we're busy-waiting, so we disable them
them while sending (we don't disable interrupts while sending (we don't disable interrupts entirely
entirely because sending over a serial line is really because sending over a serial line is really slow). We
slow). We save the status of INTST and restore it save the status of the tx interrupt and restore it when
when we're done so that using printk doesn't we're done so that using printk doesn't interfere with
interfere with normal serial transmission (other than normal serial transmission (other than interleaving the
interleaving the output, of course!). This should output, of course!). This should work correctly even if
work correctly even if this function is interrupted this function is interrupted and the interrupt printks
and the interrupt printks something. */ something. */
/* Disable interrupts while fiddling with INTST. */ /* Disable interrupts while fiddling with tx interrupt. */
local_irq_save (flags); local_irq_save (flags);
/* Get current INTST status. */ /* Get current tx interrupt status. */
irq_was_enabled = nb85e_intc_irq_enabled (irq); irq_was_enabled = v850e_intc_irq_enabled (irq);
irq_was_pending = nb85e_intc_irq_pending (irq); irq_was_pending = v850e_intc_irq_pending (irq);
/* Disable INTST if necessary. */ /* Disable tx interrupt if necessary. */
if (irq_was_enabled) if (irq_was_enabled)
nb85e_intc_disable_irq (irq); v850e_intc_disable_irq (irq);
/* Turn interrupts back on. */ /* Turn interrupts back on. */
local_irq_restore (flags); local_irq_restore (flags);
...@@ -244,72 +174,80 @@ static void nb85e_uart_cons_write (struct console *co, ...@@ -244,72 +174,80 @@ static void nb85e_uart_cons_write (struct console *co,
if (ch == '\n') { if (ch == '\n') {
/* We don't have the benefit of a tty /* We don't have the benefit of a tty
driver, so translate NL into CR LF. */ driver, so translate NL into CR LF. */
nb85e_uart_wait_for_xmit_ok (chan); v850e_uart_wait_for_xmit_ok (chan);
nb85e_uart_putc (chan, '\r'); v850e_uart_putc (chan, '\r');
} }
nb85e_uart_wait_for_xmit_ok (chan); v850e_uart_wait_for_xmit_ok (chan);
nb85e_uart_putc (chan, ch); v850e_uart_putc (chan, ch);
count--; count--;
} }
/* Restore saved INTST status. */ /* Restore saved tx interrupt status. */
if (irq_was_enabled) { if (irq_was_enabled) {
/* Wait for the last character we sent to be /* Wait for the last character we sent to be
completely transmitted (as we'll get an INTST completely transmitted (as we'll get an
interrupt at that point). */ interrupt interrupt at that point). */
nb85e_uart_wait_for_xmit_done (chan); v850e_uart_wait_for_xmit_done (chan);
/* Clear pending interrupts received due /* Clear pending interrupts received due
to our transmission, unless there was already to our transmission, unless there was already
one pending, in which case we want the one pending, in which case we want the
handler to be called. */ handler to be called. */
if (! irq_was_pending) if (! irq_was_pending)
nb85e_intc_clear_pending_irq (irq); v850e_intc_clear_pending_irq (irq);
/* ... and then turn back on handling. */ /* ... and then turn back on handling. */
nb85e_intc_enable_irq (irq); v850e_intc_enable_irq (irq);
} }
} }
} }
extern struct uart_driver nb85e_uart_driver; extern struct uart_driver v850e_uart_driver;
static struct console nb85e_uart_cons = static struct console v850e_uart_cons =
{ {
.name = "ttyS", .name = "ttyS",
.write = nb85e_uart_cons_write, .write = v850e_uart_cons_write,
.device = uart_console_device, .device = uart_console_device,
.flags = CON_PRINTBUFFER, .flags = CON_PRINTBUFFER,
.cflag = NB85E_UART_INIT_CFLAGS, .cflag = V850E_UART_INIT_CFLAGS,
.index = -1, .index = -1,
.data = &nb85e_uart_driver, .data = &v850e_uart_driver,
}; };
void nb85e_uart_cons_init (unsigned chan) void v850e_uart_cons_init (unsigned chan)
{ {
nb85e_uart_configure (chan, NB85E_UART_INIT_CFLAGS, v850e_uart_configure (chan, V850E_UART_INIT_CFLAGS,
NB85E_UART_INIT_BAUD); V850E_UART_INIT_BAUD);
nb85e_uart_cons.index = chan; v850e_uart_cons.index = chan;
register_console (&nb85e_uart_cons); register_console (&v850e_uart_cons);
printk ("Console: %s on-chip UART channel %d\n", printk ("Console: %s on-chip UART channel %d\n",
NB85E_UART_CHIP_NAME, chan); V850E_UART_CHIP_NAME, chan);
} }
#define NB85E_UART_CONSOLE &nb85e_uart_cons /* This is what the init code actually calls. */
static int v850e_uart_console_init (void)
{
v850e_uart_cons_init (V850E_UART_CONSOLE_CHANNEL);
return 0;
}
console_initcall(v850e_uart_console_init);
#define V850E_UART_CONSOLE &v850e_uart_cons
#else /* !CONFIG_V850E_NB85E_UART_CONSOLE */ #else /* !CONFIG_V850E_UART_CONSOLE */
#define NB85E_UART_CONSOLE 0 #define V850E_UART_CONSOLE 0
#endif /* CONFIG_V850E_NB85E_UART_CONSOLE */ #endif /* CONFIG_V850E_UART_CONSOLE */
/* TX/RX interrupt handlers. */ /* TX/RX interrupt handlers. */
static void nb85e_uart_stop_tx (struct uart_port *port, unsigned tty_stop); static void v850e_uart_stop_tx (struct uart_port *port, unsigned tty_stop);
void nb85e_uart_tx (struct uart_port *port) void v850e_uart_tx (struct uart_port *port)
{ {
struct circ_buf *xmit = &port->info->xmit; struct circ_buf *xmit = &port->info->xmit;
int stopped = uart_tx_stopped (port); int stopped = uart_tx_stopped (port);
if (nb85e_uart_xmit_ok (port->line)) { if (v850e_uart_xmit_ok (port->line)) {
int tx_ch; int tx_ch;
if (port->x_char) { if (port->x_char) {
...@@ -321,7 +259,7 @@ void nb85e_uart_tx (struct uart_port *port) ...@@ -321,7 +259,7 @@ void nb85e_uart_tx (struct uart_port *port)
} else } else
goto no_xmit; goto no_xmit;
nb85e_uart_putc (port->line, tx_ch); v850e_uart_putc (port->line, tx_ch);
port->icount.tx++; port->icount.tx++;
if (uart_circ_chars_pending (xmit) < WAKEUP_CHARS) if (uart_circ_chars_pending (xmit) < WAKEUP_CHARS)
...@@ -330,30 +268,31 @@ void nb85e_uart_tx (struct uart_port *port) ...@@ -330,30 +268,31 @@ void nb85e_uart_tx (struct uart_port *port)
no_xmit: no_xmit:
if (uart_circ_empty (xmit) || stopped) if (uart_circ_empty (xmit) || stopped)
nb85e_uart_stop_tx (port, stopped); v850e_uart_stop_tx (port, stopped);
} }
static void nb85e_uart_tx_irq (int irq, void *data, struct pt_regs *regs) static irqreturn_t v850e_uart_tx_irq(int irq, void *data, struct pt_regs *regs)
{ {
struct uart_port *port = data; struct uart_port *port = data;
nb85e_uart_tx (port); v850e_uart_tx (port);
return IRQ_HANDLED;
} }
static void nb85e_uart_rx_irq (int irq, void *data, struct pt_regs *regs) static irqreturn_t v850e_uart_rx_irq(int irq, void *data, struct pt_regs *regs)
{ {
struct uart_port *port = data; struct uart_port *port = data;
unsigned ch_stat = TTY_NORMAL; unsigned ch_stat = TTY_NORMAL;
unsigned ch = NB85E_UART_RXB (port->line); unsigned ch = v850e_uart_getc (port->line);
unsigned err = NB85E_UART_ASIS (port->line); unsigned err = v850e_uart_err (port->line);
if (err) { if (err) {
if (err & NB85E_UART_ASIS_OVE) { if (err & V850E_UART_ERR_OVERRUN) {
ch_stat = TTY_OVERRUN; ch_stat = TTY_OVERRUN;
port->icount.overrun++; port->icount.overrun++;
} else if (err & NB85E_UART_ASIS_FE) { } else if (err & V850E_UART_ERR_FRAME) {
ch_stat = TTY_FRAME; ch_stat = TTY_FRAME;
port->icount.frame++; port->icount.frame++;
} else if (err & NB85E_UART_ASIS_PE) { } else if (err & V850E_UART_ERR_PARITY) {
ch_stat = TTY_PARITY; ch_stat = TTY_PARITY;
port->icount.parity++; port->icount.parity++;
} }
...@@ -363,33 +302,36 @@ static void nb85e_uart_rx_irq (int irq, void *data, struct pt_regs *regs) ...@@ -363,33 +302,36 @@ static void nb85e_uart_rx_irq (int irq, void *data, struct pt_regs *regs)
tty_insert_flip_char (port->info->tty, ch, ch_stat); tty_insert_flip_char (port->info->tty, ch, ch_stat);
tty_schedule_flip (port->info->tty); tty_schedule_flip (port->info->tty);
return IRQ_HANDLED;
} }
/* Control functions for the serial framework. */ /* Control functions for the serial framework. */
static void nb85e_uart_nop (struct uart_port *port) { } static void v850e_uart_nop (struct uart_port *port) { }
static int nb85e_uart_success (struct uart_port *port) { return 0; } static int v850e_uart_success (struct uart_port *port) { return 0; }
static unsigned nb85e_uart_tx_empty (struct uart_port *port) static unsigned v850e_uart_tx_empty (struct uart_port *port)
{ {
return TIOCSER_TEMT; /* Can't detect. */ return TIOCSER_TEMT; /* Can't detect. */
} }
static void nb85e_uart_set_mctrl (struct uart_port *port, unsigned mctrl) static void v850e_uart_set_mctrl (struct uart_port *port, unsigned mctrl)
{ {
#ifdef NB85E_UART_SET_RTS #ifdef V850E_UART_SET_RTS
NB85E_UART_SET_RTS (port->line, (mctrl & TIOCM_RTS)); V850E_UART_SET_RTS (port->line, (mctrl & TIOCM_RTS));
#endif #endif
} }
static unsigned nb85e_uart_get_mctrl (struct uart_port *port) static unsigned v850e_uart_get_mctrl (struct uart_port *port)
{ {
/* We don't support DCD or DSR, so consider them permanently active. */ /* We don't support DCD or DSR, so consider them permanently active. */
int mctrl = TIOCM_CAR | TIOCM_DSR; int mctrl = TIOCM_CAR | TIOCM_DSR;
/* We may support CTS. */ /* We may support CTS. */
#ifdef NB85E_UART_CTS #ifdef V850E_UART_CTS
mctrl |= NB85E_UART_CTS(port->line) ? TIOCM_CTS : 0; mctrl |= V850E_UART_CTS(port->line) ? TIOCM_CTS : 0;
#else #else
mctrl |= TIOCM_CTS; mctrl |= TIOCM_CTS;
#endif #endif
...@@ -397,71 +339,72 @@ static unsigned nb85e_uart_get_mctrl (struct uart_port *port) ...@@ -397,71 +339,72 @@ static unsigned nb85e_uart_get_mctrl (struct uart_port *port)
return mctrl; return mctrl;
} }
static void nb85e_uart_start_tx (struct uart_port *port, unsigned tty_start) static void v850e_uart_start_tx (struct uart_port *port, unsigned tty_start)
{ {
nb85e_intc_disable_irq (IRQ_INTST (port->line)); v850e_intc_disable_irq (V850E_UART_TX_IRQ (port->line));
nb85e_uart_tx (port); v850e_uart_tx (port);
nb85e_intc_enable_irq (IRQ_INTST (port->line)); v850e_intc_enable_irq (V850E_UART_TX_IRQ (port->line));
} }
static void nb85e_uart_stop_tx (struct uart_port *port, unsigned tty_stop) static void v850e_uart_stop_tx (struct uart_port *port, unsigned tty_stop)
{ {
nb85e_intc_disable_irq (IRQ_INTST (port->line)); v850e_intc_disable_irq (V850E_UART_TX_IRQ (port->line));
} }
static void nb85e_uart_start_rx (struct uart_port *port) static void v850e_uart_start_rx (struct uart_port *port)
{ {
nb85e_intc_enable_irq (IRQ_INTSR (port->line)); v850e_intc_enable_irq (V850E_UART_RX_IRQ (port->line));
} }
static void nb85e_uart_stop_rx (struct uart_port *port) static void v850e_uart_stop_rx (struct uart_port *port)
{ {
nb85e_intc_disable_irq (IRQ_INTSR (port->line)); v850e_intc_disable_irq (V850E_UART_RX_IRQ (port->line));
} }
static void nb85e_uart_break_ctl (struct uart_port *port, int break_ctl) static void v850e_uart_break_ctl (struct uart_port *port, int break_ctl)
{ {
/* Umm, do this later. */ /* Umm, do this later. */
} }
static int nb85e_uart_startup (struct uart_port *port) static int v850e_uart_startup (struct uart_port *port)
{ {
int err; int err;
/* Alloc RX irq. */ /* Alloc RX irq. */
err = request_irq (IRQ_INTSR (port->line), nb85e_uart_rx_irq, err = request_irq (V850E_UART_RX_IRQ (port->line), v850e_uart_rx_irq,
SA_INTERRUPT, "nb85e_uart", port); SA_INTERRUPT, "v850e_uart", port);
if (err) if (err)
return err; return err;
/* Alloc TX irq. */ /* Alloc TX irq. */
err = request_irq (IRQ_INTST (port->line), nb85e_uart_tx_irq, err = request_irq (V850E_UART_TX_IRQ (port->line), v850e_uart_tx_irq,
SA_INTERRUPT, "nb85e_uart", port); SA_INTERRUPT, "v850e_uart", port);
if (err) { if (err) {
free_irq (IRQ_INTSR (port->line), port); free_irq (V850E_UART_RX_IRQ (port->line), port);
return err; return err;
} }
nb85e_uart_start_rx (port); v850e_uart_start_rx (port);
return 0; return 0;
} }
static void nb85e_uart_shutdown (struct uart_port *port) static void v850e_uart_shutdown (struct uart_port *port)
{ {
/* Disable port interrupts. */ /* Disable port interrupts. */
free_irq (IRQ_INTST (port->line), port); free_irq (V850E_UART_TX_IRQ (port->line), port);
free_irq (IRQ_INTSR (port->line), port); free_irq (V850E_UART_RX_IRQ (port->line), port);
/* Turn off xmit/recv enable bits. */ /* Turn off xmit/recv enable bits. */
NB85E_UART_ASIM (port->line) V850E_UART_CONFIG (port->line)
&= ~(NB85E_UART_ASIM_TXE | NB85E_UART_ASIM_RXE); &= ~(V850E_UART_CONFIG_TX_ENABLE
| V850E_UART_CONFIG_RX_ENABLE);
/* Then reset the channel. */ /* Then reset the channel. */
NB85E_UART_ASIM (port->line) = 0; V850E_UART_CONFIG (port->line) = 0;
} }
static void static void
nb85e_uart_set_termios (struct uart_port *port, struct termios *termios, v850e_uart_set_termios (struct uart_port *port, struct termios *termios,
struct termios *old) struct termios *old)
{ {
unsigned cflags = termios->c_cflag; unsigned cflags = termios->c_cflag;
...@@ -474,83 +417,84 @@ nb85e_uart_set_termios (struct uart_port *port, struct termios *termios, ...@@ -474,83 +417,84 @@ nb85e_uart_set_termios (struct uart_port *port, struct termios *termios,
termios->c_cflag = cflags; termios->c_cflag = cflags;
nb85e_uart_configure (port->line, cflags, v850e_uart_configure (port->line, cflags,
uart_get_baud_rate (port, termios, old, uart_get_baud_rate (port, termios, old,
min_baud(), max_baud())); v850e_uart_min_baud(),
v850e_uart_max_baud()));
} }
static const char *nb85e_uart_type (struct uart_port *port) static const char *v850e_uart_type (struct uart_port *port)
{ {
return port->type == PORT_NB85E_UART ? "nb85e_uart" : 0; return port->type == PORT_V850E_UART ? "v850e_uart" : 0;
} }
static void nb85e_uart_config_port (struct uart_port *port, int flags) static void v850e_uart_config_port (struct uart_port *port, int flags)
{ {
if (flags & UART_CONFIG_TYPE) if (flags & UART_CONFIG_TYPE)
port->type = PORT_NB85E_UART; port->type = PORT_V850E_UART;
} }
static int static int
nb85e_uart_verify_port (struct uart_port *port, struct serial_struct *ser) v850e_uart_verify_port (struct uart_port *port, struct serial_struct *ser)
{ {
if (ser->type != PORT_UNKNOWN && ser->type != PORT_NB85E_UART) if (ser->type != PORT_UNKNOWN && ser->type != PORT_V850E_UART)
return -EINVAL; return -EINVAL;
if (ser->irq != IRQ_INTST (port->line)) if (ser->irq != V850E_UART_TX_IRQ (port->line))
return -EINVAL; return -EINVAL;
return 0; return 0;
} }
static struct uart_ops nb85e_uart_ops = { static struct uart_ops v850e_uart_ops = {
.tx_empty = nb85e_uart_tx_empty, .tx_empty = v850e_uart_tx_empty,
.get_mctrl = nb85e_uart_get_mctrl, .get_mctrl = v850e_uart_get_mctrl,
.set_mctrl = nb85e_uart_set_mctrl, .set_mctrl = v850e_uart_set_mctrl,
.start_tx = nb85e_uart_start_tx, .start_tx = v850e_uart_start_tx,
.stop_tx = nb85e_uart_stop_tx, .stop_tx = v850e_uart_stop_tx,
.stop_rx = nb85e_uart_stop_rx, .stop_rx = v850e_uart_stop_rx,
.enable_ms = nb85e_uart_nop, .enable_ms = v850e_uart_nop,
.break_ctl = nb85e_uart_break_ctl, .break_ctl = v850e_uart_break_ctl,
.startup = nb85e_uart_startup, .startup = v850e_uart_startup,
.shutdown = nb85e_uart_shutdown, .shutdown = v850e_uart_shutdown,
.set_termios = nb85e_uart_set_termios, .set_termios = v850e_uart_set_termios,
.type = nb85e_uart_type, .type = v850e_uart_type,
.release_port = nb85e_uart_nop, .release_port = v850e_uart_nop,
.request_port = nb85e_uart_success, .request_port = v850e_uart_success,
.config_port = nb85e_uart_config_port, .config_port = v850e_uart_config_port,
.verify_port = nb85e_uart_verify_port, .verify_port = v850e_uart_verify_port,
}; };
/* Initialization and cleanup. */ /* Initialization and cleanup. */
static struct uart_driver nb85e_uart_driver = { static struct uart_driver v850e_uart_driver = {
.owner = THIS_MODULE, .owner = THIS_MODULE,
.driver_name = "nb85e_uart", .driver_name = "v850e_uart",
.devfs_name = "tts/", .devfs_name = "tts/",
.dev_name = "ttyS", .dev_name = "ttyS",
.major = TTY_MAJOR, .major = TTY_MAJOR,
.minor = NB85E_UART_MINOR_BASE, .minor = V850E_UART_MINOR_BASE,
.nr = NB85E_UART_NUM_CHANNELS, .nr = V850E_UART_NUM_CHANNELS,
.cons = NB85E_UART_CONSOLE, .cons = V850E_UART_CONSOLE,
}; };
static struct uart_port nb85e_uart_ports[NB85E_UART_NUM_CHANNELS]; static struct uart_port v850e_uart_ports[V850E_UART_NUM_CHANNELS];
static int __init nb85e_uart_init (void) static int __init v850e_uart_init (void)
{ {
int rval; int rval;
printk (KERN_INFO "%s on-chip UART\n", NB85E_UART_CHIP_NAME); printk (KERN_INFO "%s on-chip UART\n", V850E_UART_CHIP_NAME);
rval = uart_register_driver (&nb85e_uart_driver); rval = uart_register_driver (&v850e_uart_driver);
if (rval == 0) { if (rval == 0) {
unsigned chan; unsigned chan;
for (chan = 0; chan < NB85E_UART_NUM_CHANNELS; chan++) { for (chan = 0; chan < V850E_UART_NUM_CHANNELS; chan++) {
struct uart_port *port = &nb85e_uart_ports[chan]; struct uart_port *port = &v850e_uart_ports[chan];
memset (port, 0, sizeof *port); memset (port, 0, sizeof *port);
port->ops = &nb85e_uart_ops; port->ops = &v850e_uart_ops;
port->line = chan; port->line = chan;
port->iotype = SERIAL_IO_MEM; port->iotype = SERIAL_IO_MEM;
port->flags = UPF_BOOT_AUTOCONF; port->flags = UPF_BOOT_AUTOCONF;
...@@ -559,15 +503,15 @@ static int __init nb85e_uart_init (void) ...@@ -559,15 +503,15 @@ static int __init nb85e_uart_init (void)
framework seems to mainly use this for framework seems to mainly use this for
informational purposes anyway. Here we use the TX informational purposes anyway. Here we use the TX
irq. */ irq. */
port->irq = IRQ_INTST (chan); port->irq = V850E_UART_TX_IRQ (chan);
/* The serial framework doesn't really use these /* The serial framework doesn't really use these
membase/mapbase fields for anything useful, but membase/mapbase fields for anything useful, but
it requires that they be something non-zero to it requires that they be something non-zero to
consider the port `valid', and also uses them consider the port `valid', and also uses them
for informational purposes. */ for informational purposes. */
port->membase = (void *)NB85E_UART_BASE_ADDR (chan); port->membase = (void *)V850E_UART_BASE_ADDR (chan);
port->mapbase = NB85E_UART_BASE_ADDR (chan); port->mapbase = V850E_UART_BASE_ADDR (chan);
/* The framework insists on knowing the uart's master /* The framework insists on knowing the uart's master
clock freq, though it doesn't seem to do anything clock freq, though it doesn't seem to do anything
...@@ -576,35 +520,30 @@ static int __init nb85e_uart_init (void) ...@@ -576,35 +520,30 @@ static int __init nb85e_uart_init (void)
the framework will puke during its internal the framework will puke during its internal
calculations, and force the baud rate to be 9600. calculations, and force the baud rate to be 9600.
To be accurate though, just repeat the calculation To be accurate though, just repeat the calculation
we use when actually setting the speed. we use when actually setting the speed. */
port->uartclk = v850e_uart_max_clock() * 16;
The `* 8' means `* 16 / 2': 16 to account for for
the serial framework's built-in bias, and 2 because
there's an additional / 2 in the hardware. */
port->uartclk =
(NB85E_UART_BASE_FREQ >> cksr_min()) * 8;
uart_add_one_port (&nb85e_uart_driver, port); uart_add_one_port (&v850e_uart_driver, port);
} }
} }
return rval; return rval;
} }
static void __exit nb85e_uart_exit (void) static void __exit v850e_uart_exit (void)
{ {
unsigned chan; unsigned chan;
for (chan = 0; chan < NB85E_UART_NUM_CHANNELS; chan++) for (chan = 0; chan < V850E_UART_NUM_CHANNELS; chan++)
uart_remove_one_port (&nb85e_uart_driver, uart_remove_one_port (&v850e_uart_driver,
&nb85e_uart_ports[chan]); &v850e_uart_ports[chan]);
uart_unregister_driver (&nb85e_uart_driver); uart_unregister_driver (&v850e_uart_driver);
} }
module_init (nb85e_uart_init); module_init (v850e_uart_init);
module_exit (nb85e_uart_exit); module_exit (v850e_uart_exit);
MODULE_AUTHOR ("Miles Bader"); MODULE_AUTHOR ("Miles Bader");
MODULE_DESCRIPTION ("NEC " NB85E_UART_CHIP_NAME " on-chip UART"); MODULE_DESCRIPTION ("NEC " V850E_UART_CHIP_NAME " on-chip UART");
MODULE_LICENSE ("GPL"); MODULE_LICENSE ("GPL");
/* /*
* include/asm-v850/anna.h -- Anna V850E2 evaluation cpu chip/board * include/asm-v850/anna.h -- Anna V850E2 evaluation cpu chip/board
* *
* Copyright (C) 2001,2002 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,2002 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -14,8 +14,9 @@ ...@@ -14,8 +14,9 @@
#ifndef __V850_ANNA_H__ #ifndef __V850_ANNA_H__
#define __V850_ANNA_H__ #define __V850_ANNA_H__
#include <asm/v850e2.h> /* Based on V850E2 core. */
#define CPU_ARCH "v850e2"
#define CPU_MODEL "v850e2/anna" #define CPU_MODEL "v850e2/anna"
#define CPU_MODEL_LONG "NEC V850E2/Anna" #define CPU_MODEL_LONG "NEC V850E2/Anna"
#define PLATFORM "anna" #define PLATFORM "anna"
...@@ -48,30 +49,6 @@ ...@@ -48,30 +49,6 @@
/* Anna specific control registers. */ /* Anna specific control registers. */
#define ANNA_CSC_ADDR(n) (0xFFFFF060 + (n) * 2)
#define ANNA_CSC(n) (*(volatile u16 *)ANNA_CSC_ADDR(n))
#define ANNA_BPC_ADDR 0xFFFFF064
#define ANNA_BPC (*(volatile u16 *)ANNA_BPC_ADDR)
#define ANNA_BSC_ADDR 0xFFFFF066
#define ANNA_BSC (*(volatile u16 *)ANNA_BSC_ADDR)
#define ANNA_BEC_ADDR 0xFFFFF068
#define ANNA_BEC (*(volatile u16 *)ANNA_BEC_ADDR)
#define ANNA_BHC_ADDR 0xFFFFF06A
#define ANNA_BHC (*(volatile u16 *)ANNA_BHC_ADDR)
#define ANNA_BCT_ADDR(n) (0xFFFFF480 + (n) * 2)
#define ANNA_BCT(n) (*(volatile u16 *)ANNA_BCT_ADDR(n))
#define ANNA_DWC_ADDR(n) (0xFFFFF484 + (n) * 2)
#define ANNA_DWC(n) (*(volatile u16 *)ANNA_DWC_ADDR(n))
#define ANNA_BCC_ADDR 0xFFFFF488
#define ANNA_BCC (*(volatile u16 *)ANNA_BCC_ADDR)
#define ANNA_ASC_ADDR 0xFFFFF48A
#define ANNA_ASC (*(volatile u16 *)ANNA_ASC_ADDR)
#define ANNA_LBS_ADDR 0xFFFFF48E
#define ANNA_LBS (*(volatile u16 *)ANNA_LBS_ADDR)
#define ANNA_SCR3_ADDR 0xFFFFF4AC
#define ANNA_SCR3 (*(volatile u16 *)ANNA_SCR3_ADDR)
#define ANNA_RFS3_ADDR 0xFFFFF4AE
#define ANNA_RFS3 (*(volatile u16 *)ANNA_RFS3_ADDR)
#define ANNA_ILBEN_ADDR 0xFFFFF7F2 #define ANNA_ILBEN_ADDR 0xFFFFF7F2
#define ANNA_ILBEN (*(volatile u16 *)ANNA_ILBEN_ADDR) #define ANNA_ILBEN (*(volatile u16 *)ANNA_ILBEN_ADDR)
...@@ -85,9 +62,6 @@ ...@@ -85,9 +62,6 @@
#define ANNA_PORT_PM(n) (*(volatile u8 *)ANNA_PORT_PM_ADDR(n)) #define ANNA_PORT_PM(n) (*(volatile u8 *)ANNA_PORT_PM_ADDR(n))
/* NB85E-style interrupt system. */
#include <asm/nb85e_intc.h>
/* Hardware-specific interrupt numbers (in the kernel IRQ namespace). */ /* Hardware-specific interrupt numbers (in the kernel IRQ namespace). */
#define IRQ_INTP(n) (n) /* Pnnn (pin) interrupts 0-15 */ #define IRQ_INTP(n) (n) /* Pnnn (pin) interrupts 0-15 */
#define IRQ_INTP_NUM 16 #define IRQ_INTP_NUM 16
...@@ -116,12 +90,15 @@ extern void anna_init_irqs (void); ...@@ -116,12 +90,15 @@ extern void anna_init_irqs (void);
/* Anna UART details (basically the same as the V850E/MA1, but 2 channels). */ /* Anna UART details (basically the same as the V850E/MA1, but 2 channels). */
#define NB85E_UART_NUM_CHANNELS 2 #define V850E_UART_NUM_CHANNELS 2
#define NB85E_UART_BASE_FREQ (SYS_CLOCK_FREQ / 2) #define V850E_UART_BASE_FREQ (SYS_CLOCK_FREQ / 2)
#define NB85E_UART_CHIP_NAME "V850E2/NA85E2A" #define V850E_UART_CHIP_NAME "V850E2/NA85E2A"
/* This is the UART channel that's actually connected on the board. */
#define V850E_UART_CONSOLE_CHANNEL 1
/* This is a function that gets called before configuring the UART. */ /* This is a function that gets called before configuring the UART. */
#define NB85E_UART_PRE_CONFIGURE anna_uart_pre_configure #define V850E_UART_PRE_CONFIGURE anna_uart_pre_configure
#ifndef __ASSEMBLY__ #ifndef __ASSEMBLY__
extern void anna_uart_pre_configure (unsigned chan, extern void anna_uart_pre_configure (unsigned chan,
unsigned cflags, unsigned baud); unsigned cflags, unsigned baud);
...@@ -130,9 +107,9 @@ extern void anna_uart_pre_configure (unsigned chan, ...@@ -130,9 +107,9 @@ extern void anna_uart_pre_configure (unsigned chan,
/* This board supports RTS/CTS for the on-chip UART, but only for channel 1. */ /* This board supports RTS/CTS for the on-chip UART, but only for channel 1. */
/* CTS for UART channel 1 is pin P37 (bit 7 of port 3). */ /* CTS for UART channel 1 is pin P37 (bit 7 of port 3). */
#define NB85E_UART_CTS(chan) ((chan) == 1 ? !(ANNA_PORT_IO(3) & 0x80) : 1) #define V850E_UART_CTS(chan) ((chan) == 1 ? !(ANNA_PORT_IO(3) & 0x80) : 1)
/* RTS for UART channel 1 is pin P07 (bit 7 of port 0). */ /* RTS for UART channel 1 is pin P07 (bit 7 of port 0). */
#define NB85E_UART_SET_RTS(chan, val) \ #define V850E_UART_SET_RTS(chan, val) \
do { \ do { \
if (chan == 1) { \ if (chan == 1) { \
unsigned old = ANNA_PORT_IO(0); \ unsigned old = ANNA_PORT_IO(0); \
...@@ -145,16 +122,16 @@ extern void anna_uart_pre_configure (unsigned chan, ...@@ -145,16 +122,16 @@ extern void anna_uart_pre_configure (unsigned chan,
/* Timer C details. */ /* Timer C details. */
#define NB85E_TIMER_C_BASE_ADDR 0xFFFFF600 #define V850E_TIMER_C_BASE_ADDR 0xFFFFF600
/* Timer D details (the Anna actually has 5 of these; should change later). */ /* Timer D details (the Anna actually has 5 of these; should change later). */
#define NB85E_TIMER_D_BASE_ADDR 0xFFFFF540 #define V850E_TIMER_D_BASE_ADDR 0xFFFFF540
#define NB85E_TIMER_D_TMD_BASE_ADDR (NB85E_TIMER_D_BASE_ADDR + 0x0) #define V850E_TIMER_D_TMD_BASE_ADDR (V850E_TIMER_D_BASE_ADDR + 0x0)
#define NB85E_TIMER_D_CMD_BASE_ADDR (NB85E_TIMER_D_BASE_ADDR + 0x2) #define V850E_TIMER_D_CMD_BASE_ADDR (V850E_TIMER_D_BASE_ADDR + 0x2)
#define NB85E_TIMER_D_TMCD_BASE_ADDR (NB85E_TIMER_D_BASE_ADDR + 0x4) #define V850E_TIMER_D_TMCD_BASE_ADDR (V850E_TIMER_D_BASE_ADDR + 0x4)
#define NB85E_TIMER_D_BASE_FREQ SYS_CLOCK_FREQ #define V850E_TIMER_D_BASE_FREQ SYS_CLOCK_FREQ
#define NB85E_TIMER_D_TMCD_CS_MIN 1 /* min 2^1 divider */ #define V850E_TIMER_D_TMCD_CS_MIN 1 /* min 2^1 divider */
/* For <asm/param.h> */ /* For <asm/param.h> */
......
/* /*
* include/asm-v850/as85ep1.h -- AS85EP1 evaluation CPU chip/board * include/asm-v850/as85ep1.h -- AS85EP1 evaluation CPU chip/board
* *
* Copyright (C) 2001,2002 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,2002 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -14,8 +14,9 @@ ...@@ -14,8 +14,9 @@
#ifndef __V850_AS85EP1_H__ #ifndef __V850_AS85EP1_H__
#define __V850_AS85EP1_H__ #define __V850_AS85EP1_H__
#include <asm/v850e.h>
#define CPU_ARCH "v850e"
#define CPU_MODEL "as85ep1" #define CPU_MODEL "as85ep1"
#define CPU_MODEL_LONG "NEC V850E/AS85EP1" #define CPU_MODEL_LONG "NEC V850E/AS85EP1"
#define PLATFORM "AS85EP1" #define PLATFORM "AS85EP1"
...@@ -86,9 +87,6 @@ ...@@ -86,9 +87,6 @@
#define AS85EP1_PORT_PMC(n) (*(volatile u8 *)AS85EP1_PORT_PMC_ADDR(n)) #define AS85EP1_PORT_PMC(n) (*(volatile u8 *)AS85EP1_PORT_PMC_ADDR(n))
/* NB85E-style interrupt system. */
#include <asm/nb85e_intc.h>
/* Hardware-specific interrupt numbers (in the kernel IRQ namespace). */ /* Hardware-specific interrupt numbers (in the kernel IRQ namespace). */
#define IRQ_INTCCC(n) (0x0C + (n)) #define IRQ_INTCCC(n) (0x0C + (n))
#define IRQ_INTCCC_NUM 8 #define IRQ_INTCCC_NUM 8
...@@ -110,12 +108,12 @@ extern void as85ep1_init_irqs (void); ...@@ -110,12 +108,12 @@ extern void as85ep1_init_irqs (void);
/* AS85EP1 UART details (basically the same as the V850E/MA1, but 2 channels). */ /* AS85EP1 UART details (basically the same as the V850E/MA1, but 2 channels). */
#define NB85E_UART_NUM_CHANNELS 2 #define V850E_UART_NUM_CHANNELS 2
#define NB85E_UART_BASE_FREQ (SYS_CLOCK_FREQ / 4) #define V850E_UART_BASE_FREQ (SYS_CLOCK_FREQ / 4)
#define NB85E_UART_CHIP_NAME "V850E/NA85E" #define V850E_UART_CHIP_NAME "V850E/NA85E"
/* This is a function that gets called before configuring the UART. */ /* This is a function that gets called before configuring the UART. */
#define NB85E_UART_PRE_CONFIGURE as85ep1_uart_pre_configure #define V850E_UART_PRE_CONFIGURE as85ep1_uart_pre_configure
#ifndef __ASSEMBLY__ #ifndef __ASSEMBLY__
extern void as85ep1_uart_pre_configure (unsigned chan, extern void as85ep1_uart_pre_configure (unsigned chan,
unsigned cflags, unsigned baud); unsigned cflags, unsigned baud);
...@@ -124,9 +122,9 @@ extern void as85ep1_uart_pre_configure (unsigned chan, ...@@ -124,9 +122,9 @@ extern void as85ep1_uart_pre_configure (unsigned chan,
/* This board supports RTS/CTS for the on-chip UART, but only for channel 1. */ /* This board supports RTS/CTS for the on-chip UART, but only for channel 1. */
/* CTS for UART channel 1 is pin P54 (bit 4 of port 5). */ /* CTS for UART channel 1 is pin P54 (bit 4 of port 5). */
#define NB85E_UART_CTS(chan) ((chan) == 1 ? !(AS85EP1_PORT_IO(5) & 0x10) : 1) #define V850E_UART_CTS(chan) ((chan) == 1 ? !(AS85EP1_PORT_IO(5) & 0x10) : 1)
/* RTS for UART channel 1 is pin P53 (bit 3 of port 5). */ /* RTS for UART channel 1 is pin P53 (bit 3 of port 5). */
#define NB85E_UART_SET_RTS(chan, val) \ #define V850E_UART_SET_RTS(chan, val) \
do { \ do { \
if (chan == 1) { \ if (chan == 1) { \
unsigned old = AS85EP1_PORT_IO(5); \ unsigned old = AS85EP1_PORT_IO(5); \
...@@ -139,16 +137,16 @@ extern void as85ep1_uart_pre_configure (unsigned chan, ...@@ -139,16 +137,16 @@ extern void as85ep1_uart_pre_configure (unsigned chan,
/* Timer C details. */ /* Timer C details. */
#define NB85E_TIMER_C_BASE_ADDR 0xFFFFF600 #define V850E_TIMER_C_BASE_ADDR 0xFFFFF600
/* Timer D details (the AS85EP1 actually has 5 of these; should change later). */ /* Timer D details (the AS85EP1 actually has 5 of these; should change later). */
#define NB85E_TIMER_D_BASE_ADDR 0xFFFFF540 #define V850E_TIMER_D_BASE_ADDR 0xFFFFF540
#define NB85E_TIMER_D_TMD_BASE_ADDR (NB85E_TIMER_D_BASE_ADDR + 0x0) #define V850E_TIMER_D_TMD_BASE_ADDR (V850E_TIMER_D_BASE_ADDR + 0x0)
#define NB85E_TIMER_D_CMD_BASE_ADDR (NB85E_TIMER_D_BASE_ADDR + 0x2) #define V850E_TIMER_D_CMD_BASE_ADDR (V850E_TIMER_D_BASE_ADDR + 0x2)
#define NB85E_TIMER_D_TMCD_BASE_ADDR (NB85E_TIMER_D_BASE_ADDR + 0x4) #define V850E_TIMER_D_TMCD_BASE_ADDR (V850E_TIMER_D_BASE_ADDR + 0x4)
#define NB85E_TIMER_D_BASE_FREQ SYS_CLOCK_FREQ #define V850E_TIMER_D_BASE_FREQ SYS_CLOCK_FREQ
#define NB85E_TIMER_D_TMCD_CS_MIN 2 /* min 2^2 divider */ #define V850E_TIMER_D_TMCD_CS_MIN 2 /* min 2^2 divider */
/* For <asm/param.h> */ /* For <asm/param.h> */
......
/* /*
* include/asm-v850/asm.h -- Macros for writing assembly code * include/asm-v850/asm.h -- Macros for writing assembly code
* *
* Copyright (C) 2001,02,03 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
......
/* /*
* include/asm-v850/cacheflush.h * include/asm-v850/cacheflush.h
* *
* Copyright (C) 2001,02 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -21,21 +21,40 @@ ...@@ -21,21 +21,40 @@
#include <asm/machdep.h> #include <asm/machdep.h>
#ifndef flush_cache_all /* The following are all used by the kernel in ways that only affect
/* If there's no flush_cache_all macro defined by <asm/machdep.h>, then systems with MMUs, so we don't need them. */
this processor has no cache, so just define these as nops. */
#define flush_cache_all() ((void)0) #define flush_cache_all() ((void)0)
#define flush_cache_mm(mm) ((void)0) #define flush_cache_mm(mm) ((void)0)
#define flush_cache_range(vma, start, end) ((void)0) #define flush_cache_range(vma, start, end) ((void)0)
#define flush_cache_page(vma, vmaddr) ((void)0) #define flush_cache_page(vma, vmaddr) ((void)0)
#define flush_dcache_page(page) ((void)0) #define flush_dcache_page(page) ((void)0)
#ifdef CONFIG_NO_CACHE
/* Some systems have no cache at all, in which case we don't need these
either. */
#define flush_icache() ((void)0) #define flush_icache() ((void)0)
#define flush_icache_range(start, end) ((void)0) #define flush_icache_range(start, end) ((void)0)
#define flush_icache_page(vma,pg) ((void)0) #define flush_icache_page(vma,pg) ((void)0)
#define flush_icache_user_range(vma,pg,adr,len) ((void)0) #define flush_icache_user_range(vma,pg,adr,len) ((void)0)
#define flush_cache_sigtramp(vaddr) ((void)0) #define flush_cache_sigtramp(vaddr) ((void)0)
#endif /* !flush_cache_all */ #else /* !CONFIG_NO_CACHE */
struct page;
struct mm_struct;
struct vm_area_struct;
/* Otherwise, somebody had better define them. */
extern void flush_icache (void);
extern void flush_icache_range (unsigned long start, unsigned long end);
extern void flush_icache_page (struct vm_area_struct *vma, struct page *page);
extern void flush_icache_user_range (struct vm_area_struct *vma,
struct page *page,
unsigned long adr, int len);
extern void flush_cache_sigtramp (unsigned long addr);
#endif /* CONFIG_NO_CACHE */
#endif /* __V850_CACHEFLUSH_H__ */ #endif /* __V850_CACHEFLUSH_H__ */
...@@ -65,10 +65,10 @@ ...@@ -65,10 +65,10 @@
#define RESET_GUARD_ACTIVE 0xFAB4BEEF #define RESET_GUARD_ACTIVE 0xFAB4BEEF
#endif /* CONFIG_RESET_GUARD */ #endif /* CONFIG_RESET_GUARD */
#ifdef CONFIG_V850E_MA1_HIGHRES_TIMER #ifdef CONFIG_V850E_HIGHRES_TIMER
#define HIGHRES_TIMER_SLOW_TICKS_ADDR (KERNEL_VAR_SPACE_ADDR + 32) #define HIGHRES_TIMER_SLOW_TICKS_ADDR (KERNEL_VAR_SPACE_ADDR + 32)
#define HIGHRES_TIMER_SLOW_TICKS KERNEL_VAR (HIGHRES_TIMER_SLOW_TICKS_ADDR) #define HIGHRES_TIMER_SLOW_TICKS KERNEL_VAR (HIGHRES_TIMER_SLOW_TICKS_ADDR)
#endif /* CONFIG_V850E_MA1_HIGHRES_TIMER */ #endif /* CONFIG_V850E_HIGHRES_TIMER */
#ifndef __ASSEMBLY__ #ifndef __ASSEMBLY__
......
...@@ -2,8 +2,8 @@ ...@@ -2,8 +2,8 @@
* include/asm-v850/fpga85e2c.h -- Machine-dependent defs for * include/asm-v850/fpga85e2c.h -- Machine-dependent defs for
* FPGA implementation of V850E2/NA85E2C * FPGA implementation of V850E2/NA85E2C
* *
* Copyright (C) 2002 NEC Corporation * Copyright (C) 2002,03 NEC Electronics Corporation
* Copyright (C) 2002 Miles Bader <miles@gnu.org> * Copyright (C) 2002,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -15,11 +15,10 @@ ...@@ -15,11 +15,10 @@
#ifndef __V850_FPGA85E2C_H__ #ifndef __V850_FPGA85E2C_H__
#define __V850_FPGA85E2C_H__ #define __V850_FPGA85E2C_H__
#include <asm/v850e2.h>
#include <asm/clinkage.h> #include <asm/clinkage.h>
#define CPU_ARCH "v850e2"
#define CPU_MODEL "v850e2/fpga85e2c" #define CPU_MODEL "v850e2/fpga85e2c"
#define CPU_MODEL_LONG "NEC V850E2/NA85E2C" #define CPU_MODEL_LONG "NEC V850E2/NA85E2C"
#define PLATFORM "fpga85e2c" #define PLATFORM "fpga85e2c"
...@@ -42,27 +41,6 @@ ...@@ -42,27 +41,6 @@
#define CSDEV_ADDR(n) (0xFFE80110 + 2*(n)) #define CSDEV_ADDR(n) (0xFFE80110 + 2*(n))
#define CSDEV(n) (*(volatile unsigned char *)CSDEV_ADDR (n)) #define CSDEV(n) (*(volatile unsigned char *)CSDEV_ADDR (n))
/* The BSC register controls bus-sizing. Each memory area CSn uses a pair
of bits N*2 and N*2+1, where 00 means an 8-bit bus size, 01 16-bit, and
10 32-bit. */
#define BSC_ADDR 0xFFFFF066
#define BSC (*(volatile unsigned short *)BSC_ADDR)
#define DWC_ADDR(n) (0xFFFFF484 + 2*(n))
#define DWC(n) (*(volatile unsigned short *)DWC_ADDR (n))
#define ASC_ADDR 0xFFFFF48A
#define ASC (*(volatile unsigned short *)ASC_ADDR)
#define BTSC_ADDR 0xFFFFF070
#define BTSC (*(volatile unsigned short *)BTSC_ADDR)
#define BHC_ADDR 0xFFFFF06A
#define BHC (*(volatile unsigned short *)BHC_ADDR)
/* NB85E-style interrupt system. */
#include <asm/nb85e_intc.h>
/* Timer interrupts 0-3, interrupt at intervals from CLK/4096 to CLK/16384. */ /* Timer interrupts 0-3, interrupt at intervals from CLK/4096 to CLK/16384. */
#define IRQ_RPU(n) (60 + (n)) #define IRQ_RPU(n) (60 + (n))
......
/* /*
* include/asm-v850/highres_timer.h -- High resolution timing routines * include/asm-v850/highres_timer.h -- High resolution timing routines
* *
* Copyright (C) 2001 NEC Corporation * Copyright (C) 2001,03 NEC Electronics Corporation
* Copyright (C) 2001 Miles Bader <miles@gnu.org> * Copyright (C) 2001,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -25,7 +25,7 @@ ...@@ -25,7 +25,7 @@
counter overflows). */ counter overflows). */
#define HIGHRES_TIMER_SLOW_TICK_RATE 25 #define HIGHRES_TIMER_SLOW_TICK_RATE 25
/* Which timer in the nb85e `Timer D' we use. */ /* Which timer in the V850E `Timer D' we use. */
#define HIGHRES_TIMER_TIMER_D_UNIT 3 #define HIGHRES_TIMER_TIMER_D_UNIT 3
......
/* /*
* include/asm-v850/ma.h -- V850E/MA series of cpu chips * include/asm-v850/ma.h -- V850E/MA series of cpu chips
* *
* Copyright (C) 2001,02 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -14,9 +14,8 @@ ...@@ -14,9 +14,8 @@
#ifndef __V850_MA_H__ #ifndef __V850_MA_H__
#define __V850_MA_H__ #define __V850_MA_H__
/* The MA series uses the V850E cpu core. */
/* The MA series uses the NB85E cpu core. */ #include <asm/v850e.h>
#include <asm/nb85e.h>
/* For <asm/entry.h> */ /* For <asm/entry.h> */
...@@ -28,10 +27,10 @@ ...@@ -28,10 +27,10 @@
/* MA series UART details. */ /* MA series UART details. */
#define NB85E_UART_BASE_FREQ CPU_CLOCK_FREQ #define V850E_UART_BASE_FREQ CPU_CLOCK_FREQ
/* This is a function that gets called before configuring the UART. */ /* This is a function that gets called before configuring the UART. */
#define NB85E_UART_PRE_CONFIGURE ma_uart_pre_configure #define V850E_UART_PRE_CONFIGURE ma_uart_pre_configure
#ifndef __ASSEMBLY__ #ifndef __ASSEMBLY__
extern void ma_uart_pre_configure (unsigned chan, extern void ma_uart_pre_configure (unsigned chan,
unsigned cflags, unsigned baud); unsigned cflags, unsigned baud);
...@@ -39,16 +38,16 @@ extern void ma_uart_pre_configure (unsigned chan, ...@@ -39,16 +38,16 @@ extern void ma_uart_pre_configure (unsigned chan,
/* MA series timer C details. */ /* MA series timer C details. */
#define NB85E_TIMER_C_BASE_ADDR 0xFFFFF600 #define V850E_TIMER_C_BASE_ADDR 0xFFFFF600
/* MA series timer D details. */ /* MA series timer D details. */
#define NB85E_TIMER_D_BASE_ADDR 0xFFFFF540 #define V850E_TIMER_D_BASE_ADDR 0xFFFFF540
#define NB85E_TIMER_D_TMD_BASE_ADDR (NB85E_TIMER_D_BASE_ADDR + 0x0) #define V850E_TIMER_D_TMD_BASE_ADDR (V850E_TIMER_D_BASE_ADDR + 0x0)
#define NB85E_TIMER_D_CMD_BASE_ADDR (NB85E_TIMER_D_BASE_ADDR + 0x2) #define V850E_TIMER_D_CMD_BASE_ADDR (V850E_TIMER_D_BASE_ADDR + 0x2)
#define NB85E_TIMER_D_TMCD_BASE_ADDR (NB85E_TIMER_D_BASE_ADDR + 0x4) #define V850E_TIMER_D_TMCD_BASE_ADDR (V850E_TIMER_D_BASE_ADDR + 0x4)
#define NB85E_TIMER_D_BASE_FREQ CPU_CLOCK_FREQ #define V850E_TIMER_D_BASE_FREQ CPU_CLOCK_FREQ
/* Port 0 */ /* Port 0 */
......
/* /*
* include/asm-v850/ma1.h -- V850E/MA1 cpu chip * include/asm-v850/ma1.h -- V850E/MA1 cpu chip
* *
* Copyright (C) 2001,02 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -40,12 +40,11 @@ ...@@ -40,12 +40,11 @@
#define IRQ_INTST(n) (0x27 + (n)*4) /* UART 0-2 transmission completion */ #define IRQ_INTST(n) (0x27 + (n)*4) /* UART 0-2 transmission completion */
#define IRQ_INTST_NUM 3 #define IRQ_INTST_NUM 3
/* For <asm/irq.h> */
#define NUM_CPU_IRQS 0x30 #define NUM_CPU_IRQS 0x30
/* The MA1 has a UART with 3 channels. */ /* The MA1 has a UART with 3 channels. */
#define NB85E_UART_NUM_CHANNELS 3 #define V850E_UART_NUM_CHANNELS 3
#endif /* __V850_MA1_H__ */ #endif /* __V850_MA1_H__ */
/* /*
* include/asm-v850/machdep.h -- Machine-dependent definitions * include/asm-v850/machdep.h -- Machine-dependent definitions
* *
* Copyright (C) 2001,02 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -20,6 +20,9 @@ ...@@ -20,6 +20,9 @@
#ifdef CONFIG_V850E_MA1 #ifdef CONFIG_V850E_MA1
#include <asm/ma1.h> #include <asm/ma1.h>
#endif #endif
#ifdef CONFIG_V850E_ME2
#include <asm/me2.h>
#endif
#ifdef CONFIG_V850E_TEG #ifdef CONFIG_V850E_TEG
#include <asm/teg.h> #include <asm/teg.h>
#endif #endif
...@@ -36,6 +39,9 @@ ...@@ -36,6 +39,9 @@
#ifdef CONFIG_RTE_CB_MA1 #ifdef CONFIG_RTE_CB_MA1
#include <asm/rte_ma1_cb.h> #include <asm/rte_ma1_cb.h>
#endif #endif
#ifdef CONFIG_RTE_CB_ME2
#include <asm/rte_me2_cb.h>
#endif
#ifdef CONFIG_RTE_CB_NB85E #ifdef CONFIG_RTE_CB_NB85E
#include <asm/rte_nb85e_cb.h> #include <asm/rte_nb85e_cb.h>
#endif #endif
...@@ -45,6 +51,9 @@ ...@@ -45,6 +51,9 @@
#ifdef CONFIG_V850E2_SIM85E2C #ifdef CONFIG_V850E2_SIM85E2C
#include <asm/sim85e2c.h> #include <asm/sim85e2c.h>
#endif #endif
#ifdef CONFIG_V850E2_SIM85E2S
#include <asm/sim85e2s.h>
#endif
#ifdef CONFIG_V850E2_FPGA85E2C #ifdef CONFIG_V850E2_FPGA85E2C
#include <asm/fpga85e2c.h> #include <asm/fpga85e2c.h>
#endif #endif
......
/*
* include/asm-v850/me2.h -- V850E/ME2 cpu chip
*
* Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
*
* This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this
* archive for more details.
*
* Written by Miles Bader <miles@gnu.org>
*/
#ifndef __V850_ME2_H__
#define __V850_ME2_H__
#include <asm/v850e.h>
#include <asm/v850e_cache.h>
#define CPU_MODEL "v850e/me2"
#define CPU_MODEL_LONG "NEC V850E/ME2"
/* Hardware-specific interrupt numbers (in the kernel IRQ namespace). */
#define IRQ_INTP(n) (n) /* Pnnn (pin) interrupts */
#define IRQ_INTP_NUM 31
#define IRQ_INTCMD(n) (0x31 + (n)) /* interval timer interrupts 0-3 */
#define IRQ_INTCMD_NUM 4
#define IRQ_INTDMA(n) (0x41 + (n)) /* DMA interrupts 0-3 */
#define IRQ_INTDMA_NUM 4
#define IRQ_INTUBTIRE(n) (0x49 + (n)*5)/* UARTB 0-1 reception error */
#define IRQ_INTUBTIRE_NUM 2
#define IRQ_INTUBTIR(n) (0x4a + (n)*5) /* UARTB 0-1 reception complete */
#define IRQ_INTUBTIR_NUM 2
#define IRQ_INTUBTIT(n) (0x4b + (n)*5) /* UARTB 0-1 transmission complete */
#define IRQ_INTUBTIT_NUM 2
#define IRQ_INTUBTIF(n) (0x4c + (n)*5) /* UARTB 0-1 FIFO trans. complete */
#define IRQ_INTUBTIF_NUM 2
#define IRQ_INTUBTITO(n) (0x4d + (n)*5) /* UARTB 0-1 reception timeout */
#define IRQ_INTUBTITO_NUM 2
/* For <asm/irq.h> */
#define NUM_CPU_IRQS 0x59 /* V850E/ME2 */
/* For <asm/entry.h> */
/* We use on-chip RAM, for a few miscellaneous variables that must be
accessible using a load instruction relative to R0. */
#define R0_RAM_ADDR 0xFFFFB000 /* V850E/ME2 */
/* V850E/ME2 UARTB details.*/
#define V850E_UART_NUM_CHANNELS 2
#define V850E_UARTB_BASE_FREQ (CPU_CLOCK_FREQ / 4)
/* This is a function that gets called before configuring the UART. */
#define V850E_UART_PRE_CONFIGURE me2_uart_pre_configure
#ifndef __ASSEMBLY__
extern void me2_uart_pre_configure (unsigned chan,
unsigned cflags, unsigned baud);
#endif /* __ASSEMBLY__ */
/* V850E/ME2 timer C details. */
#define V850E_TIMER_C_BASE_ADDR 0xFFFFF600
/* V850E/ME2 timer D details. */
#define V850E_TIMER_D_BASE_ADDR 0xFFFFF540
#define V850E_TIMER_D_TMD_BASE_ADDR (V850E_TIMER_D_BASE_ADDR + 0x0)
#define V850E_TIMER_D_CMD_BASE_ADDR (V850E_TIMER_D_BASE_ADDR + 0x2)
#define V850E_TIMER_D_TMCD_BASE_ADDR (V850E_TIMER_D_BASE_ADDR + 0x4)
#define V850E_TIMER_D_BASE_FREQ (CPU_CLOCK_FREQ / 2)
/* Select iRAM mode. */
#define ME2_IRAMM_ADDR 0xFFFFF80A
#define ME2_IRAMM (*(volatile u8*)ME2_IRAMM_ADDR)
/* Interrupt edge-detection configuration. INTF(n) and INTR(n) are only
valid for n == 1, 2, or 5. */
#define ME2_INTF_ADDR(n) (0xFFFFFC00 + (n) * 0x2)
#define ME2_INTF(n) (*(volatile u8*)ME2_INTF_ADDR(n))
#define ME2_INTR_ADDR(n) (0xFFFFFC20 + (n) * 0x2)
#define ME2_INTR(n) (*(volatile u8*)ME2_INTR_ADDR(n))
#define ME2_INTFAL_ADDR 0xFFFFFC10
#define ME2_INTFAL (*(volatile u8*)ME2_INTFAL_ADDR)
#define ME2_INTRAL_ADDR 0xFFFFFC30
#define ME2_INTRAL (*(volatile u8*)ME2_INTRAL_ADDR)
#define ME2_INTFDH_ADDR 0xFFFFFC16
#define ME2_INTFDH (*(volatile u16*)ME2_INTFDH_ADDR)
#define ME2_INTRDH_ADDR 0xFFFFFC36
#define ME2_INTRDH (*(volatile u16*)ME2_INTRDH_ADDR)
#define ME2_SESC_ADDR(n) (0xFFFFF609 + (n) * 0x10)
#define ME2_SESC(n) (*(volatile u8*)ME2_SESC_ADDR(n))
#define ME2_SESA10_ADDR 0xFFFFF5AD
#define ME2_SESA10 (*(volatile u8*)ME2_SESA10_ADDR)
#define ME2_SESA11_ADDR 0xFFFFF5DD
#define ME2_SESA11 (*(volatile u8*)ME2_SESA11_ADDR)
/* Port 1 */
/* Direct I/O. Bits 0-3 are pins P10-P13. */
#define ME2_PORT1_IO_ADDR 0xFFFFF402
#define ME2_PORT1_IO (*(volatile u8 *)ME2_PORT1_IO_ADDR)
/* Port mode (for direct I/O, 0 = output, 1 = input). */
#define ME2_PORT1_PM_ADDR 0xFFFFF422
#define ME2_PORT1_PM (*(volatile u8 *)ME2_PORT1_PM_ADDR)
/* Port mode control (0 = direct I/O mode, 1 = alternative I/O mode). */
#define ME2_PORT1_PMC_ADDR 0xFFFFF442
#define ME2_PORT1_PMC (*(volatile u8 *)ME2_PORT1_PMC_ADDR)
/* Port function control (for serial interfaces, 0 = CSI30, 1 = UARTB0 ). */
#define ME2_PORT1_PFC_ADDR 0xFFFFF462
#define ME2_PORT1_PFC (*(volatile u8 *)ME2_PORT1_PFC_ADDR)
/* Port 2 */
/* Direct I/O. Bits 0-3 are pins P20-P25. */
#define ME2_PORT2_IO_ADDR 0xFFFFF404
#define ME2_PORT2_IO (*(volatile u8 *)ME2_PORT2_IO_ADDR)
/* Port mode (for direct I/O, 0 = output, 1 = input). */
#define ME2_PORT2_PM_ADDR 0xFFFFF424
#define ME2_PORT2_PM (*(volatile u8 *)ME2_PORT2_PM_ADDR)
/* Port mode control (0 = direct I/O mode, 1 = alternative I/O mode). */
#define ME2_PORT2_PMC_ADDR 0xFFFFF444
#define ME2_PORT2_PMC (*(volatile u8 *)ME2_PORT2_PMC_ADDR)
/* Port function control (for serial interfaces, 0 = INTP2x, 1 = UARTB1 ). */
#define ME2_PORT2_PFC_ADDR 0xFFFFF464
#define ME2_PORT2_PFC (*(volatile u8 *)ME2_PORT2_PFC_ADDR)
/* Port 5 */
/* Direct I/O. Bits 0-5 are pins P50-P55. */
#define ME2_PORT5_IO_ADDR 0xFFFFF40A
#define ME2_PORT5_IO (*(volatile u8 *)ME2_PORT5_IO_ADDR)
/* Port mode (for direct I/O, 0 = output, 1 = input). */
#define ME2_PORT5_PM_ADDR 0xFFFFF42A
#define ME2_PORT5_PM (*(volatile u8 *)ME2_PORT5_PM_ADDR)
/* Port mode control (0 = direct I/O mode, 1 = alternative I/O mode). */
#define ME2_PORT5_PMC_ADDR 0xFFFFF44A
#define ME2_PORT5_PMC (*(volatile u8 *)ME2_PORT5_PMC_ADDR)
/* Port function control (). */
#define ME2_PORT5_PFC_ADDR 0xFFFFF46A
#define ME2_PORT5_PFC (*(volatile u8 *)ME2_PORT5_PFC_ADDR)
/* Port 6 */
/* Direct I/O. Bits 5-7 are pins P65-P67. */
#define ME2_PORT6_IO_ADDR 0xFFFFF40C
#define ME2_PORT6_IO (*(volatile u8 *)ME2_PORT6_IO_ADDR)
/* Port mode (for direct I/O, 0 = output, 1 = input). */
#define ME2_PORT6_PM_ADDR 0xFFFFF42C
#define ME2_PORT6_PM (*(volatile u8 *)ME2_PORT6_PM_ADDR)
/* Port mode control (0 = direct I/O mode, 1 = alternative I/O mode). */
#define ME2_PORT6_PMC_ADDR 0xFFFFF44C
#define ME2_PORT6_PMC (*(volatile u8 *)ME2_PORT6_PMC_ADDR)
/* Port function control (). */
#define ME2_PORT6_PFC_ADDR 0xFFFFF46C
#define ME2_PORT6_PFC (*(volatile u8 *)ME2_PORT6_PFC_ADDR)
/* Port 7 */
/* Direct I/O. Bits 2-7 are pins P72-P77. */
#define ME2_PORT7_IO_ADDR 0xFFFFF40E
#define ME2_PORT7_IO (*(volatile u8 *)ME2_PORT7_IO_ADDR)
/* Port mode (for direct I/O, 0 = output, 1 = input). */
#define ME2_PORT7_PM_ADDR 0xFFFFF42E
#define ME2_PORT7_PM (*(volatile u8 *)ME2_PORT7_PM_ADDR)
/* Port mode control (0 = direct I/O mode, 1 = alternative I/O mode). */
#define ME2_PORT7_PMC_ADDR 0xFFFFF44E
#define ME2_PORT7_PMC (*(volatile u8 *)ME2_PORT7_PMC_ADDR)
/* Port function control (). */
#define ME2_PORT7_PFC_ADDR 0xFFFFF46E
#define ME2_PORT7_PFC (*(volatile u8 *)ME2_PORT7_PFC_ADDR)
#ifndef __ASSEMBLY__
/* Initialize V850E/ME2 chip interrupts. */
extern void me2_init_irqs (void);
#endif /* !__ASSEMBLY__ */
#endif /* __V850_ME2_H__ */
/*
* include/asm-v850/nb85e_cache_cache.h -- Cache control for NB85E_CACHE212 and
* NB85E_CACHE213 cache memories
*
* Copyright (C) 2001,03 NEC Electronics Corporation
* Copyright (C) 2001,03 Miles Bader <miles@gnu.org>
*
* This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this
* archive for more details.
*
* Written by Miles Bader <miles@gnu.org>
*/
#ifndef __V850_NB85E_CACHE_H__
#define __V850_NB85E_CACHE_H__
#include <asm/types.h>
/* Cache control registers. */
#define NB85E_CACHE_BHC_ADDR 0xFFFFF06A
#define NB85E_CACHE_BHC (*(volatile u16 *)NB85E_CACHE_BHC_ADDR)
#define NB85E_CACHE_ICC_ADDR 0xFFFFF070
#define NB85E_CACHE_ICC (*(volatile u16 *)NB85E_CACHE_ICC_ADDR)
#define NB85E_CACHE_ISI_ADDR 0xFFFFF072
#define NB85E_CACHE_ISI (*(volatile u16 *)NB85E_CACHE_ISI_ADDR)
#define NB85E_CACHE_DCC_ADDR 0xFFFFF078
#define NB85E_CACHE_DCC (*(volatile u16 *)NB85E_CACHE_DCC_ADDR)
/* Size of a cache line in bytes. */
#define NB85E_CACHE_LINE_SIZE 16
/* For <asm/cache.h> */
#define L1_CACHE_BYTES NB85E_CACHE_LINE_SIZE
#if defined(__KERNEL__) && !defined(__ASSEMBLY__)
/* Set caching params via the BHC and DCC registers. */
void nb85e_cache_enable (u16 bhc, u16 dcc);
struct page;
struct mm_struct;
struct vm_area_struct;
extern void nb85e_cache_flush_all (void);
extern void nb85e_cache_flush_mm (struct mm_struct *mm);
extern void nb85e_cache_flush_range (struct mm_struct *mm,
unsigned long start,
unsigned long end);
extern void nb85e_cache_flush_page (struct vm_area_struct *vma,
unsigned long page_addr);
extern void nb85e_cache_flush_dcache_page (struct page *page);
extern void nb85e_cache_flush_icache (void);
extern void nb85e_cache_flush_icache_range (unsigned long start,
unsigned long end);
extern void nb85e_cache_flush_icache_page (struct vm_area_struct *vma,
struct page *page);
extern void nb85e_cache_flush_icache_user_range (struct vm_area_struct *vma,
struct page *page,
unsigned long adr, int len);
extern void nb85e_cache_flush_sigtramp (unsigned long addr);
#define flush_cache_all nb85e_cache_flush_all
#define flush_cache_mm nb85e_cache_flush_mm
#define flush_cache_range nb85e_cache_flush_range
#define flush_cache_page nb85e_cache_flush_page
#define flush_dcache_page nb85e_cache_flush_dcache_page
#define flush_icache nb85e_cache_flush_icache
#define flush_icache_range nb85e_cache_flush_icache_range
#define flush_icache_page nb85e_cache_flush_icache_page
#define flush_icache_user_range nb85e_cache_flush_icache_user_range
#define flush_cache_sigtramp nb85e_cache_flush_sigtramp
#endif /* __KERNEL__ && !__ASSEMBLY__ */
#endif /* __V850_NB85E_CACHE_H__ */
/*
* include/asm-v850/nb85e_uart.h -- On-chip UART often used with the
* NB85E cpu core
*
* Copyright (C) 2001,02 NEC Corporation
* Copyright (C) 2001,02 Miles Bader <miles@gnu.org>
*
* This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this
* archive for more details.
*
* Written by Miles Bader <miles@gnu.org>
*/
/* There's not actually a single UART implementation used by nb85e
derivatives, but rather a series of implementations that are all
`close' to one another. This file attempts to capture some
commonality between them. */
#ifndef __V850_NB85E_UART_H__
#define __V850_NB85E_UART_H__
#include <asm/types.h>
#include <asm/machdep.h> /* Pick up chip-specific defs. */
/* The base address of the UART control registers for channel N.
The default is the address used on the V850E/MA1. */
#ifndef NB85E_UART_BASE_ADDR
#define NB85E_UART_BASE_ADDR(n) (0xFFFFFA00 + 0x10 * (n))
#endif
/* Addresses of specific UART control registers for channel N.
The defaults are the addresses used on the V850E/MA1; if a platform
wants to redefine any of these, it must redefine them all. */
#ifndef NB85E_UART_ASIM_ADDR
#define NB85E_UART_ASIM_ADDR(n) (NB85E_UART_BASE_ADDR(n) + 0x0)
#define NB85E_UART_RXB_ADDR(n) (NB85E_UART_BASE_ADDR(n) + 0x2)
#define NB85E_UART_ASIS_ADDR(n) (NB85E_UART_BASE_ADDR(n) + 0x3)
#define NB85E_UART_TXB_ADDR(n) (NB85E_UART_BASE_ADDR(n) + 0x4)
#define NB85E_UART_ASIF_ADDR(n) (NB85E_UART_BASE_ADDR(n) + 0x5)
#define NB85E_UART_CKSR_ADDR(n) (NB85E_UART_BASE_ADDR(n) + 0x6)
#define NB85E_UART_BRGC_ADDR(n) (NB85E_UART_BASE_ADDR(n) + 0x7)
#endif
#ifndef NB85E_UART_CKSR_MAX_FREQ
#define NB85E_UART_CKSR_MAX_FREQ (25*1000*1000)
#endif
/* UART config registers. */
#define NB85E_UART_ASIM(n) (*(volatile u8 *)NB85E_UART_ASIM_ADDR(n))
/* Control bits for config registers. */
#define NB85E_UART_ASIM_CAE 0x80 /* clock enable */
#define NB85E_UART_ASIM_TXE 0x40 /* transmit enable */
#define NB85E_UART_ASIM_RXE 0x20 /* receive enable */
#define NB85E_UART_ASIM_PS_MASK 0x18 /* mask covering parity-select bits */
#define NB85E_UART_ASIM_PS_NONE 0x00 /* no parity */
#define NB85E_UART_ASIM_PS_ZERO 0x08 /* zero parity */
#define NB85E_UART_ASIM_PS_ODD 0x10 /* odd parity */
#define NB85E_UART_ASIM_PS_EVEN 0x18 /* even parity */
#define NB85E_UART_ASIM_CL_8 0x04 /* char len is 8 bits (otherwise, 7) */
#define NB85E_UART_ASIM_SL_2 0x02 /* 2 stop bits (otherwise, 1) */
#define NB85E_UART_ASIM_ISRM 0x01 /* generate INTSR interrupt on errors
(otherwise, generate INTSER) */
/* UART serial interface status registers. */
#define NB85E_UART_ASIS(n) (*(volatile u8 *)NB85E_UART_ASIS_ADDR(n))
/* Control bits for status registers. */
#define NB85E_UART_ASIS_PE 0x04 /* parity error */
#define NB85E_UART_ASIS_FE 0x02 /* framing error */
#define NB85E_UART_ASIS_OVE 0x01 /* overrun error */
/* UART serial interface transmission status registers. */
#define NB85E_UART_ASIF(n) (*(volatile u8 *)NB85E_UART_ASIF_ADDR(n))
#define NB85E_UART_ASIF_TXBF 0x02 /* transmit buffer flag (data in TXB) */
#define NB85E_UART_ASIF_TXSF 0x01 /* transmit shift flag (sending data) */
/* UART receive buffer register. */
#define NB85E_UART_RXB(n) (*(volatile u8 *)NB85E_UART_RXB_ADDR(n))
/* UART transmit buffer register. */
#define NB85E_UART_TXB(n) (*(volatile u8 *)NB85E_UART_TXB_ADDR(n))
/* UART baud-rate generator control registers. */
#define NB85E_UART_CKSR(n) (*(volatile u8 *)NB85E_UART_CKSR_ADDR(n))
#define NB85E_UART_CKSR_MAX 11
#define NB85E_UART_BRGC(n) (*(volatile u8 *)NB85E_UART_BRGC_ADDR(n))
/* This UART doesn't implement RTS/CTS by default, but some platforms
implement them externally, so check to see if <asm/machdep.h> defined
anything. */
#ifdef NB85E_UART_CTS
#define nb85e_uart_cts(n) NB85E_UART_CTS(n)
#else
#define nb85e_uart_cts(n) (1)
#endif
/* Do the same for RTS. */
#ifdef NB85E_UART_SET_RTS
#define nb85e_uart_set_rts(n,v) NB85E_UART_SET_RTS(n,v)
#else
#define nb85e_uart_set_rts(n,v) ((void)0)
#endif
/* Return true if all characters awaiting transmission on uart channel N
have been transmitted. */
#define nb85e_uart_xmit_done(n) \
(! (NB85E_UART_ASIF(n) & NB85E_UART_ASIF_TXBF))
/* Wait for this to be true. */
#define nb85e_uart_wait_for_xmit_done(n) \
do { } while (! nb85e_uart_xmit_done (n))
/* Return true if uart channel N is ready to transmit a character. */
#define nb85e_uart_xmit_ok(n) \
(nb85e_uart_xmit_done(n) && nb85e_uart_cts(n))
/* Wait for this to be true. */
#define nb85e_uart_wait_for_xmit_ok(n) \
do { } while (! nb85e_uart_xmit_ok (n))
/* Write character CH to uart channel N. */
#define nb85e_uart_putc(n, ch) (NB85E_UART_TXB(n) = (ch))
#define NB85E_UART_MINOR_BASE 64
#ifndef __ASSEMBLY__
/* Setup a console using channel 0 of the builtin uart. */
extern void nb85e_uart_cons_init (unsigned chan);
/* Configure and turn on uart channel CHAN, using the termios `control
modes' bits in CFLAGS, and a baud-rate of BAUD. */
void nb85e_uart_configure (unsigned chan, unsigned cflags, unsigned baud);
/* If the macro NB85E_UART_PRE_CONFIGURE is defined (presumably by a
<asm/machdep.h>), it is called from nb85e_uart_pre_configure before
anything else is done, with interrupts disabled. */
#endif /* !__ASSEMBLY__ */
#endif /* __V850_NB85E_UART_H__ */
/* /*
* include/asm-v850/processor.h * include/asm-v850/processor.h
* *
* Copyright (C) 2001,02,03 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
......
/* /*
* include/asm-v850/ptrace.h -- Access to CPU registers * include/asm-v850/ptrace.h -- Access to CPU registers
* *
* Copyright (C) 2001,02,03 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
......
/* /*
* include/asm-v850/rte_cb.h -- Midas labs RTE-CB series of evaluation boards * include/asm-v850/rte_cb.h -- Midas labs RTE-CB series of evaluation boards
* *
* Copyright (C) 2001,02,03 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
...@@ -20,42 +20,54 @@ ...@@ -20,42 +20,54 @@
#define MB_A_SRAM_SIZE 0x00200000 /* 2MB */ #define MB_A_SRAM_SIZE 0x00200000 /* 2MB */
#ifdef CONFIG_RTE_GBUS_INT
/* GBUS interrupt support. */ /* GBUS interrupt support. */
#define GBUS_INT_BASE_IRQ NUM_CPU_IRQS
#define GBUS_INT_BASE_ADDR (GCS2_ADDR + 0x00006000)
#include <asm/gbus_int.h>
/* We define NUM_MACH_IRQS to include extra interrupts from the GBUS. */ # include <asm/gbus_int.h>
#define NUM_MACH_IRQS (NUM_CPU_IRQS + IRQ_GBUS_INT_NUM)
# define GBUS_INT_BASE_IRQ NUM_RTE_CB_IRQS
# define GBUS_INT_BASE_ADDR (GCS2_ADDR + 0x00006000)
/* Some specific interrupts. */ /* Some specific interrupts. */
#define IRQ_MB_A_LAN IRQ_GBUS_INT(10) # define IRQ_MB_A_LAN IRQ_GBUS_INT(10)
#define IRQ_MB_A_PCI1(n) (IRQ_GBUS_INT(16) + (n)) # define IRQ_MB_A_PCI1(n) (IRQ_GBUS_INT(16) + (n))
#define IRQ_MB_A_PCI1_NUM 4 # define IRQ_MB_A_PCI1_NUM 4
#define IRQ_MB_A_PCI2(n) (IRQ_GBUS_INT(20) + (n)) # define IRQ_MB_A_PCI2(n) (IRQ_GBUS_INT(20) + (n))
#define IRQ_MB_A_PCI2_NUM 4 # define IRQ_MB_A_PCI2_NUM 4
#define IRQ_MB_A_EXT(n) (IRQ_GBUS_INT(24) + (n)) # define IRQ_MB_A_EXT(n) (IRQ_GBUS_INT(24) + (n))
#define IRQ_MB_A_EXT_NUM 4 # define IRQ_MB_A_EXT_NUM 4
#define IRQ_MB_A_USB_OC(n) (IRQ_GBUS_INT(28) + (n)) # define IRQ_MB_A_USB_OC(n) (IRQ_GBUS_INT(28) + (n))
#define IRQ_MB_A_USB_OC_NUM 2 # define IRQ_MB_A_USB_OC_NUM 2
#define IRQ_MB_A_PCMCIA_OC IRQ_GBUS_INT(30) # define IRQ_MB_A_PCMCIA_OC IRQ_GBUS_INT(30)
/* We define NUM_MACH_IRQS to include extra interrupts from the GBUS. */
# define NUM_MACH_IRQS (NUM_RTE_CB_IRQS + IRQ_GBUS_INT_NUM)
#else /* !CONFIG_RTE_GBUS_INT */
# define NUM_MACH_IRQS NUM_RTE_CB_IRQS
#endif /* CONFIG_RTE_GBUS_INT */
#ifdef CONFIG_RTE_MB_A_PCI
/* Mother-A PCI bus support. */ /* Mother-A PCI bus support. */
#include <asm/rte_mb_a_pci.h>
# include <asm/rte_mb_a_pci.h>
/* These are the base addresses used for allocating device address /* These are the base addresses used for allocating device address
space. 512K of the motherboard SRAM is in the same space, so we have space. 512K of the motherboard SRAM is in the same space, so we have
to be careful not to let it be allocated. */ to be careful not to let it be allocated. */
#define PCIBIOS_MIN_MEM (MB_A_PCI_MEM_ADDR + 0x80000) # define PCIBIOS_MIN_MEM (MB_A_PCI_MEM_ADDR + 0x80000)
#define PCIBIOS_MIN_IO MB_A_PCI_IO_ADDR # define PCIBIOS_MIN_IO MB_A_PCI_IO_ADDR
/* As we don't really support PCI DMA to cpu memory, and use bounce-buffers /* As we don't really support PCI DMA to cpu memory, and use bounce-buffers
instead, perversely enough, this becomes always true! */ instead, perversely enough, this becomes always true! */
#define pci_dma_supported(dev, mask) 1 # define pci_dma_supported(dev, mask) 1
#define pci_dac_dma_supported(dev, mask) 0 # define pci_dac_dma_supported(dev, mask) 0
#define pcibios_assign_all_busses() 1 # define pcibios_assign_all_busses() 1
#endif /* CONFIG_RTE_MB_A_PCI */
/* For <asm/param.h> */ /* For <asm/param.h> */
......
...@@ -17,25 +17,6 @@ ...@@ -17,25 +17,6 @@
#include <asm/rte_cb.h> /* Common defs for Midas RTE-CB boards. */ #include <asm/rte_cb.h> /* Common defs for Midas RTE-CB boards. */
/* CPU addresses of GBUS memory spaces. */
#define GCS0_ADDR 0x05000000 /* GCS0 - Common SRAM (2MB) */
#define GCS0_SIZE 0x00200000 /* 2MB */
#define GCS1_ADDR 0x06000000 /* GCS1 - Flash ROM (8MB) */
#define GCS1_SIZE 0x00800000 /* 8MB */
#define GCS2_ADDR 0x07900000 /* GCS2 - I/O registers */
#define GCS2_SIZE 0x00400000 /* 4MB */
#define GCS5_ADDR 0x04000000 /* GCS5 - PCI bus space */
#define GCS5_SIZE 0x01000000 /* 16MB */
#define GCS6_ADDR 0x07980000 /* GCS6 - PCI control registers */
#define GCS6_SIZE 0x00000200 /* 512B */
/* The GBUS GINT0 - GINT4 interrupts are connected to the INTP000 - INTP011
pins on the CPU. These are shared among the GBUS interrupts. */
#define IRQ_GINT(n) IRQ_INTP(n)
#define IRQ_GINT_NUM 4
#define PLATFORM "rte-v850e/ma1-cb" #define PLATFORM "rte-v850e/ma1-cb"
#define PLATFORM_LONG "Midas lab RTE-V850E/MA1-CB" #define PLATFORM_LONG "Midas lab RTE-V850E/MA1-CB"
...@@ -53,10 +34,32 @@ ...@@ -53,10 +34,32 @@
#define SDRAM_SIZE 0x02000000 /* 32MB */ #define SDRAM_SIZE 0x02000000 /* 32MB */
/* CPU addresses of GBUS memory spaces. */
#define GCS0_ADDR 0x05000000 /* GCS0 - Common SRAM (2MB) */
#define GCS0_SIZE 0x00200000 /* 2MB */
#define GCS1_ADDR 0x06000000 /* GCS1 - Flash ROM (8MB) */
#define GCS1_SIZE 0x00800000 /* 8MB */
#define GCS2_ADDR 0x07900000 /* GCS2 - I/O registers */
#define GCS2_SIZE 0x00400000 /* 4MB */
#define GCS5_ADDR 0x04000000 /* GCS5 - PCI bus space */
#define GCS5_SIZE 0x01000000 /* 16MB */
#define GCS6_ADDR 0x07980000 /* GCS6 - PCI control registers */
#define GCS6_SIZE 0x00000200 /* 512B */
/* For <asm/page.h> */ /* For <asm/page.h> */
#define PAGE_OFFSET SRAM_ADDR #define PAGE_OFFSET SRAM_ADDR
/* The GBUS GINT0 - GINT3 interrupts are connected to the INTP000 - INTP011
pins on the CPU. These are shared among the GBUS interrupts. */
#define IRQ_GINT(n) IRQ_INTP(n)
#define IRQ_GINT_NUM 4
/* Used by <asm/rte_cb.h> to derive NUM_MACH_IRQS. */
#define NUM_RTE_CB_IRQS NUM_CPU_IRQS
#ifdef CONFIG_ROM_KERNEL #ifdef CONFIG_ROM_KERNEL
/* Kernel is in ROM, starting at address 0. */ /* Kernel is in ROM, starting at address 0. */
...@@ -98,8 +101,8 @@ ...@@ -98,8 +101,8 @@
/* Override the basic MA uart pre-initialization so that we can /* Override the basic MA uart pre-initialization so that we can
initialize extra stuff. */ initialize extra stuff. */
#undef NB85E_UART_PRE_CONFIGURE /* should be defined by <asm/ma.h> */ #undef V850E_UART_PRE_CONFIGURE /* should be defined by <asm/ma.h> */
#define NB85E_UART_PRE_CONFIGURE rte_ma1_cb_uart_pre_configure #define V850E_UART_PRE_CONFIGURE rte_ma1_cb_uart_pre_configure
#ifndef __ASSEMBLY__ #ifndef __ASSEMBLY__
extern void rte_ma1_cb_uart_pre_configure (unsigned chan, extern void rte_ma1_cb_uart_pre_configure (unsigned chan,
unsigned cflags, unsigned baud); unsigned cflags, unsigned baud);
...@@ -108,9 +111,9 @@ extern void rte_ma1_cb_uart_pre_configure (unsigned chan, ...@@ -108,9 +111,9 @@ extern void rte_ma1_cb_uart_pre_configure (unsigned chan,
/* This board supports RTS/CTS for the on-chip UART, but only for channel 0. */ /* This board supports RTS/CTS for the on-chip UART, but only for channel 0. */
/* CTS for UART channel 0 is pin P43 (bit 3 of port 4). */ /* CTS for UART channel 0 is pin P43 (bit 3 of port 4). */
#define NB85E_UART_CTS(chan) ((chan) == 0 ? !(MA_PORT4_IO & 0x8) : 1) #define V850E_UART_CTS(chan) ((chan) == 0 ? !(MA_PORT4_IO & 0x8) : 1)
/* RTS for UART channel 0 is pin P42 (bit 2 of port 4). */ /* RTS for UART channel 0 is pin P42 (bit 2 of port 4). */
#define NB85E_UART_SET_RTS(chan, val) \ #define V850E_UART_SET_RTS(chan, val) \
do { \ do { \
if (chan == 0) { \ if (chan == 0) { \
unsigned old = MA_PORT4_IO; \ unsigned old = MA_PORT4_IO; \
......
/*
* include/asm-v850/rte_me2_cb.h -- Midas labs RTE-V850E/ME2-CB board
*
* Copyright (C) 2001,02,03 NEC Corporation
* Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
*
* This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this
* archive for more details.
*
* Written by Miles Bader <miles@gnu.org>
*/
#ifndef __V850_RTE_ME2_CB_H__
#define __V850_RTE_ME2_CB_H__
#include <asm/rte_cb.h> /* Common defs for Midas RTE-CB boards. */
#define PLATFORM "rte-v850e/me2-cb"
#define PLATFORM_LONG "Midas lab RTE-V850E/ME2-CB"
#define CPU_CLOCK_FREQ 150000000 /* 150MHz */
#define FIXED_BOGOMIPS 50
/* 32MB of onbard SDRAM. */
#define SDRAM_ADDR 0x00800000
#define SDRAM_SIZE 0x02000000 /* 32MB */
/* CPU addresses of GBUS memory spaces. */
#define GCS0_ADDR 0x04000000 /* GCS0 - Common SRAM (2MB) */
#define GCS0_SIZE 0x00800000 /* 8MB */
#define GCS1_ADDR 0x04800000 /* GCS1 - Flash ROM (8MB) */
#define GCS1_SIZE 0x00800000 /* 8MB */
#define GCS2_ADDR 0x07000000 /* GCS2 - I/O registers */
#define GCS2_SIZE 0x00800000 /* 8MB */
#define GCS5_ADDR 0x08000000 /* GCS5 - PCI bus space */
#define GCS5_SIZE 0x02000000 /* 32MB */
#define GCS6_ADDR 0x07800000 /* GCS6 - PCI control registers */
#define GCS6_SIZE 0x00800000 /* 8MB */
/* For <asm/page.h> */
#define PAGE_OFFSET SDRAM_ADDR
#ifdef CONFIG_ROM_KERNEL
/* Kernel is in ROM, starting at address 0. */
#define INTV_BASE 0
#define ROOT_FS_IMAGE_RW 0
#else /* !CONFIG_ROM_KERNEL */
/* Using RAM-kernel. Assume some sort of boot-loader got us loaded at
address 0. */
#define INTV_BASE 0
#define ROOT_FS_IMAGE_RW 1
#endif /* CONFIG_ROM_KERNEL */
/* Some misc. on-board devices. */
/* Seven-segment LED display (four digits). */
#define LED_ADDR(n) (0x0FE02000 + (n))
#define LED(n) (*(volatile unsigned char *)LED_ADDR(n))
#define LED_NUM_DIGITS 4
/* On-board PIC. */
#define CB_PIC_BASE_ADDR 0x0FE04000
#define CB_PIC_INT0M_ADDR (CB_PIC_BASE_ADDR + 0x00)
#define CB_PIC_INT0M (*(volatile u16 *)CB_PIC_INT0M_ADDR)
#define CB_PIC_INT1M_ADDR (CB_PIC_BASE_ADDR + 0x10)
#define CB_PIC_INT1M (*(volatile u16 *)CB_PIC_INT1M_ADDR)
#define CB_PIC_INTR_ADDR (CB_PIC_BASE_ADDR + 0x20)
#define CB_PIC_INTR (*(volatile u16 *)CB_PIC_INTR_ADDR)
#define CB_PIC_INTEN_ADDR (CB_PIC_BASE_ADDR + 0x30)
#define CB_PIC_INTEN (*(volatile u16 *)CB_PIC_INTEN_ADDR)
#define CB_PIC_INT0EN 0x0001
#define CB_PIC_INT1EN 0x0002
#define CB_PIC_INT0SEL 0x0080
/* The PIC interrupts themselves. */
#define CB_PIC_BASE_IRQ NUM_CPU_IRQS
#define IRQ_CB_PIC_NUM 10
/* Some specific CB_PIC interrupts. */
#define IRQ_CB_EXTTM0 (CB_PIC_BASE_IRQ + 0)
#define IRQ_CB_EXTSIO (CB_PIC_BASE_IRQ + 1)
#define IRQ_CB_TOVER (CB_PIC_BASE_IRQ + 2)
#define IRQ_CB_GINT0 (CB_PIC_BASE_IRQ + 3)
#define IRQ_CB_USB (CB_PIC_BASE_IRQ + 4)
#define IRQ_CB_LANC (CB_PIC_BASE_IRQ + 5)
#define IRQ_CB_USB_VBUS_ON (CB_PIC_BASE_IRQ + 6)
#define IRQ_CB_USB_VBUS_OFF (CB_PIC_BASE_IRQ + 7)
#define IRQ_CB_EXTTM1 (CB_PIC_BASE_IRQ + 8)
#define IRQ_CB_EXTTM2 (CB_PIC_BASE_IRQ + 9)
/* The GBUS GINT1 - GINT3 (note, not GINT0!) interrupts are connected to
the INTP65 - INTP67 pins on the CPU. These are shared among the GBUS
interrupts. */
#define IRQ_GINT(n) IRQ_INTP((n) + 9) /* 0 is unused! */
#define IRQ_GINT_NUM 4 /* 0 is unused! */
/* The shared interrupt line from the PIC is connected to CPU pin INTP23. */
#define IRQ_CB_PIC IRQ_INTP(4) /* P23 */
/* Used by <asm/rte_cb.h> to derive NUM_MACH_IRQS. */
#define NUM_RTE_CB_IRQS (NUM_CPU_IRQS + IRQ_CB_PIC_NUM)
#ifndef __ASSEMBLY__
struct cb_pic_irq_init {
const char *name; /* name of interrupt type */
/* Range of kernel irq numbers for this type:
BASE, BASE+INTERVAL, ..., BASE+INTERVAL*NUM */
unsigned base, num, interval;
unsigned priority; /* interrupt priority to assign */
};
struct hw_interrupt_type; /* fwd decl */
/* Enable interrupt handling for interrupt IRQ. */
extern void cb_pic_enable_irq (unsigned irq);
/* Disable interrupt handling for interrupt IRQ. Note that any interrupts
received while disabled will be delivered once the interrupt is enabled
again, unless they are explicitly cleared using `cb_pic_clear_pending_irq'. */
extern void cb_pic_disable_irq (unsigned irq);
/* Initialize HW_IRQ_TYPES for PIC irqs described in array INITS (which is
terminated by an entry with the name field == 0). */
extern void cb_pic_init_irq_types (struct cb_pic_irq_init *inits,
struct hw_interrupt_type *hw_irq_types);
/* Initialize PIC interrupts. */
extern void cb_pic_init_irqs (void);
#endif /* __ASSEMBLY__ */
/* TL16C550C on board UART see also asm/serial.h */
#define CB_UART_BASE 0x0FE08000
#define CB_UART_REG_GAP 0x10
#define CB_UART_CLOCK 0x16000000
/* CompactFlash setting see also asm/ide.h, asm/hdreg.h. */
#define CB_CF_BASE 0x0FE0C000
#define CB_CF_CCR_ADDR (CB_CF_BASE+0x200)
#define CB_CF_CCR (*(volatile u8 *)CB_CF_CCR_ADDR)
#define CB_CF_REG0_ADDR (CB_CF_BASE+0x1000)
#define CB_CF_REG0 (*(volatile u16 *)CB_CF_REG0_ADDR)
#define CB_CF_STS0_ADDR (CB_CF_BASE+0x1004)
#define CB_CF_STS0 (*(volatile u16 *)CB_CF_STS0_ADDR)
#define CB_PCATA_BASE (CB_CF_BASE+0x800)
#define CB_IDE_BASE (CB_CF_BASE+0x9F0)
#define CB_IDE_CTRL (CB_CF_BASE+0xBF6)
#define CB_IDE_REG_OFFS 0x1
/* SMSC LAN91C111 setting */
#if defined(CONFIG_SMC91111)
#define CB_LANC_BASE 0x0FE10300
#define CONFIG_SMC16BITONLY
#define ETH0_ADDR CB_LANC_BASE
#define ETH0_IRQ IRQ_CB_LANC
#endif /* CONFIG_SMC16BITONLY */
#undef V850E_UART_PRE_CONFIGURE
#define V850E_UART_PRE_CONFIGURE rte_me2_cb_uart_pre_configure
#ifndef __ASSEMBLY__
extern void rte_me2_cb_uart_pre_configure (unsigned chan,
unsigned cflags, unsigned baud);
#endif /* __ASSEMBLY__ */
/* This board supports RTS/CTS for the on-chip UART, but only for channel 0. */
/* CTS for UART channel 0 is pin P22 (bit 2 of port 2). */
#define V850E_UART_CTS(chan) ((chan) == 0 ? !(ME2_PORT2_IO & 0x4) : 1)
/* RTS for UART channel 0 is pin P21 (bit 1 of port 2). */
#define V850E_UART_SET_RTS(chan, val) \
do { \
if (chan == 0) { \
unsigned old = ME2_PORT2_IO; \
if (val) \
ME2_PORT2_IO = old & ~0x2; \
else \
ME2_PORT2_IO = old | 0x2; \
} \
} while (0)
#ifndef __ASSEMBLY__
extern void rte_me2_cb_init_irqs (void);
#endif /* !__ASSEMBLY__ */
#endif /* __V850_RTE_ME2_CB_H__ */
...@@ -17,6 +17,21 @@ ...@@ -17,6 +17,21 @@
#include <asm/rte_cb.h> /* Common defs for Midas RTE-CB boards. */ #include <asm/rte_cb.h> /* Common defs for Midas RTE-CB boards. */
#define PLATFORM "rte-v850e/nb85e-cb"
#define PLATFORM_LONG "Midas lab RTE-V850E/NB85E-CB"
#define CPU_CLOCK_FREQ 50000000 /* 50MHz */
/* 1MB of onboard SRAM. Note that the monitor ROM uses parts of this
for its own purposes, so care must be taken. */
#define SRAM_ADDR 0x03C00000
#define SRAM_SIZE 0x00100000 /* 1MB */
/* 16MB of onbard SDRAM. */
#define SDRAM_ADDR 0x01000000
#define SDRAM_SIZE 0x01000000 /* 16MB */
/* CPU addresses of GBUS memory spaces. */ /* CPU addresses of GBUS memory spaces. */
#define GCS0_ADDR 0x00400000 /* GCS0 - Common SRAM (2MB) */ #define GCS0_ADDR 0x00400000 /* GCS0 - Common SRAM (2MB) */
#define GCS0_SIZE 0x00400000 /* 4MB */ #define GCS0_SIZE 0x00400000 /* 4MB */
...@@ -39,20 +54,8 @@ ...@@ -39,20 +54,8 @@
#define IRQ_GINT(n) (10 + (n)) #define IRQ_GINT(n) (10 + (n))
#define IRQ_GINT_NUM 3 #define IRQ_GINT_NUM 3
/* Used by <asm/rte_cb.h> to derive NUM_MACH_IRQS. */
#define PLATFORM "rte-v850e/nb85e-cb" #define NUM_RTE_CB_IRQS NUM_CPU_IRQS
#define PLATFORM_LONG "Midas lab RTE-V850E/NB85E-CB"
#define CPU_CLOCK_FREQ 50000000 /* 50MHz */
/* 1MB of onboard SRAM. Note that the monitor ROM uses parts of this
for its own purposes, so care must be taken. */
#define SRAM_ADDR 0x03C00000
#define SRAM_SIZE 0x00100000 /* 1MB */
/* 16MB of onbard SDRAM. */
#define SDRAM_ADDR 0x01000000
#define SDRAM_SIZE 0x01000000 /* 16MB */
#ifdef CONFIG_ROM_KERNEL #ifdef CONFIG_ROM_KERNEL
...@@ -86,8 +89,8 @@ ...@@ -86,8 +89,8 @@
/* Override the basic TEG UART pre-initialization so that we can /* Override the basic TEG UART pre-initialization so that we can
initialize extra stuff. */ initialize extra stuff. */
#undef NB85E_UART_PRE_CONFIGURE /* should be defined by <asm/teg.h> */ #undef V850E_UART_PRE_CONFIGURE /* should be defined by <asm/teg.h> */
#define NB85E_UART_PRE_CONFIGURE rte_nb85e_cb_uart_pre_configure #define V850E_UART_PRE_CONFIGURE rte_nb85e_cb_uart_pre_configure
#ifndef __ASSEMBLY__ #ifndef __ASSEMBLY__
extern void rte_nb85e_cb_uart_pre_configure (unsigned chan, extern void rte_nb85e_cb_uart_pre_configure (unsigned chan,
unsigned cflags, unsigned baud); unsigned cflags, unsigned baud);
...@@ -96,9 +99,9 @@ extern void rte_nb85e_cb_uart_pre_configure (unsigned chan, ...@@ -96,9 +99,9 @@ extern void rte_nb85e_cb_uart_pre_configure (unsigned chan,
/* This board supports RTS/CTS for the on-chip UART. */ /* This board supports RTS/CTS for the on-chip UART. */
/* CTS is pin P00. */ /* CTS is pin P00. */
#define NB85E_UART_CTS(chan) (! (TEG_PORT0_IO & 0x1)) #define V850E_UART_CTS(chan) (! (TEG_PORT0_IO & 0x1))
/* RTS is pin P02. */ /* RTS is pin P02. */
#define NB85E_UART_SET_RTS(chan, val) \ #define V850E_UART_SET_RTS(chan, val) \
do { \ do { \
unsigned old = TEG_PORT0_IO; \ unsigned old = TEG_PORT0_IO; \
TEG_PORT0_IO = val ? (old & ~0x4) : (old | 0x4); \ TEG_PORT0_IO = val ? (old & ~0x4) : (old | 0x4); \
......
/*
* This file is subject to the terms and conditions of the GNU General Public
* License. See the file "COPYING" in the main directory of this archive
* for more details.
*
* Copyright (C) 1999 by Ralf Baechle
* Copyright (C) 1999, 2000 Silicon Graphics, Inc.
*/
#include <linux/config.h>
#ifdef CONFIG_RTE_CB_ME2
#include <asm/rte_me2_cb.h>
#define STD_COM_FLAGS (ASYNC_BOOT_AUTOCONF | ASYNC_SKIP_TEST)
#define irq_cannonicalize(x) (x)
#define BASE_BAUD 250000 /* (16MHz / (16 * 38400)) * 9600 */
#define RS_TABLE_SIZE 1
#define SERIAL_PORT_DFNS \
{ 0, BASE_BAUD, CB_UART_BASE, IRQ_CB_EXTSIO, STD_COM_FLAGS },
/* Redefine UART register offsets. */
#undef UART_RX
#undef UART_TX
#undef UART_DLL
#undef UART_TRG
#undef UART_DLM
#undef UART_IER
#undef UART_FCTR
#undef UART_IIR
#undef UART_FCR
#undef UART_EFR
#undef UART_LCR
#undef UART_MCR
#undef UART_LSR
#undef UART_MSR
#undef UART_SCR
#undef UART_EMSR
#define UART_RX (0 * CB_UART_REG_GAP)
#define UART_TX (0 * CB_UART_REG_GAP)
#define UART_DLL (0 * CB_UART_REG_GAP)
#define UART_TRG (0 * CB_UART_REG_GAP)
#define UART_DLM (1 * CB_UART_REG_GAP)
#define UART_IER (1 * CB_UART_REG_GAP)
#define UART_FCTR (1 * CB_UART_REG_GAP)
#define UART_IIR (2 * CB_UART_REG_GAP)
#define UART_FCR (2 * CB_UART_REG_GAP)
#define UART_EFR (2 * CB_UART_REG_GAP)
#define UART_LCR (3 * CB_UART_REG_GAP)
#define UART_MCR (4 * CB_UART_REG_GAP)
#define UART_LSR (5 * CB_UART_REG_GAP)
#define UART_MSR (6 * CB_UART_REG_GAP)
#define UART_SCR (7 * CB_UART_REG_GAP)
#define UART_EMSR (7 * CB_UART_REG_GAP)
#endif /* CONFIG_RTE_CB_ME2 */
/*
* include/asm-v850/sim85e2.h -- Machine-dependent defs for
* V850E2 RTL simulator
*
* Copyright (C) 2002,03 NEC Electronics Corporation
* Copyright (C) 2002,03 Miles Bader <miles@gnu.org>
*
* This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this
* archive for more details.
*
* Written by Miles Bader <miles@gnu.org>
*/
#ifndef __V850_SIM85E2_H__
#define __V850_SIM85E2_H__
#include <asm/v850e2.h> /* Based on V850E2 core. */
/* Various memory areas supported by the simulator.
These should match the corresponding definitions in the linker script. */
/* `instruction RAM'; instruction fetches are much faster from IRAM than
from DRAM. */
#define IRAM_ADDR 0
#define IRAM_SIZE 0x00100000 /* 1MB */
/* `data RAM', below and contiguous with the I/O space.
Data fetches are much faster from DRAM than from IRAM. */
#define DRAM_ADDR 0xfff00000
#define DRAM_SIZE 0x000ff000 /* 1020KB */
/* `external ram'. Unlike the above RAM areas, this memory is cached,
so both instruction and data fetches should be (mostly) fast --
however, currently only write-through caching is supported, so writes
to ERAM will be slow. */
#define ERAM_ADDR 0x00100000
#define ERAM_SIZE 0x07f00000 /* 127MB (max) */
/* Dynamic RAM; uses memory controller. */
#define SDRAM_ADDR 0x10000000
#if 0
#define SDRAM_SIZE 0x01000000 /* 16MB */
#else
#define SDRAM_SIZE 0x00200000 /* Only use 2MB for testing */
#endif
/* Simulator specific control registers. */
/* NOTHAL controls whether the simulator will stop at a `halt' insn. */
#define SIM85E2_NOTHAL_ADDR 0xffffff22
#define SIM85E2_NOTHAL (*(volatile u8 *)SIM85E2_NOTHAL_ADDR)
/* The simulator will stop N cycles after N is written to SIMFIN. */
#define SIM85E2_SIMFIN_ADDR 0xffffff24
#define SIM85E2_SIMFIN (*(volatile u16 *)SIM85E2_SIMFIN_ADDR)
/* For <asm/irq.h> */
#define NUM_CPU_IRQS 64
/* For <asm/page.h> */
#define PAGE_OFFSET SDRAM_ADDR
/* For <asm/entry.h> */
/* `R0 RAM', used for a few miscellaneous variables that must be accessible
using a load instruction relative to R0. The sim85e2 simulator
actually puts 1020K of RAM from FFF00000 to FFFFF000, so we arbitarily
choose a small portion at the end of that. */
#define R0_RAM_ADDR 0xFFFFE000
/* For <asm/param.h> */
#ifndef HZ
#define HZ 24 /* Minimum supported frequency. */
#endif
#endif /* __V850_SIM85E2_H__ */
...@@ -15,78 +15,12 @@ ...@@ -15,78 +15,12 @@
#ifndef __V850_SIM85E2C_H__ #ifndef __V850_SIM85E2C_H__
#define __V850_SIM85E2C_H__ #define __V850_SIM85E2C_H__
/* Use generic sim85e2 settings, other than the various names. */
#include <asm/sim85e2.h>
#define CPU_ARCH "v850e2"
#define CPU_MODEL "v850e2" #define CPU_MODEL "v850e2"
#define CPU_MODEL_LONG "NEC V850E2" #define CPU_MODEL_LONG "NEC V850E2"
#define PLATFORM "sim85e2c" #define PLATFORM "sim85e2c"
#define PLATFORM_LONG "SIM85E2C V850E2 simulator" #define PLATFORM_LONG "SIM85E2C V850E2 simulator"
/* Various memory areas supported by the simulator.
These should match the corresponding definitions in the linker script. */
/* `instruction RAM'; instruction fetches are much faster from IRAM than
from DRAM. */
#define IRAM_ADDR 0
#define IRAM_SIZE 0x00100000 /* 1MB */
/* `data RAM', below and contiguous with the I/O space.
Data fetches are much faster from DRAM than from IRAM. */
#define DRAM_ADDR 0xfff00000
#define DRAM_SIZE 0x000ff000 /* 1020KB */
/* `external ram'. Unlike the above RAM areas, this memory is cached,
so both instruction and data fetches should be (mostly) fast --
however, currently only write-through caching is supported, so writes
to ERAM will be slow. */
#define ERAM_ADDR 0x00100000
#define ERAM_SIZE 0x07f00000 /* 127MB (max) */
/* CPU core control registers; these should be expanded and moved into
separate header files when we support some other processors based on
the same E2 core. */
/* Bus Transaction Control Register */
#define NA85E2C_CACHE_BTSC_ADDR 0xfffff070
#define NA85E2C_CACHE_BTSC (*(volatile unsigned short *)NA85E2C_CACHE_BTSC_ADDR)
#define NA85E2C_CACHE_BTSC_ICM 0x1 /* icache enable */
#define NA85E2C_CACHE_BTSC_DCM0 0x4 /* dcache enable, bit 0 */
#define NA85E2C_CACHE_BTSC_DCM1 0x8 /* dcache enable, bit 1 */
/* Cache Configuration Register */
#define NA85E2C_BUSM_BHC_ADDR 0xfffff06a
#define NA85E2C_BUSM_BHC (*(volatile unsigned short *)NA85E2C_BUSM_BHC_ADDR)
/* Simulator specific control registers. */
/* NOTHAL controls whether the simulator will stop at a `halt' insn. */
#define NOTHAL_ADDR 0xffffff22
#define NOTHAL (*(volatile unsigned char *)NOTHAL_ADDR)
/* The simulator will stop N cycles after N is written to SIMFIN. */
#define SIMFIN_ADDR 0xffffff24
#define SIMFIN (*(volatile unsigned short *)SIMFIN_ADDR)
/* The simulator has an nb85e-style interrupt system. */
#include <asm/nb85e_intc.h>
/* For <asm/irq.h> */
#define NUM_CPU_IRQS 64
/* For <asm/page.h> */
#define PAGE_OFFSET DRAM_ADDR
/* For <asm/entry.h> */
/* `R0 RAM', used for a few miscellaneous variables that must be accessible
using a load instruction relative to R0. The sim85e2c simulator
actually puts 1020K of RAM from FFF00000 to FFFFF000, so we arbitarily
choose a small portion at the end of that. */
#define R0_RAM_ADDR 0xFFFFE000
/* For <asm/param.h> */
#ifndef HZ
#define HZ 24 /* Minimum supported frequency. */
#endif
#endif /* __V850_SIM85E2C_H__ */ #endif /* __V850_SIM85E2C_H__ */
/*
* include/asm-v850/sim85e2s.h -- Machine-dependent defs for
* V850E2 RTL simulator
*
* Copyright (C) 2003 NEC Electronics Corporation
* Copyright (C) 2003 Miles Bader <miles@gnu.org>
*
* This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this
* archive for more details.
*
* Written by Miles Bader <miles@gnu.org>
*/
#ifndef __V850_SIM85E2S_H__
#define __V850_SIM85E2S_H__
#include <asm/sim85e2.h> /* Use generic sim85e2 settings. */
#if 0
#include <asm/v850e2_cache.h> /* + cache */
#endif
#define CPU_MODEL "v850e2"
#define CPU_MODEL_LONG "NEC V850E2"
#define PLATFORM "sim85e2s"
#define PLATFORM_LONG "SIM85E2S V850E2 simulator"
#endif /* __V850_SIM85E2S_H__ */
/* /*
* include/asm-v850/stat.h -- v850 stat structure * include/asm-v850/stat.h -- v850 stat structure
* *
* Copyright (C) 2001,02,03 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
......
/* /*
* include/asm-v850/system.h -- Low-level interrupt/thread ops * include/asm-v850/system.h -- Low-level interrupt/thread ops
* *
* Copyright (C) 2001,02,03 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
......
...@@ -15,9 +15,9 @@ ...@@ -15,9 +15,9 @@
#define __V850_TEG_H__ #define __V850_TEG_H__
/* The TEG uses the NB85E cpu core. */ /* The TEG uses the V850E cpu core. */
#include <asm/nb85e.h> #include <asm/v850e.h>
#include <asm/nb85e_cache.h> #include <asm/v850e_cache.h>
#define CPU_MODEL "v850e/nb85e-teg" #define CPU_MODEL "v850e/nb85e-teg"
...@@ -51,18 +51,18 @@ ...@@ -51,18 +51,18 @@
/* TEG UART details. */ /* TEG UART details. */
#define NB85E_UART_BASE_ADDR(n) (0xFFFFF600 + 0x10 * (n)) #define V850E_UART_BASE_ADDR(n) (0xFFFFF600 + 0x10 * (n))
#define NB85E_UART_ASIM_ADDR(n) (NB85E_UART_BASE_ADDR(n) + 0x0) #define V850E_UART_ASIM_ADDR(n) (V850E_UART_BASE_ADDR(n) + 0x0)
#define NB85E_UART_ASIS_ADDR(n) (NB85E_UART_BASE_ADDR(n) + 0x2) #define V850E_UART_ASIS_ADDR(n) (V850E_UART_BASE_ADDR(n) + 0x2)
#define NB85E_UART_ASIF_ADDR(n) (NB85E_UART_BASE_ADDR(n) + 0x4) #define V850E_UART_ASIF_ADDR(n) (V850E_UART_BASE_ADDR(n) + 0x4)
#define NB85E_UART_CKSR_ADDR(n) (NB85E_UART_BASE_ADDR(n) + 0x6) #define V850E_UART_CKSR_ADDR(n) (V850E_UART_BASE_ADDR(n) + 0x6)
#define NB85E_UART_BRGC_ADDR(n) (NB85E_UART_BASE_ADDR(n) + 0x8) #define V850E_UART_BRGC_ADDR(n) (V850E_UART_BASE_ADDR(n) + 0x8)
#define NB85E_UART_TXB_ADDR(n) (NB85E_UART_BASE_ADDR(n) + 0xA) #define V850E_UART_TXB_ADDR(n) (V850E_UART_BASE_ADDR(n) + 0xA)
#define NB85E_UART_RXB_ADDR(n) (NB85E_UART_BASE_ADDR(n) + 0xC) #define V850E_UART_RXB_ADDR(n) (V850E_UART_BASE_ADDR(n) + 0xC)
#define NB85E_UART_NUM_CHANNELS 1 #define V850E_UART_NUM_CHANNELS 1
#define NB85E_UART_BASE_FREQ CPU_CLOCK_FREQ #define V850E_UART_BASE_FREQ CPU_CLOCK_FREQ
/* This is a function that gets called before configuring the UART. */ /* This is a function that gets called before configuring the UART. */
#define NB85E_UART_PRE_CONFIGURE teg_uart_pre_configure #define V850E_UART_PRE_CONFIGURE teg_uart_pre_configure
#ifndef __ASSEMBLY__ #ifndef __ASSEMBLY__
extern void teg_uart_pre_configure (unsigned chan, extern void teg_uart_pre_configure (unsigned chan,
unsigned cflags, unsigned baud); unsigned cflags, unsigned baud);
...@@ -70,15 +70,15 @@ extern void teg_uart_pre_configure (unsigned chan, ...@@ -70,15 +70,15 @@ extern void teg_uart_pre_configure (unsigned chan,
/* The TEG RTPU. */ /* The TEG RTPU. */
#define NB85E_RTPU_BASE_ADDR 0xFFFFF210 #define V850E_RTPU_BASE_ADDR 0xFFFFF210
/* TEG series timer D details. */ /* TEG series timer D details. */
#define NB85E_TIMER_D_BASE_ADDR 0xFFFFF210 #define V850E_TIMER_D_BASE_ADDR 0xFFFFF210
#define NB85E_TIMER_D_TMCD_BASE_ADDR (NB85E_TIMER_D_BASE_ADDR + 0x0) #define V850E_TIMER_D_TMCD_BASE_ADDR (V850E_TIMER_D_BASE_ADDR + 0x0)
#define NB85E_TIMER_D_TMD_BASE_ADDR (NB85E_TIMER_D_BASE_ADDR + 0x4) #define V850E_TIMER_D_TMD_BASE_ADDR (V850E_TIMER_D_BASE_ADDR + 0x4)
#define NB85E_TIMER_D_CMD_BASE_ADDR (NB85E_TIMER_D_BASE_ADDR + 0x8) #define V850E_TIMER_D_CMD_BASE_ADDR (V850E_TIMER_D_BASE_ADDR + 0x8)
#define NB85E_TIMER_D_BASE_FREQ CPU_CLOCK_FREQ #define V850E_TIMER_D_BASE_FREQ CPU_CLOCK_FREQ
/* `Interrupt Source Select' control register. */ /* `Interrupt Source Select' control register. */
......
/* /*
* include/asm-v850/nb85e.h -- NB85E cpu core * include/asm-v850/v850e.h -- V850E CPU
* *
* Copyright (C) 2001,02 NEC Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -11,11 +11,11 @@ ...@@ -11,11 +11,11 @@
* Written by Miles Bader <miles@gnu.org> * Written by Miles Bader <miles@gnu.org>
*/ */
#ifndef __V850_NB85E_H__ #ifndef __V850_V850E_H__
#define __V850_NB85E_H__ #define __V850_V850E_H__
#include <asm/nb85e_intc.h> #include <asm/v850e_intc.h>
#define CPU_ARCH "v850e" #define CPU_ARCH "v850e"
#endif /* __V850_NB85E_H__ */ #endif /* __V850_V850E_H__ */
/*
* include/asm-v850/v850e2.h -- Machine-dependent defs for V850E2 CPUs
*
* Copyright (C) 2002,03 NEC Electronics Corporation
* Copyright (C) 2002,03 Miles Bader <miles@gnu.org>
*
* This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this
* archive for more details.
*
* Written by Miles Bader <miles@gnu.org>
*/
#ifndef __V850_V850E2_H__
#define __V850_V850E2_H__
#include <asm/v850e_intc.h> /* v850e-style interrupt system. */
#define CPU_ARCH "v850e2"
/* Control registers. */
/* Chip area select control */
#define V850E2_CSC_ADDR(n) (0xFFFFF060 + (n) * 2)
#define V850E2_CSC(n) (*(volatile u16 *)V850E2_CSC_ADDR(n))
/* I/O area select control */
#define V850E2_BPC_ADDR 0xFFFFF064
#define V850E2_BPC (*(volatile u16 *)V850E2_BPC_ADDR)
/* Bus size configuration */
#define V850E2_BSC_ADDR 0xFFFFF066
#define V850E2_BSC (*(volatile u16 *)V850E2_BSC_ADDR)
/* Endian configuration */
#define V850E2_BEC_ADDR 0xFFFFF068
#define V850E2_BEC (*(volatile u16 *)V850E2_BEC_ADDR)
/* Cache configuration */
#define V850E2_BHC_ADDR 0xFFFFF06A
#define V850E2_BHC (*(volatile u16 *)V850E2_BHC_ADDR)
/* NPB strobe-wait configuration */
#define V850E2_VSWC_ADDR 0xFFFFF06E
#define V850E2_VSWC (*(volatile u16 *)V850E2_VSWC_ADDR)
/* Bus cycle type */
#define V850E2_BCT_ADDR(n) (0xFFFFF480 + (n) * 2)
#define V850E2_BCT(n) (*(volatile u16 *)V850E2_BCT_ADDR(n))
/* Data wait control */
#define V850E2_DWC_ADDR(n) (0xFFFFF484 + (n) * 2)
#define V850E2_DWC(n) (*(volatile u16 *)V850E2_DWC_ADDR(n))
/* Bus cycle control */
#define V850E2_BCC_ADDR 0xFFFFF488
#define V850E2_BCC (*(volatile u16 *)V850E2_BCC_ADDR)
/* Address wait control */
#define V850E2_ASC_ADDR 0xFFFFF48A
#define V850E2_ASC (*(volatile u16 *)V850E2_ASC_ADDR)
/* Local bus sizing control */
#define V850E2_LBS_ADDR 0xFFFFF48E
#define V850E2_LBS (*(volatile u16 *)V850E2_LBS_ADDR)
/* Line buffer control */
#define V850E2_LBC_ADDR(n) (0xFFFFF490 + (n) * 2)
#define V850E2_LBC(n) (*(volatile u16 *)V850E2_LBC_ADDR(n))
/* SDRAM configuration */
#define V850E2_SCR_ADDR(n) (0xFFFFF4A0 + (n) * 4)
#define V850E2_SCR(n) (*(volatile u16 *)V850E2_SCR_ADDR(n))
/* SDRAM refresh cycle control */
#define V850E2_RFS_ADDR(n) (0xFFFFF4A2 + (n) * 4)
#define V850E2_RFS(n) (*(volatile u16 *)V850E2_RFS_ADDR(n))
#endif /* __V850_V850E2_H__ */
/*
* include/asm-v850/v850e2_cache_cache.h -- Cache control for V850E2
* cache memories
*
* Copyright (C) 2003 NEC Electronics Corporation
* Copyright (C) 2003 Miles Bader <miles@gnu.org>
*
* This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this
* archive for more details.
*
* Written by Miles Bader <miles@gnu.org>
*/
#ifndef __V850_V850E2_CACHE_H__
#define __V850_V850E2_CACHE_H__
#include <asm/types.h>
/* Cache control registers. */
/* Bus Transaction Control */
#define V850E2_CACHE_BTSC_ADDR 0xFFFFF070
#define V850E2_CACHE_BTSC (*(volatile u16 *)V850E2_CACHE_BTSC_ADDR)
#define V850E2_CACHE_BTSC_ICM 0x0001 /* icache enable */
#define V850E2_CACHE_BTSC_DCM0 0x0004 /* dcache enable, bit 0 */
#define V850E2_CACHE_BTSC_DCM1 0x0008 /* dcache enable, bit 1 */
#define V850E2_CACHE_BTSC_DCM_WT /* write-through */ \
V850E2_CACHE_BTSC_DCM0
#ifdef CONFIG_V850E2_V850E2S
# define V850E2_CACHE_BTSC_DCM_WB_NO_ALLOC /* write-back, non-alloc */ \
V850E2_CACHE_BTSC_DCM1
# define V850E2_CACHE_BTSC_DCM_WB_ALLOC /* write-back, non-alloc */ \
(V850E2_CACHE_BTSC_DCM1 | V850E2_CACHE_BTSC_DCM0)
# define V850E2_CACHE_BTSC_ISEQ 0x0010 /* icache `address sequence mode' */
# define V850E2_CACHE_BTSC_DSEQ 0x0020 /* dcache `address sequence mode' */
# define V850E2_CACHE_BTSC_IRFC 0x0030
# define V850E2_CACHE_BTSC_ILCD 0x4000
# define V850E2_CACHE_BTSC_VABE 0x8000
#endif /* CONFIG_V850E2_V850E2S */
/* Cache operation start address register (low-bits). */
#define V850E2_CACHE_CADL_ADDR 0xFFFFF074
#define V850E2_CACHE_CADL (*(volatile u16 *)V850E2_CACHE_CADL_ADDR)
/* Cache operation start address register (high-bits). */
#define V850E2_CACHE_CADH_ADDR 0xFFFFF076
#define V850E2_CACHE_CADH (*(volatile u16 *)V850E2_CACHE_CADH_ADDR)
/* Cache operation count register. */
#define V850E2_CACHE_CCNT_ADDR 0xFFFFF078
#define V850E2_CACHE_CCNT (*(volatile u16 *)V850E2_CACHE_CCNT_ADDR)
/* Cache operation specification register. */
#define V850E2_CACHE_COPR_ADDR 0xFFFFF07A
#define V850E2_CACHE_COPR (*(volatile u16 *)V850E2_CACHE_COPR_ADDR)
#define V850E2_CACHE_COPR_STRT 0x0001 /* start cache operation */
#define V850E2_CACHE_COPR_LBSL 0x0100 /* 0 = icache, 1 = dcache */
#define V850E2_CACHE_COPR_WSLE 0x0200 /* operate on cache way */
#define V850E2_CACHE_COPR_WSL(way) ((way) * 0x0400) /* way select */
#define V850E2_CACHE_COPR_CFC(op) ((op) * 0x1000) /* cache function code */
/* Size of a cache line in bytes. */
#define V850E2_CACHE_LINE_SIZE_BITS 4
#define V850E2_CACHE_LINE_SIZE (1 << V850E2_CACHE_LINE_SIZE_BITS)
/* The size of each cache `way' in lines. */
#define V850E2_CACHE_WAY_SIZE 256
/* For <asm/cache.h> */
#define L1_CACHE_BYTES V850E2_CACHE_LINE_SIZE
#endif /* __V850_V850E2_CACHE_H__ */
/*
* include/asm-v850/v850e_cache.h -- Cache control for V850E cache memories
*
* Copyright (C) 2001,03 NEC Electronics Corporation
* Copyright (C) 2001,03 Miles Bader <miles@gnu.org>
*
* This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this
* archive for more details.
*
* Written by Miles Bader <miles@gnu.org>
*/
/* This file implements cache control for the rather simple cache used on
some V850E CPUs, specifically the NB85E/TEG CPU-core and the V850E/ME2
CPU. V850E2 processors have their own (better) cache
implementation. */
#ifndef __V850_V850E_CACHE_H__
#define __V850_V850E_CACHE_H__
#include <asm/types.h>
/* Cache control registers. */
#define V850E_CACHE_BHC_ADDR 0xFFFFF06A
#define V850E_CACHE_BHC (*(volatile u16 *)V850E_CACHE_BHC_ADDR)
#define V850E_CACHE_ICC_ADDR 0xFFFFF070
#define V850E_CACHE_ICC (*(volatile u16 *)V850E_CACHE_ICC_ADDR)
#define V850E_CACHE_ISI_ADDR 0xFFFFF072
#define V850E_CACHE_ISI (*(volatile u16 *)V850E_CACHE_ISI_ADDR)
#define V850E_CACHE_DCC_ADDR 0xFFFFF078
#define V850E_CACHE_DCC (*(volatile u16 *)V850E_CACHE_DCC_ADDR)
/* Size of a cache line in bytes. */
#define V850E_CACHE_LINE_SIZE 16
/* For <asm/cache.h> */
#define L1_CACHE_BYTES V850E_CACHE_LINE_SIZE
#if defined(__KERNEL__) && !defined(__ASSEMBLY__)
/* Set caching params via the BHC, ICC, and DCC registers. */
void v850e_cache_enable (u16 bhc, u16 icc, u16 dcc);
#endif /* __KERNEL__ && !__ASSEMBLY__ */
#endif /* __V850_V850E_CACHE_H__ */
/* /*
* include/asm-v850/nb85e_intc.h -- NB85E cpu core interrupt controller (INTC) * include/asm-v850/v850e_intc.h -- V850E CPU interrupt controller (INTC)
* *
* Copyright (C) 2001,02,03 NEC Electronics Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
...@@ -11,106 +11,106 @@ ...@@ -11,106 +11,106 @@
* Written by Miles Bader <miles@gnu.org> * Written by Miles Bader <miles@gnu.org>
*/ */
#ifndef __V850_NB85E_INTC_H__ #ifndef __V850_V850E_INTC_H__
#define __V850_NB85E_INTC_H__ #define __V850_V850E_INTC_H__
/* There are 4 16-bit `Interrupt Mask Registers' located contiguously /* There are 4 16-bit `Interrupt Mask Registers' located contiguously
starting from this base. Each interrupt uses a single bit to starting from this base. Each interrupt uses a single bit to
indicated enabled/disabled status. */ indicated enabled/disabled status. */
#define NB85E_INTC_IMR_BASE_ADDR 0xFFFFF100 #define V850E_INTC_IMR_BASE_ADDR 0xFFFFF100
#define NB85E_INTC_IMR_ADDR(irq) (NB85E_INTC_IMR_BASE_ADDR + ((irq) >> 3)) #define V850E_INTC_IMR_ADDR(irq) (V850E_INTC_IMR_BASE_ADDR + ((irq) >> 3))
#define NB85E_INTC_IMR_BIT(irq) ((irq) & 0x7) #define V850E_INTC_IMR_BIT(irq) ((irq) & 0x7)
/* Each maskable interrupt has a single-byte control register at this /* Each maskable interrupt has a single-byte control register at this
address. */ address. */
#define NB85E_INTC_IC_BASE_ADDR 0xFFFFF110 #define V850E_INTC_IC_BASE_ADDR 0xFFFFF110
#define NB85E_INTC_IC_ADDR(irq) (NB85E_INTC_IC_BASE_ADDR + ((irq) << 1)) #define V850E_INTC_IC_ADDR(irq) (V850E_INTC_IC_BASE_ADDR + ((irq) << 1))
#define NB85E_INTC_IC(irq) (*(volatile u8 *)NB85E_INTC_IC_ADDR(irq)) #define V850E_INTC_IC(irq) (*(volatile u8 *)V850E_INTC_IC_ADDR(irq))
/* Encode priority PR for storing in an interrupt control register. */ /* Encode priority PR for storing in an interrupt control register. */
#define NB85E_INTC_IC_PR(pr) (pr) #define V850E_INTC_IC_PR(pr) (pr)
/* Interrupt disable bit in an interrupt control register. */ /* Interrupt disable bit in an interrupt control register. */
#define NB85E_INTC_IC_MK_BIT 6 #define V850E_INTC_IC_MK_BIT 6
#define NB85E_INTC_IC_MK (1 << NB85E_INTC_IC_MK_BIT) #define V850E_INTC_IC_MK (1 << V850E_INTC_IC_MK_BIT)
/* Interrupt pending flag in an interrupt control register. */ /* Interrupt pending flag in an interrupt control register. */
#define NB85E_INTC_IC_IF_BIT 7 #define V850E_INTC_IC_IF_BIT 7
#define NB85E_INTC_IC_IF (1 << NB85E_INTC_IC_IF_BIT) #define V850E_INTC_IC_IF (1 << V850E_INTC_IC_IF_BIT)
/* The ISPR (In-service priority register) contains one bit for each interrupt /* The ISPR (In-service priority register) contains one bit for each interrupt
priority level, which is set to one when that level is currently being priority level, which is set to one when that level is currently being
serviced (and thus blocking any interrupts of equal or lesser level). */ serviced (and thus blocking any interrupts of equal or lesser level). */
#define NB85E_INTC_ISPR_ADDR 0xFFFFF1FA #define V850E_INTC_ISPR_ADDR 0xFFFFF1FA
#define NB85E_INTC_ISPR (*(volatile u8 *)NB85E_INTC_ISPR_ADDR) #define V850E_INTC_ISPR (*(volatile u8 *)V850E_INTC_ISPR_ADDR)
#ifndef __ASSEMBLY__ #ifndef __ASSEMBLY__
/* Enable interrupt handling for interrupt IRQ. */ /* Enable interrupt handling for interrupt IRQ. */
static inline void nb85e_intc_enable_irq (unsigned irq) static inline void v850e_intc_enable_irq (unsigned irq)
{ {
__asm__ __volatile__ ("clr1 %0, [%1]" __asm__ __volatile__ ("clr1 %0, [%1]"
:: "r" (NB85E_INTC_IMR_BIT (irq)), :: "r" (V850E_INTC_IMR_BIT (irq)),
"r" (NB85E_INTC_IMR_ADDR (irq)) "r" (V850E_INTC_IMR_ADDR (irq))
: "memory"); : "memory");
} }
/* Disable interrupt handling for interrupt IRQ. Note that any /* Disable interrupt handling for interrupt IRQ. Note that any
interrupts received while disabled will be delivered once the interrupts received while disabled will be delivered once the
interrupt is enabled again, unless they are explicitly cleared using interrupt is enabled again, unless they are explicitly cleared using
`nb85e_intc_clear_pending_irq'. */ `v850e_intc_clear_pending_irq'. */
static inline void nb85e_intc_disable_irq (unsigned irq) static inline void v850e_intc_disable_irq (unsigned irq)
{ {
__asm__ __volatile__ ("set1 %0, [%1]" __asm__ __volatile__ ("set1 %0, [%1]"
:: "r" (NB85E_INTC_IMR_BIT (irq)), :: "r" (V850E_INTC_IMR_BIT (irq)),
"r" (NB85E_INTC_IMR_ADDR (irq)) "r" (V850E_INTC_IMR_ADDR (irq))
: "memory"); : "memory");
} }
/* Return true if interrupt handling for interrupt IRQ is enabled. */ /* Return true if interrupt handling for interrupt IRQ is enabled. */
static inline int nb85e_intc_irq_enabled (unsigned irq) static inline int v850e_intc_irq_enabled (unsigned irq)
{ {
int rval; int rval;
__asm__ __volatile__ ("tst1 %1, [%2]; setf z, %0" __asm__ __volatile__ ("tst1 %1, [%2]; setf z, %0"
: "=r" (rval) : "=r" (rval)
: "r" (NB85E_INTC_IMR_BIT (irq)), : "r" (V850E_INTC_IMR_BIT (irq)),
"r" (NB85E_INTC_IMR_ADDR (irq))); "r" (V850E_INTC_IMR_ADDR (irq)));
return rval; return rval;
} }
/* Disable irqs from 0 until LIMIT. LIMIT must be a multiple of 8. */ /* Disable irqs from 0 until LIMIT. LIMIT must be a multiple of 8. */
static inline void _nb85e_intc_disable_irqs (unsigned limit) static inline void _v850e_intc_disable_irqs (unsigned limit)
{ {
unsigned long addr; unsigned long addr;
for (addr = NB85E_INTC_IMR_BASE_ADDR; limit >= 8; addr++, limit -= 8) for (addr = V850E_INTC_IMR_BASE_ADDR; limit >= 8; addr++, limit -= 8)
*(char *)addr = 0xFF; *(char *)addr = 0xFF;
} }
/* Disable all irqs. This is purposely a macro, because NUM_MACH_IRQS /* Disable all irqs. This is purposely a macro, because NUM_MACH_IRQS
will be only be defined later. */ will be only be defined later. */
#define nb85e_intc_disable_irqs() _nb85e_intc_disable_irqs (NUM_MACH_IRQS) #define v850e_intc_disable_irqs() _v850e_intc_disable_irqs (NUM_MACH_IRQS)
/* Clear any pending interrupts for IRQ. */ /* Clear any pending interrupts for IRQ. */
static inline void nb85e_intc_clear_pending_irq (unsigned irq) static inline void v850e_intc_clear_pending_irq (unsigned irq)
{ {
__asm__ __volatile__ ("clr1 %0, 0[%1]" __asm__ __volatile__ ("clr1 %0, 0[%1]"
:: "i" (NB85E_INTC_IC_IF_BIT), :: "i" (V850E_INTC_IC_IF_BIT),
"r" (NB85E_INTC_IC_ADDR (irq)) "r" (V850E_INTC_IC_ADDR (irq))
: "memory"); : "memory");
} }
/* Return true if interrupt IRQ is pending (but disabled). */ /* Return true if interrupt IRQ is pending (but disabled). */
static inline int nb85e_intc_irq_pending (unsigned irq) static inline int v850e_intc_irq_pending (unsigned irq)
{ {
int rval; int rval;
__asm__ __volatile__ ("tst1 %1, 0[%2]; setf nz, %0" __asm__ __volatile__ ("tst1 %1, 0[%2]; setf nz, %0"
: "=r" (rval) : "=r" (rval)
: "i" (NB85E_INTC_IC_IF_BIT), : "i" (V850E_INTC_IC_IF_BIT),
"r" (NB85E_INTC_IC_ADDR (irq))); "r" (V850E_INTC_IC_ADDR (irq)));
return rval; return rval;
} }
struct nb85e_intc_irq_init { struct v850e_intc_irq_init {
const char *name; /* name of interrupt type */ const char *name; /* name of interrupt type */
/* Range of kernel irq numbers for this type: /* Range of kernel irq numbers for this type:
...@@ -123,11 +123,11 @@ struct hw_interrupt_type; /* fwd decl */ ...@@ -123,11 +123,11 @@ struct hw_interrupt_type; /* fwd decl */
/* Initialize HW_IRQ_TYPES for INTC-controlled irqs described in array /* Initialize HW_IRQ_TYPES for INTC-controlled irqs described in array
INITS (which is terminated by an entry with the name field == 0). */ INITS (which is terminated by an entry with the name field == 0). */
extern void nb85e_intc_init_irq_types (struct nb85e_intc_irq_init *inits, extern void v850e_intc_init_irq_types (struct v850e_intc_irq_init *inits,
struct hw_interrupt_type *hw_irq_types); struct hw_interrupt_type *hw_irq_types);
#endif /* !__ASSEMBLY__ */ #endif /* !__ASSEMBLY__ */
#endif /* __V850_NB85E_INTC_H__ */ #endif /* __V850_V850E_INTC_H__ */
/* /*
* include/asm-v850/nb85e_timer_c.h -- `Timer C' component often used * include/asm-v850/v850e_timer_c.h -- `Timer C' component often used
* with the NB85E cpu core * with the V850E cpu core
* *
* Copyright (C) 2001 NEC Corporation * Copyright (C) 2001,03 NEC Electronics Corporation
* Copyright (C) 2001 Miles Bader <miles@gnu.org> * Copyright (C) 2001,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -15,8 +15,8 @@ ...@@ -15,8 +15,8 @@
/* NOTE: this include file currently contains only enough to allow us to /* NOTE: this include file currently contains only enough to allow us to
use timer C as an interrupt pass-through. */ use timer C as an interrupt pass-through. */
#ifndef __V850_NB85E_TIMER_C_H__ #ifndef __V850_V850E_TIMER_C_H__
#define __V850_NB85E_TIMER_C_H__ #define __V850_V850E_TIMER_C_H__
#include <asm/types.h> #include <asm/types.h>
#include <asm/machdep.h> /* Pick up chip-specific defs. */ #include <asm/machdep.h> /* Pick up chip-specific defs. */
...@@ -25,24 +25,24 @@ ...@@ -25,24 +25,24 @@
/* Timer C (16-bit interval timers). */ /* Timer C (16-bit interval timers). */
/* Control register 0 for timer C. */ /* Control register 0 for timer C. */
#define NB85E_TIMER_C_TMCC0_ADDR(n) (NB85E_TIMER_C_BASE_ADDR + 0x6 + 0x10 *(n)) #define V850E_TIMER_C_TMCC0_ADDR(n) (V850E_TIMER_C_BASE_ADDR + 0x6 + 0x10 *(n))
#define NB85E_TIMER_C_TMCC0(n) (*(volatile u8 *)NB85E_TIMER_C_TMCC0_ADDR(n)) #define V850E_TIMER_C_TMCC0(n) (*(volatile u8 *)V850E_TIMER_C_TMCC0_ADDR(n))
#define NB85E_TIMER_C_TMCC0_CAE 0x01 /* clock action enable */ #define V850E_TIMER_C_TMCC0_CAE 0x01 /* clock action enable */
#define NB85E_TIMER_C_TMCC0_CE 0x02 /* count enable */ #define V850E_TIMER_C_TMCC0_CE 0x02 /* count enable */
/* ... */ /* ... */
/* Control register 1 for timer C. */ /* Control register 1 for timer C. */
#define NB85E_TIMER_C_TMCC1_ADDR(n) (NB85E_TIMER_C_BASE_ADDR + 0x8 + 0x10 *(n)) #define V850E_TIMER_C_TMCC1_ADDR(n) (V850E_TIMER_C_BASE_ADDR + 0x8 + 0x10 *(n))
#define NB85E_TIMER_C_TMCC1(n) (*(volatile u8 *)NB85E_TIMER_C_TMCC1_ADDR(n)) #define V850E_TIMER_C_TMCC1(n) (*(volatile u8 *)V850E_TIMER_C_TMCC1_ADDR(n))
#define NB85E_TIMER_C_TMCC1_CMS0 0x01 /* capture/compare mode select (ccc0) */ #define V850E_TIMER_C_TMCC1_CMS0 0x01 /* capture/compare mode select (ccc0) */
#define NB85E_TIMER_C_TMCC1_CMS1 0x02 /* capture/compare mode select (ccc1) */ #define V850E_TIMER_C_TMCC1_CMS1 0x02 /* capture/compare mode select (ccc1) */
/* ... */ /* ... */
/* Interrupt edge-sensitivity control for timer C. */ /* Interrupt edge-sensitivity control for timer C. */
#define NB85E_TIMER_C_SESC_ADDR(n) (NB85E_TIMER_C_BASE_ADDR + 0x9 + 0x10 *(n)) #define V850E_TIMER_C_SESC_ADDR(n) (V850E_TIMER_C_BASE_ADDR + 0x9 + 0x10 *(n))
#define NB85E_TIMER_C_SESC(n) (*(volatile u8 *)NB85E_TIMER_C_SESC_ADDR(n)) #define V850E_TIMER_C_SESC(n) (*(volatile u8 *)V850E_TIMER_C_SESC_ADDR(n))
/* ...etc... */ /* ...etc... */
#endif /* __V850_NB85E_TIMER_C_H__ */ #endif /* __V850_V850E_TIMER_C_H__ */
/* /*
* include/asm-v850/nb85e_timer_d.h -- `Timer D' component often used * include/asm-v850/v850e_timer_d.h -- `Timer D' component often used
* with the NB85E cpu core * with the V850E cpu core
* *
* Copyright (C) 2001,02,03 NEC Electronics Corporation * Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org> * Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
...@@ -12,8 +12,8 @@ ...@@ -12,8 +12,8 @@
* Written by Miles Bader <miles@gnu.org> * Written by Miles Bader <miles@gnu.org>
*/ */
#ifndef __V850_NB85E_TIMER_D_H__ #ifndef __V850_V850E_TIMER_D_H__
#define __V850_NB85E_TIMER_D_H__ #define __V850_V850E_TIMER_D_H__
#include <asm/types.h> #include <asm/types.h>
#include <asm/machdep.h> /* Pick up chip-specific defs. */ #include <asm/machdep.h> /* Pick up chip-specific defs. */
...@@ -22,31 +22,31 @@ ...@@ -22,31 +22,31 @@
/* Timer D (16-bit interval timers). */ /* Timer D (16-bit interval timers). */
/* Count registers for timer D. */ /* Count registers for timer D. */
#define NB85E_TIMER_D_TMD_ADDR(n) (NB85E_TIMER_D_TMD_BASE_ADDR + 0x10 * (n)) #define V850E_TIMER_D_TMD_ADDR(n) (V850E_TIMER_D_TMD_BASE_ADDR + 0x10 * (n))
#define NB85E_TIMER_D_TMD(n) (*(volatile u16 *)NB85E_TIMER_D_TMD_ADDR(n)) #define V850E_TIMER_D_TMD(n) (*(volatile u16 *)V850E_TIMER_D_TMD_ADDR(n))
/* Count compare registers for timer D. */ /* Count compare registers for timer D. */
#define NB85E_TIMER_D_CMD_ADDR(n) (NB85E_TIMER_D_CMD_BASE_ADDR + 0x10 * (n)) #define V850E_TIMER_D_CMD_ADDR(n) (V850E_TIMER_D_CMD_BASE_ADDR + 0x10 * (n))
#define NB85E_TIMER_D_CMD(n) (*(volatile u16 *)NB85E_TIMER_D_CMD_ADDR(n)) #define V850E_TIMER_D_CMD(n) (*(volatile u16 *)V850E_TIMER_D_CMD_ADDR(n))
/* Control registers for timer D. */ /* Control registers for timer D. */
#define NB85E_TIMER_D_TMCD_ADDR(n) (NB85E_TIMER_D_TMCD_BASE_ADDR + 0x10 * (n)) #define V850E_TIMER_D_TMCD_ADDR(n) (V850E_TIMER_D_TMCD_BASE_ADDR + 0x10 * (n))
#define NB85E_TIMER_D_TMCD(n) (*(volatile u8 *)NB85E_TIMER_D_TMCD_ADDR(n)) #define V850E_TIMER_D_TMCD(n) (*(volatile u8 *)V850E_TIMER_D_TMCD_ADDR(n))
/* Control bits for timer D. */ /* Control bits for timer D. */
#define NB85E_TIMER_D_TMCD_CE 0x2 /* count enable */ #define V850E_TIMER_D_TMCD_CE 0x2 /* count enable */
#define NB85E_TIMER_D_TMCD_CAE 0x1 /* clock action enable */ #define V850E_TIMER_D_TMCD_CAE 0x1 /* clock action enable */
/* Clock divider setting (log2). */ /* Clock divider setting (log2). */
#define NB85E_TIMER_D_TMCD_CS(divlog2) (((divlog2) - NB85E_TIMER_D_TMCD_CS_MIN) << 4) #define V850E_TIMER_D_TMCD_CS(divlog2) (((divlog2) - V850E_TIMER_D_TMCD_CS_MIN) << 4)
/* Minimum clock divider setting (log2). */ /* Minimum clock divider setting (log2). */
#ifndef NB85E_TIMER_D_TMCD_CS_MIN /* Can be overridden by mach-specific hdrs */ #ifndef V850E_TIMER_D_TMCD_CS_MIN /* Can be overridden by mach-specific hdrs */
#define NB85E_TIMER_D_TMCD_CS_MIN 2 /* Default is correct for the v850e/ma1 */ #define V850E_TIMER_D_TMCD_CS_MIN 2 /* Default is correct for the v850e/ma1 */
#endif #endif
/* Maximum clock divider setting (log2). */ /* Maximum clock divider setting (log2). */
#define NB85E_TIMER_D_TMCD_CS_MAX (NB85E_TIMER_D_TMCD_CS_MIN + 7) #define V850E_TIMER_D_TMCD_CS_MAX (V850E_TIMER_D_TMCD_CS_MIN + 7)
/* Return the clock-divider (log2) of timer D unit N. */ /* Return the clock-divider (log2) of timer D unit N. */
#define NB85E_TIMER_D_DIVLOG2(n) \ #define V850E_TIMER_D_DIVLOG2(n) \
(((NB85E_TIMER_D_TMCD(n) >> 4) & 0x7) + NB85E_TIMER_D_TMCD_CS_MIN) (((V850E_TIMER_D_TMCD(n) >> 4) & 0x7) + V850E_TIMER_D_TMCD_CS_MIN)
#ifndef __ASSEMBLY__ #ifndef __ASSEMBLY__
...@@ -54,9 +54,9 @@ ...@@ -54,9 +54,9 @@
/* Start interval timer TIMER (0-3). The timer will issue the /* Start interval timer TIMER (0-3). The timer will issue the
corresponding INTCMD interrupt RATE times per second. This function corresponding INTCMD interrupt RATE times per second. This function
does not enable the interrupt. */ does not enable the interrupt. */
extern void nb85e_timer_d_configure (unsigned timer, unsigned rate); extern void v850e_timer_d_configure (unsigned timer, unsigned rate);
#endif /* !__ASSEMBLY__ */ #endif /* !__ASSEMBLY__ */
#endif /* __V850_NB85E_TIMER_D_H__ */ #endif /* __V850_V850E_TIMER_D_H__ */
/*
* include/asm-v850/v850e_uart.h -- common V850E on-chip UART driver
*
* Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
*
* This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this
* archive for more details.
*
* Written by Miles Bader <miles@gnu.org>
*/
/* There's not actually a single UART implementation used by V850E CPUs,
but rather a series of implementations that are all `close' to one
another. This file corresponds to the single driver which handles all
of them. */
#ifndef __V850_V850E_UART_H__
#define __V850_V850E_UART_H__
#include <linux/config.h>
#include <linux/termios.h>
#include <asm/v850e_utils.h>
#include <asm/types.h>
#include <asm/machdep.h> /* Pick up chip-specific defs. */
/* Include model-specific definitions. */
#ifdef CONFIG_V850E_UART
# ifdef CONFIG_V850E_UARTB
# include <asm-v850/v850e_uartb.h>
# else
# include <asm-v850/v850e_uarta.h> /* original V850E UART */
# endif
#endif
/* Optional capabilities some hardware provides. */
/* This UART doesn't implement RTS/CTS by default, but some platforms
implement them externally, so check to see if <asm/machdep.h> defined
anything. */
#ifdef V850E_UART_CTS
#define v850e_uart_cts(n) V850E_UART_CTS(n)
#else
#define v850e_uart_cts(n) (1)
#endif
/* Do the same for RTS. */
#ifdef V850E_UART_SET_RTS
#define v850e_uart_set_rts(n,v) V850E_UART_SET_RTS(n,v)
#else
#define v850e_uart_set_rts(n,v) ((void)0)
#endif
/* This is the serial channel to use for the boot console (if desired). */
#ifndef V850E_UART_CONSOLE_CHANNEL
# define V850E_UART_CONSOLE_CHANNEL 0
#endif
#ifndef __ASSEMBLY__
/* Setup a console using channel 0 of the builtin uart. */
extern void v850e_uart_cons_init (unsigned chan);
/* Configure and turn on uart channel CHAN, using the termios `control
modes' bits in CFLAGS, and a baud-rate of BAUD. */
void v850e_uart_configure (unsigned chan, unsigned cflags, unsigned baud);
#endif /* !__ASSEMBLY__ */
#endif /* __V850_V850E_UART_H__ */
/*
* include/asm-v850/v850e_uarta.h -- original V850E on-chip UART
*
* Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
*
* This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this
* archive for more details.
*
* Written by Miles Bader <miles@gnu.org>
*/
/* This is the original V850E UART implementation is called just `UART' in
the docs, but we name this header file <asm/v850e_uarta.h> because the
name <asm/v850e_uart.h> is used for the common driver that handles both
`UART' and `UARTB' implementations. */
#ifndef __V850_V850E_UARTA_H__
#define __V850_V850E_UARTA_H__
/* Raw hardware interface. */
/* The base address of the UART control registers for channel N.
The default is the address used on the V850E/MA1. */
#ifndef V850E_UART_BASE_ADDR
#define V850E_UART_BASE_ADDR(n) (0xFFFFFA00 + 0x10 * (n))
#endif
/* Addresses of specific UART control registers for channel N.
The defaults are the addresses used on the V850E/MA1; if a platform
wants to redefine any of these, it must redefine them all. */
#ifndef V850E_UART_ASIM_ADDR
#define V850E_UART_ASIM_ADDR(n) (V850E_UART_BASE_ADDR(n) + 0x0)
#define V850E_UART_RXB_ADDR(n) (V850E_UART_BASE_ADDR(n) + 0x2)
#define V850E_UART_ASIS_ADDR(n) (V850E_UART_BASE_ADDR(n) + 0x3)
#define V850E_UART_TXB_ADDR(n) (V850E_UART_BASE_ADDR(n) + 0x4)
#define V850E_UART_ASIF_ADDR(n) (V850E_UART_BASE_ADDR(n) + 0x5)
#define V850E_UART_CKSR_ADDR(n) (V850E_UART_BASE_ADDR(n) + 0x6)
#define V850E_UART_BRGC_ADDR(n) (V850E_UART_BASE_ADDR(n) + 0x7)
#endif
/* UART config registers. */
#define V850E_UART_ASIM(n) (*(volatile u8 *)V850E_UART_ASIM_ADDR(n))
/* Control bits for config registers. */
#define V850E_UART_ASIM_CAE 0x80 /* clock enable */
#define V850E_UART_ASIM_TXE 0x40 /* transmit enable */
#define V850E_UART_ASIM_RXE 0x20 /* receive enable */
#define V850E_UART_ASIM_PS_MASK 0x18 /* mask covering parity-select bits */
#define V850E_UART_ASIM_PS_NONE 0x00 /* no parity */
#define V850E_UART_ASIM_PS_ZERO 0x08 /* zero parity */
#define V850E_UART_ASIM_PS_ODD 0x10 /* odd parity */
#define V850E_UART_ASIM_PS_EVEN 0x18 /* even parity */
#define V850E_UART_ASIM_CL_8 0x04 /* char len is 8 bits (otherwise, 7) */
#define V850E_UART_ASIM_SL_2 0x02 /* 2 stop bits (otherwise, 1) */
#define V850E_UART_ASIM_ISRM 0x01 /* generate INTSR interrupt on errors
(otherwise, generate INTSER) */
/* UART serial interface status registers. */
#define V850E_UART_ASIS(n) (*(volatile u8 *)V850E_UART_ASIS_ADDR(n))
/* Control bits for status registers. */
#define V850E_UART_ASIS_PE 0x04 /* parity error */
#define V850E_UART_ASIS_FE 0x02 /* framing error */
#define V850E_UART_ASIS_OVE 0x01 /* overrun error */
/* UART serial interface transmission status registers. */
#define V850E_UART_ASIF(n) (*(volatile u8 *)V850E_UART_ASIF_ADDR(n))
#define V850E_UART_ASIF_TXBF 0x02 /* transmit buffer flag (data in TXB) */
#define V850E_UART_ASIF_TXSF 0x01 /* transmit shift flag (sending data) */
/* UART receive buffer register. */
#define V850E_UART_RXB(n) (*(volatile u8 *)V850E_UART_RXB_ADDR(n))
/* UART transmit buffer register. */
#define V850E_UART_TXB(n) (*(volatile u8 *)V850E_UART_TXB_ADDR(n))
/* UART baud-rate generator control registers. */
#define V850E_UART_CKSR(n) (*(volatile u8 *)V850E_UART_CKSR_ADDR(n))
#define V850E_UART_CKSR_MAX 11
#define V850E_UART_BRGC(n) (*(volatile u8 *)V850E_UART_BRGC_ADDR(n))
#define V850E_UART_BRGC_MIN 8
#ifndef V850E_UART_CKSR_MAX_FREQ
#define V850E_UART_CKSR_MAX_FREQ (25*1000*1000)
#endif
/* Calculate the minimum value for CKSR on this processor. */
static inline unsigned v850e_uart_cksr_min (void)
{
int min = 0;
unsigned freq = V850E_UART_BASE_FREQ;
while (freq > V850E_UART_CKSR_MAX_FREQ) {
freq >>= 1;
min++;
}
return min;
}
/* Slightly abstract interface used by driver. */
/* Interrupts used by the UART. */
/* Received when the most recently transmitted character has been sent. */
#define V850E_UART_TX_IRQ(chan) IRQ_INTST (chan)
/* Received when a new character has been received. */
#define V850E_UART_RX_IRQ(chan) IRQ_INTSR (chan)
/* UART clock generator interface. */
/* This type encapsulates a particular uart frequency. */
typedef struct {
unsigned clk_divlog2;
unsigned brgen_count;
} v850e_uart_speed_t;
/* Calculate a uart speed from BAUD for this uart. */
static inline v850e_uart_speed_t v850e_uart_calc_speed (unsigned baud)
{
v850e_uart_speed_t speed;
/* Calculate the log2 clock divider and baud-rate counter values
(note that the UART divides the resulting clock by 2, so
multiply BAUD by 2 here to compensate). */
calc_counter_params (V850E_UART_BASE_FREQ, baud * 2,
v850e_uart_cksr_min(),
V850E_UART_CKSR_MAX, 8/*bits*/,
&speed.clk_divlog2, &speed.brgen_count);
return speed;
}
/* Return the current speed of uart channel CHAN. */
static inline v850e_uart_speed_t v850e_uart_speed (unsigned chan)
{
v850e_uart_speed_t speed;
speed.clk_divlog2 = V850E_UART_CKSR (chan);
speed.brgen_count = V850E_UART_BRGC (chan);
return speed;
}
/* Set the current speed of uart channel CHAN. */
static inline void v850e_uart_set_speed(unsigned chan,v850e_uart_speed_t speed)
{
V850E_UART_CKSR (chan) = speed.clk_divlog2;
V850E_UART_BRGC (chan) = speed.brgen_count;
}
static inline int
v850e_uart_speed_eq (v850e_uart_speed_t speed1, v850e_uart_speed_t speed2)
{
return speed1.clk_divlog2 == speed2.clk_divlog2
&& speed1.brgen_count == speed2.brgen_count;
}
/* Minimum baud rate possible. */
#define v850e_uart_min_baud() \
((V850E_UART_BASE_FREQ >> V850E_UART_CKSR_MAX) / (2 * 255) + 1)
/* Maximum baud rate possible. The error is quite high at max, though. */
#define v850e_uart_max_baud() \
((V850E_UART_BASE_FREQ >> v850e_uart_cksr_min()) / (2 *V850E_UART_BRGC_MIN))
/* The `maximum' clock rate the uart can used, which is wanted (though not
really used in any useful way) by the serial framework. */
#define v850e_uart_max_clock() \
((V850E_UART_BASE_FREQ >> v850e_uart_cksr_min()) / 2)
/* UART configuration interface. */
/* Type of the uart config register; must be a scalar. */
typedef u16 v850e_uart_config_t;
/* The uart hardware config register for channel CHAN. */
#define V850E_UART_CONFIG(chan) V850E_UART_ASIM (chan)
/* This config bit set if the uart is enabled. */
#define V850E_UART_CONFIG_ENABLED V850E_UART_ASIM_CAE
/* If the uart _isn't_ enabled, store this value to it to do so. */
#define V850E_UART_CONFIG_INIT V850E_UART_ASIM_CAE
/* Store this config value to disable the uart channel completely. */
#define V850E_UART_CONFIG_FINI 0
/* Setting/clearing these bits enable/disable TX/RX, respectively (but
otherwise generally leave things running). */
#define V850E_UART_CONFIG_RX_ENABLE V850E_UART_ASIM_RXE
#define V850E_UART_CONFIG_TX_ENABLE V850E_UART_ASIM_TXE
/* These masks define which config bits affect TX/RX modes, respectively. */
#define V850E_UART_CONFIG_RX_BITS \
(V850E_UART_ASIM_PS_MASK | V850E_UART_ASIM_CL_8 | V850E_UART_ASIM_ISRM)
#define V850E_UART_CONFIG_TX_BITS \
(V850E_UART_ASIM_PS_MASK | V850E_UART_ASIM_CL_8 | V850E_UART_ASIM_SL_2)
static inline v850e_uart_config_t v850e_uart_calc_config (unsigned cflags)
{
v850e_uart_config_t config = 0;
/* Figure out new configuration of control register. */
if (cflags & CSTOPB)
/* Number of stop bits, 1 or 2. */
config |= V850E_UART_ASIM_SL_2;
if ((cflags & CSIZE) == CS8)
/* Number of data bits, 7 or 8. */
config |= V850E_UART_ASIM_CL_8;
if (! (cflags & PARENB))
/* No parity check/generation. */
config |= V850E_UART_ASIM_PS_NONE;
else if (cflags & PARODD)
/* Odd parity check/generation. */
config |= V850E_UART_ASIM_PS_ODD;
else
/* Even parity check/generation. */
config |= V850E_UART_ASIM_PS_EVEN;
if (cflags & CREAD)
/* Reading enabled. */
config |= V850E_UART_ASIM_RXE;
config |= V850E_UART_ASIM_CAE;
config |= V850E_UART_ASIM_TXE; /* Writing is always enabled. */
config |= V850E_UART_ASIM_ISRM; /* Errors generate a read-irq. */
return config;
}
/* This should delay as long as necessary for a recently written config
setting to settle, before we turn the uart back on. */
static inline void
v850e_uart_config_delay (v850e_uart_config_t config, v850e_uart_speed_t speed)
{
/* The UART may not be reset properly unless we wait at least 2
`basic-clocks' until turning on the TXE/RXE bits again.
A `basic clock' is the clock used by the baud-rate generator,
i.e., the cpu clock divided by the 2^new_clk_divlog2.
The loop takes 2 insns, so loop CYCLES / 2 times. */
register unsigned count = 1 << speed.clk_divlog2;
while (--count != 0)
/* nothing */;
}
/* RX/TX interface. */
/* Return true if all characters awaiting transmission on uart channel N
have been transmitted. */
#define v850e_uart_xmit_done(n) \
(! (V850E_UART_ASIF(n) & V850E_UART_ASIF_TXBF))
/* Wait for this to be true. */
#define v850e_uart_wait_for_xmit_done(n) \
do { } while (! v850e_uart_xmit_done (n))
/* Return true if uart channel N is ready to transmit a character. */
#define v850e_uart_xmit_ok(n) \
(v850e_uart_xmit_done(n) && v850e_uart_cts(n))
/* Wait for this to be true. */
#define v850e_uart_wait_for_xmit_ok(n) \
do { } while (! v850e_uart_xmit_ok (n))
/* Write character CH to uart channel CHAN. */
#define v850e_uart_putc(chan, ch) (V850E_UART_TXB(chan) = (ch))
/* Return latest character read on channel CHAN. */
#define v850e_uart_getc(chan) V850E_UART_RXB (chan)
/* Return bit-mask of uart error status. */
#define v850e_uart_err(chan) V850E_UART_ASIS (chan)
/* Various error bits set in the error result. */
#define V850E_UART_ERR_OVERRUN V850E_UART_ASIS_OVE
#define V850E_UART_ERR_FRAME V850E_UART_ASIS_FE
#define V850E_UART_ERR_PARITY V850E_UART_ASIS_PE
#endif /* __V850_V850E_UARTA_H__ */
/*
* include/asm-v850/v850e_uartb.h -- V850E on-chip `UARTB' UART
*
* Copyright (C) 2001,02,03 NEC Electronics Corporation
* Copyright (C) 2001,02,03 Miles Bader <miles@gnu.org>
*
* This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this
* archive for more details.
*
* Written by Miles Bader <miles@gnu.org>
*/
/* The V850E UARTB is basically a superset of the original V850E UART, but
even where it's the same, the names and details have changed a bit.
It's similar enough to use the same driver (v850e_uart.c), but the
details have been abstracted slightly to do so. */
#ifndef __V850_V850E_UARTB_H__
#define __V850_V850E_UARTB_H__
/* Raw hardware interface. */
#define V850E_UARTB_BASE_ADDR(n) (0xFFFFFA00 + 0x10 * (n))
/* Addresses of specific UART control registers for channel N. */
#define V850E_UARTB_CTL0_ADDR(n) (V850E_UARTB_BASE_ADDR(n) + 0x0)
#define V850E_UARTB_CTL2_ADDR(n) (V850E_UARTB_BASE_ADDR(n) + 0x2)
#define V850E_UARTB_STR_ADDR(n) (V850E_UARTB_BASE_ADDR(n) + 0x4)
#define V850E_UARTB_RX_ADDR(n) (V850E_UARTB_BASE_ADDR(n) + 0x6)
#define V850E_UARTB_RXAP_ADDR(n) (V850E_UARTB_BASE_ADDR(n) + 0x6)
#define V850E_UARTB_TX_ADDR(n) (V850E_UARTB_BASE_ADDR(n) + 0x8)
#define V850E_UARTB_FIC0_ADDR(n) (V850E_UARTB_BASE_ADDR(n) + 0xA)
#define V850E_UARTB_FIC1_ADDR(n) (V850E_UARTB_BASE_ADDR(n) + 0xB)
#define V850E_UARTB_FIC2_ADDR(n) (V850E_UARTB_BASE_ADDR(n) + 0xC)
#define V850E_UARTB_FIS0_ADDR(n) (V850E_UARTB_BASE_ADDR(n) + 0xE)
#define V850E_UARTB_FIS1_ADDR(n) (V850E_UARTB_BASE_ADDR(n) + 0xF)
/* UARTB control register 0 (general config). */
#define V850E_UARTB_CTL0(n) (*(volatile u8 *)V850E_UARTB_CTL0_ADDR(n))
/* Control bits for config registers. */
#define V850E_UARTB_CTL0_PWR 0x80 /* clock enable */
#define V850E_UARTB_CTL0_TXE 0x40 /* transmit enable */
#define V850E_UARTB_CTL0_RXE 0x20 /* receive enable */
#define V850E_UARTB_CTL0_DIR 0x10 /* */
#define V850E_UARTB_CTL0_PS1 0x08 /* parity */
#define V850E_UARTB_CTL0_PS0 0x04 /* parity */
#define V850E_UARTB_CTL0_CL 0x02 /* char len 1:8bit, 0:7bit */
#define V850E_UARTB_CTL0_SL 0x01 /* stop bit 1:2bit, 0:1bit */
#define V850E_UARTB_CTL0_PS_MASK 0x0C /* mask covering parity bits */
#define V850E_UARTB_CTL0_PS_NONE 0x00 /* no parity */
#define V850E_UARTB_CTL0_PS_ZERO 0x04 /* zero parity */
#define V850E_UARTB_CTL0_PS_ODD 0x08 /* odd parity */
#define V850E_UARTB_CTL0_PS_EVEN 0x0C /* even parity */
#define V850E_UARTB_CTL0_CL_8 0x02 /* char len 1:8bit, 0:7bit */
#define V850E_UARTB_CTL0_SL_2 0x01 /* stop bit 1:2bit, 0:1bit */
/* UARTB control register 2 (clock divider). */
#define V850E_UARTB_CTL2(n) (*(volatile u16 *)V850E_UARTB_CTL2_ADDR(n))
#define V850E_UARTB_CTL2_MIN 4
#define V850E_UARTB_CTL2_MAX 0xFFFF
/* UARTB serial interface status register. */
#define V850E_UARTB_STR(n) (*(volatile u8 *)V850E_UARTB_STR_ADDR(n))
/* Control bits for status registers. */
#define V850E_UARTB_STR_TSF 0x80 /* UBTX or FIFO exist data */
#define V850E_UARTB_STR_OVF 0x08 /* overflow error */
#define V850E_UARTB_STR_PE 0x04 /* parity error */
#define V850E_UARTB_STR_FE 0x02 /* framing error */
#define V850E_UARTB_STR_OVE 0x01 /* overrun error */
/* UARTB receive data register. */
#define V850E_UARTB_RX(n) (*(volatile u8 *)V850E_UARTB_RX_ADDR(n))
#define V850E_UARTB_RXAP(n) (*(volatile u16 *)V850E_UARTB_RXAP_ADDR(n))
/* Control bits for status registers. */
#define V850E_UARTB_RXAP_PEF 0x0200 /* parity error */
#define V850E_UARTB_RXAP_FEF 0x0100 /* framing error */
/* UARTB transmit data register. */
#define V850E_UARTB_TX(n) (*(volatile u8 *)V850E_UARTB_TX_ADDR(n))
/* UARTB FIFO control register 0. */
#define V850E_UARTB_FIC0(n) (*(volatile u8 *)V850E_UARTB_FIC0_ADDR(n))
/* UARTB FIFO control register 1. */
#define V850E_UARTB_FIC1(n) (*(volatile u8 *)V850E_UARTB_FIC1_ADDR(n))
/* UARTB FIFO control register 2. */
#define V850E_UARTB_FIC2(n) (*(volatile u16 *)V850E_UARTB_FIC2_ADDR(n))
/* UARTB FIFO status register 0. */
#define V850E_UARTB_FIS0(n) (*(volatile u8 *)V850E_UARTB_FIS0_ADDR(n))
/* UARTB FIFO status register 1. */
#define V850E_UARTB_FIS1(n) (*(volatile u8 *)V850E_UARTB_FIS1_ADDR(n))
/* Slightly abstract interface used by driver. */
/* Interrupts used by the UART. */
/* Received when the most recently transmitted character has been sent. */
#define V850E_UART_TX_IRQ(chan) IRQ_INTUBTIT (chan)
/* Received when a new character has been received. */
#define V850E_UART_RX_IRQ(chan) IRQ_INTUBTIR (chan)
/* Use by serial driver for information purposes. */
#define V850E_UART_BASE_ADDR(chan) V850E_UARTB_BASE_ADDR(chan)
/* UART clock generator interface. */
/* This type encapsulates a particular uart frequency. */
typedef u16 v850e_uart_speed_t;
/* Calculate a uart speed from BAUD for this uart. */
static inline v850e_uart_speed_t v850e_uart_calc_speed (unsigned baud)
{
v850e_uart_speed_t speed;
/*
* V850E/ME2 UARTB baud rate is determined by the value of UBCTL2
* fx = V850E_UARTB_BASE_FREQ = CPU_CLOCK_FREQ/4
* baud = fx / 2*speed [ speed >= 4 ]
*/
speed = V850E_UARTB_CTL2_MIN;
while (((V850E_UARTB_BASE_FREQ / 2) / speed ) > baud)
speed++;
return speed;
}
/* Return the current speed of uart channel CHAN. */
#define v850e_uart_speed(chan) V850E_UARTB_CTL2 (chan)
/* Set the current speed of uart channel CHAN. */
#define v850e_uart_set_speed(chan, speed) (V850E_UARTB_CTL2 (chan) = (speed))
/* Return true if SPEED1 and SPEED2 are the same. */
#define v850e_uart_speed_eq(speed1, speed2) ((speed1) == (speed2))
/* Minimum baud rate possible. */
#define v850e_uart_min_baud() \
((V850E_UARTB_BASE_FREQ / 2) / V850E_UARTB_CTL2_MAX)
/* Maximum baud rate possible. The error is quite high at max, though. */
#define v850e_uart_max_baud() \
((V850E_UARTB_BASE_FREQ / 2) / V850E_UARTB_CTL2_MIN)
/* The `maximum' clock rate the uart can used, which is wanted (though not
really used in any useful way) by the serial framework. */
#define v850e_uart_max_clock() \
(V850E_UARTB_BASE_FREQ / 2)
/* UART configuration interface. */
/* Type of the uart config register; must be a scalar. */
typedef u16 v850e_uart_config_t;
/* The uart hardware config register for channel CHAN. */
#define V850E_UART_CONFIG(chan) V850E_UARTB_CTL0 (chan)
/* This config bit set if the uart is enabled. */
#define V850E_UART_CONFIG_ENABLED V850E_UARTB_CTL0_PWR
/* If the uart _isn't_ enabled, store this value to it to do so. */
#define V850E_UART_CONFIG_INIT V850E_UARTB_CTL0_PWR
/* Store this config value to disable the uart channel completely. */
#define V850E_UART_CONFIG_FINI 0
/* Setting/clearing these bits enable/disable TX/RX, respectively (but
otherwise generally leave things running). */
#define V850E_UART_CONFIG_RX_ENABLE V850E_UARTB_CTL0_RXE
#define V850E_UART_CONFIG_TX_ENABLE V850E_UARTB_CTL0_TXE
/* These masks define which config bits affect TX/RX modes, respectively. */
#define V850E_UART_CONFIG_RX_BITS \
(V850E_UARTB_CTL0_PS_MASK | V850E_UARTB_CTL0_CL_8)
#define V850E_UART_CONFIG_TX_BITS \
(V850E_UARTB_CTL0_PS_MASK | V850E_UARTB_CTL0_CL_8 | V850E_UARTB_CTL0_SL_2)
static inline v850e_uart_config_t v850e_uart_calc_config (unsigned cflags)
{
v850e_uart_config_t config = 0;
/* Figure out new configuration of control register. */
if (cflags & CSTOPB)
/* Number of stop bits, 1 or 2. */
config |= V850E_UARTB_CTL0_SL_2;
if ((cflags & CSIZE) == CS8)
/* Number of data bits, 7 or 8. */
config |= V850E_UARTB_CTL0_CL_8;
if (! (cflags & PARENB))
/* No parity check/generation. */
config |= V850E_UARTB_CTL0_PS_NONE;
else if (cflags & PARODD)
/* Odd parity check/generation. */
config |= V850E_UARTB_CTL0_PS_ODD;
else
/* Even parity check/generation. */
config |= V850E_UARTB_CTL0_PS_EVEN;
if (cflags & CREAD)
/* Reading enabled. */
config |= V850E_UARTB_CTL0_RXE;
config |= V850E_UARTB_CTL0_PWR;
config |= V850E_UARTB_CTL0_TXE; /* Writing is always enabled. */
config |= V850E_UARTB_CTL0_DIR; /* LSB first. */
return config;
}
/* This should delay as long as necessary for a recently written config
setting to settle, before we turn the uart back on. */
static inline void
v850e_uart_config_delay (v850e_uart_config_t config, v850e_uart_speed_t speed)
{
/* The UART may not be reset properly unless we wait at least 2
`basic-clocks' until turning on the TXE/RXE bits again.
A `basic clock' is the clock used by the baud-rate generator,
i.e., the cpu clock divided by the 2^new_clk_divlog2.
The loop takes 2 insns, so loop CYCLES / 2 times. */
register unsigned count = 1 << speed;
while (--count != 0)
/* nothing */;
}
/* RX/TX interface. */
/* Return true if all characters awaiting transmission on uart channel N
have been transmitted. */
#define v850e_uart_xmit_done(n) \
(! (V850E_UARTB_STR(n) & V850E_UARTB_STR_TSF))
/* Wait for this to be true. */
#define v850e_uart_wait_for_xmit_done(n) \
do { } while (! v850e_uart_xmit_done (n))
/* Return true if uart channel N is ready to transmit a character. */
#define v850e_uart_xmit_ok(n) \
(v850e_uart_xmit_done(n) && v850e_uart_cts(n))
/* Wait for this to be true. */
#define v850e_uart_wait_for_xmit_ok(n) \
do { } while (! v850e_uart_xmit_ok (n))
/* Write character CH to uart channel CHAN. */
#define v850e_uart_putc(chan, ch) (V850E_UARTB_TX(chan) = (ch))
/* Return latest character read on channel CHAN. */
#define v850e_uart_getc(chan) V850E_UARTB_RX (chan)
/* Return bit-mask of uart error status. */
#define v850e_uart_err(chan) V850E_UARTB_STR (chan)
/* Various error bits set in the error result. */
#define V850E_UART_ERR_OVERRUN V850E_UARTB_STR_OVE
#define V850E_UART_ERR_FRAME V850E_UARTB_STR_FE
#define V850E_UART_ERR_PARITY V850E_UARTB_STR_PE
#endif /* __V850_V850E_UARTB_H__ */
/* /*
* include/asm-v850/nb85e_utils.h -- Utility functions associated with * include/asm-v850/v850e_utils.h -- Utility functions associated with
* the NB85E cpu core * V850E CPUs
* *
* Copyright (C) 2001 NEC Corporation * Copyright (C) 2001,03 NEC Electronics Corporation
* Copyright (C) 2001 Miles Bader <miles@gnu.org> * Copyright (C) 2001,03 Miles Bader <miles@gnu.org>
* *
* This file is subject to the terms and conditions of the GNU General * This file is subject to the terms and conditions of the GNU General
* Public License. See the file COPYING in the main directory of this * Public License. See the file COPYING in the main directory of this
...@@ -12,8 +12,8 @@ ...@@ -12,8 +12,8 @@
* Written by Miles Bader <miles@gnu.org> * Written by Miles Bader <miles@gnu.org>
*/ */
#ifndef __V850_NB85E_UTILS_H__ #ifndef __V850_V850E_UTILS_H__
#define __V850_NB85E_UTILS_H__ #define __V850_V850E_UTILS_H__
/* Calculate counter clock-divider and count values to attain the /* Calculate counter clock-divider and count values to attain the
desired frequency RATE from the base frequency BASE_FREQ. The desired frequency RATE from the base frequency BASE_FREQ. The
...@@ -32,4 +32,4 @@ extern int calc_counter_params (unsigned long base_freq, ...@@ -32,4 +32,4 @@ extern int calc_counter_params (unsigned long base_freq,
unsigned counter_size, unsigned counter_size,
unsigned *divlog2, unsigned *count); unsigned *divlog2, unsigned *count);
#endif /* __V850_NB85E_UTILS_H__ */ #endif /* __V850_V850E_UTILS_H__ */
...@@ -57,7 +57,7 @@ ...@@ -57,7 +57,7 @@
#define PORT_SUNSAB 39 #define PORT_SUNSAB 39
/* NEC v850. */ /* NEC v850. */
#define PORT_NB85E_UART 40 #define PORT_V850E_UART 40
/* NEC PC-9800 */ /* NEC PC-9800 */
#define PORT_8251_PC98 41 #define PORT_8251_PC98 41
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment