Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame^] | 1 | /* |
| 2 | * include/asm-v850/fpga85e2c.h -- Machine-dependent defs for |
| 3 | * FPGA implementation of V850E2/NA85E2C |
| 4 | * |
| 5 | * Copyright (C) 2002,03 NEC Electronics Corporation |
| 6 | * Copyright (C) 2002,03 Miles Bader <miles@gnu.org> |
| 7 | * |
| 8 | * This file is subject to the terms and conditions of the GNU General |
| 9 | * Public License. See the file COPYING in the main directory of this |
| 10 | * archive for more details. |
| 11 | * |
| 12 | * Written by Miles Bader <miles@gnu.org> |
| 13 | */ |
| 14 | |
| 15 | #ifndef __V850_FPGA85E2C_H__ |
| 16 | #define __V850_FPGA85E2C_H__ |
| 17 | |
| 18 | #include <asm/v850e2.h> |
| 19 | #include <asm/clinkage.h> |
| 20 | |
| 21 | |
| 22 | #define CPU_MODEL "v850e2/fpga85e2c" |
| 23 | #define CPU_MODEL_LONG "NEC V850E2/NA85E2C" |
| 24 | #define PLATFORM "fpga85e2c" |
| 25 | #define PLATFORM_LONG "NA85E2C FPGA implementation" |
| 26 | |
| 27 | |
| 28 | /* `external ram'. */ |
| 29 | #define ERAM_ADDR 0 |
| 30 | #define ERAM_SIZE 0x00100000 /* 1MB */ |
| 31 | |
| 32 | |
| 33 | /* FPGA specific control registers. */ |
| 34 | |
| 35 | /* Writing a non-zero value to FLGREG(0) will signal the controlling CPU |
| 36 | to stop execution. */ |
| 37 | #define FLGREG_ADDR(n) (0xFFE80100 + 2*(n)) |
| 38 | #define FLGREG(n) (*(volatile unsigned char *)FLGREG_ADDR (n)) |
| 39 | #define FLGREG_NUM 2 |
| 40 | |
| 41 | #define CSDEV_ADDR(n) (0xFFE80110 + 2*(n)) |
| 42 | #define CSDEV(n) (*(volatile unsigned char *)CSDEV_ADDR (n)) |
| 43 | |
| 44 | |
| 45 | /* Timer interrupts 0-3, interrupt at intervals from CLK/4096 to CLK/16384. */ |
| 46 | #define IRQ_RPU(n) (60 + (n)) |
| 47 | #define IRQ_RPU_NUM 4 |
| 48 | |
| 49 | /* For <asm/irq.h> */ |
| 50 | #define NUM_CPU_IRQS 64 |
| 51 | |
| 52 | |
| 53 | /* General-purpose timer. */ |
| 54 | /* control/status register (can only be read/written via bit insns) */ |
| 55 | #define RPU_GTMC_ADDR 0xFFFFFB00 |
| 56 | #define RPU_GTMC (*(volatile unsigned char *)RPU_GTMC_ADDR) |
| 57 | #define RPU_GTMC_CE_BIT 7 /* clock enable (control) */ |
| 58 | #define RPU_GTMC_OV_BIT 6 /* overflow (status) */ |
| 59 | #define RPU_GTMC_CLK_BIT 1 /* 0 = .5 MHz CLK, 1 = 1 Mhz (control) */ |
| 60 | /* 32-bit count (8 least-significant bits are always zero). */ |
| 61 | #define RPU_GTM_ADDR 0xFFFFFB28 |
| 62 | #define RPU_GTM (*(volatile unsigned long *)RPU_GTMC_ADDR) |
| 63 | |
| 64 | |
| 65 | /* For <asm/page.h> */ |
| 66 | #define PAGE_OFFSET ERAM_ADDR /* minimum allocatable address */ |
| 67 | |
| 68 | |
| 69 | /* For <asm/entry.h> */ |
| 70 | /* `R0 RAM', used for a few miscellaneous variables that must be accessible |
| 71 | using a load instruction relative to R0. The FPGA implementation |
| 72 | actually has no on-chip RAM, so we use part of main ram just after the |
| 73 | interrupt vectors. */ |
| 74 | #ifdef __ASSEMBLY__ |
| 75 | #define R0_RAM_ADDR lo(C_SYMBOL_NAME(_r0_ram)) |
| 76 | #else |
| 77 | extern char _r0_ram; |
| 78 | #define R0_RAM_ADDR ((unsigned long)&_r0_ram); |
| 79 | #endif |
| 80 | |
| 81 | |
| 82 | /* For <asm/param.h> */ |
| 83 | #ifndef HZ |
| 84 | #define HZ 122 /* actually, 8.192ms ticks =~ 122.07 */ |
| 85 | #endif |
| 86 | |
| 87 | |
| 88 | #endif /* __V850_FPGA85E2C_H__ */ |