250 likes | 359 Views
ELEN 468 Advanced Logic Design. Lecture 6 Delay Models. Delay Models. Propagation Delay. Xin. Xout. Xin. 50%Vdd. t. Xout. 50%Vdd. t. Tpd_1_0. Delay Models. Gate delay Intrinsic delay Layout-induced delay due to capacitive load Waveform slope-induced delay
E N D
ELEN 468Advanced Logic Design Lecture 6 Delay Models ELEN 468 Lecture 6
Delay Models ELEN 468 Lecture 6
Propagation Delay Xin Xout Xin 50%Vdd t Xout 50%Vdd t Tpd_1_0 ELEN 468 Lecture 6
Delay Models • Gate delay • Intrinsic delay • Layout-induced delay due to capacitive load • Waveform slope-induced delay • Net delay/transport delay • Signal propagation delay along interconnect wires • Module path delay • Delay between input port and output port ELEN 468 Lecture 6
Signal Transitions • Rising • 0->1, x->1, z->1 • Falling • 1->0, x->0, z->0 • Turnoff • 0->z, 1->z, x->z ELEN 468 Lecture 6
Model Delay Uncertainties:Min, Typical and Max Delays • Process variations • Defects, etching errors, photomask misalignment … • Power-ground noise • Power supply level lower than ideal level • Ground voltage level greater than zero • Crosstalk noise • Signal switching in neighboring wires causes extra net delay ELEN 468 Lecture 6
Gate Delay • and (yout, x1, x2); // default, zero gate delay • and #3 (yout, x1, x2); // 3 units delay for all transitions • and #(2,3) G1(yout, x1, x2); // rising, falling delay • and #(2,3) G1(yout, x1, x2), G2(yout2, x3, x4); // Multiple instances • a_buffer #(3,5,2) (yout, x); // UDP, rise, fall, turnoff • bufif1 #(3:4:5, 6:7:9, 5:7:8) (yout, xin, enable); // min:typ:max / rise, fall, turnoff • Simulators simulate with only one of min, typ and max delay values • Selection is made through compiler directives or user interfaces • Default delay is typ delay ELEN 468 Lecture 6
Options for Delay Specifications • dr = rising delay, df = falling delay, dz = turnoff delay • If 2 delays are specified • d* = d** = min ( dr, df ) • If 3 delays are specified • d* = min( dr, df, dz ), d** = dz ELEN 468 Lecture 6
Time Scales • Time scale directive: ‘ timescale <time_unit>/<time_precision> • time_unit -> physical unit of measure, time scale of delay • time_precision -> time resolution/minimum step size during simulation • time_unit time_precision ELEN 468 Lecture 6
Example of Time Scale `timescale 1 ns / 10 ps module modA( y, x1, x2 ); input x1, x2; output y; nand #(3.225, 4.237) ( y, x1, x2 ); endmodule `timescale 10 ns / 10 ns module modB(); reg x1, x2; wire y; modA M1(y, x1, x2); initial begin $monitor ( $time, “%f x1= %b x2= %b y= %b”, $realtime, x1, x2, y ); end initial begin #5 x1 = 0; x2 = 0; #5 x2 = 1; #5 x1 = 1; #5 x2 = 0; end endmodule ELEN 468 Lecture 6
`timescale 1 ns / 10 ps module modA( y, x1, x2 ); … … nand #(3.225, 4.237) ( y, x1, x2 ); endmodule `timescale 10 ns / 10 ns module modB(); … … modA M1(y, x1, x2); initial begin $monitor ( $time, “%f x1= %b x2= %b y= %b”, $realtime, x1, x2, y ); end initial begin #5 x1 = 0; x2 = 0; #5 x2 = 1; #5 x1 = 1; #5 x2 = 0; end endmodule $t $real_t x1 x2 y ------------------------------------------------- 0 0.000000 x1=x x2=x y=x 5 5.000000 x1=0 x2=0 y=x 5 5.323000 x1=0 x2=0 y=1 10 10.000000 x1=0 x2=1 y=1 15 15.000000 x1=1 x2=1 y=1 15 15.424000 x1=1 x2=1 y=0 20 20.000000 x1=1 x2=0 y=0 20 20.323000 x1=1 x2=0 y=1 Example of Time Scale ELEN 468 Lecture 6
`timescale 1 ns / 1 ps module modA( y, x1, x2 ); … … nand #(3.225, 4.237) ( y, x1, x2 ); endmodule `timescale 10 ns / 10 ns module modB(); … … modA M1(y, x1, x2); initial begin $timeformat (-12, 1, “ ps”, 10); $monitor ( $time, “%f x1= %b x2= %b y= %b”, $realtime, x1, x2, y ); end initial begin #5 x1 = 0; x2 = 0; #5 x2 = 1; #5 x1 = 1; #5 x2 = 0; end endmodule $t $real_t x1 x2 y ------------------------------------------------- 50000. 0ps 0.000000 x1=x x2=x y=x 50000. 0ps 5.000000 x1=0 x2=0 y=x 53225. 0ps 5.322500 x1=0 x2=0 y=1 100000. 0ps 10.000000 x1=0 x2=1 y=1 150000. 0ps 15.000000 x1=1 x2=1 y=1 154237. 0ps 15.423700 x1=1 x2=1 y=0 200000. 0ps 20.000000 x1=1 x2=0 y=0 203225. 0ps 20.322500 x1=1 x2=0 y=1 Time Display Format $timeformat ( units_number, precision_number, suffix_string, min_field_width ); ELEN 468 Lecture 6
Unit Number in Time Format ELEN 468 Lecture 6
2 2 2 2 2 4 4 4 4 4 6 6 6 6 6 8 8 8 8 8 10 10 10 10 10 Net Delay … … wire #2 y_tran; and #3 (y_tran, x1, x2); buf #1 (buf_out, y_tran); and #3 (y_inertial, x1, x2); … … x1 x2 y_inertial x1 y_tran buf_out y_tran x2 y_inertial buf_out ELEN 468 Lecture 6
module xor1( y, a, b ); input a, b; output y; parameter delay = 5; assign #delay y = a ^ b; endmodule module xor2( y, a, b ); input a, b; output y; wire #5 y; assign y = a ^ b; endmodule Examples of Net Delay module xor3( y, a, b ); input a, b; output y; parameter wire_delay = 5; parameter gate_delay =3; wire #wire_delay y; assign #gate_delay y = a ^ b; endmodule ELEN 468 Lecture 6
Module Delays and Paths • In structural description, module delays can be obtained by tracing gate and net delays • In behavioral description, module paths can be described separately to allow delay descriptions ELEN 468 Lecture 6
Module Paths • Simple module paths • Unconditional direct input to output path • State-dependent paths • Exists when certain condition is satisfied • Describe transparent latch • Edge-dependent paths • Exists for a synchronizing signal • Describe edge-triggered flip-flop ELEN 468 Lecture 6
Simple Module Path • Source of path must be a net declared as input or output • Destination of path must be a net or reg declared as output or inout Full connection paths, “*>” Parallel paths, “=>” ELEN 468 Lecture 6
Example of Simple Module Path Delay A module nand1( out, A, B ); output out; input A, B; nand ( out, A, B ); specify ( A,B *> out ) = ( 15, 14, 11, 10, 16,15 ); // 0->1, 1->0, 0->z, z->1, 1->z, z->0 endspecify endmodule out B • Specify blocks declare paths • Its path can override structural delays ELEN 468 Lecture 6
Edge-Sensitive Paths module edge_FF ( clock, data, clear, preset, q ); input clock, data, clear, preset; output q; specify specparam t_rise_clk_q = 100; t_fall_clk_q = 120; t_rise_ctl_q = 50; t_fall_ctl_q = 60; ( posedge clock *> (q:data) ) = ( t_rise_clk_q, t_fall_clk_q ); ( clear, preset *> q ) = ( t_rise_ctl_q, t_fall_ctl_q ); endspecify … … endmodule ELEN 468 Lecture 6
State-Dependent Paths specify if ( enable ) ( data *> q ) = ( t_rise_clk_q, t_fall_clk_q ); endspecify specify if ( !set && !clear ) ( posedge clock *> ( q:data )) = ( t_rise_clk_q, t_fall_clk_q ); endspecify ELEN 468 Lecture 6
Path Polarity Specify whether a transition at output of a path has the same direction (rising or falling) as the input ( siga +*> q1 ) = delay_to_q1; // positive path polarity ( sigb -*> q2 ) = delay_to_q2; // negative path polarity ( sigc *> q3 ) = delay_to_q3; // unknown polarity ELEN 468 Lecture 6
Specify Block Parameters module nand1 ( O, A, B ); input A, B; output O; nand ( O, A, B ); specify specparam T01 = 1.13:3.09:7.75; T10 = 0.93:2.50:7.34; ( A=>O ) = ( T01, T10 ); ( B=>O ) = ( T01, T10 ); endspecify endmodule Local to specify block ELEN 468 Lecture 6
Specify Pulse Width module nand1 ( O, A, B ); input A, B; output O; nand ( O, A, B ); specify specparam T01 = 1.13:3.09:7.75; T10 = 0.93:2.50:7.34; ( A=>O ) = ( T01, T10 ); ( B=>O ) = ( T01, T10 ); pathpulse$ (0.0011 : 0.0024 : 0.0057 ); endspecify endmodule Specify inertial delays ELEN 468 Lecture 6
Reject limit Error limit Single value for both reject and error For any other paths not specified Pulse Reject Limit and Error Limit specify ( clk => q ) = 10; ( data => q ) = 7; ( clr, preset *> q ) = 3; specparam pathpulse$ clk$q = ( 3, 8 ); pathpulse$ clr$q = ( 0, 5 ); pathpulse$ = 4; endspecify • If pulse_width < reject_limit, pulse is rejected • If reject_limit < pulse_width < error_limit, ‘x’ is at output • If error_limit < pulse_width, signal is transported to output ELEN 468 Lecture 6