OpenCores
URL https://opencores.org/ocsvn/t400/t400/trunk

Subversion Repositories t400

[/] [t400/] [trunk/] [rtl/] [vhdl/] [t400_core.vhd] - Blame information for rev 49

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 2 arniml
-------------------------------------------------------------------------------
2
--
3
-- T400 Microcontroller Core
4
--
5 49 arniml
-- $Id: t400_core.vhd,v 1.4 2006-05-22 00:03:29 arniml Exp $
6 2 arniml
--
7
-- Copyright (c) 2006 Arnim Laeuger (arniml@opencores.org)
8
--
9
-- All rights reserved
10
--
11
-- Redistribution and use in source and synthezised forms, with or without
12
-- modification, are permitted provided that the following conditions are met:
13
--
14
-- Redistributions of source code must retain the above copyright notice,
15
-- this list of conditions and the following disclaimer.
16
--
17
-- Redistributions in synthesized form must reproduce the above copyright
18
-- notice, this list of conditions and the following disclaimer in the
19
-- documentation and/or other materials provided with the distribution.
20
--
21
-- Neither the name of the author nor the names of other contributors may
22
-- be used to endorse or promote products derived from this software without
23
-- specific prior written permission.
24
--
25
-- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
26
-- AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
27
-- THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
28
-- PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE
29
-- LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
30
-- CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
31
-- SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
32
-- INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
33
-- CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
34
-- ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
35
-- POSSIBILITY OF SUCH DAMAGE.
36
--
37
-- Please report bugs to the author, but before you do so, please
38
-- make sure that this is not a derivative work and that
39
-- you have the latest version of this file.
40
--
41
-- The latest version of this file can be found at:
42
--      http://www.opencores.org/cvsweb.shtml/t400/
43
--
44
-- Limitations :
45
-- =============
46
--
47
-- Compared to the original COP400 architecture, the following limitations
48
-- apply:
49
--
50
--   * Features of the COP42x devices are either not yet implemented or
51
--     not verified.
52
--
53
-------------------------------------------------------------------------------
54
 
55
library ieee;
56
use ieee.std_logic_1164.all;
57
 
58
use work.t400_opt_pack.all;
59
 
60
entity t400_core is
61
 
62
  generic (
63
    opt_type_g           : integer := t400_opt_type_420_c;
64
    opt_ck_div_g         : integer := t400_opt_ck_div_16_c;
65
    opt_cko_g            : integer := t400_opt_cko_crystal_c;
66
    opt_l_out_type_7_g   : integer := t400_opt_out_type_std_c;
67
    opt_l_out_type_6_g   : integer := t400_opt_out_type_std_c;
68
    opt_l_out_type_5_g   : integer := t400_opt_out_type_std_c;
69
    opt_l_out_type_4_g   : integer := t400_opt_out_type_std_c;
70
    opt_l_out_type_3_g   : integer := t400_opt_out_type_std_c;
71
    opt_l_out_type_2_g   : integer := t400_opt_out_type_std_c;
72
    opt_l_out_type_1_g   : integer := t400_opt_out_type_std_c;
73
    opt_l_out_type_0_g   : integer := t400_opt_out_type_std_c;
74
    opt_microbus_g       : integer := t400_opt_no_microbus_c;
75
    opt_d_out_type_3_g   : integer := t400_opt_out_type_std_c;
76
    opt_d_out_type_2_g   : integer := t400_opt_out_type_std_c;
77
    opt_d_out_type_1_g   : integer := t400_opt_out_type_std_c;
78
    opt_d_out_type_0_g   : integer := t400_opt_out_type_std_c;
79
    opt_g_out_type_3_g   : integer := t400_opt_out_type_std_c;
80
    opt_g_out_type_2_g   : integer := t400_opt_out_type_std_c;
81
    opt_g_out_type_1_g   : integer := t400_opt_out_type_std_c;
82
    opt_g_out_type_0_g   : integer := t400_opt_out_type_std_c;
83
    opt_so_output_type_g : integer := t400_opt_out_type_std_c;
84
    opt_sk_output_type_g : integer := t400_opt_out_type_std_c
85
  );
