APPLICATION NOTE

Xilinx has acquired the entire Philips CoolRunner Low Power CPLD Product Family. For more technical or sales information, please see: www.xilinx.com

**XAPP 303**

Altera (AHDL) to Philips (PHDL) design conversion guidelines

Author: Reno L. Sanchez 1998 Jun 26
Altera (AHDL) to Philips (PHDL) design conversion guidelines

Xilinx has acquired the entire Philips CoolRunner Low Power CPLD Product Family. For more technical or sales information, please see: www.xilinx.com

DOCUMENT SCOPE
This document provides information required to translate an Altera Hardware Description Language (AHDL) based design into a Philips Hardware Description Language (PHDL) based design. Designs which should be targeted for conversions are ones in which the customer system needs require one of Philips CoolRunner CPLD advanced features including: dramatic power savings, increased routability with fixed pins, and higher logic density, etc.

This memorandum first gives the key conversion factors which must be addressed before the design conversion is attempted. If these key conversion factors are not met, the design conversion has no possibility of success and the designer should not attempt the conversion. In other words, the factors given in this section must be satisfied or the design conversion is not possible (with fixed pins). If these factors are satisfied, then the designer should attempt the design conversion.

Terminology
- AHDL: Altera Hardware Description Language
- CPLD: Complex Programmable Logic Device
- CR32: CoolRunner 32 Macrocell CPLD
- CR32CS: CoolRunner 32 Macrocell ISP and Enhanced Clocking CPLD
- CR64: CoolRunner 64 Macrocell CPLD
- CR64CS: CoolRunner 64 Macrocell ISP and Enhanced Clocking CPLD
- CR128: CoolRunner 128 Macrocell CPLD
- CR128CS: CoolRunner 128 Macrocell ISP and Enhanced Clocking CPLD
- CR320: CoolRunner 320 Macrocell CPLD
- CR960: CoolRunner 960 Macrocell CPLD
- DFF: D type flip-flop
- DFFE: D-type flip-flop with Clock Enable
- JKFF: JK type flip-flop
- JKFFE: JK-type flip-flop with Clock Enable
- OE: Output Enable
- PHDL: Philips Hardware Description Language
- SRFFE: SR-type flip-flop with Clock Enable
- TFF: T type flip-flop
- TFFE: T-type flip-flop with Clock Enable
- XPLA1: Philips CoolRunner CPLD family ranging from 32 to 128 Macrocells

KEY CONVERSION FACTORS
This section gives the key conversion factors which must be addressed before the design conversion is attempted. If these key conversion factors are not met, the design conversion has no possibility of success and the designer should not attempt the conversion. In other words, the factors given in this section must be satisfied or the design conversion is not possible (with fixed pins). If these factors are satisfied, then the designer should attempt the design conversion.

Number of Macrocells
First and foremost, one must ensure that the number of macrocells between an Altera CPLD and a Philips CPLD are equivalent. One should attempt to convert a 32 macrocell Altera CPLD (EPM7032) into a 32 macrocell Philips CPLD (PZ5032). In some cases however, it may be possible to fit a larger macrocell Altera CPLD (i.e. EPM7064) into a smaller Philips CPLD (i.e. PZ5032) if the design is logic (product term) constrained and not macrocell constrained.

Clocking
The clocking approach taken is dependent on which CoolRunner family is being used. The XPLA1 enhanced clocking CPLDs (CR32CS, CR64CS, and CR128CS) have more clocking capabilities than the XPLA1 non-enhanced clocking CPLDs (CR32, CR64, and CR128). The XPLA1 non-enhanced clocking CPLDs have either 2 or 4 clock pins, depending on macrocell count (see Table 2). The XPLA1 enhanced clocking CPLDs have the same clocks pins but also contain 2 additional control term clocks per logic block. These control term clocks can be used to make any input a clock resource. Therefore, it is much easier to match the pinout of a corresponding Altera CPLD to a XPLA1 enhanced clocking device than to a XPLA1 non-enhanced clocking device. The main constraint for the XPLA1 enhanced clocking devices to be pin compatible (in the context of clocking constraints) with the Altera MAX7000 family is the number of available clocks. As long as the maximum number of clocks is not exceeded, the XPLA1 enhanced clocking CPLDs should be pin compatible. Table 1 gives the number of clocks provided by the XPLA1 enhanced clocking CPLDs.

