File: autoinst_crawford_array_a.v

package info (click to toggle)
verilog-mode 20161124.fd230e6-2
  • links: PTS, VCS
  • area: main
  • in suites: buster, stretch
  • size: 3,764 kB
  • ctags: 5,143
  • sloc: lisp: 12,430; perl: 293; makefile: 146; sh: 35; fortran: 2
file content (39 lines) | stat: -rw-r--r-- 1,006 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
`define auto_trq #1     // clock to q delay
`define auto_tcq #1     // reset to q delay

module autoinst_crawford_array_a(/*AUTOARG*/
                                 // Outputs
                                 a_valid, a_data,
                                 // Inputs
                                 a_ready, clk, rst_n
                                 );
   
   // a interface
   output       a_valid;
   output [7:0] a_data;
   input        a_ready;
   
   // clock interface
   input        clk;
   input        rst_n;
   
   /*AUTOREG*/
   // Beginning of automatic regs (for this module's undeclared outputs)
   reg [7:0]    a_data;
   reg          a_valid;
   // End of automatics
   
   always @(posedge clk or negedge rst_n) begin
      if(~rst_n) begin
         a_valid <= `auto_trq 0;
         a_data  <= `auto_trq 0;
      end
      else begin
         if(a_ready) begin
            a_valid <= `auto_tcq 1;
            a_data  <= `auto_tcq 8'hcc;
         end
      end
   end
   
endmodule