Continue to Site

Welcome to EDAboard.com

Welcome to our site! EDAboard.com is an international Electronics Discussion Forum focused on EDA software, circuits, schematics, books, theory, papers, asic, pld, 8051, DSP, Network, RF, Analog Design, PCB, Service Manuals... and a whole lot more! To participate you need to register. Registration is free. Click here to register now.

SystemVerilog simulation in Questasim 6.2b ?

Status
Not open for further replies.

subos

Newbie level 5
Newbie level 5
Joined
Nov 13, 2006
Messages
8
Helped
0
Reputation
0
Reaction score
0
Trophy points
1,281
Activity points
1,357
questasim 6.2b systemverilog

The following warning is reported.

Some checking for conflicts with continuous assignments to variables not yet supported. Run vopt to provide additional design-level checks.

It can be seen clearly in the technotes that QuestaSim6.2b supports "continuous assignments to variables". Why does it report the above warning?
 

systemverilog svchk

Hi,
Can you send the file which gives you this warning .. ?
 

[svchk] - some checking for conflicts

walid said:
Hi,
Can you send the file which gives you this warning .. ?

Thanks for your reply.

The following is the source file. I download it from an open-core website.

/* -------------------------------------------------------------------------------
* (C)2007 Robert Mullins
* Computer Architecture Group, Computer Laboratory
* University of Cambridge, UK.
* -------------------------------------------------------------------------------
*
* Pipelined channel (link) between routers
*
* 'stages' may range from 0 (routers are clocked but link is simply a wire)
* to N
*
*/

module NW_pipelined_channel (data_in, data_out, clk, rst_n);

parameter type reg_t = flit_t;

parameter stages = 4;

input reg_t data_in;
output reg_t data_out;
input clk, rst_n;

genvar st;

reg_t ch_reg[stages-1:0];

generate
if (stages==0) begin
// no registers in channel
assign data_out = data_in;
end else begin
for (st=0; st<stages; st++) begin:eachstage
if (st==0) begin
// first register in channel
NW_reg #(.reg_t(flit_t)) rg (.data_in(data_in), .data_out(ch_reg[0]), .clk, .rst_n);
end else begin
// other registers
NW_reg #(.reg_t(flit_t)) rg (.data_in(ch_reg[st-1]), .data_out(ch_reg[st]), .clk, .rst_n);
end
end

assign data_out = ch_reg[stages-1];

end
endgenerate


endmodule // NW_pipelined_channel

The related warnings are shown below:
# ** Warning: lib/NW_pipelined_channel.v(31): [SVCHK] - Some checking for conflicts with continuous assignments to variables not yet supported. Run vopt to provide additional design-level checks.
# ** Warning: lib/NW_pipelined_channel.v(43): [SVCHK] - Some checking for conflicts with continuous assignments to variables not yet supported. Run vopt to provide additional design-level checks.
 

these features are only supported in questasim.

What i figured that you get this message only if the continuous assignments are inside a generate block.
However, when i ran a simulation the results were ok.
 

    subos

    Points: 2
    Helpful Answer Positive Rating
systemverilog questasim

walid said:
What i figured that you get this message only if the continuous assignments are inside a generate block.
However, when i ran a simulation the results were ok.

Thanks for your help.

So, I can omit these warnings.
 

Status
Not open for further replies.

Part and Inventory Search

Welcome to EDABoard.com

Sponsor

Back
Top