86
  port (
87
    ck_i      : in  std_logic;
88
    ck_en_i   : in  std_logic;
89
    por_n_i   : in  std_logic;
90
    reset_n_i : in  std_logic;
91
    cko_i     : in  std_logic;
92
    pm_addr_o : out std_logic_vector(9 downto 0);
93
    pm_data_i : in  std_logic_vector(7 downto 0);
94
    dm_addr_o : out std_logic_vector(5 downto 0);
95
    dm_we_o   : out std_logic;
96
    dm_data_o : out std_logic_vector(3 downto 0);
97
    dm_data_i : in  std_logic_vector(3 downto 0);
98
    io_l_i    : in  std_logic_vector(7 downto 0);
99
    io_l_o    : out std_logic_vector(7 downto 0);
100
    io_l_en_o : out std_logic_vector(7 downto 0);
101
    io_d_o    : out std_logic_vector(3 downto 0);
102
    io_d_en_o : out std_logic_vector(3 downto 0);
103
    io_g_i    : in  std_logic_vector(3 downto 0);
104
    io_g_o    : out std_logic_vector(3 downto 0);
105
    io_g_en_o : out std_logic_vector(3 downto 0);
106
    io_in_i   : in  std_logic_vector(3 downto 0);
107
    si_i      : in  std_logic;
108
    so_o      : out std_logic;
109
    so_en_o   : out std_logic;
110
    sk_o      : out std_logic;
111
    sk_en_o   : out std_logic
112
  );
113
 
114
end t400_core;
115
 
116
 
117
use work.t400_pack.all;
118
use work.t400_comp_pack.all;
119
 
120
architecture struct of t400_core is
121
 
122
  signal ck_en_s         : boolean;
123
  signal por_s           : boolean;
124
  signal res_s           : boolean;
125
 
126
  signal phi1_s          : std_logic;
127
  signal out_en_s        : boolean;
128
  signal in_en_s         : boolean;
129
  signal icyc_en_s       : boolean;
130
 
131
  signal pm_addr_s       : pc_t;
132
 
133
  signal a_s             : dw_t;
134
  signal dec_data_s      : dec_data_t;
135
 
136
  signal pc_to_stack_s,
137
         pc_from_stack_s : pc_t;
138
 
139
  signal q_s             : byte_t;
140
  signal b_s             : b_t;
141
 
142
  signal c_s,
143
         carry_s         : std_logic;
144
 
145
  signal sio_s           : dw_t;
146
 
147
  signal pc_op_s         : pc_op_t;
148
  signal stack_op_s      : stack_op_t;
149
  signal dmem_op_s       : dmem_op_t;
150
  signal b_op_s          : b_op_t;
151
  signal skip_op_s       : skip_op_t;
152
  signal alu_op_s        : alu_op_t;
153
  signal io_l_op_s       : io_l_op_t;
154
  signal io_d_op_s       : io_d_op_t;
155
  signal io_g_op_s       : io_g_op_t;
156 49 arniml
  signal io_in_op_s      : io_in_op_t;
157 2 arniml
  signal sio_op_s        : sio_op_t;
158
  signal is_lbi_s        : boolean;
159
  signal en_s            : dw_t;
160
 
161
  signal skip_s,
162
         skip_lbi_s      : boolean;
163 37 arniml
  signal tim_c_s         : boolean;
164 2 arniml
 
165 49 arniml
  signal in_s            : dw_t;
166 2 arniml
 
167
  signal vdd_s  : std_logic;
168
  signal gnd4_s : dw_t;
169
 
170
begin
171
 
172
  -- dummies
173
  vdd_s  <= '1';
174
  gnd4_s <= (others => '0');
175
 
176
  ck_en_s <= ck_en_i = '1';
177 49 arniml
  por_s   <= por_n_i = '0';
178 2 arniml
 
179
  -----------------------------------------------------------------------------
180
  -- Clock generator
181
  -----------------------------------------------------------------------------
182
  clkgen_b : t400_clkgen
183
    generic map (
184
      opt_ck_div_g => opt_ck_div_g
185
    )
186
    port map (
187
      ck_i      => ck_i,
188
      ck_en_i   => ck_en_s,
189
      por_i     => por_s,
190
      phi1_o    => phi1_s,
191
      out_en_o  => out_en_s,
192
      in_en_o   => in_en_s,
193
      icyc_en_o => icyc_en_s
194
    );
