

# 1164 PACKAGES QUICK REFERENCE CARD

## Revision 2.1

| ()     |     | rouping       | []       | Optional        |
|--------|-----|---------------|----------|-----------------|
| {}     |     | epeated       | ı        | Alternative     |
| bolo   | A t | s is          | CAPS     | User Identifier |
| italic | : V | HDL-93        | С        | commutative     |
| b      | ::= | BIT           |          |                 |
| bv     | ::= | BIT_VECTOR    |          |                 |
| u/l    | ::= | STD_ULOGIC    | STD_LC   | OGIC            |
| uv     | ::= | STD_ULOGIC    | _VECTO   | R               |
| lv     | ::= | STD_LOGIC_    | VECTOR   |                 |
| un     | ::= | UNSIGNED      |          |                 |
| sg     | ::= | SIGNED        |          |                 |
| in     | ::= | INTEGER       |          |                 |
| na     | ::= | NATURAL       |          |                 |
| sm     | ::= | SMALL_INT     |          |                 |
|        |     | (subtype INTE | GER rang | ge 0 to 1)      |

# 1. IEEE's STD\_LOGIC\_1164

# 1.1. LOGIC VALUES

| 'U'         | Uninitialized       |
|-------------|---------------------|
| 'X'/'W'     | Strong/Weak unknown |
| '0'/'L'     | Strong/Weak 0       |
| '1'/'H'     | Strong/Weak 1       |
| <b>'Z</b> ' | High Impedance      |
| <b>'_'</b>  | Don't care          |
|             |                     |

## 1.2. PREDEFINED TYPES

| STD_ULUGIC | Base type               |
|------------|-------------------------|
| Subtypes:  |                         |
| STD_LOGIC  | Resolved STD_ULOGIC     |
| X01        | Resolved X, 0 & 1       |
| X01Z       | Resolved X, 0, 1 & Z    |
| UX01       | Resolved U, X, 0 & 1    |
| UX01Z      | Resolved U, X, 0, 1 & Z |
|            |                         |

# STD\_ULOGIC\_VECTOR(na to | downto na)

Array of STD\_ULOGIC

STD\_LOGIC\_VECTOR(na to | downto na)

Array of STD\_LOGIC

## © 1995-1998 Qualis Design Corporation

## 1.3. OVERLOADED OPERATORS

| Description | Left      | Operator         | Right     |
|-------------|-----------|------------------|-----------|
| bitwise-and | u/l,uv,lv | and, nand        | u/l,uv,lv |
| bitwise-or  | u/l,uv,lv | or, nor          | u/l,uv,lv |
| bitwise-xor | u/l,uv,lv | xor, <i>xnor</i> | u/l,uv,lv |
| bitwise-not |           | not              | u/l,uv,lv |

## 1.4. Conversion Functions

| From  | To  | Function                   |
|-------|-----|----------------------------|
| u/l   | b   | TO_BIT(from[, xmap])       |
| uv,lv | bv  | TO_BITVECTOR(from[, xmap]) |
| b     | u/l | TO_STDULOGIC(from)         |
| bv,uv | lv  | TO_STDLOGICVECTOR(from)    |
| bv,lv | uv  | TO_STDULOGICVECTOR(from)   |

# 2. IEEE'S NUMERIC STD

#### 2.1. PREDEFINED TYPES

UNSIGNED(na to | downto na) Array of STD\_LOGIC SIGNED(na to | downto na) Array of STD\_LOGIC

# 2.2. OVERLOADED OPERATORS

| Left | Op                        | Right | Return |
|------|---------------------------|-------|--------|
|      | abs                       | sg    | sg     |
|      | -                         | sg    | sg     |
| un   | +,-,*,/,rem,mod           | un    | un     |
| sg   | +,-,*,/,rem,mod           | sg    | sg     |
| un   | +,-,*,/,rem,mod           | na na | un     |
| sg   | +,-,*,/,rem,mod           | ; in  | sg     |
| un   | <,>,<=,>=,=, <b>/</b> =   | un    | bool   |
| sg   | <,>,<=,>=,=, <b>/</b> =   | sg    | bool   |
| un   | <,>,<=,>=,=, <b>/</b> = c | na    | bool   |
| sg   | <,>,<=,>=,=, <b>/</b> = c | In    | bool   |

