IEEE 1164
The IEEE 1164 standard is a technical standard published by the IEEE in 1993. It describes the definitions of logic values to be used in electronic design automation, for the VHDL hardware description language. It was sponsored by the Design Automation Standards Committee of the Institute of Electrical and Electronics Engineers. The standardization effort was based on the donation of the Synopsys MVL-9 type declaration.
The primary data type std_ulogic consists of nine character literals in the following order:
Character | Value |
'U' | uninitialized |
'X' | strong drive, unknown logic value |
'0' | strong drive, logic zero |
'1' | strong drive, logic one |
'Z' | high impedance |
'W' | weak drive, unknown logic value |
'L' | weak drive, logic zero |
'H' | weak drive, logic one |
'-' | don't care |
This system promoted a useful set of logic values that typical CMOS logic designs could implement in the vast majority of modeling situations. The
'Z'
literal makes tri-state buffer logic easy. The 'H'
and 'L'
weak drives permit wired-AND and wired-OR logic. Additionally, the 'U'
state is the default value for all object declarations so that during simulations uninitialized values are easily detectable and thus easily corrected if necessary.In VHDL, the hardware designer makes the declarations visible via the following
library
and use
statements:library IEEE;
use IEEE.std_logic_1164.all;
Using values in simulation
Use of 'U'
Many hardware description language simulation tools, such as Verilog and VHDL, support an unknown value like that shown above during simulation of digital electronics. The unknown value may be the result of a design error, which the designer can correct before synthesis into an actual circuit. The unknown also represents uninitialised memory values and circuit inputs before the simulation has asserted what the real input value should be.HDL synthesis tools usually produce circuits that operate only on binary logic.
Use of '-'
When designing a digital circuit, some conditions may be outside the scope of the purpose that the circuit will perform. Thus, the designer does not care what happens under those conditions. In addition, the situation occurs that inputs to a circuit are masked by other signals so the value of that input has no effect on circuit behaviour.In these situations, it is traditional to use
'X'
as a placeholder to indicate "Don't Care" when building truth tables, but VHDL uses -
. "Don't care"s are especially common in state machine design and Karnaugh map simplification. The '-'
values provide additional degrees of freedom to the final circuit design, generally resulting in a simplified and smaller circuit.Once the circuit design is complete and a real circuit is constructed, the
'-'
values will no longer exist. They will become some tangible '0'
or '1'
value but could be either depending on the final design optimization.Use of 'Z'
Some digital devices support a form of three-state logic on their outputs only. The three states are "0", "1", and "Z".Commonly referred to as tristate logic, it comprises the usual true and false states, with a third transparent high impedance state which effectively disconnects the logic output. This provides an effective way to connect several logic outputs to a single input, where all but one are put into the high impedance state, allowing the remaining output to operate in the normal binary sense. This is commonly used to connect banks of computer memory and other similar devices to a common data bus; a large number of devices can communicate over the same channel simply by ensuring only one is enabled at a time.
While outputs can have one of three states, inputs can only recognise two. Although it could be argued that the high-impedance state is effectively an "unknown", there is no provision in most electronics to interpret a high-impedance state as a state in itself. Inputs can only detect "0" and "1".
When a digital input is left disconnected, the digital value interpreted by the input depends on the type of technology used. TTL technology will reliably default to a "1" state. On the other hand, CMOS technology will temporarily hold the previous state seen on that input. Over time, leakage current causes the CMOS input to drift in a random direction, possibly causing the input state to flip. Disconnected inputs on CMOS devices can pick up noise, they can cause oscillation, the supply current may dramatically increase or the device may completely destroy itself.