The approach is much different with the XPLA1 non-enhanced clocking CPLDs. Before starting the design conversion, one must ensure that all clocks used in the design conform to the Philips CoolRunner pinout. Table 1 gives the Philips CoolRunner clock pinout for the CR32, CR64, and CR128 CPLDs. Please note that CLK0 is a Synchronous clock (must be driven by an external source) while CLK1, CLK2, and CLK3 can be used as either Synchronous clocks (driven by an external source) or Asynchronous clocks (driven by a macrocell equation).

If the design uses any pin as a clock that is different than the ones specified in Table 1, the design will not be pin compatible with the CoolRunner CPLD. However, as long as the number of clocks in the design does not exceed the number of clocks offered by the specific CoolRunner CPLD, the design will probably still fit. What you lose in this case is pin compatibility with the corresponding Altera MAX7000 CPLD. Your decision on whether or not to proceed with the design conversion depends on whether pin compatibility is important. If pin compatibility is a requirement, then there is no reason to convert the design. However, if pin compatibility is not a requirement, then you should convert the design.

Table 1. XPLA1 Enhanced Clocking Clock Resources

<table>
<thead>
<tr>
<th>Device</th>
<th># of Clocks Pins</th>
<th># of Control Term Clocks</th>
<th>Total # of Clocks</th>
</tr>
</thead>
<tbody>
<tr>
<td>CR32CS</td>
<td>2</td>
<td>4</td>
<td>6</td>
</tr>
<tr>
<td>CR64CS</td>
<td>4</td>
<td>8</td>
<td>12</td>
</tr>
<tr>
<td>CR128CS</td>
<td>4</td>
<td>16</td>
<td>20</td>
</tr>
<tr>
<td>CR3320</td>
<td>8</td>
<td>32</td>
<td>40</td>
</tr>
<tr>
<td>CR3960</td>
<td>8</td>
<td>96</td>
<td>104</td>
</tr>
</tbody>
</table>

1998 Jun 26
Table 2. XPLA1 Non-enhanced Clocking Clock Pinouts

<table>
<thead>
<tr>
<th>Package/Device</th>
<th>Clock</th>
<th>Clock Type</th>
<th>44 PLCC</th>
<th>44 TQFP</th>
<th>48 PLCC</th>
<th>48 TQFP</th>
<th>84 PLCC</th>
<th>84 TQFP</th>
<th>100 PQFP</th>
<th>100 TQFP</th>
<th>128 LQFP</th>
<th>160 PQFP</th>
</tr>
</thead>
<tbody>
<tr>
<td>CR32</td>
<td>CLK0</td>
<td>Sync</td>
<td>43</td>
<td>43</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>CLK1</td>
<td>Sync/Async</td>
<td>4</td>
<td>4</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CR64</td>
<td>CLK0</td>
<td>Sync</td>
<td>43</td>
<td>43</td>
<td>67</td>
<td>83</td>
<td>89</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>CLK1</td>
<td>Sync/Async</td>
<td>24</td>
<td>18</td>
<td>36</td>
<td>44</td>
<td>42</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>CLK2</td>
<td>Sync/Async</td>
<td>21</td>
<td>15</td>
<td>33</td>
<td>41</td>
<td>39</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>CLK3</td>
<td>Sync/Async</td>
<td>4</td>
<td>41</td>
<td>4</td>
<td>4</td>
<td>94</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CR128</td>
<td>CLK0</td>
<td>Sync</td>
<td></td>
<td></td>
<td>83</td>
<td>89</td>
<td>87</td>
<td>114</td>
<td>139</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>CLK1</td>
<td>Sync/Async</td>
<td></td>
<td></td>
<td>44</td>
<td>42</td>
<td>40</td>
<td>53</td>
<td>62</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>CLK2</td>
<td>Sync/Async</td>
<td></td>
<td></td>
<td>41</td>
<td>39</td>
<td>37</td>
<td>50</td>
<td>59</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>CLK3</td>
<td>Sync/Async</td>
<td></td>
<td></td>
<td>4</td>
<td>94</td>
<td>92</td>
<td>119</td>
<td>144</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

If the number of clocks used in the design exceeds the number of clocks contained within the targeted Philips CPLD, then the design will not fit. It may be possible to convert asynchronous clocks in an Altera design to synchronous clocks by modifying the original design. Of course, any design modifications must be tested to insure functionality.