195
 
196
 
197
  -----------------------------------------------------------------------------
198
  -- Reset module
199
  -----------------------------------------------------------------------------
200
  reset_b : t400_reset
201
    port map (
202
      ck_i      => ck_i,
203
      icyc_en_i => icyc_en_s,
204
      por_i     => por_s,
205
      reset_n_i => reset_n_i,
206
      res_o     => res_s
207
    );
208
 
209
 
210
  -----------------------------------------------------------------------------
211
  -- Program memory controller
212
  -----------------------------------------------------------------------------
213
  pmem_ctrl_b : t400_pmem_ctrl
214
    generic map (
215
      opt_type_g => opt_type_g
216
    )
217
    port map (
218
      ck_i       => ck_i,
219
      ck_en_i    => ck_en_s,
220
      por_i      => por_s,
221
      res_i      => res_s,
222
      a_i        => a_s,
223
      m_i        => dm_data_i,
224
      op_i       => pc_op_s,
225
      dec_data_i => dec_data_s,
226
      pc_o       => pc_to_stack_s,
227
      pc_i       => pc_from_stack_s,
228
      pm_addr_o  => pm_addr_s
229
    );
230
  --
231
  pm_addr_o <= std_logic_vector(pm_addr_s);
232
 
233
 
234
  -----------------------------------------------------------------------------
235
  -- Data memory controller
236
  -----------------------------------------------------------------------------
237
  dmem_ctrl_b : t400_dmem_ctrl
238
    generic map (
239
      opt_type_g => opt_type_g
240
    )
241
    port map (
242
      ck_i       => ck_i,
243
      ck_en_i    => ck_en_s,
244
      por_i      => por_s,
245
      res_i      => res_s,
246
      dmem_op_i  => dmem_op_s,
247
      b_op_i     => b_op_s,
248
      dec_data_i => dec_data_s,
249
      a_i        => a_s,
250
      q_high_i   => q_s(7 downto 4),
251
      b_o        => b_s,
252
      dm_addr_o  => dm_addr_o,
253
      dm_data_i  => dm_data_i,
254
      dm_data_o  => dm_data_o,
255
      dm_we_o    => dm_we_o
256
    );
257
 
258
 
259
  -----------------------------------------------------------------------------
260
  -- Decoder
261
  -----------------------------------------------------------------------------
262
  decoder_b : t400_decoder
263
    generic map (
264
      opt_type_g => opt_type_g
265
    )
266
    port map (
267
      ck_i       => ck_i,
268
      ck_en_i    => ck_en_s,
269
      por_i      => por_s,
270
      res_i      => res_s,
271
      out_en_i   => out_en_s,
272
      in_en_i    => in_en_s,
273
      icyc_en_i  => icyc_en_s,
274
      pc_op_o    => pc_op_s,
275
      stack_op_o => stack_op_s,
276
      dmem_op_o  => dmem_op_s,
277
      b_op_o     => b_op_s,
278
      skip_op_o  => skip_op_s,
279
      alu_op_o   => alu_op_s,
280
      io_l_op_o  => io_l_op_s,
281
      io_d_op_o  => io_d_op_s,
282
      io_g_op_o  => io_g_op_s,
283 49 arniml
      io_in_op_o => io_in_op_s,
284 2 arniml
      sio_op_o   => sio_op_s,
285
      dec_data_o => dec_data_s,
286
      is_lbi_o   => is_lbi_s,
287
      en_o       => en_s,
288
      skip_i     => skip_s,
289
      skip_lbi_i => skip_lbi_s,
290
      pm_addr_i  => pm_addr_s,
291
      pm_data_i  => pm_data_i
292
    );
293
 
294
 
295
  -----------------------------------------------------------------------------
296
  -- Skip logic
297
  -----------------------------------------------------------------------------
298
  skip_b : t400_skip
