Differences
This shows you the differences between two versions of the page.
| Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
| asic:timing:xcell:start [2024/05/31 18:57] – [Cell definitions] rajit | asic:timing:xcell:start [2024/06/03 16:40] (current) – [Cells with external SPICE netlists and user-defined scenarios] rajit | ||
|---|---|---|---|
| Line 20: | Line 20: | ||
| an output signal '' | an output signal '' | ||
| this is not exposed via its port list. The circuit is specified using the [[language: | this is not exposed via its port list. The circuit is specified using the [[language: | ||
| + | |||
| + | '' | ||
| + | |||
| + | For more complex cells, the user must specify the characterization trajectory in the '' | ||
| + | |||
| + | ===== Configuration file ===== | ||
| + | |||
| + | Typically the configuration file is found in the directory where '' | ||
| + | |||
| + | < | ||
| + | # example xcell configuration | ||
| + | begin xcell | ||
| + | # config goes here | ||
| + | end | ||
| + | </ | ||
| + | |||
| + | By default '' | ||
| + | < | ||
| + | string tech_setup " | ||
| + | </ | ||
| + | This will use '' | ||
| + | |||
| + | < | ||
| + | string corner " | ||
| + | </ | ||
| + | This specifies the process corner name to be included in the '' | ||
| + | |||
| + | < | ||
| + | real Vdd 1.8 | ||
| + | </ | ||
| + | This specifies the power supply voltage to be used during characterization. | ||
| + | |||
| + | < | ||
| + | real T 298 | ||
| + | </ | ||
| + | This specifies the temperature (in Kelvin). | ||
| + | |||
| + | < | ||
| + | real P_value 1.0 | ||
| + | </ | ||
| + | This specifies the process value for the '' | ||
| + | |||
| + | The input capacitance of a gate is characterized by computing the RC delay used to switch it. The characterization resistor is specified using the parameter below. | ||
| + | < | ||
| + | real R_value 100 # in KOhms | ||
| + | </ | ||
| + | |||
| + | The units for the '' | ||
| + | < | ||
| + | begin units | ||
| + | real power_conv 1e-6 | ||
| + | real resis_conv 1e3 | ||
| + | real time_conv 1e-12 | ||
| + | real cap_conv 1e-15 | ||
| + | real current_conv 1e-6 | ||
| + | end | ||
| + | </ | ||
| + | |||
| + | Waveforms used for characterization and transit time threshold computations for rising and falling edges are specified as below. | ||
| + | < | ||
| + | begin waveform | ||
| + | # 20% to 80% | ||
| + | real rise_low 20 | ||
| + | real rise_high 80 | ||
| + | |||
| + | real fall_high 80 | ||
| + | real fall_low 20 | ||
| + | end | ||
| + | </ | ||
| + | |||
| + | ==== Cells with external SPICE netlists and user-defined scenarios ==== | ||
| + | |||
| + | The following is an example of a cell that needs special support for characterization. | ||
| + | |||
| + | < | ||
| + | begin cells | ||
| + | # the full ACT name of the cell | ||
| + | begin :: | ||
| + | |||
| + | # for an external netlist, uncomment the next line | ||
| + | # string spice " | ||
| + | |||
| + | # characterization arcs | ||
| + | begin scenario | ||
| + | # scenario format | ||
| + | # | ||
| + | # | ||
| + | # | ||
| + | # | ||
| + | # | ||
| + | # | ||
| + | # | ||
| + | # | ||
| + | # | ||
| + | |||
| + |  | ||
| + | 0 0 1 1 3 2 0 1 \ | ||
| + | 1 0 0 1 3 1 0 2 \ | ||
| + | 1 0 1 0 3 1 0 2 | ||
| + | |||
| + |  | ||
| + | " | ||
| + | |||
| + | end | ||
| + | end | ||
| + | end | ||
| + | </ | ||
| + | |||
| + | The '' | ||
| + | * Step 1: apply an input vector to set the output vector to say zero. | ||
| + | * Step 2: change one of the inputs to cause the output to make a zero to one transition. | ||
| + | (State-holding gates can require more complex scenarios for characterization.) | ||
| + | |||
| + | The input vector is specified as an unsigned integer that corresponds to the values of all the input bits. The order is the same order as in the SPICE cell corresponding to subcircuit for the cell generated by ACT (e.g the same output order as you would find by running '' | ||