1 |
32 |
wfjm |
-- $Id: sys_conf.vhd 692 2015-06-21 11:53:24Z mueller $
|
2 |
2 |
wfjm |
--
|
3 |
29 |
wfjm |
-- Copyright 2010-2015 by Walter F.J. Mueller <W.F.J.Mueller@gsi.de>
|
4 |
2 |
wfjm |
--
|
5 |
|
|
-- This program is free software; you may redistribute and/or modify it under
|
6 |
|
|
-- the terms of the GNU General Public License as published by the Free
|
7 |
|
|
-- Software Foundation, either version 2, or at your option any later version.
|
8 |
|
|
--
|
9 |
|
|
-- This program is distributed in the hope that it will be useful, but
|
10 |
|
|
-- WITHOUT ANY WARRANTY, without even the implied warranty of MERCHANTABILITY
|
11 |
|
|
-- or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
12 |
|
|
-- for complete details.
|
13 |
|
|
--
|
14 |
|
|
------------------------------------------------------------------------------
|
15 |
|
|
-- Package Name: sys_conf
|
16 |
|
|
-- Description: Definitions for sys_w11a_n2 (for synthesis)
|
17 |
|
|
--
|
18 |
|
|
-- Dependencies: -
|
19 |
28 |
wfjm |
-- Tool versions: xst 11.4-14.7; ghdl 0.26-0.31
|
20 |
2 |
wfjm |
-- Revision History:
|
21 |
|
|
-- Date Rev Version Comment
|
22 |
32 |
wfjm |
-- 2015-06-21 692 1.4.1 use clksys=52 (no closure after rhrp fixes)
|
23 |
30 |
wfjm |
-- 2015-03-14 658 1.4 add sys_conf_ibd_* definitions
|
24 |
29 |
wfjm |
-- 2015-02-15 647 1.3 drop bram and minisys options
|
25 |
|
|
-- 2015-01-04 630 1.2.2 use clksys=54 (no closure after rlink r4 + RL11)
|
26 |
28 |
wfjm |
-- 2014-12-22 619 1.2.1 add _rbmon_awidth
|
27 |
20 |
wfjm |
-- 2013-04-21 509 1.2 add fx2 settings
|
28 |
13 |
wfjm |
-- 2011-11-19 428 1.1.1 use clksys=56 (58 no closure after numeric_std...)
|
29 |
8 |
wfjm |
-- 2010-11-27 341 1.1 add dcm and memctl related constants (clksys=58)
|
30 |
2 |
wfjm |
-- 2010-05-05 295 1.0 Initial version (derived from _s3 version)
|
31 |
|
|
------------------------------------------------------------------------------
|
32 |
|
|
|
33 |
|
|
library ieee;
|
34 |
|
|
use ieee.std_logic_1164.all;
|
35 |
|
|
|
36 |
|
|
use work.slvtypes.all;
|
37 |
|
|
|
38 |
8 |
wfjm |
-- valid system clock / delay combinations:
|
39 |
|
|
-- div mul clksys read0 read1 write
|
40 |
|
|
-- 1 1 50.0 2 2 3
|
41 |
|
|
-- 25 27 54.0 3 3 3
|
42 |
|
|
-- 25 29 58.0 3 3 4
|
43 |
|
|
|
44 |
2 |
wfjm |
package sys_conf is
|
45 |
|
|
|
46 |
30 |
wfjm |
-- configure clocks --------------------------------------------------------
|
47 |
8 |
wfjm |
constant sys_conf_clkfx_divide : positive := 25;
|
48 |
32 |
wfjm |
constant sys_conf_clkfx_multiply : positive := 26; -- ==> 52 MHz
|
49 |
8 |
wfjm |
|
50 |
30 |
wfjm |
-- configure rlink and hio interfaces --------------------------------------
|
51 |
8 |
wfjm |
constant sys_conf_ser2rri_defbaud : integer := 115200; -- default 115k baud
|
52 |
30 |
wfjm |
constant sys_conf_hio_debounce : boolean := true; -- instantiate debouncers
|
53 |
8 |
wfjm |
|
54 |
20 |
wfjm |
-- fx2 settings: petowidth=10 -> 2^10 30 MHz clocks -> ~33 usec
|
55 |
|
|
constant sys_conf_fx2_petowidth : positive := 10;
|
56 |
|
|
constant sys_conf_fx2_ccwidth : positive := 5;
|
57 |
|
|
|
58 |
30 |
wfjm |
-- configure debug and monitoring units ------------------------------------
|
59 |
|
|
constant sys_conf_rbmon_awidth : integer := 9; -- use 0 to disable rbmon
|
60 |
|
|
constant sys_conf_ibmon_awidth : integer := 9; -- use 0 to disable ibmon
|
61 |
2 |
wfjm |
|
62 |
30 |
wfjm |
-- configure memory controller ---------------------------------------------
|
63 |
|
|
constant sys_conf_memctl_read0delay : positive := 3;
|
64 |
|
|
constant sys_conf_memctl_read1delay : positive := sys_conf_memctl_read0delay;
|
65 |
|
|
constant sys_conf_memctl_writedelay : positive := 4;
|
66 |
|
|
|
67 |
|
|
-- configure w11 cpu core --------------------------------------------------
|
68 |
2 |
wfjm |
constant sys_conf_mem_losize : integer := 8#167777#; -- 4 MByte
|
69 |
|
|
|
70 |
|
|
constant sys_conf_cache_fmiss : slbit := '0'; -- cache enabled
|
71 |
|
|
|
72 |
30 |
wfjm |
-- configure w11 system devices --------------------------------------------
|
73 |
|
|
-- configure character and communication devices
|
74 |
|
|
constant sys_conf_ibd_dl11_1 : boolean := true; -- 2nd DL11
|
75 |
|
|
constant sys_conf_ibd_pc11 : boolean := true; -- PC11
|
76 |
|
|
constant sys_conf_ibd_lp11 : boolean := true; -- LP11
|
77 |
8 |
wfjm |
|
78 |
30 |
wfjm |
-- configure mass storage devices
|
79 |
|
|
constant sys_conf_ibd_rk11 : boolean := true; -- RK11
|
80 |
|
|
constant sys_conf_ibd_rl11 : boolean := true; -- RL11
|
81 |
|
|
constant sys_conf_ibd_rhrp : boolean := true; -- RHRP
|
82 |
31 |
wfjm |
constant sys_conf_ibd_tm11 : boolean := true; -- TM11
|
83 |
30 |
wfjm |
|
84 |
|
|
-- configure other devices
|
85 |
|
|
constant sys_conf_ibd_iist : boolean := true; -- IIST
|
86 |
|
|
|
87 |
|
|
-- derived constants =======================================================
|
88 |
8 |
wfjm |
constant sys_conf_clksys : integer :=
|
89 |
|
|
(50000000/sys_conf_clkfx_divide)*sys_conf_clkfx_multiply;
|
90 |
|
|
constant sys_conf_clksys_mhz : integer := sys_conf_clksys/1000000;
|
91 |
|
|
|
92 |
|
|
constant sys_conf_ser2rri_cdinit : integer :=
|
93 |
|
|
(sys_conf_clksys/sys_conf_ser2rri_defbaud)-1;
|
94 |
|
|
|
95 |
2 |
wfjm |
end package sys_conf;
|