# 2.3. PREDEFINED FUNCTIONS

| SHIFT_LEFT(un, na)   | un   |
|----------------------|------|
| SHIFT_RIGHT(un, na)  | un   |
| SHIFT_LEFT(sg, na)   | sg   |
| SHIFT_RIGHT(sg, na)  | sg   |
| ROTATE_LEFT(un, na)  | un   |
| ROTATE_RIGHT(un, na) | un   |
| ROTATE_LEFT(sg, na)  | sg   |
| ROTATE_RIGHT(sg, na) | sg   |
| RESIZE(sg, na)       | sg   |
| RESIZE(un, na)       | un   |
| STD_MATCH(u/l, u/l)  | bool |
| STD_MATCH(ul, ul)    | bool |
| STD_MATCH(Iv, Iv)    | bool |
| STD_MATCH(un, un)    | bool |
| STD_MATCH(sg, sg)    | bool |

## 2.4. Conversion Functions

| From  | To | Function                |
|-------|----|-------------------------|
| un,lv | sg | SIGNED(from)            |
| sg,lv | un | UNSIGNED(from)          |
| un,sg | lv | STD_LOGIC_VECTOR(from)  |
| un,sg | in | TO_INTEGER(from)        |
| na    | un | TO_UNSIGNED(from, size) |
| in    | sg | TO_SIGNED(from, size)   |

# 3. IEEE's NUMERIC BIT

## 3.1. PREDEFINED TYPES

UNSIGNED(na to | downto na) Array of BIT SIGNED(na to | downto na) Array of BIT

## 3.2. OVERLOADED OPERATORS

| Left | Op                                   | Right | Return |
|------|--------------------------------------|-------|--------|
|      | abs                                  | sg    | sg     |
|      | -                                    | sg    | sg     |
| un   | +,-,*,/,rem,mod                      | un    | un     |
| sg   | +,-,*,/,rem,mod                      | sg    | sg     |
| un   | +,-,*,/,rem,mod                      | na    | un     |
| sg   | +,-,*,/,rem,mod                      | in    | sg     |
| un   | <,>,<=,>=,=, <b>/</b> =              | un    | bool   |
| sg   | <,>,<=,>=,=, <b>/</b> =              | sg    | bool   |
| un   | <,>,<=,>=,=, <b>/</b> = <sub>c</sub> | na    | bool   |
| sg   | <,>,<=,>=,=,/= c                     | in    | bool   |

## 3.3. PREDEFINED FUNCTIONS

| SHIFT_LEFT(un, na)   | un |
|----------------------|----|
| SHIFT_RIGHT(un, na)  | un |
| SHIFT_LEFT(sg, na)   | sg |
| SHIFT_RIGHT(sg, na)  | sg |
| ROTATE_LEFT(un, na)  | un |
| ROTATE_RIGHT(un, na) | un |
| ROTATE_LEFT(sg, na)  | sg |
| ROTATE_RIGHT(sg, na) | sg |
| RESIZE(sg, na)       | sg |
| RESIZE(un, na)       | un |

## 3.4. Conversion Functions

| From  | To | Function          |
|-------|----|-------------------|
| un,bv | sg | SIGNED(from)      |
| sg,bv | un | UNSIGNED(from)    |
| un,sg | bv | BIT_VECTOR(from)  |
| un,sg | in | TO_INTEGER(from)  |
| na    | un | TO_UNSIGNED(from) |
| in    | sq | TO SIGNED(from)   |

© 1995-1998 Qualis Design Corporation. Permission to reproduce and distribute strictly verbatim copies of this document in whole is hereby granted.

See reverse side for additional information.

# 4. SYNOPSYS' STD LOGIC ARITH

# 4.1. PREDEFINED TYPES

UNSIGNED(na to | downto na) Array of STD\_LOGIC
SIGNED(na to | downto na) Array of STD\_LOGIC
SMALL\_INT Array of STD\_LOGIC
Integer subtype, 0 or 1

## 4.2. OVERLOADED OPERATORS

