lattice双口ram读写

2019-03-25 08:25发布

lattice双口ram怎么不能写入数据呀??? 此帖出自小平头技术问答
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
3条回答
lxglovehome
1楼-- · 2019-03-25 16:20
< / module        TEST_DPRAM(clk,outA);

        input        clk;
        output        wire        [7:0]        outA;
       
        wire        [7:0]        dpraminaddr;
        wire        [7:0]        dpramindata;
        wire        [7:0]        ramoutdataA;
        wire        WrEn;
//        wire        clken;
       
//        assign        clken = ~clk;
        assign        WrEn = (count == 3) ? clk : 0;
       
        assign        dpraminaddr = addrin;
        assign        dpramindata = datain;
        assign        outA = ramoutdataA;
       
        integer        count = 0;
        always        @(posedge clk)
                begin
                        if(count == 3)
                                begin
                                        count <= 3;
                                end
                        else
                                begin
                                        count <= count + 1;
                                end
                end
       
        reg                [7:0]        addrin = 0;
        always        @(posedge clk)
                begin
                        if(addrin == 255)
                                begin
                                        addrin <= 0;
                                end
                        else
                                begin
                                        addrin <= addrin + 1;
                                end
                end
               
        reg                [7:0]        datain = 0;
        always        @(posedge clk)
                begin
                        if(datain == 255)
                                begin
                                        datain <= 0;
                                end
                        else
                                begin
                                        datain <= datain + 1;
                                end
                end

        GSR GSR_INST (.GSR(1'b1));
        PUR PUR_INST (.PUR(1'b1));
       
        RAM_DP RAM_DP_BLOCK(.Clock(clk), .ClockEn(1'b1), .Reset(1'b0),
                            .WE(clk), .Address(addrin), .Data(datain), .Q(ramoutdataA));
       
/*        DPRAM DPRAM_BLOCK(.DataInA(datain), .DataInB(datain), .AddressA(addrin),
                                          .AddressB(addrin),.ClockA(clken), .ClockB(clken),
                                          .ClockEnA(1'b1), .ClockEnB(1'b1), .WrA(WrEn), .WrB(WrEn),
                                          .ResetA(1'b0), .ResetB(1'b0), .QA(ramoutdataA), .QB(ramoutdataB));*/
endmodule
lxglovehome
2楼-- · 2019-03-25 17:35
module        TEST_DPRAM(clk,outA);

        input        clk;
        output        wire        [7:0]        outA;
       
        wire        [7:0]        dpraminaddr;
        wire        [7:0]        dpramindata;
        wire        [7:0]        ramoutdataA;
        wire        WrEn;
//        wire        clken;
       
//        assign        clken = ~clk;
        assign        WrEn = (count == 3) ? clk : 0;
       
        assign        dpraminaddr = addrin;
        assign        dpramindata = datain;
        assign        outA = ramoutdataA;
       
        integer        count = 0;
        always        @(posedge clk)
                begin
                        if(count == 3)
                                begin
                                        count <= 3;
                                end
                        else
                                begin
                                        count <= count + 1;
                                end
                end
       
        reg                [7:0]        addrin = 0;
        always        @(posedge clk)
                begin
                        if(addrin == 255)
                                begin
                                        addrin <= 0;
                                end
                        else
                                begin
                                        addrin <= addrin + 1;
                                end
                end
               
        reg                [7:0]        datain = 0;
        always        @(posedge clk)
                begin
                        if(datain == 255)
                                begin
                                        datain <= 0;
                                end
                        else
                                begin
                                        datain <= datain + 1;
                                end
                end

        GSR GSR_INST (.GSR(1'b1));
        PUR PUR_INST (.PUR(1'b1));
       
        RAM_DP RAM_DP_BLOCK(.Clock(clk), .ClockEn(1'b1), .Reset(1'b0),
                            .WE(clk), .Address(addrin), .Data(datain), .Q(ramoutdataA));
       
/*        DPRAM DPRAM_BLOCK(.DataInA(datain), .DataInB(datain), .AddressA(addrin),
                                          .AddressB(addrin),.ClockA(clken), .ClockB(clken),
                                          .ClockEnA(1'b1), .ClockEnB(1'b1), .WrA(WrEn), .WrB(WrEn),
                                          .ResetA(1'b0), .ResetB(1'b0), .QA(ramoutdataA), .QB(ramoutdataB));*/
endmodule
lxglovehome
3楼-- · 2019-03-25 18:52
问题在哪里??请看看!

一周热门 更多>