URL
https://opencores.org/ocsvn/hive/hive/trunk
Subversion Repositories hive
[/] [hive/] [trunk/] [v04.05/] [thread_ring.v] - Rev 4
Compare with Previous | Blame | View Log
/* -------------------------------------------------------------------------------- Module : thread_ring.v -------------------------------------------------------------------------------- Function: - Processor thread pipeline. Instantiates: - Nothing. Notes: - 8 stage pipeline. - Counter in stage 0 ensures long-term correct operation. -------------------------------------------------------------------------------- */ module thread_ring #( parameter integer THREADS = 8, // threads parameter integer THRD_W = 3 // thread width ) ( // clocks & resets input wire clk_i, // clock input wire rst_i, // async. reset, active high // threads output wire [THRD_W-1:0] thrd_0_o, output wire [THRD_W-1:0] thrd_1_o, output wire [THRD_W-1:0] thrd_2_o, output wire [THRD_W-1:0] thrd_3_o, output wire [THRD_W-1:0] thrd_4_o, output wire [THRD_W-1:0] thrd_5_o, output wire [THRD_W-1:0] thrd_6_o, output wire [THRD_W-1:0] thrd_7_o ); /* ---------------------- -- internal signals -- ---------------------- */ reg [THRD_W-1:0] thrd[0:THREADS-1]; localparam [THRD_W-1:0] THRD_OS = 'd5; /* ================ == code start == ================ */ // pipeline thread integer j; always @ ( posedge clk_i or posedge rst_i ) begin if ( rst_i ) begin for ( j = 0; j < THREADS; j = j + 1 ) begin thrd[j] <= THRD_OS - j[THRD_W-1:0]; end end else begin for ( j = 0; j < THREADS; j = j + 1 ) begin if ( j == 0 ) thrd[j] <= thrd[j] + 1'b1; // note: counter terminus else thrd[j] <= thrd[j-1]; end end end // output thrd assign thrd_0_o = thrd[0]; assign thrd_1_o = thrd[1]; assign thrd_2_o = thrd[2]; assign thrd_3_o = thrd[3]; assign thrd_4_o = thrd[4]; assign thrd_5_o = thrd[5]; assign thrd_6_o = thrd[6]; assign thrd_7_o = thrd[7]; endmodule