299
    port map (
300
      ck_i       => ck_i,
301
      ck_en_i    => ck_en_s,
302
      por_i      => por_s,
303
      res_i      => res_s,
304
      op_i       => skip_op_s,
305
      dec_data_i => dec_data_s,
306
      carry_i    => carry_s,
307
      c_i        => c_s,
308
      bd_i       => b_s(bd_range_t),
309
      is_lbi_i   => is_lbi_s,
310
      a_i        => a_s,
311
      m_i        => dm_data_i,
312
      g_i        => io_g_i,
313 37 arniml
      tim_c_i    => tim_c_s,
314 2 arniml
      skip_o     => skip_s,
315
      skip_lbi_o => skip_lbi_s
316
    );
317
 
318
 
319
  -----------------------------------------------------------------------------
320
  -- ALU
321
  -----------------------------------------------------------------------------
322
  alu_b : t400_alu
323 43 arniml
    generic map (
324
      opt_cko_g => opt_cko_g
325
    )
326 2 arniml
    port map (
327
      ck_i       => ck_i,
328
      ck_en_i    => ck_en_s,
329
      por_i      => por_s,
330
      res_i      => res_s,
331 43 arniml
      cko_i      => cko_i,
332 2 arniml
      op_i       => alu_op_s,
333
      m_i        => dm_data_i,
334
      dec_data_i => dec_data_s,
335
      q_low_i    => q_s(3 downto 0),
336
      b_i        => b_s,
337
      g_i        => io_g_i,
338
      in_i       => in_s,
339
      sio_i      => sio_s,
340
      a_o        => a_s,
341
      carry_o    => carry_s,
342
      c_o        => c_s
343
    );
344
 
345
 
346
  -----------------------------------------------------------------------------
347
  -- Stack module
348
  -----------------------------------------------------------------------------
349
  stack_b : t400_stack
350
    generic map (
351
      opt_type_g => opt_type_g
352
    )
353
    port map (
354
      ck_i    => ck_i,
355
      ck_en_i => ck_en_s,
356
      por_i   => por_s,
357
      op_i    => stack_op_s,
358
      pc_i    => pc_to_stack_s,
359
      pc_o    => pc_from_stack_s
360
    );
361
 
362
 
363
  -----------------------------------------------------------------------------
364
  -- IO L module
365
  -----------------------------------------------------------------------------
366
  io_l_b : t400_io_l
367
    generic map (
368
      opt_out_type_7_g => opt_l_out_type_7_g,
369
      opt_out_type_6_g => opt_l_out_type_6_g,
370
      opt_out_type_5_g => opt_l_out_type_5_g,
371
      opt_out_type_4_g => opt_l_out_type_4_g,
372
      opt_out_type_3_g => opt_l_out_type_3_g,
373
      opt_out_type_2_g => opt_l_out_type_2_g,
374
      opt_out_type_1_g => opt_l_out_type_1_g,
375
      opt_out_type_0_g => opt_l_out_type_0_g,
376
      opt_microbus_g   => opt_microbus_g
377
    )
378
    port map (
379
      ck_i      => ck_i,
380
      ck_en_i   => ck_en_s,
381
      por_i     => por_s,
382
      op_i      => io_l_op_s,
383
      en2_i     => en_s(2),
384
      m_i       => dm_data_i,
385
      a_i       => a_s,
386
      pm_data_i => pm_data_i,
387
      q_o       => q_s,
388
      cs_n_i    => vdd_s,
389
      rd_n_i    => vdd_s,
390
      wr_n_i    => vdd_s,
391
      io_l_i    => io_l_i,
392
      io_l_o    => io_l_o,
393
      io_l_en_o => io_l_en_o
394
    );
395
 
396
 
397
  -----------------------------------------------------------------------------
398
  -- IO D module
399
  -----------------------------------------------------------------------------
400
  io_d_b : t400_io_d
401
    generic map (
402
      opt_out_type_3_g => opt_d_out_type_3_g,
403
      opt_out_type_2_g => opt_d_out_type_2_g,
404
      opt_out_type_1_g => opt_d_out_type_1_g,
405
      opt_out_type_0_g => opt_d_out_type_0_g
406
    )
407
    port map (
408
      ck_i      => ck_i,
409
      ck_en_i   => ck_en_s,
410
      por_i     => por_s,
411
      res_i     => res_s,
412
      op_i      => io_d_op_s,
413
      bd_i      => b_s(bd_range_t),
414
      io_d_o    => io_d_o,
415
      io_d_en_o => io_d_en_o
416
    );
