| | | (3 Hours) | [Total Marks: 80] | 200 | |------|--------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|-----------------------------------|------| | | | | | | | N.B. | : (1) | Question No. 1 is compulsory. | | SO | | | (2) | Attempt any three out of remaining. | | 200 | | | (3) | Assume suitable data wherever required. | | | | Q.1 | Solve | the following (Any four) | | [20] | | | A. What is the significance of 'scope resolution operator'. | | | | | | B. Justify if code coverage is 100%, it indicates verification is done 100%. | | | | | | C. Short note on mailbox and describe their use in System Verilog with suitable example. | | | | | | D. Exp | plain the concept of an interface with suitable exam | mple and why it is used? | 977 | | | E. Dra | aw layered test bench block diagram mentioning e | ach layer clearly. | | | Q.2 | A. Draw the architecture of FPGA and specify its important components. Highlight the features of Virtex – 7. | | | [10] | | | B. Explain the concept of Switch level modelling. Write Verilog code for 2:1 mux using | | | [] | | | | uctural modelling. | | [10] | | Q.3 | A. Discuss Silicon challenges considering time closure, capacity, physical properties, | | | | | | de | sign productivity gap and time to market. | 7.2.2.8° | [10] | | | В. | | | [10] | | | i. | Create an unpacked array, 'my_array', conta<br>type. | aining 4 elements of user defir | ned | | | ji.s | Initialize it to 4'hA, 4'hB, 4'hC, and 4'hD. | 7 | | | | ii). | Stream my_array into my_array_s, right to | left on a bit basis and print out | | | | | my_array_s. | | | | | iv. | Given the following code, determine what v | vill be displayed. | | | | | string students[\$]={"Austin", "Noel", "Gary initial begin | <b>"</b> "}; | | | | | \$students.insert(2,"Sakshi"); | | | | | | \$display("students[2]=%s", students[2]); | | | | | | \$students.pop front("Swapnaja"); | | | | | 3000 | \$display("students[2]=%s", students[2]); | | | | | 2320 | \$display("size=%d", students.size); | | | | | 733 | \$display("push back=%s", students.push_ | back); | | | | STA S | \$display("size=%d", students.size); | | | | | ON THE | end | | | | | 1,000 | endmodule | | | **55058** Page **1** of **2** ``` Q.4 For the following interface, add the system verilog code: [10] A. interface my_if (input bit clk); bit write; bit [15:0] data_in; bit [7:0] address; logic [15:0] data_out; endinterface i) A clocking block that is sensitive to negative of the clock and I/O that are synchronous to the clock ii) A modport for Testbench called Master A modport for DUT called Slave B. Explain immediate and concurrent assertions in detail. [10] Q.5 A. Explain how communication between threads is achieved with fork....join, [10] fork...join_none and fork....join_any. Give example. B. What is cross coverage, code coverage and function coverage? Explain with proper example. [10] A. Explain System Verilog Constraint Random stimulus generation with suitable example. Q.6 [10] B. Write a covergroup to collect coverage on the test plan requirement with [10] following code: typedef enum {ADD, SUB, MULT, DIV} opcode_e; class Transaction; rand opcode e opcode; rand byte operand1; rand byte operand2; endclass Transaction tr; 1. The opcode shall take on the values ADD or SUB (Use 1 coverage bin). 2. The opcode shall take on the values ADD followed by SUB. Opcode must not equal DIV" (hint: report an error using illegal_bins). ``` 55058 Page 2 of 2