Macros for packing and unpacking 3-D arrays in Verilog












0















I am a beginner with Verilog, I want to pack and unpack 3-D inputs and outputs in the code for which I have defined two macros as below:



`define PACK_3D(PK_WIDTH,PK_HEIGHT, PK_DEPTH, PK_SRC, PK_DEST) 
genvar pk_idh;
genvar pk_idd;
generate for (pk_idd=0; pk_idd<(PK_DEPTH); pk_idd=pk_idd+1) begin
generate for (pk_idh=0; pk_idh<(PK_HEIGHT); pk_idh=pk_idh+1) begin
assign PK_DEST[pk_idd*(PK_HEIGHT*PK_WIDTH) + pk_idh*(PK_WIDTH) + (PK_WIDTH-1): pk_idd*(PK_HEIGHT*PK_WIDTH) + pk_idh*(PK_WIDTH)] = PK_SRC[pk_idd][pk_idh][(PK_WIDTH)-1):0];
end
endgenerate
end
endgenerate



`define UNPACK_3D(PK_WIDTH, PK_HEIGHT, PK_DEPTH, PK_SRC, PK_DEST)
genvar pk_idh;
genvar pk_idd;
generate for (pk_idd=0; pk_idd<(PK_DEPTH); pk_idd=pk_idd+1) begin
generate for (pk_idh=0; pk_idh<(PK_HEIGHT); pk_idh=pk_idh+1) begin
assign PK_DEST[pk_idd][pk_idh][(PK_WIDTH)-1):0] = PK_SRC[pk_idd*(PK_HEIGHT*PK_WIDTH) + pk_idh*(PK_WIDTH) + (PK_WIDTH-1): pk_idd*(PK_HEIGHT*PK_WIDTH) + pk_idh*(PK_WIDTH)];
end
endgenerate
end
endgenerate


Next, I have built an add module to add two 3-D matrices and return the output as below:



module add(clk, rst, g_input, e_input, o);
input clk,rst;
localparam num=4;
localparam h = 3;
localparam w = 3;
localparam d = 2;

input [2*num*h*w*d-1:0] g_input;
input [2*num*h*w*d-1:0] e_input;
output reg [2*num*h*w*d-1:0] o;

reg [2*num -1: 0] g_unpack[d-1:0][h-1:0][w-1:0];
reg [2*num -1: 0] e_unpack[d-1:0][h-1:0][w-1:0];
reg [2*num -1: 0] o_unpack[d-1:0][h-1:0][w-1:0];


`UNPACK_3D(w,h,d,g_input,g_unpack);
`UNPACK_3D(w,h,d,e_input,e_unpack);

integer i_d, i_h, i_w

always@* // always combinational block
begin
for (i_d = 0; i_d < d; i_d = i_d+1)
begin
for (i_h = 0; i_h < d; i_h = i_h+1)
begin
for (i_w = 0; i_w < d; i_w = i_w+1)
begin
o_unpack[i_d][i_h][i_w] = g_unpack[i_d][i_h][i_w] + e_unpack[i_d][i_h][i_w];
end
end
end
end