| Left | Op                                   | Right | Return |
|------|--------------------------------------|-------|--------|
|      | abs                                  | sg    | sg,lv  |
|      | -                                    | sg    | sg,lv  |
| un   | +,-,*,/                              | un    | un,lv  |
| sg   | +,-,*,/                              | sg    | sg,lv  |
| sg   | +,-,*, <b>/</b> c                    | un    | sg,lv  |
| un   | +,- <sub>c</sub>                     | in    | un,lv  |
| sg   | +,- <sub>c</sub>                     | in    | sg,lv  |
| un   | +,- <sub>c</sub>                     | u/l   | un,lv  |
| sg   | +,- <sub>c</sub>                     | u/l   | sg,lv  |
| un   | <,>,<=,>=,=, <b>/</b> =              | un    | bool   |
| sg   | <,>,<=,>=,=, <b>/</b> =              | sg    | bool   |
| un   | <,>,<=,>=,=, <b>/</b> = <sub>c</sub> | in    | bool   |
| sg   | <,>,<=,>=,=, <b>/</b> = <sub>c</sub> | in    | bool   |

# 4.3. PREDEFINED FUNCTIONS

| SHL(un, un)  | un | SHR(un, un) | un |
|--------------|----|-------------|----|
| SHL(sg, un)  | sg | SHR(sg, un) | sg |
| EXT(lv, in)  | lv | zero-extend |    |
| SEXT(lv, in) | lv | sign-extend |    |

# 4.4. Conversion Functions

| То | Function                         |
|----|----------------------------------|
| sg | SIGNED(from)                     |
| un | UNSIGNED(from)                   |
| lv | STD_LOGIC_VECTOR(from)           |
| in | CONV_INTEGER(from)               |
| un | CONV_UNSIGNED(from, size)        |
| sg | CONV_SIGNED(from, size)          |
| lv |                                  |
|    | sg<br>un<br>lv<br>in<br>un<br>sg |

CONV STD LOGIC VECTOR(from, size)

# 5. SYNOPSYS' STD LOGIC UNSIGNED

# 5.1. OVERLOADED OPERATORS

| Left | Op                                   | Right | Return |
|------|--------------------------------------|-------|--------|
|      | +                                    | ĺv    | lv     |
| lv   | +,-,*                                | lv    | lv     |
| lv   | +,-c                                 | in    | lv     |
| lv   | +,- <sub>c</sub>                     | u/l   | lv     |
| lv   | <,>,<=,>=,=, <b>/</b> =              | lv    | bool   |
| lv   | <,>,<=,>=,=, <b>/</b> = <sub>C</sub> | in    | bool   |

## 5.2. Conversion Functions

| From | To | Function           |
|------|----|--------------------|
| lv   | in | CONV INTEGER(from) |

# 6. SYNOPSYS' STD LOGIC SIGNED

## 6.1. OVERLOADED OPERATORS

| Left | : Op                    | Right | Return |
|------|-------------------------|-------|--------|
|      | abs                     | ĺv    | lv     |
|      | +,-                     | lv    | lv     |
| lv   | +,-,*                   | lv    | lv     |
| lv   | +,-c                    | in    | lv     |
| lv   | +,- <sub>c</sub>        | u/l   | lv     |
| lv   | <,>,<=,>=,=, <b>/</b> = | lv    | bool   |
| lv   | <,>,<=,>=,=,/= c        | in    | bool   |

## 6.2. Conversion Functions

| From | To | Function           |
|------|----|--------------------|
| lv   | in | CONV_INTEGER(from) |

# 7. SYNOPSYS' STD\_LOGIC\_MISC

## 7.1. PREDEFINED FUNCTIONS

| AND_REDUCE(Iv   uv) | u/ |
|---------------------|----|
| OR_REDUCE(lv   uv)  | u/ |
| XOR REDUCE(ly Luv)  | u/ |

# 8. CADENCE'S STD LOGIC ARITH

# 8.1. OVERLOADED OPERATORS

| Left | Op                   | Right | Return |
|------|----------------------|-------|--------|
| u/l  | +,-,*,/              | u/l   | u/l    |
| lv   | +,-,*,/              | lv    | lv     |
| lv   | +,-,*,/ <sub>c</sub> | u/l   | lv     |
| lv   | +,-c                 | in    | lv     |
| uv   | +,-,*                | uv    | uv     |
| uv   | +,-,* <sub>c</sub>   | u/l   | uv     |
| uv   | +,-c                 | in    | uv     |
| lv   | <,>,<=,>=,=,/= c     | in    | bool   |
| uv   | <,>,<=,>=,=,/= c     | in    | bool   |
|      |                      |       |        |