Reset/Preset/Output Enable

The final restriction is reset/preset/oe functionality. The Philips CoolRunner CPLDs have the ability to provide either 36 AND terms or 36 SUM terms (control terms) for each preset/reset/oe function without using any of the macrocells. For example:

- signal.ar = A & B & C & ... – up to 36 terms
- signal.oe = A # B # C # ... – up to 36 terms

However, if a combination of AND and SUM terms are needed to control reset/preset/oe, then a macrocell must be used as an internal node to generate the sum of product signal. For example:

node = (A & B) # (C & D);

signal.ar = node;

In the Altera MAX7000 family, a macrocell is not needed for a very limited set of combination of AND and SUM terms which control the reset/preset/oe function.

STRUCTURE TRANSLATION

This section describes the structural differences between the AHDL and PHDL languages.

AHDL Structure

An AHDL file is broken into several sections including: a Header section, a Design Section, a Subdesign section, a Variable section, and a Logic section. An example of the AHDL structure is given in Figure 1. Listed below is a brief description of each section:

- The Header section can contain the following items: Title Statement, a Constant Statement, a Function Prototype Statement, an Include Statement, and an Options Statement.
- The optional Design Section specifies pin, buried logic cell, chip, clique, logic option, and device assignments.

- The Subdesign Section declares the input, output, and bi-directional ports of the file.
- The Variable Section is used to declare any variable used in the Logic Sections. These variables include both external and internal logic.
- The Logic Section specifies the logical operations of the design file and is the body of the Subdesign Section.

PHDL Structure

A PHDL file is broken into four distinct sections: the Header, the Declarations, the Logic Description, and the End. An example of the PHDL structure is given in Figure 2. Listed below is a brief description of each section:

- The Header section contains descriptive information about the design. This section must contain a name for the PHDL file and it can contain title and property statements.
- The Declaration section is where constants, variables, signals, and macro functions are declared and initialized. The start of the declaration section is indicated by the reserved word “Declarations” placed by itself on one line and the declarations that follow.
- The Logic section is where the design is defined by establishing relationships between the inputs and outputs created in the Declaration section. The design may be defined using equations, state machines, or truth tables.
- All PHDL files must close with the reserved word “end”.

Key Structural Differences

The key differences between the PHDL and AHDL design file structure is the way pins and outputs of logic functions are defined. In PHDL, if the output of the logic function drives an external pin, the name of function can be the same as the pin name and only needs to be declared once. In AHDL, if the output of the logic function drives an external pin, the name of function must be different from the pin name and the two must be equated in the Logic section. This can be confusing in AHDL because it is not obvious which logic will drive external pins and which are used as buried logic until you examine the entire AHDL file. In PHDL, all node and pin declarations
are made in the Declaration section near the front of the PHDL file where the user can easily distinguish between logic which drives external pins and logic which drives internal nodes.

**LANGUAGE TRANSLATION**
The following subsections give the PHDL equivalent for keywords, operators, and ports for primary inputs. These subsections can serve as a quick reference as you begin creating designs with PHDL.

**Keyword cross-reference**
Table 3 lists AHDL keywords in the first column and gives the PHDL equivalents in the second column.

### Table 3. AHDL – PHDL Keyword Cross Reference

