2014年11月3日 星期一

三位元多工器行為模式

module top
wire [2:0]A,B,OUT;
wire SEL;
system_clock #6400 clock1(A[1]);
system_clock #3200 clock2(A[0]);
system_clock #1600 clock3(A[2]);
system_clock #800 clock4(B[1]);
system_clock #400 clock5(B[0]);
system_clock #200 clock6(B[2]);
system_clock #100 clock7(SEL);
mux3  M1(OUT,A,B,SEL)
endmodule

module mux3(OUT, A, B, SEL);
 output OUT;
 input  [2:0] A,B;
 input   SEL;
 wire   [2:0] A, B;
 wire         SEL;
 reg    [1:0] OUT

  always @(A[0] or A[1] or A[2] or B[0] or B[1] or B[2] or SEL)
   begin
    OUT = (A[0] & SEL)|(B[0] & ~SEL );
    OUT = (A[1] & SEL)|(B[1] & ~SEL );
    OUT = (A[2] & SEL)|(B[2] & ~SEL );
   end
endmodule

/*宣告兩位元以上的,需要begin & end  */

/*系統時脈  */
module system_clock(clk);
parameter PERIOD=100;
output clk;
reg clk;
initial clk=0;
always
 begin
#(PERIOD/2) clk=~clk;
 end
always@(posedge clk)
 if($time>7000)$stop
endmodule

沒有留言:

張貼留言