我是靠谱客的博主 唠叨丝袜,最近开发中收集的这篇文章主要介绍Exams/ece241 2014 q4经验,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

总结:模块命名注意不能与内置模块同名

Given the finite state machine circuit as shown, assume that the D flip-flops are initially reset to zero before the machine begins.

Build this circuit.

方法一:模块实例化

1)当按端口名称进行端口对应实例化时,success。

module top_module (
    input clk,
    input x,
    output z
); 
    /*第一部分的连接*/
    wire    q0        ;
    wire    d0    ;
    assign d0 = q0 ^ x;
    dff dff_module_inst0(.clk(clk),.d(d0),.q(q0));
    /*第二部分的连接*/
    wire    q1        ;
    wire    d1    ;
    assign    d1 = ~q1 & x; 
    dff dff_module_inst1(.clk(clk),.d(d1),.q(q1));
    /*第三部分的连接*/
    wire    q2        ;
    wire    d2    ;
    assign    d2 = ~q2 | x; 
    dff dff_module_inst2(.clk(clk),.d(d2),.q(q2));
    
    /*最后的输出结果*/
    assign z = ~(q0 | q1 | q2);

endmodule

/*D触发器模块*/
module dff(input clk,input d,output    reg    q);
    always@(posedge clk) begin
           q <= d; 
    end
    
endmodule

 

2)当按端口位置实例化时,结果不正确。

代码仅在实例化语句处作更改。

module top_module (
    input clk,
    input x,
    output z
); 
    /*第一部分的连接*/
    wire    q0        ;
    wire    d0    ;
    assign d0 = q0 ^ x;
    dff dff_module_inst0(clk,d0,q0);         //
    /*第二部分的连接*/
    wire    q1        ;
    wire    d1    ;
    assign    d1 = ~q1 & x; 
    dff dff_module_inst1(clk,d1,q1);         //
    /*第三部分的连接*/
    wire    q2        ;
    wire    d2    ;
    assign    d2 = ~q2 | x; 
    dff dff_module_inst2(clk,d2,q2);         //
    
    /*最后的输出结果*/
    assign z = ~(q0 | q1 | q2);

endmodule

/*D触发器模块*/
module dff(input clk,input d,output    reg    q);
    always@(posedge clk) begin
           q <= d; 
    end
    
endmodule

编译成功,但结果错误。

Status: Incorrect

Compile and simulation succeeded, but the circuit's output wasn't entirely correct. The hints below may help.

# Hint: Output 'z' has 94 mismatches. First mismatch occurred at time 10.
# Hint: Total mismatched samples is 94 out of 115 samples

 

原因查明为d触发器模块名称为内置模块名称,所引起冲突,造成错误。

Warning (12018): Entity "dff" will be ignored because it conflicts with Quartus Prime primitive name File: /home/h/work/hdlbits.3688841/top_module.v Line: 28

Quartus has a number of built-in "primitive" modules. Don't give any of your modules the same name as a primitive. This message warns you that you are instantiating the built-in primitive instead of your module.

将dff修改为mydff后,success

module top_module (
    input clk,
    input x,
    output z
); 
    /*第一部分的连接*/
    wire    q0        ;
    wire    d0    ;
    assign d0 = q0 ^ x;
    mydff dff_module_inst0(clk,d0,q0);
    /*第二部分的连接*/
    wire    q1        ;
    wire    d1    ;
    assign    d1 = ~q1 & x; 
    mydff dff_module_inst1(clk,d1,q1);
    /*第三部分的连接*/
    wire    q2        ;
    wire    d2    ;
    assign    d2 = ~q2 | x; 
    mydff dff_module_inst2(clk,d2,q2);
    
    /*最后的输出结果*/
    assign z = ~(q0 | q1 | q2);

endmodule

/*D触发器模块*/
module mydff(input clk,input d,output reg q);
    always@(posedge clk) begin
           q <= d; 
    end
    
endmodule

再改变一下排版,依旧success

module top_module (
    input clk,
    input x,
    output z
); 
    wire d0,d1,d2;
    wire q0,q1,q2;
    
    assign d0 = q0 ^ x;
    assign    d1 = ~q1 & x;
    assign    d2 = ~q2 | x;
    
    mydff mydff_inst0(clk,d0,q0);
    mydff mydff_inst1(clk,d1,q1);
    mydff mydff_inst2(clk,d2,q2);

    assign z = ~(q0 | q1 | q2);

endmodule

module mydff (input clk,input d,output reg q);
    
    always @(posedge clk) begin
           q <= d; 
    end
    
endmodule

方法二:

 module top_module (
    input clk,
    input x,
    output z
); 
    wire q0,q1,q2;
    always @(posedge clk) begin
        q0 <= x ^ q0;
        q1 <= x & ~q1;
        q2 <= x | ~q2;
    end
    assign z = ~(q0 | q1 | q2);
endmodule

 

 

最后

以上就是唠叨丝袜为你收集整理的Exams/ece241 2014 q4经验的全部内容,希望文章能够帮你解决Exams/ece241 2014 q4经验所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(50)

评论列表共有 0 条评论

立即
投稿
返回
顶部