<table>
<thead>
<tr>
<th>AHDL Keyword</th>
<th>PHDL Equivalent or Cross Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>CASE</td>
<td>CASE</td>
</tr>
<tr>
<td>DEVICE IS</td>
<td>DEVICE</td>
</tr>
<tr>
<td>ELSE, ELSIF, and END IF</td>
<td>ELSE</td>
</tr>
<tr>
<td>END CASE</td>
<td>END_CASE</td>
</tr>
<tr>
<td>AHDL State Machine section</td>
<td>ENDWITH</td>
</tr>
<tr>
<td>AHDL Logic Section</td>
<td>EQUATIONS</td>
</tr>
<tr>
<td>AHDL Options Statement</td>
<td>FLAG</td>
</tr>
<tr>
<td>None</td>
<td>FUSES</td>
</tr>
<tr>
<td>AHDL State Machine Section</td>
<td>GOTO</td>
</tr>
<tr>
<td>IF</td>
<td>IF</td>
</tr>
<tr>
<td>AHDL Subdesign Section</td>
<td>IN</td>
</tr>
<tr>
<td>AHDL Primitives</td>
<td>ISTYPE</td>
</tr>
<tr>
<td>AHDL Function Prototype Statement</td>
<td>LIBRARY</td>
</tr>
<tr>
<td>AHDL Function Prototype Statement</td>
<td>MACRO</td>
</tr>
<tr>
<td>DESIGN IS</td>
<td>MODULE</td>
</tr>
<tr>
<td>NODE</td>
<td>NODE</td>
</tr>
<tr>
<td>@</td>
<td>PIN</td>
</tr>
<tr>
<td>WITH STATES</td>
<td>STATE</td>
</tr>
<tr>
<td>MACHINE OF BITS</td>
<td>STATE_DIAGRAM</td>
</tr>
<tr>
<td>THEN</td>
<td>THEN</td>
</tr>
<tr>
<td>TITLE</td>
<td>TITLE</td>
</tr>
<tr>
<td>TABLE</td>
<td>TRUTH_TABLE</td>
</tr>
<tr>
<td>WHEN</td>
<td>WHEN</td>
</tr>
<tr>
<td>AHDL State Machine Section</td>
<td>WITH</td>
</tr>
</tbody>
</table>

### Operator Equivalents
Table 4 shows AHDL operators and their PHDL equivalents. Each operator’s priority is listed in parentheses beside the symbol for both AHDL and PHDL operators. The operators are similar in AHDL and PHDL.

### Table 4. AHDL – PHDL Operator Equivalents

<table>
<thead>
<tr>
<th>AHDL</th>
<th>PHDL</th>
<th>Operation</th>
</tr>
</thead>
<tbody>
<tr>
<td>–</td>
<td>– (1)</td>
<td>negation</td>
</tr>
<tr>
<td>!</td>
<td>! (1)</td>
<td>NOT (invert)</td>
</tr>
<tr>
<td>+</td>
<td>+ (2)</td>
<td>arithmetic addition</td>
</tr>
<tr>
<td>–</td>
<td>– (2)</td>
<td>arithmetic subtraction</td>
</tr>
<tr>
<td>= =</td>
<td>= = (3)</td>
<td>equal to</td>
</tr>
<tr>
<td>! =</td>
<td>! = (3)</td>
<td>not equal to</td>
</tr>
<tr>
<td>&lt;</td>
<td>&lt; (3)</td>
<td>less than</td>
</tr>
<tr>
<td>&lt;=</td>
<td>&lt;= (3)</td>
<td>less than or equal to</td>
</tr>
<tr>
<td>&gt;</td>
<td>&gt; (3)</td>
<td>greater than</td>
</tr>
<tr>
<td>&gt;=</td>
<td>&gt;= (3)</td>
<td>greater than or equal to</td>
</tr>
<tr>
<td>&amp;</td>
<td>&amp; (4)</td>
<td>AND</td>
</tr>
<tr>
<td>!&amp;</td>
<td>none</td>
<td>NAND (invert AND)</td>
</tr>
<tr>
<td>$</td>
<td>$ (5)</td>
<td>XOR (exclusive OR)</td>
</tr>
<tr>
<td>!$</td>
<td>$ (5)</td>
<td>XNOR (exclusive NOR)</td>
</tr>
<tr>
<td>#</td>
<td># (6)</td>
<td>OR</td>
</tr>
<tr>
<td>! #</td>
<td>none</td>
<td>NOR (invert OR)</td>
</tr>
</tbody>
</table>

### Dot Extensions
In both AHDL and PHDL, dot extensions are used to connect the features of the macrocell. The ports of an instance of a function are declared in the following format:

```
<macrocell>.<dot extension>
```

Table 5 shows the AHDL and PHDL dot extension notations for connections to macrocell logic.

### Table 5. AHDL – PHDL Dot Extensions

