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

Subversion Repositories socwire

[/] [socwire/] [trunk/] [Testbench/] [switch_tb.vhd] - Diff between revs 18 and 24

Show entire file | Details | Blame | View Log

Rev 18 Rev 24
Line 7... Line 7...
--== Contact ...... Björn Osterloh (b.osterloh@tu-bs.de)                ==--
--== Contact ...... Björn Osterloh (b.osterloh@tu-bs.de)                ==--
--== Copyright .... Copyright (c) 2008 IDA                              ==--
--== Copyright .... Copyright (c) 2008 IDA                              ==--
--== Project ...... SoCWire Switch Testbench                            ==--
--== Project ...... SoCWire Switch Testbench                            ==--
--== Version ...... 1.00                                                ==--
--== Version ...... 1.00                                                ==--
--== Conception ... 22 April 2009                                       ==--
--== Conception ... 22 April 2009                                       ==--
--== Modified ..... N/A                                                 ==--
--== Modified ..... holgerm : minor bug fix marked with holgerm         ==--
--==                                                                    ==--
--==                                                                    ==--
---======================= End Copyright Notice =========================---
---======================= End Copyright Notice =========================---
 
 
LIBRARY ieee;
LIBRARY ieee;
USE ieee.std_logic_1164.ALL;
USE ieee.std_logic_1164.ALL;
Line 39... Line 39...
 
 
COMPONENT socwire_switch IS
COMPONENT socwire_switch IS
  GENERIC(
  GENERIC(
          datawidth : NATURAL RANGE 8 TO 8192;
          datawidth : NATURAL RANGE 8 TO 8192;
          nports     : NATURAL RANGE 2 TO 32;
          nports     : NATURAL RANGE 2 TO 32;
          speed : NATURAL RANGE  1 TO 100
          speed : NATURAL RANGE  1 TO 100;
 
          -- holgerm
 
               after64              : NATURAL RANGE 1 TO 6400:=6400;   -- Spacewire Standard 6400 = 6.4 us
 
          after128             : NATURAL RANGE 1 TO 12800:=12800; -- Spacewire Standard 12800 = 12.8 us
 
          disconnect_detection : NATURAL RANGE 1 TO 850:=850     -- Spacewire Standard 850 = 850 ns
 
          -- holgerm
         );
         );
  PORT(
  PORT(
       --==  General Interface (Sync Rst, 50MHz Clock) ==--
       --==  General Interface (Sync Rst, 50MHz Clock) ==--
 
 
       rst        : IN  STD_LOGIC;
       rst        : IN  STD_LOGIC;
Line 124... Line 129...
SIGNAL dat_din_P0 : STD_LOGIC_VECTOR (datawidth downto 0);
SIGNAL dat_din_P0 : STD_LOGIC_VECTOR (datawidth downto 0);
SIGNAL dat_din_P1 : STD_LOGIC_VECTOR (datawidth downto 0);
SIGNAL dat_din_P1 : STD_LOGIC_VECTOR (datawidth downto 0);
SIGNAL dat_din_P2 : STD_LOGIC_VECTOR (datawidth downto 0);
SIGNAL dat_din_P2 : STD_LOGIC_VECTOR (datawidth downto 0);
SIGNAL dat_din_P3 : STD_LOGIC_VECTOR (datawidth downto 0);
SIGNAL dat_din_P3 : STD_LOGIC_VECTOR (datawidth downto 0);
 
 
 
-- holgerm
 
-- compile with "vsim -novopt switch_tb" otherwise optimization will delete these signals
 
SIGNAL dat_empty_P0 : STD_LOGIC;
 
SIGNAL dat_empty_P1 : STD_LOGIC;
 
SIGNAL dat_empty_P2 : STD_LOGIC;
 
SIGNAL dat_empty_P3 : STD_LOGIC;
 
SIGNAL dat_dout_P0 : STD_LOGIC_VECTOR (datawidth downto 0);
 
SIGNAL dat_dout_P1 : STD_LOGIC_VECTOR (datawidth downto 0);
 
SIGNAL dat_dout_P2 : STD_LOGIC_VECTOR (datawidth downto 0);
 
SIGNAL dat_dout_P3 : STD_LOGIC_VECTOR (datawidth downto 0);
 
-- holgerm
 
 
BEGIN
BEGIN
 
 
        -- Component Declaration for the Unit Under Test (UUT)
        -- Component Declaration for the Unit Under Test (UUT)
 
 
  U0 : socwire_switch
  U0 : socwire_switch
    GENERIC MAP
    GENERIC MAP
      (
      (
       datawidth =>datawidth,
       datawidth =>datawidth,
       nports    => nports,
       nports    => nports,
       speed      => speed
       speed      => speed,
 
       -- holgerm
 
       after64              =>after64,
 
       after128             =>after128,
 
       disconnect_detection =>disconnect_detection
 
       -- holgerm
      )
      )
    PORT MAP
    PORT MAP
      (--==  General Interface (Sync Rst) ==--
      (--==  General Interface (Sync Rst) ==--
       clk      => clk,
       clk      => clk,
       rst      => rst,
       rst      => rst,
Line 199... Line 219...
        dat_din(8 downto 0)  <=dat_din_P0;
        dat_din(8 downto 0)  <=dat_din_P0;
        dat_din(17 downto 9) <=dat_din_P1;
        dat_din(17 downto 9) <=dat_din_P1;
        dat_din(26 downto 18)<=dat_din_P2;
        dat_din(26 downto 18)<=dat_din_P2;
        dat_din(35 downto 27)<=dat_din_P3;
        dat_din(35 downto 27)<=dat_din_P3;
 
 
 
   -- holgerm
 
   -- compile with "vsim -novopt switch_tb" otherwise optimization will delete these signals
 
   dat_empty_P0 <= dat_empty(0);
 
   dat_empty_P1 <= dat_empty(1);
 
   dat_empty_P2 <= dat_empty(2);
 
   dat_empty_P3 <= dat_empty(3);
 
   dat_dout_P0 <= dat_dout(8  downto  0);
 
   dat_dout_P1 <= dat_dout(17 downto  9);
 
   dat_dout_P2 <= dat_dout(26 downto 18);
 
   dat_dout_P3 <= dat_dout(35 downto 27);
 
   -- holgerm
 
 
 
 
 
 
        tb : PROCESS
        tb : PROCESS
 
 
        BEGIN
        BEGIN
 
 

powered by: WebSVN 2.1.0

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