Open main menu
Home
Random
Recent changes
Special pages
Community portal
Preferences
About Wikipedia
Disclaimers
Incubator escapee wiki
Search
User menu
Talk
Dark mode
Contributions
Create account
Log in
Editing
Programmable Array Logic
Warning:
You are not logged in. Your IP address will be publicly visible if you make any edits. If you
log in
or
create an account
, your edits will be attributed to your username, along with other benefits.
Anti-spam check. Do
not
fill this in!
{{Short description|Field-programmable semiconductor devices}} {{distinguish|Programmable logic array}} [[File:MMI PAL 16R6.jpg|thumb|MMI 16R6 in 20-pin [[Dual in-line package|DIP]]]] [[File:AMD PAL 22V10.jpg|thumb|AMD 22V10 in 24-pin DIP]] '''Programmable Array Logic''' ('''PAL''') is a family of [[programmable logic device]] semiconductors used to implement [[logic]] functions in digital [[electrical network|circuits]] that was introduced by [[Monolithic Memories]], Inc. (MMI) in March 1978.<ref name="MMI PAL Ad">{{Cite journal |title=Monolithic Memories announces: a revolution in logic design |journal=Electronic Design |volume=26 |issue=6 |pages=148B, 148C |publisher=Hayden Publishing |location=Rochelle, NJ |date=March 18, 1978}} Introductory advertisement on PAL (Programmable Array Logic).</ref> MMI obtained a registered trademark on the term PAL for use in "Programmable Semiconductor Logic Circuits". The trademark is currently held by [[Lattice Semiconductor]].<ref name="PAL trademark">Monolithic Memories, Inc (MMI) filed for a work mark on the term "PAL" for use in "Programmable Semiconductor Logic Circuits" on April 13, 1978. A registered trademark was granted on April 29, 1980, registration number 1134025. MMI's first use of the term PAL in commerce was on February 21, 1978. The trademark is currently held by Lattice Semiconductor Corporation of Hillsboro, Oregon. Source: United States Patent and Trademark Office online database.</ref> PAL devices consisted of a small [[Programmable read-only memory|PROM]] (programmable read-only memory) core and additional output logic used to implement particular desired logic functions with few components. Using specialized machines, PAL devices were "field-programmable". PALs were available in several variants: * "[[One-time programmable]]" (OTP) devices could not be updated and reused after initial programming. (MMI also offered a similar family called HAL, or "hard array logic", which were like PAL devices except that they were mask-programmed at the factory.) * UV erasable versions (e.g.: PALCxxxxx e.g.: PALC22V10) had a quartz window over the chip die and could be erased for re-use with an ultraviolet light source just like an [[EPROM]]. * Later versions (PALCExxx e.g.: PALCE22V10) were flash erasable devices. In most applications, electrically erasable [[generic array logic|GAL]]s are now deployed as [[Pin compatibility|pin-compatible]] direct replacements for one-time programmable PALs. ==History== Before PALs were introduced, designers of digital logic circuits would use [[small-scale integration]] (SSI) components, such as those in the [[7400 series]] TTL ([[transistor-transistor logic]]) family; the 7400 family included a variety of logic building blocks, such as gates ([[NOT gate|NOT]], [[NAND gate|NAND]], [[NOR gate|NOR]], [[AND gate|AND]], [[OR gate|OR]]), [[multiplexers]] (MUXes) and demultiplexers (DEMUXes), [[Flip-flop (electronics)|flip-flops]] (D-type, JK, etc.) and others. One PAL device would typically replace dozens of such "discrete" logic packages, so the SSI business declined as the PAL business took off. PALs were used advantageously in many products, such as [[minicomputers]], as documented in [[Tracy Kidder]]'s best-selling book ''[[The Soul of a New Machine]]''. PALs were not the first commercial programmable logic devices; [[Signetics]] had been selling its [[field programmable logic array]] (FPLA) since 1975. These devices were completely unfamiliar to most circuit designers and were perceived to be too difficult to use. The FPLA had a relatively slow maximum operating speed (due to having both programmable-AND and programmable-OR arrays), was expensive, and had a poor reputation for testability. Another factor limiting the acceptance of the FPLA was the large package, a 600-[[Thou (unit of length)|mil]] (0.6", or 15.24 mm) wide 28-pin [[dual in-line package]] (DIP). The project to create the PAL device was managed by [[John Birkner]] and the actual PAL circuit was designed by [[H. T. Chua]].<ref name=" Birkner 1978">{{Cite journal |last=Birkner |first=John |author-link=John Birkner |title=Reduce random-logic complexity |journal=Electronic Design |volume=26 |issue=17 |pages=98β105 |location=Rochelle, NJ |date=August 16, 1978 |publisher=Hayden Publishing}}</ref> In a previous job (at mini-computer manufacturer [[Computer Automation]]), Birkner had developed a 16-bit processor using 80 standard logic devices. His experience with standard logic led him to believe that user-programmable devices would be more attractive if the devices were designed to replace standard logic. This meant that the package sizes had to be more typical of the existing devices, and the speeds had to be improved. MMI intended PALs to be a relatively low cost (sub $3) part. However, the company initially had severe manufacturing yield problems{{citation needed|date=January 2020}} and had to sell the devices for over $50.{{citation needed|date=January 2020}} This threatened the viability of the PAL as a commercial product, and MMI was forced to license the product line to National Semiconductor.{{citation needed|date=January 2020}} PALs were later "[[second source]]d" by [[Texas Instruments]] and [[Advanced Micro Devices]]. ==Process technologies== Early PALs were 20-pin [[Dual in-line package|DIP]] components fabricated in silicon using bipolar transistor technology with one-time programmable (OTP) titanium-tungsten programming fuses.<ref name="TI PAL 16R8">{{Cite book |title=TIBPAL 16R8-15C Data Sheet |publisher=Texas Instruments |orig-year=February 1984| date=April 2000 |location=Dallas TX |url=http://focus.ti.com/lit/ds/symlink/tibpal16r8-15c.pdf}} "These IMPACT circuits combine the latest Advanced Low-Power Schottky technology with proven titanium-tungsten fuses to provide reliable, high-performance substitutes for conventional TTL logic." TI was a second source vendor for the MMI PALS.</ref> Later devices were manufactured by [[Cypress Semiconductor|Cypress]], [[Lattice Semiconductor]] and [[Advanced Micro Devices]] using [[CMOS]] technology. The original 20- and 24-pin PALs were denoted by MMI as [[medium-scale integration]] (MSI) devices. ==PAL architecture== [[File:Programmable Logic Device.svg|thumb|350px|The programmable elements (shown as a fuse) connect both the true and complemented inputs to the AND gates. These AND gates, also known as ''product terms'', are ORed together to form a ''sum-of-products'' logic array.]] The PAL architecture consists of two main components: a logic plane and output logic macrocells. ===Programmable logic plane=== The programmable logic plane is a [[programmable read-only memory]] (PROM) array that allows the signals present on the device pins, or the logical complements of those signals, to be routed to output logic macrocells. PAL devices have arrays of transistor cells arranged in a "fixed-OR, programmable-AND" plane used to implement "[[disjunctive normal form|sum-of-products]]" binary logic equations for each of the outputs in terms of the inputs and either synchronous or asynchronous feedback from the outputs. ===Output logic=== The early 20-pin PALs had 10 inputs and 8 outputs. The outputs were active low and could be registered or combinational. Members of the PAL family were available with various output structures called "[[output logic macrocell]]s" or OLMCs. Prior to the introduction of the "V" (for "variable") series, the types of OLMCs available in each PAL were fixed at the time of manufacture. (The PAL16L8 had 8 combinational outputs, and the PAL16R8 had 8 registered outputs. The PAL16R6 had 6 registered and 2 combinational outputs, while the PAL16R4 had 4 of each.) Each output could have up to 8 product terms (effectively AND gates); however, the combinational outputs used one of the terms to control a bidirectional output buffer. There were other combinations that had fewer outputs with more product terms per output and were available with active high outputs ("H" series).<ref name="mmi3" />{{rp|1–14}} The "X" series of devices had an XOR gate before the register.<ref name="mmi3">{{cite book |title=PAL Programmable Array Logic Handbook |edition=3rd |last1=Birkner |first1=John M. |last2=Coli |first2=Vincent J. |publisher=Monolithic Memories, Inc. |year=1983}}</ref>{{rp|1–9}} There were also similar 24-pin versions of these PALs. This fixed output structure often frustrated designers attempting to optimize the utility of PAL devices because output structures of different types were often required by their applications. (For example, one could not get 5 registered outputs with 3 active high combinational outputs.) So, in June 1983 [[AMD]] introduced the 22V10, a 24-pin device with 10 output logic macrocells.<ref name="22V10 Data Sheet">{{Cite book |date=June 1983 |title=AmPAL 22V10 Advanced Information |publication-place=Sunnyvale CA |publisher=Advanced Micro Devices |id=04126A-PLP}} Note: This is the data sheet published by AMD when the AmPAL 22V10 was introduced.</ref> Each macrocell could be configured by the user to be combinational or registered, active high or active low. The number of product terms allocated to an output varied from 8 to 16. This one device could replace all of the 24-pin fixed function PAL devices. Members of the PAL "V" ("variable") series included the PAL16V8, PAL20V8 and PAL22V10. <gallery class= "center"> PAL Block Diagram.jpg|PAL 16R4 Block Diagram 22V10 Block Diagram.jpg|AMD 22V10 Block Diagram AMD 22V10 Macrocell.jpg|AMD 22V10 Output Macrocell </gallery> ==Programming PALs== PALs were programmed electrically using binary patterns (as [[JEDEC]] [[ASCII]]/[[hexadecimal]] files) and a special electronic programming system available from either the manufacturer or a third party, such as [[Data I/O Corporation|DATA I/O]]. In addition to single-unit device programmers, device feeders and gang programmers were often used when more than just a few PALs needed to be programmed. (For large volumes, electrical programming costs could be eliminated by having the manufacturer fabricate a custom metal mask used to program the customers' patterns at the time of manufacture; MMI used the term "[[hard array logic]]" (HAL) to refer to devices programmed in this way.) ===Programming languages (by chronological order of appearance) === [[File:PALASM Design.jpg|thumb|PALASM design of a 4-bit [[Counter (digital)|counter]]]] Though some engineers programmed PAL devices by manually editing files containing the binary fuse pattern data, most opted to design their logic using a [[hardware description language]] (HDL) such as Data I/O's [[Advanced Boolean Expression Language|ABEL]], Logical Devices' CUPL, or MMI's [[PALASM]]. These were [[computer-assisted design]] ([[Computer-aided design|CAD]]) (now referred to as "[[electronic design automation]]") programs which translated (or "compiled") the designers' logic equations into binary fuse map files used to program (and often test) each device. ====PALASM==== The [[PALASM]] (from "PAL assembler") language was developed by [[John Birkner]] in the early 1980s and the PALASM compiler was written by MMI in FORTRAN IV on an IBM 370/168. MMI made the source code available to users at no cost. By 1983, MMI customers ran versions on the [[Digital Equipment Corporation|DEC]] [[PDP-11]], [[Data General Nova|Data General NOVA]], [[Hewlett-Packard]] [[HP 2100]], [[MDS800]] and others. It was used to express Boolean equations for the output pins in a text file, which was then converted to the 'fuse map' file for the programming system using a vendor-supplied program; later the option of translation from schematics became common, and later still, 'fuse maps' could be 'synthesized' from an [[hardware description language|HDL]] (hardware description language) such as [[Verilog]]. ====CUPL==== Assisted Technology released CUPL ('''C'''ompiler for '''U'''niversal '''P'''rogrammable '''L'''ogic) in September 1983.<ref name="Alford 1989">{{cite book |last=Alford |first=Roger C.| title=Programmable Logic Designer's Guide |publisher=Howard W. Sams| date=1989 |pages=14β15, 166β168 |isbn =0-672-22575-1 |quote=In 1981, [Bob] Osann started Assisted Technology to develop PLD support tools. In September 1983 Assisted Technology released version 1.01a of its CUPL (Universal Compiler for Programmable Logic) PLD compiler, supporting 29 devices.}}</ref> The software was always referred to as CUPL and never the expanded acronym. It was the first commercial design tool that supported multiple PLD families. The initial release was for the IBM PC and MS-DOS, but it was written in the [[C (programming language)|C programming language]] so it could be ported to additional platforms.<ref name="CUPL Datasheet 1983">{{cite press release |title=CUPL - The Universal Language For Programmable Logic |publisher=Assisted Technology, Inc. |location=San Jose, CA |date=1983 |url=http://www.swtpc.com/mholley/PLD_History/ABEL_project/CUPL_Data_Sheet_1983_ocr.pdf |access-date=2013-08-10 |archive-url=https://web.archive.org/web/20131029195406/http://www.swtpc.com/mholley/PLD_History/ABEL_project/CUPL_Data_Sheet_1983_ocr.pdf |archive-date=2013-10-29 |url-status=dead}} An early 1983 pre-release datasheet for CUPL.</ref> Assisted Technology was acquired by Personal CAD Systems (P-CAD) in July 1985. In 1986, PCAD's schematic capture package could be used as a front end for CUPL.<ref name="PCAD 1985">{{cite journal| title=Personal CAD Systems |journal=Computer World |volume=19 |issue=29 |page =97 |publisher=CW Communications |location=Framingham, MA |date=July 22, 1985| url=https://books.google.com/books?id=6mxHXqXKdFMC&pg=PA97| issn=0010-4841}}</ref> CUPL was later acquired by Logical Devices and is now owned by [[Altium]].<ref name="CUPL trademark">US Patent and Trademark Office. "CUPL" Computer software, namely, software used to develop and compile designs for programmable logic devices, and related user manuals distributed therewith. First used in 1983, status Active. Serial Number 76357007. Registration Number 2909461. Owner: Altium Limited, Australia 3 Minna Close, Belrose NSW2085, Australia.</ref> CUPL is currently available as an integrated development package for Microsoft Windows.<ref name="CUBEL">{{cite web |title=CUBEL ChipDesigner 5.0 |publisher=Logical Devices |date=August 2013 |url=http://www.logicaldevices.com/cubel.htm |archive-url=https://web.archive.org/web/20150529134635/http://www.logicaldevices.com:80/cubel.htm |archive-date=May 29, 2015 |url-status=dead}}</ref> [[Atmel]] releases for free [http://www.atmel.com/tools/WINCUPL.aspx WinCUPL] (their own design software for all Atmel SPLDs and CPLDs). Atmel was acquired by Microchip in 2016. ====ABEL==== [[Data I/O Corporation]] released [[Advanced Boolean Expression Language|ABEL]] in April, 1984. The development team was Michael Holley, Mike Mraz, Gerrit Barrere, [[Walter Bright]], Bjorn Freeman-Benson, Kyu Lee, David Pellerin, Mary Bailey, Daniel Burrier and Charles Olivier. Data I/O spun off the ABEL product line into an electronic design automation company called Synario Design Systems and then sold Synario to MINC Inc in 1997. MINC was focused on developing FPGA development tools. The company closed its doors in 1998 and Xilinx acquired some of MINC's assets including the ABEL language and tool set. ABEL then became part of the Xilinx Webpack tool suite. Now Xilinx owns ABEL. ===Device programmers=== Popular device programmers included [[Data I/O Corporation]]'s Model 60A Logic Programmer and Model 2900. One of the first PAL programmers was the Structured Design SD20/24. They had the PALASM software built-in and only required a CRT terminal to enter the equations and view the fuse plots. After fusing, the outputs of the PAL could be verified if test vectors were entered in the source file. ==Successors== After MMI succeeded with the 20-pin PAL parts introduced circa 1978, [[AMD]] introduced the 24-pin 22V10 PAL with additional features. After buying out MMI (circa 1987), AMD spun off a consolidated operation as Vantis, and that business was acquired by [[Lattice Semiconductor]] in 1999.<ref name="EE Times 1999">{{cite web |title=Lattice Semiconductor Acquires Vantis Corp. from AMD |website=EE Times |date=26 April 1999 |url=http://www.eetimes.com/document.asp?doc_id=1213080 |access-date=May 13, 2015 }}</ref> Altera introduced the EP300 (first CMOS PAL) in 1983 and later moved into the FPGA business. Lattice Semiconductor introduced the [[generic array logic]] ([[generic array logic|GAL]]) family in 1985, with functional equivalents of the "V" series PALs that used reprogrammable logic planes based on [[EEPROM]] (electrically eraseable programmable read-only memory) technology. National Semiconductor was a [[second source]] for GAL parts. [[File:PALCE20V8H-15JC.jpg|thumb|AMD PALCE 20V8H-15JC in 28-pin [[Plastic leaded chip carrier|PLCC]]]] AMD introduced a similar family called PALCE. In general one GAL part is able to function as any of the similar family PAL devices. For example, the 16V8 GAL is able to replace the 16L8, 16H8, 16H6, 16H4, 16H2 and 16R8 PALs (and many others besides). ICT (International CMOS Technology) introduced the PEEL 18CV8 in 1986. The 20-pin CMOS EEPROM part could be used in place of any of the registered-output bipolar PALs and used much less power. Larger-scale programmable logic devices were introduced by [[Atmel]], [[Lattice Semiconductor]], and others. These devices extended the PAL architecture by including multiple logic planes and/or burying logic macrocells within the logic plane(s). The term ''[[complex programmable logic device]]'' (CPLD) was introduced to differentiate these devices from their PAL and GAL predecessors, which were then sometimes referred to as ''simple programmable logic devices'' (SPLDs). Another large programmable logic device is the [[field-programmable gate array]] (FPGA). These are devices currently{{when|date=December 2019}} made by [[Intel]] (who acquired [[Altera]]) and [[Xilinx]] (who was acquired by [[AMD]]) and other semiconductor manufacturers. ==See also== {{Commons category|Programmable Array Logic}} * [[Combinational logic]] ==References== {{Reflist}} ==Further reading== ;Books * ''Programmable Logic Designer's Guide''; Roger Alford; [[Sams Publishing]]; 1989; {{ISBN|0-672-22575-1}}. <small>[https://archive.org/details/programmablelogi0000alfo/ (archive)]</small> * ''PAL Programmable Logic Handbook''; 4ed; [[Monolithic Memories]]; 1985. <small>[https://archive.org/details/MonolithicMemories-MMI-ProgrammableLogicHandbookOCR/ (archive)]</small> ;Databooks * ''Bipolar LSI 1984 Databook''; 5ed; [[Monolithic Memories]]; 1984. <small>[https://archive.org/details/bipolar-lsi-1984-databook-fifth-edition/ (archive)]</small> ;Specifications * ''Standard Data Transfer Format Between Data Preparation System and Programmable Logic Device Programmer''; JEDEC Standard JESD3-C; [[JEDEC]]; June 1994. {{Programmable Logic}} {{Digital electronics}} {{Authority control}} [[Category:Electronic design automation]] [[Category:Gate arrays]]
Edit summary
(Briefly describe your changes)
By publishing changes, you agree to the
Terms of Use
, and you irrevocably agree to release your contribution under the
CC BY-SA 4.0 License
and the
GFDL
. You agree that a hyperlink or URL is sufficient attribution under the Creative Commons license.
Cancel
Editing help
(opens in new window)
Pages transcluded onto the current version of this page
(
help
)
:
Template:Authority control
(
edit
)
Template:Citation needed
(
edit
)
Template:Cite book
(
edit
)
Template:Cite journal
(
edit
)
Template:Cite press release
(
edit
)
Template:Cite web
(
edit
)
Template:Commons category
(
edit
)
Template:Digital electronics
(
edit
)
Template:Distinguish
(
edit
)
Template:ISBN
(
edit
)
Template:Programmable Logic
(
edit
)
Template:Reflist
(
edit
)
Template:Rp
(
edit
)
Template:Short description
(
edit
)
Template:When
(
edit
)