<table>
<thead>
<tr>
<th>AHDL</th>
<th>PHDL</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>.d</td>
<td>.D</td>
<td>D input to D flip-flop</td>
</tr>
<tr>
<td>.t</td>
<td>.T</td>
<td>T input to T flip-flop</td>
</tr>
<tr>
<td>.q</td>
<td>.Q</td>
<td>Register feedback</td>
</tr>
<tr>
<td>.j</td>
<td>.J</td>
<td>J input to JK flip-flop</td>
</tr>
<tr>
<td>.k</td>
<td>.K</td>
<td>K input to JK flip-flop</td>
</tr>
<tr>
<td>.s</td>
<td>.S</td>
<td>S input to SR flip-flop</td>
</tr>
<tr>
<td>.r</td>
<td>.R</td>
<td>R input to SR flip-flop</td>
</tr>
<tr>
<td>.clk</td>
<td>.C</td>
<td>Clock to flip-flop</td>
</tr>
<tr>
<td>.pm</td>
<td>.AP</td>
<td>Preset</td>
</tr>
<tr>
<td>.clrn</td>
<td>.AR</td>
<td>Clear</td>
</tr>
<tr>
<td>TRI</td>
<td>.OE</td>
<td>Tri-state buffer</td>
</tr>
</tbody>
</table>
AHDL has active-low Preset and Clear signals to all flip-flop types:
DFF, DFFE, TFF, TFFE, JKFF, JKFFE, and SRFFE. You must explicitly use the TRI primitive when you create a tri-state output. If no port is explicitly used in AHDL and PHDL, the default port on the left-hand side of an equation is the primary data input to the instance of the primitive; the default port on the right-hand side of the equation is the primary output. JK and SR flip-flops always require an explicit port for all inputs.

PITFALLS
This section describes potential pitfalls (language differences) when converting between AHDL and PHDL.

Logic Synthesis
Both PHDL and AHDL do not need to represent a physical "polarity control" for an output. Both compilers automatically apply De Morgan’s inversion to all functions as part of logic synthesis. These compilers then compute the most appropriate configuration to obtain the logical behavior that has been defined.

Identifiers
Identifiers are case-sensitive in PHDL designs, while AHDL identifiers (symbolic names) are case insensitive.

Groups
You declare a set of signals in PHDL with an identifier followed by square brackets that enclose a comma-separated list of set members. Subsequent references to the set are made using the identifier only. AHDL notation is slightly different. In AHDL, you declare a group of signals with an identifier followed by an empty pair of square brackets.

The following examples show how a group of seven associated D flip-flops are declared and used in AHDL and PHDL.

AHDL Declaration:
\[ \text{countq}[6..0] : \text{DFF} \]

AHDL Reference:
\[ \text{countq}[6] = \text{countq}[6] \& \text{incadr} \& \text{clradr} \& \text{lcarryq} \]

PHDL Declaration:
\[ \text{countq} = [q6..q0]; \]

