From e509e5dcbbd9d875cfffdc8a6dfb915d959f5235 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Joachim=20Stro=CC=88mbergson?= <joachim@secworks.se>
Date: Tue, 23 Jun 2015 10:53:28 +0200
Subject: montprod now supports generic operand size.

---
 src/rtl/montprod.v | 36 ++++++++++++++++++------------------
 1 file changed, 18 insertions(+), 18 deletions(-)

(limited to 'src/rtl')

diff --git a/src/rtl/montprod.v b/src/rtl/montprod.v
index ffee748..c50751b 100644
--- a/src/rtl/montprod.v
+++ b/src/rtl/montprod.v
@@ -233,8 +233,8 @@ module montprod #(parameter OPW = 32, parameter ADW = 8)
         begin
           ready_reg           <= 1'b1;
           loop_ctr_reg        <= 13'h0;
-          word_index_reg      <= 8'h0;
-          word_index_prev_reg <= 8'h0;
+          word_index_reg      <= {ADW{1'b0}};
+          word_index_prev_reg <= {ADW{1'b0}};
           add_carry_in_sa_reg <= 1'b0;
           add_carry_in_sm_reg <= 1'b0;
           shr_carry_in_reg    <= 1'b0;
@@ -242,8 +242,8 @@ module montprod #(parameter OPW = 32, parameter ADW = 8)
           q_reg               <= 1'b0;
           s_mux_reg           <= SMUX_0;
           s_mem_we_reg        <= 1'b0;
-          s_mem_wr_addr_reg   <= 8'h0;
-          b_bit_index_reg     <= 5'h0;
+          s_mem_wr_addr_reg   <= {ADW{1'b0}};
+          b_bit_index_reg     <= {(13 - ADW){1'b0}};
           first_iteration_reg <= 1'b0;
           montprod_ctrl_reg   <= CTRL_IDLE;
         end
@@ -312,11 +312,11 @@ module montprod #(parameter OPW = 32, parameter ADW = 8)
         tmp_result_we = 1'b1;
 
 
-      if (reset_word_index_lsw == 1'b1)
+      if (reset_word_index_lsw)
         word_index_new = length_m1;
 
-      else if (reset_word_index_msw == 1'b1)
-        word_index_new = 8'h0;
+      else if (reset_word_index_msw)
+        word_index_new = {ADW{1'b0}};
 
       else if (montprod_ctrl_reg == CTRL_CALC_SDIV2)
         word_index_new = word_index_reg + 1'b1;
@@ -332,11 +332,11 @@ module montprod #(parameter OPW = 32, parameter ADW = 8)
   always @*
     begin : s_logic
       shr_carry_in_new      = 1'b0;
-      muxed_s_mem_read_data = 32'h0;
-      sa_adder_data_in      = 32'h0;
+      muxed_s_mem_read_data = {OPW{1'b0}};
+      sa_adder_data_in      = {OPW{1'b0}};
       add_carry_in_sa_new   = 1'b0;
       add_carry_in_sm_new   = 1'b0;
-      s_mem_new             = 32'h0;
+      s_mem_new             = {OPW{1'b0}};
       s_mem_we_new          = 1'b0;
 
 
@@ -368,7 +368,7 @@ module montprod #(parameter OPW = 32, parameter ADW = 8)
         SMUX_ADD:
           begin
             if (first_iteration_reg)
-              muxed_s_mem_read_data = 32'h0;
+              muxed_s_mem_read_data = {OPW{1'b0}};
             else
               muxed_s_mem_read_data = s_mem_read_data;
 
@@ -383,7 +383,7 @@ module montprod #(parameter OPW = 32, parameter ADW = 8)
             else if (q_reg)
               s_mem_new = add_result_sm;
             else if (first_iteration_reg)
-              s_mem_new = 32'h0;
+              s_mem_new = {OPW{1'b0}};
             else
               s_mem_new = s_mem_read_data;
 
@@ -430,12 +430,12 @@ module montprod #(parameter OPW = 32, parameter ADW = 8)
      loop_ctr_we      = 1'b0;
      length_m1        = length - 1'b1;
 
-     b_bit_index_new  = 5'h1f - loop_ctr_reg[4:0];
-     b_word_index     = loop_ctr_reg[12:5];
+     b_bit_index_new  = (2**(13 - ADW) - 1) - loop_ctr_reg[(13 - ADW - 1) : 0];
+     b_word_index     = loop_ctr_reg[12 : (13 - ADW)];
 
      if (loop_ctr_set)
          begin
-           loop_ctr_new = {length, 5'b00000} - 1'b1;
+           loop_ctr_new = {length, {(13 - ADW){1'b0}}} - 1'b1;
            loop_ctr_we  = 1'b1;
          end
 
@@ -485,7 +485,7 @@ module montprod #(parameter OPW = 32, parameter ADW = 8)
 
         CTRL_INIT_S:
           begin
-            if (word_index_reg == 8'h0)
+            if (word_index_reg == 0)
               begin
                 loop_ctr_set      = 1'b1;
                 montprod_ctrl_new = CTRL_WAIT;
@@ -521,7 +521,7 @@ module montprod #(parameter OPW = 32, parameter ADW = 8)
           begin
             s_mux_new = SMUX_ADD;
 
-            if (word_index_reg == 8'h0)
+            if (word_index_reg == 0)
               begin
                 reset_word_index_lsw = 1'b1;
                 montprod_ctrl_new    = CTRL_STALLPIPE_ADD;
@@ -571,7 +571,7 @@ module montprod #(parameter OPW = 32, parameter ADW = 8)
 
         CTRL_EMIT_S:
            begin
-             if (word_index_prev_reg == 8'h0)
+             if (word_index_prev_reg == 0)
                begin
                  ready_new         = 1'b1;
                  ready_we          = 1'b1;
-- 
cgit v1.2.3