417
 
418
 
419
  -----------------------------------------------------------------------------
420 49 arniml
  -- IO G module
421 2 arniml
  -----------------------------------------------------------------------------
422
  io_g_b : t400_io_g
423
    generic map (
424
      opt_out_type_3_g => opt_g_out_type_3_g,
425
      opt_out_type_2_g => opt_g_out_type_2_g,
426
      opt_out_type_1_g => opt_g_out_type_1_g,
427
      opt_out_type_0_g => opt_g_out_type_0_g
428
    )
429
    port map (
430
      ck_i       => ck_i,
431
      ck_en_i    => ck_en_s,
432
      por_i      => por_s,
433
      res_i      => res_s,
434
      op_i       => io_g_op_s,
435
      m_i        => dm_data_i,
436
      dec_data_i => dec_data_s,
437
      io_g_o     => io_g_o,
438
      io_g_en_o  => io_g_en_o
439
    );
440
 
441
 
442
  -----------------------------------------------------------------------------
443 49 arniml
  -- IO IN module
444
  -----------------------------------------------------------------------------
445
  use_in: if opt_type_g = t400_opt_type_420_c generate
446
    io_in_b : t400_io_in
447
      port map (
448
        ck_i    => ck_i,
449
        ck_en_i => ck_en_s,
450
        por_i   => por_s,
451
        in_en_i => in_en_s,
452
        op_i    => io_in_op_s,
453
        en1_i   => en_s(1),
454
        io_in_i => io_in_i,
455
        in_o    => in_s,
456
        int_o   => open
457
      );
458
  end generate;
459
 
460
  no_in: if opt_type_g /= t400_opt_type_420_c generate
461
    in_s <= (others => '0');
462
  end generate;
463
 
464
 
465
  -----------------------------------------------------------------------------
466 2 arniml
  -- SIO module
467
  -----------------------------------------------------------------------------
468
  sio_b : t400_sio
469
    generic map (
470
      opt_so_output_type_g => opt_so_output_type_g,
471
      opt_sk_output_type_g => opt_sk_output_type_g
472
    )
473
    port map (
474
      ck_i       => ck_i,
475
      ck_en_i    => ck_en_s,
476
      por_i      => por_s,
477
      res_i      => res_s,
478
      phi1_i     => phi1_s,
479
      out_en_i   => out_en_s,
480
      in_en_i    => in_en_s,
481
      op_i       => sio_op_s,
482
      en0_i      => en_s(0),
483
      en3_i      => en_s(3),
484
      a_i        => a_s,
485
      c_i        => c_s,
486
      sio_o      => sio_s,
487
      si_i       => si_i,
488
      so_o       => so_o,
489
      so_en_o    => so_en_o,
490
      sk_o       => sk_o,
491
      sk_en_o    => sk_en_o
492
    );
493
 
494 37 arniml
 
495
  -----------------------------------------------------------------------------
496
  -- Timer module
497
  -----------------------------------------------------------------------------
498 49 arniml
  use_tim: if opt_type_g = t400_opt_type_420_c generate
499 37 arniml
    timer_b : t400_timer
500
      port map (
501
        ck_i      => ck_i,
502
        ck_en_i   => ck_en_s,
503
        por_i     => por_s,
504
        icyc_en_i => icyc_en_s,
505
        op_i      => skip_op_s,
506
        c_o       => tim_c_s
507
      );
508
  end generate;
509
 
510
  notim: if opt_type_g /= t400_opt_type_420_c generate
511
    tim_c_s <= false;
512
  end generate;
513
 
514 2 arniml
end struct;
515
 
516
 
517
-------------------------------------------------------------------------------
518
-- File History:
519
--
520
-- $Log: not supported by cvs2svn $
521 49 arniml
-- Revision 1.3  2006/05/21 21:47:40  arniml
522
-- route cko to ALU for INIL instruction
523
--
524 43 arniml
-- Revision 1.2  2006/05/20 02:48:17  arniml
525
-- timer module included
526
--
527 37 arniml
-- Revision 1.1.1.1  2006/05/06 01:56:44  arniml
528
-- import from local CVS repository, LOC_CVS_0_1
529
--
530 2 arniml
-------------------------------------------------------------------------------

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.