`PACK_3D(w,h,d,o_unpack,o);
endmodule


I got the idea from the this discussion. Although I when I try to compile the code above, I get a compilation error:



Error:  ./add.v:43: Syntax error at or near token 'generate'
in macro "UNPACK_3D"
called from file "./add.v" (line 43). (VER-294)
Error: ./add.v:43: Syntax error at or near token '('
in macro "UNPACK_3D"
called from file "./add.v" (line 43). (VER-294)
Error: ./add.v:44: Syntax error at or near token 'generate'
in macro "UNPACK_3D"
called from file "./add.v" (line 44). (VER-294)
Error: ./add.v:44: Syntax error at or near token '('
in macro "UNPACK_3D"
called from file "./add.v" (line 44). (VER-294)
Error: ./add.v:44: Syntax error at or near token '('
in macro "UNPACK_3D"
called from file "./add.v" (line 44). (VER-294)
Error: ./add.v:48: Syntax error at or near token 'always'. (VER-294)
Error: ./add.v:50: Syntax error at or near token ';'. (VER-294)
Error: ./add.v:52: Syntax error at or near token ';'. (VER-294)
Error: ./add.v:54: Syntax error at or near token ';'. (VER-294)
Error: ./add.v:62: Syntax error at or near token 'generate'
in macro "PACK_3D"
called from file "./add.v" (line 62). (VER-294)
Error: ./add.v:62: Syntax error at or near token '('
in macro "PACK_3D"
called from file "./add.v" (line 62). (VER-294)
Error: ./add.v:62: Syntax error at or near token '('
in macro "PACK_3D"
called from file "./add.v" (line 62). (VER-294)
*** Presto compilation terminated with 12 errors. ***


Can anyone please help to resolve this?
Thank you.










share|improve this question





























    0















    I am a beginner with Verilog, I want to pack and unpack 3-D inputs and outputs in the code for which I have defined two macros as below:



    `define PACK_3D(PK_WIDTH,PK_HEIGHT, PK_DEPTH, PK_SRC, PK_DEST) 
    genvar pk_idh;
    genvar pk_idd;
    generate for (pk_idd=0; pk_idd<(PK_DEPTH); pk_idd=pk_idd+1) begin
    generate for (pk_idh=0; pk_idh<(PK_HEIGHT); pk_idh=pk_idh+1) begin
    assign PK_DEST[pk_idd*(PK_HEIGHT*PK_WIDTH) + pk_idh*(PK_WIDTH) + (PK_WIDTH-1): pk_idd*(PK_HEIGHT*PK_WIDTH) + pk_idh*(PK_WIDTH)] = PK_SRC[pk_idd][pk_idh][(PK_WIDTH)-1):0];
    end
    endgenerate
    end
    endgenerate



    `define UNPACK_3D(PK_WIDTH, PK_HEIGHT, PK_DEPTH, PK_SRC, PK_DEST)
    genvar pk_idh;
    genvar pk_idd;
    generate for (pk_idd=0; pk_idd<(PK_DEPTH); pk_idd=pk_idd+1) begin
    generate for (pk_idh=0; pk_idh<(PK_HEIGHT); pk_idh=pk_idh+1) begin
    assign PK_DEST[pk_idd][pk_idh][(PK_WIDTH)-1):0] = PK_SRC[pk_idd*(PK_HEIGHT*PK_WIDTH) + pk_idh*(PK_WIDTH) + (PK_WIDTH-1): pk_idd*(PK_HEIGHT*PK_WIDTH) + pk_idh*(PK_WIDTH)];
    end
    endgenerate
    end
    endgenerate


    Next, I have built an add module to add two 3-D matrices and return the output as below:



    module add(clk, rst, g_input, e_input, o);
    input clk,rst;
    localparam num=4;
    localparam h = 3;
    localparam w = 3;
    localparam d = 2;

    input [2*num*h*w*d-1:0] g_input;
    input [2*num*h*w*d-1:0] e_input;
    output reg [2*num*h*w*d-1:0] o;

    reg [2*num -1: 0] g_unpack[d-1:0][h-1:0][w-1:0];
    reg [2*num -1: 0] e_unpack[d-1:0][h-1:0][w-1:0];
    reg [2*num -1: 0] o_unpack[d-1:0][h-1:0][w-1:0];


    `UNPACK_3D(w,h,d,g_input,g_unpack);
    `UNPACK_3D(w,h,d,e_input,e_unpack);

    integer i_d, i_h, i_w

    always@* // always combinational block
    begin
    for (i_d = 0; i_d < d; i_d = i_d+1)
    begin
    for (i_h = 0; i_h < d; i_h = i_h+1)
    begin
    for (i_w = 0; i_w < d; i_w = i_w+1)
    begin
    o_unpack[i_d][i_h][i_w] = g_unpack[i_d][i_h][i_w] + e_unpack[i_d][i_h][i_w];
    end
    end
    end
    end

    `PACK_3D(w,h,d,o_unpack,o);
    endmodule


    I got the idea from the this discussion. Although I when I try to compile the code above, I get a compilation error:



    Error:  ./add.v:43: Syntax error at or near token 'generate'
    in macro "UNPACK_3D"
    called from file "./add.v" (line 43). (VER-294)
    Error: ./add.v:43: Syntax error at or near token '('
    in macro "UNPACK_3D"
    called from file "./add.v" (line 43). (VER-294)
    Error: ./add.v:44: Syntax error at or near token 'generate'
    in macro "UNPACK_3D"
    called from file "./add.v" (line 44). (VER-294)
    Error: ./add.v:44: Syntax error at or near token '('
    in macro "UNPACK_3D"
    called from file "./add.v" (line 44). (VER-294)
    Error: ./add.v:44: Syntax error at or near token '('
    in macro "UNPACK_3D"
    called from file "./add.v" (line 44). (VER-294)
    Error: ./add.v:48: Syntax error at or near token 'always'. (VER-294)
    Error: ./add.v:50: Syntax error at or near token ';'. (VER-294)
    Error: ./add.v:52: Syntax error at or near token ';'. (VER-294)
    Error: ./add.v:54: Syntax error at or near token ';'. (VER-294)
    Error: ./add.v:62: Syntax error at or near token 'generate'
    in macro "PACK_3D"
    called from file "./add.v" (line 62). (VER-294)
    Error: ./add.v:62: Syntax error at or near token '('
    in macro "PACK_3D"
    called from file "./add.v" (line 62). (VER-294)
    Error: ./add.v:62: Syntax error at or near token '('
    in macro "PACK_3D"
    called from file "./add.v" (line 62). (VER-294)
    *** Presto compilation terminated with 12 errors. ***


    Can anyone please help to resolve this?
    Thank you.










    share|improve this question



























      0












      0








      0








      I am a beginner with Verilog, I want to pack and unpack 3-D inputs and outputs in the code for which I have defined two macros as below:



      `define PACK_3D(PK_WIDTH,PK_HEIGHT, PK_DEPTH, PK_SRC, PK_DEST) 
      genvar pk_idh;
      genvar pk_idd;
      generate for (pk_idd=0; pk_idd<(PK_DEPTH); pk_idd=pk_idd+1) begin
      generate for (pk_idh=0; pk_idh<(PK_HEIGHT); pk_idh=pk_idh+1) begin
      assign PK_DEST[pk_idd*(PK_HEIGHT*PK_WIDTH) + pk_idh*(PK_WIDTH) + (PK_WIDTH-1): pk_idd*(PK_HEIGHT*PK_WIDTH) + pk_idh*(PK_WIDTH)] = PK_SRC[pk_idd][pk_idh][(PK_WIDTH)-1):0];
      end
      endgenerate
      end
      endgenerate



      `define UNPACK_3D(PK_WIDTH, PK_HEIGHT, PK_DEPTH, PK_SRC, PK_DEST)
      genvar pk_idh;
      genvar pk_idd;
      generate for (pk_idd=0; pk_idd<(PK_DEPTH); pk_idd=pk_idd+1) begin
      generate for (pk_idh=0; pk_idh<(PK_HEIGHT); pk_idh=pk_idh+1) begin
      assign PK_DEST[pk_idd][pk_idh][(PK_WIDTH)-1):0] = PK_SRC[pk_idd*(PK_HEIGHT*PK_WIDTH) + pk_idh*(PK_WIDTH) + (PK_WIDTH-1): pk_idd*(PK_HEIGHT*PK_WIDTH) + pk_idh*(PK_WIDTH)];
      end
      endgenerate
      end
      endgenerate


      Next, I have built an add module to add two 3-D matrices and return the output as below:



      module add(clk, rst, g_input, e_input, o);
      input clk,rst;
      localparam num=4;
      localparam h = 3;
      localparam w = 3;
      localparam d = 2;

      input [2*num*h*w*d-1:0] g_input;
      input [2*num*h*w*d-1:0] e_input;
      output reg [2*num*h*w*d-1:0] o;

      reg [2*num -1: 0] g_unpack[d-1:0][h-1:0][w-1:0];
      reg [2*num -1: 0] e_unpack[d-1:0][h-1:0][w-1:0];
      reg [2*num -1: 0] o_unpack[d-1:0][h-1:0][w-1:0];


      `UNPACK_3D(w,h,d,g_input,g_unpack);
      `UNPACK_3D(w,h,d,e_input,e_unpack);

      integer i_d, i_h, i_w

      always@* // always combinational block
      begin
      for (i_d = 0; i_d < d; i_d = i_d+1)
      begin
      for (i_h = 0; i_h < d; i_h = i_h+1)
      begin
      for (i_w = 0; i_w < d; i_w = i_w+1)
      begin
      o_unpack[i_d][i_h][i_w] = g_unpack[i_d][i_h][i_w] + e_unpack[i_d][i_h][i_w];
      end
      end
      end
      end

      `PACK_3D(w,h,d,o_unpack,o);
      endmodule


      I got the idea from the this discussion. Although I when I try to compile the code above, I get a compilation error:



      Error:  ./add.v:43: Syntax error at or near token 'generate'
      in macro "UNPACK_3D"
      called from file "./add.v" (line 43). (VER-294)
      Error: ./add.v:43: Syntax error at or near token '('
      in macro "UNPACK_3D"
      called from file "./add.v" (line 43). (VER-294)
      Error: ./add.v:44: Syntax error at or near token 'generate'
      in macro "UNPACK_3D"
      called from file "./add.v" (line 44). (VER-294)
      Error: ./add.v:44: Syntax error at or near token '('
      in macro "UNPACK_3D"
      called from file "./add.v" (line 44). (VER-294)
      Error: ./add.v:44: Syntax error at or near token '('
      in macro "UNPACK_3D"
      called from file "./add.v" (line 44). (VER-294)
      Error: ./add.v:48: Syntax error at or near token 'always'. (VER-294)
      Error: ./add.v:50: Syntax error at or near token ';'. (VER-294)
      Error: ./add.v:52: Syntax error at or near token ';'. (VER-294)
      Error: ./add.v:54: Syntax error at or near token ';'. (VER-294)
      Error: ./add.v:62: Syntax error at or near token 'generate'
      in macro "PACK_3D"
      called from file "./add.v" (line 62). (VER-294)
      Error: ./add.v:62: Syntax error at or near token '('
      in macro "PACK_3D"
      called from file "./add.v" (line 62). (VER-294)
      Error: ./add.v:62: Syntax error at or near token '('
      in macro "PACK_3D"
      called from file "./add.v" (line 62). (VER-294)
      *** Presto compilation terminated with 12 errors. ***


      Can anyone please help to resolve this?
      Thank you.










      share|improve this question
















      I am a beginner with Verilog, I want to pack and unpack 3-D inputs and outputs in the code for which I have defined two macros as below:



      `define PACK_3D(PK_WIDTH,PK_HEIGHT, PK_DEPTH, PK_SRC, PK_DEST) 
      genvar pk_idh;
      genvar pk_idd;
      generate for (pk_idd=0; pk_idd<(PK_DEPTH); pk_idd=pk_idd+1) begin
      generate for (pk_idh=0; pk_idh<(PK_HEIGHT); pk_idh=pk_idh+1) begin
      assign PK_DEST[pk_idd*(PK_HEIGHT*PK_WIDTH) + pk_idh*(PK_WIDTH) + (PK_WIDTH-1): pk_idd*(PK_HEIGHT*PK_WIDTH) + pk_idh*(PK_WIDTH)] = PK_SRC[pk_idd][pk_idh][(PK_WIDTH)-1):0];
      end
      endgenerate
      end
      endgenerate



      `define UNPACK_3D(PK_WIDTH, PK_HEIGHT, PK_DEPTH, PK_SRC, PK_DEST)
      genvar pk_idh;
      genvar pk_idd;
      generate for (pk_idd=0; pk_idd<(PK_DEPTH); pk_idd=pk_idd+1) begin
      generate for (pk_idh=0; pk_idh<(PK_HEIGHT); pk_idh=pk_idh+1) begin
      assign PK_DEST[pk_idd][pk_idh][(PK_WIDTH)-1):0] = PK_SRC[pk_idd*(PK_HEIGHT*PK_WIDTH) + pk_idh*(PK_WIDTH) + (PK_WIDTH-1): pk_idd*(PK_HEIGHT*PK_WIDTH) + pk_idh*(PK_WIDTH)];
      end
      endgenerate
      end
      endgenerate


      Next, I have built an add module to add two 3-D matrices and return the output as below:



      module add(clk, rst, g_input, e_input, o);
      input clk,rst;
      localparam num=4;
      localparam h = 3;
      localparam w = 3;
      localparam d = 2;

      input [2*num*h*w*d-1:0] g_input;
      input [2*num*h*w*d-1:0] e_input;
      output reg [2*num*h*w*d-1:0] o;

      reg [2*num -1: 0] g_unpack[d-1:0][h-1:0][w-1:0];
      reg [2*num -1: 0] e_unpack[d-1:0][h-1:0][w-1:0];
      reg [2*num -1: 0] o_unpack[d-1:0][h-1:0][w-1:0];


      `UNPACK_3D(w,h,d,g_input,g_unpack);
      `UNPACK_3D(w,h,d,e_input,e_unpack);

      integer i_d, i_h, i_w

      always@* // always combinational block
      begin
      for (i_d = 0; i_d < d; i_d = i_d+1)
      begin
      for (i_h = 0; i_h < d; i_h = i_h+1)
      begin
      for (i_w = 0; i_w < d; i_w = i_w+1)
      begin
      o_unpack[i_d][i_h][i_w] = g_unpack[i_d][i_h][i_w] + e_unpack[i_d][i_h][i_w];
      end
      end
      end
      end

      `PACK_3D(w,h,d,o_unpack,o);
      endmodule


      I got the idea from the this discussion. Although I when I try to compile the code above, I get a compilation error:



      Error:  ./add.v:43: Syntax error at or near token 'generate'
      in macro "UNPACK_3D"
      called from file "./add.v" (line 43). (VER-294)
      Error: ./add.v:43: Syntax error at or near token '('
      in macro "UNPACK_3D"
      called from file "./add.v" (line 43). (VER-294)
      Error: ./add.v:44: Syntax error at or near token 'generate'
      in macro "UNPACK_3D"
      called from file "./add.v" (line 44). (VER-294)
      Error: ./add.v:44: Syntax error at or near token '('
      in macro "UNPACK_3D"
      called from file "./add.v" (line 44). (VER-294)
      Error: ./add.v:44: Syntax error at or near token '('
      in macro "UNPACK_3D"
      called from file "./add.v" (line 44). (VER-294)
      Error: ./add.v:48: Syntax error at or near token 'always'. (VER-294)
      Error: ./add.v:50: Syntax error at or near token ';'. (VER-294)
      Error: ./add.v:52: Syntax error at or near token ';'. (VER-294)
      Error: ./add.v:54: Syntax error at or near token ';'. (VER-294)
      Error: ./add.v:62: Syntax error at or near token 'generate'
      in macro "PACK_3D"
      called from file "./add.v" (line 62). (VER-294)
      Error: ./add.v:62: Syntax error at or near token '('
      in macro "PACK_3D"
      called from file "./add.v" (line 62). (VER-294)
      Error: ./add.v:62: Syntax error at or near token '('
      in macro "PACK_3D"
      called from file "./add.v" (line 62). (VER-294)
      *** Presto compilation terminated with 12 errors. ***


      Can anyone please help to resolve this?
      Thank you.







      compiler-errors verilog






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Jan 19 at 11:52







      Yash Kant

















      asked Jan 19 at 11:41









      Yash KantYash Kant

      86128




      86128
























          1 Answer
          1






          active

          oldest

          votes


















          1














          You have nested your generates.



          You should only have one generate..endgenerate pair with both for loops inside.



          Also if you instance that code your genvars are declared twice ( genvar pk_idh; genvar pk_idd;) Even if you make them different between pack and unpack, you can only call each macro once per module.



          I would also recommend you first try the code without the macros. Then when the syntax is correct and the code works try to convert it to a macro.






          share|improve this answer
























          • Thanks, I'll try your suggestions and revert back.

            – Yash Kant
            Jan 19 at 12:05











          • You can eliminate all generate/endgenerate keywords. There were made optional in Verilog-2001.

            – dave_59
            Jan 19 at 16:07











          Your Answer






          StackExchange.ifUsing("editor", function () {
          StackExchange.using("externalEditor", function () {
          StackExchange.using("snippets", function () {
          StackExchange.snippets.init();
          });
          });
          }, "code-snippets");

          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "1"
          };
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function() {
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled) {
          StackExchange.using("snippets", function() {
          createEditor();
          });
          }
          else {
          createEditor();
          }
          });

          function createEditor() {
          StackExchange.prepareEditor({
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: true,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: 10,
          bindNavPrevention: true,
          postfix: "",
          imageUploader: {
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          },
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          });


          }
          });














          draft saved

          draft discarded


















          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54266694%2fmacros-for-packing-and-unpacking-3-d-arrays-in-verilog%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes









          1














          You have nested your generates.



          You should only have one generate..endgenerate pair with both for loops inside.



          Also if you instance that code your genvars are declared twice ( genvar pk_idh; genvar pk_idd;) Even if you make them different between pack and unpack, you can only call each macro once per module.



          I would also recommend you first try the code without the macros. Then when the syntax is correct and the code works try to convert it to a macro.






          share|improve this answer
























          • Thanks, I'll try your suggestions and revert back.

            – Yash Kant
            Jan 19 at 12:05











          • You can eliminate all generate/endgenerate keywords. There were made optional in Verilog-2001.

            – dave_59
            Jan 19 at 16:07
















          1














          You have nested your generates.



          You should only have one generate..endgenerate pair with both for loops inside.



          Also if you instance that code your genvars are declared twice ( genvar pk_idh; genvar pk_idd;) Even if you make them different between pack and unpack, you can only call each macro once per module.



          I would also recommend you first try the code without the macros. Then when the syntax is correct and the code works try to convert it to a macro.






          share|improve this answer
























          • Thanks, I'll try your suggestions and revert back.

            – Yash Kant
            Jan 19 at 12:05











          • You can eliminate all generate/endgenerate keywords. There were made optional in Verilog-2001.

            – dave_59
            Jan 19 at 16:07














          1












          1








          1







          You have nested your generates.



          You should only have one generate..endgenerate pair with both for loops inside.



          Also if you instance that code your genvars are declared twice ( genvar pk_idh; genvar pk_idd;) Even if you make them different between pack and unpack, you can only call each macro once per module.



          I would also recommend you first try the code without the macros. Then when the syntax is correct and the code works try to convert it to a macro.






          share|improve this answer













          You have nested your generates.



          You should only have one generate..endgenerate pair with both for loops inside.



          Also if you instance that code your genvars are declared twice ( genvar pk_idh; genvar pk_idd;) Even if you make them different between pack and unpack, you can only call each macro once per module.



          I would also recommend you first try the code without the macros. Then when the syntax is correct and the code works try to convert it to a macro.







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Jan 19 at 12:03









          OldfartOldfart

          2,7372711




          2,7372711













          • Thanks, I'll try your suggestions and revert back.

            – Yash Kant
            Jan 19 at 12:05











          • You can eliminate all generate/endgenerate keywords. There were made optional in Verilog-2001.

            – dave_59
            Jan 19 at 16:07



















          • Thanks, I'll try your suggestions and revert back.

            – Yash Kant
            Jan 19 at 12:05











          • You can eliminate all generate/endgenerate keywords. There were made optional in Verilog-2001.

            – dave_59
            Jan 19 at 16:07

















          Thanks, I'll try your suggestions and revert back.

          – Yash Kant
          Jan 19 at 12:05





          Thanks, I'll try your suggestions and revert back.

          – Yash Kant
          Jan 19 at 12:05













          You can eliminate all generate/endgenerate keywords. There were made optional in Verilog-2001.

          – dave_59
          Jan 19 at 16:07





          You can eliminate all generate/endgenerate keywords. There were made optional in Verilog-2001.

          – dave_59
          Jan 19 at 16:07


















          draft saved

          draft discarded




















































          Thanks for contributing an answer to Stack Overflow!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid



          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.


          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54266694%2fmacros-for-packing-and-unpacking-3-d-arrays-in-verilog%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          Homophylophilia

          Updating UILabel text programmatically using a function

          Cloud Functions - OpenCV Videocapture Read method fails for larger files from cloud storage