## 8.2. PREDEFINED FUNCTIONS

| SH_LEFT(Iv, na)         | lv    |
|-------------------------|-------|
| SH_LEFT(uv, na)         | uv    |
| SH_RIGHT(Iv, na)        | lv    |
| SH_RIGHT(uv, na)        | uv    |
| ALIGN_SIZE(Iv, na)      | lv    |
| ALIGN_SIZE(uv, na)      | uv    |
| ALIGN_SIZE(u/l, na)     | lv,uv |
| C-like ?: replacements: |       |
| COND_OP(bool, lv, lv)   | lv    |
| COND_OP(bool, uv, uv)   | uv    |
| COND(bool, u/l, u/l)    | u/l   |
|                         |       |

# 8.3. Conversion Functions

| From      | 10 | Function                       |
|-----------|----|--------------------------------|
| lv,uv,u/l | in | TO_INTEGER(from)               |
| in        | lv | TO_STDLOGICVECTOR(from, size)  |
| in        | uv | TO_STDULOGICVECTOR(from, size) |

# 9. MENTOR'S STD LOGIC ARITH

## 9.1. PREDEFINED TYPES

UNSIGNED(na to | downto na) Array of STD\_LOGIC SIGNED(na to | downto na) Array of STD\_LOGIC Array of STD\_LOGIC

## 9.2. OVERLOADED OPERATORS

| Left | <u>Op</u>                | Right | Return |
|------|--------------------------|-------|--------|
|      | abs                      | sg    | sg     |
|      | -                        | sg    | sg     |
| u/l  | +,-                      | u/l   | u/l    |
| uv   | +,-,*,/,mod,rem,**       | uv    | uv     |
| lv   | +,-,*,/,mod,rem,**       | lv    | lv     |
| un   | +,-,*,/,mod,rem,**       | un    | un     |
| sg   | +,-,*,/,mod,rem,**       | sg    | sg     |
| un   | <,>,<=,>=, <b>/</b> =    | un    | bool   |
| sg   | <,>,<=,>=, <b>/</b> =    | sg    | bool   |
|      | not                      | un    | un     |
|      | not                      | sg    | sg     |
| un   | and,nand,or,nor,xor      | un    | un     |
| sg   | and,nand,or,nor,xor,xnor | sg    | sg     |
| uv   | sla,sra,sll,srl,rol,ror  | uv    | uv     |
| lv   | sla,sra,sll,srl,rol,ror  | lv    | lv     |
| un   | sla,sra,sll,srl,rol,ror  | un    | un     |
| sg   | sla,sra,sll,srl,rol,ror  | sg    | sg     |

## 9.3. PREDEFINED FUNCTIONS

| ZERO_EXTEND(uv   lv   un, na) | same |
|-------------------------------|------|
| ZERO_EXTEND(u/l, na)          | lv   |
| SIGN_EXTEND(sg, na)           | sg   |
| AND_REDUCE(uv   lv   un   sg) | u/l  |
| OR_REDUCE(uv   lv   un   sg)  | u/l  |
| XOR REDUCE(uv   Iv   un   sa) | u/l  |

## 9.4. Conversion Functions

| From            | To             | Function                   |
|-----------------|----------------|----------------------------|
| u/l,uv,lv,un,sg | in             | TO_INTEGER(from)           |
| u/l,uv,lv,un,sg | in             | CONV_INTEGER(from)         |
| bool            | u/l            | TO_STDLOGIC(from)          |
| na              | un             | TO_UNSIGNED(from,size)     |
| na              | un             | CONV_UNSIGNED(from,size)   |
| in              | sg             | TO_SIGNED(from,size)       |
| in              | sg             | CONV_SIGNED(from,size)     |
| na              | lv TO_         | STDLOGICVECTOR(from,size)  |
| na              | uv <b>TO</b> _ | STDULOGICVECTOR(from,size) |

© 1995-1998 Qualis Design Corporation. Permission to reproduce and distribute strictly verbatim copies of this document in whole is hereby granted.

# **Qualis Design Corporation**

Elite Consulting and Training in High-Level Design

Phone: +1-503-670-7200 FAX: +1-503-670-0809
E-mail: info@qualis.com Web: http://www.qualis.com
Also available: VHDL Quick Reference Card
Verilog HDL Quick Reference Card