PHDL Reference:
\[ \text{countq} = \text{countq} \& \text{incadr} \& \text{clradr} \& \text{lcarryq} \]
\[ \# \text{countq} \& \text{lincadr} \& \text{cladr} \]

Equations
All flip-flops must be explicitly specified before being used in AHDL. Equations in AHDL are used only to describe combinatorial logic. The explicit declaration of flip-flops in AHDL is somewhat analogous to PHDL’s ISTYPE declaration and makes registered assignment operators superfluous.

Comments
Comments in AHDL can span multiple lines and a comment must begin and end with a percent character (%). Comments in PHDL begin with either a quotation mark (") or double slash (//) and continue to the end of the line. Comments in PHDL can span multiple lines with a /* */ enclosing the comments.

Active-Low Specification
The exclamation mark (!) in PHDL is used to declare active-low ports. In AHDL, however, you cannot create active-low ports in the Subdesign Section with the NOT (!) operator. In AHDL, the Logic Section may refer to signals that are either actual device pins or ports that connect to the next higher level of hierarchy. Therefore, the names of ports and their logical sense must agree for the design to compile without errors.

DESIGN CONVERSION EXAMPLE
This section contains a Counter design which is implemented in AHDL and then re-implemented using PHDL. This should give the reader an idea of how to convert other designs.
AHDL Design Example
Figure 1 gives a Counter implemented in AHDL.

```
TITLE "Arbitrary–length counter with Carry Out";
CONSTANT PENULTIMATE_COUNT = 109
DESIGN IS "count110"
BEGIN
  DEVICE IS EPM5032
  BEGIN
    clradr @ 28, incadr @ 27, osc @ 16 : INPUT
    a@3, a@4, a@5, a@6 : OUTPUT
    a@9, a@10, a@11 : OUTPUT
    carrya @ 12 : OUTPUT
  END;
END;

%––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––
This counter uses registered look–ahead carry to implement an arbitrary length count. The input to the carryq register will be high at the 109 count. On the next Clock with incadr high, the carryq will be set and the count will advance to 110. The counter keeps incrementing as long as carryq is low, so the counter will return to 0 on the next Clock with incadr high.
%––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––
SUBDESIGN Count110
  (osc, incadr, clradr : INPUT
   a[6..0], carrya : OUTPUT)
VARIABLE
carryq, count[6..0] : DFF
BEGIN
  countq[].clk = osc;
  countq[] = (count[] + 1) & incadr & clradr & !carryq
  # countq[] & !incadr & clradr;
  a[] = countq[];
  carryq = (countq[] == PENULTIMATE_COUNT) & incadr & clradr
  # carryq & !incadr & clradr;
  carrya = carryq;
END;
```

Figure 1. AHDL Counter Design
PHDL Design Example
Figure 2 gives a Counter implemented in PHDL.

Module Count110
TITLE 'Arbitrary–length counter with Carry Out'

Declarations
osc, incadr, cladr           pin 16, 27, 28;
A0, A1, A2, A3, A4, A5, A6  pin 3, 4, 5, 6, 9, 10, 11 istype 'reg_d';
carrya                        pin 12 istype 'reg_d';
counta = [A6, A5, A4, A3, A2, A1, A0];
PENULTIMATE_COUNT = 109;

" This counter uses registered look–ahead carry to implement an arbitrary length count.
" The input to the carryq register will be high at the 109 count. On the next Clock
" with incadr high, the carryq will be set and the count will advance to 110. The
" counter keeps incrementing as long as carryq is low, so the counter will return to 0
" on the next Clock with incadr high.

Equations
  counta.clk = osc;
  counta.d := ((counta.q + 1) & incadr & cladr & !carrya
               # counta & !incadr & cladr);
  carrya := (counta == PENULTIMATE_COUNT) & incadr & cladr
            # carrya & !incadr & cladr;
END;

Figure 2. PHDL Counter Design

TECHNICAL SUPPORT
With these guidelines, you should be well on your way to converting designs written in AHDL into design utilizing the PHDL language. This will enable you to take advantage of all the great features the Philips CoolRunner CPLDs offer. If you wish to learn more about PHDL, please refer to the XPLA Designer Users Manual.

This document was authored by Reno Sanchez, Applications and Architecture Development Manager. If you need more information, please contact me at 505–858–2790 or call the Philips CPLD Technical Support Line at 1–888–COOLPLD (1–888–266–5753) or 505–858–2996; or send email to coolpld@scs.philips.com.
Definitions
Short-form specification — The data in a short-form specification is extracted from a full data sheet with the same type number and title. For detailed information see the relevant data sheet or data handbook.

Limiting values definition — Limiting values given are in accordance with the Absolute Maximum Rating System (IEC 134). Stress above one or more of the limiting values may cause permanent damage to the device. These are stress ratings only and operation of the device at these or at any other conditions above those given in the Characteristics sections of the specification is not implied. Exposure to limiting values for extended periods may affect device reliability.

Application information — Applications that are described herein for any of these products are for illustrative purposes only. Philips Semiconductors make no representation or warranty that such applications will be suitable for the specified use without further testing or modification.

Disclaimers
Life support — These products are not designed for use in life support appliances, devices or systems where malfunction of these products can reasonably be expected to result in personal injury. Philips Semiconductors customers using or selling these products for use in such applications do so at their own risk and agree to fully indemnify Philips Semiconductors for any damages resulting from such application.

Right to make changes — Philips Semiconductors reserves the right to make changes, without notice, in the products, including circuits, standard cells, and/or software, described or contained herein in order to improve design and/or performance. Philips Semiconductors assumes no responsibility or liability for the use of any of these products, conveys no license or title under any patent, copyright, or mask work right to these products, and makes no representations or warranties that these products are free from patent, copyright, or mask work right infringement, unless otherwise specified.

Philips Semiconductors
811 East Arques Avenue
P.O. Box 3409
Sunnyvale, California 94088–3409
Telephone 800-234-7381

© Copyright Philips Electronics North America Corporation 1998
All rights reserved. Printed in U.S.A.

print code
Document order number: 9397 750 04154

Date of release: 07-98