Microprocessor: From Wikipedia, The Free Encyclopedia

Download as docx, pdf, or txt
Download as docx, pdf, or txt
You are on page 1of 33

Microprocessor

From Wikipedia, the free encyclopedia

Intel 4004, the first general-purpose, commercial microprocessor

A microprocessor incorporates the functions of a computer's central processing unit (CPU) on a


single integrated circuit,[1] (IC) or at most a few integrated circuits.[2] It is a multipurpose,programmable device
that accepts digital data as input, processes it according to instructions stored in its memory, and provides
results as output. It is an example of sequential digital logic, as it has internal memory. Microprocessors
operate on numbers and symbols represented in the binary numeral system. The advent of low-cost computers
on integrated circuits has transformed modern society. General-purpose microprocessors in personal
computers are used for computation, text editing, multimedia display, and communication over the Internet.
Many more microprocessors are part of embedded systems, providing digital control of a myriad of objects from
appliances to automobiles to cellular phones and industrial process control.

Contents
  [hide] 

1 Origins

2 Embedded applications

3 Structure

4 Firsts

o 4.1 Intel 4004

o 4.2 TMS 1000

o 4.3 Pico/General

Instrument

o 4.4 CADC
o 4.5 Gilbert Hyatt

o 4.6 Four-Phase Systems

AL1

5 8-bit designs

6 12-bit designs

7 16-bit designs

8 32-bit designs

9 64-bit designs in personal

computers

10 Multicore designs

11 RISC

12 Special-purpose designs

13 Market statistics

14 See also

15 Notes and references

16 External links

[edit]Origins

During the 1960s, computer processors were constructed out of small and medium-scale ICs each containing
from tens to a few hundredtransistors. For each computer built, all of these had to be placed and soldered onto
printed circuit boards, and often multiple boards would have to be interconnected in a chassis. The large
number of discrete logic gates used more electrical power—and therefore, produced more heat—than a more
integrated design with fewer ICs. The distance that signals had to travel between ICs on the boards limited the
speed at which a computer could operate.

In the NASA Apollo space missions to the moon in the 1960's and 1970's, all onboard computations for primary
guidance, navigation and control were provided by a small custom processor called "The Apollo Guidance
Computer". It utilized a primitive gate array whose onlylogic elements were three-input NOR gates.[3]

The integration of a whole CPU onto a single chip or on a few chips greatly reduced the cost of processing
power. The integrated circuit processor was produced in large numbers by highly automated processes, so unit
cost was low. Single-chip processors increase reliability as there were many fewer electrical connections to fail.
As microprocessor designs get faster, the cost of manufacturing a chip (with smaller components built on a
semiconductor chip the same size) generally stays the same.

Microprocessors integrated into one or a few large-scale ICs the architectures that had previously been
implemented using many medium- and small-scale integrated circuits. Continued increases in microprocessor
capacity have rendered other forms of computers almost completely obsolete (see history of computing
hardware), with one or more microprocessors used in everything from the smallestembedded
systems and handheld devices to the largest mainframes and supercomputers.

The first microprocessors emerged in the early 1970s and were used for electronic calculators, using binary-
coded decimal (BCD) arithmetic on 4-bit words. Other embedded uses of 4-bit and 8-bit microprocessors, such
as terminals, printers, various kinds ofautomation etc., followed soon after. Affordable 8-bit microprocessors
with 16-bit addressing also led to the first general-purposemicrocomputers from the mid-1970s on.

Since the early 1970s, the increase in capacity of microprocessors has followed Moore's law, which suggests
that the number of transistors that can be fitted onto a chip doubles every two years. Although originally
calculated as a doubling every year,[4] Moore later refined the period to two years.[5] It is often incorrectly quoted
as a doubling of transistors every 18 months.

[edit]Embedded applications

Microprocessors make it possible to put a computer into thousands of items that were traditionally not
computer-related. These include large and small household appliances, cars (and their accessory equipment
units), car keys, tools and test instruments, toys, light switches/dimmers and electrical circuit breakers, smoke
alarms, battery packs, and hi-fi audio/visual components (from DVD players tophonograph turntables.) Such
products as cellular telephones, DVD video system and ATSC HDTV broadcast system fundamentally require
consumer devices with powerful, low-cost, microprocessors. Increasingly stringent pollution control standards
effectively require automobile manufacturers to use microprocessor engine management systems, to allow
optimal control of emissions over widely varying operating conditions of an automobile. Non-programmable
controls would require complex, bulky, or costly implementation to achieve the results possible with a
microprocessor.

A microprocessor control program can be easily tailored to different needs of a product line, allowing upgrades
in performance with minimal redesign of the product. Different features can be implemented in different models
of a product line at negligible production cost.

Microprocessor control of a system can provide control strategies that would be impractical to implement using
electromechanical controls or purpose-built electronic controls. For example, an engine control system in an
automobile can adjust ignition timing based on engine speed, load on the engine, ambient temperature, and
any observed tendency for knocking - allowing an automobile to operate on a range of fuel grades.

[edit]Structure
A block diagram of the internal architecture of a popular microprocessor, showing the arithmetic and logic section, register file, control logic

section, and buffers to external address and data lines

The internal arrangement of a microprocessor varies depending on the age of the design and the intended
purposes of the processor. The complexity of an integrated circuit is bounded by physical limitations of the
number of transistors that can be put onto one chip, the number of package terminations that can connect the
processor to other parts of the system, the number of interconnections it is possible to make on the chip, and
the heat that the chip can dissipate. Advancing technology makes more complex and powerful chips feasible to
manufacture.

A minimal hypothetical microprocessor might only include an arithmetic logic unit (ALU) and a control logic
section. The ALU performs operations such as addition, subtraction, and operations such as AND or OR. Each
operation of the ALU sets one or more flags in a status register, which indicate the results of the last operation
(zero value, negative number, overflow. or others). The logic section retrieves instruction operation codes from
memory, and iniates whatever sequence of operations of the ALU required to carry out the instruction. A single
operation code might affect many individual data paths, registers, and other elements of the processor.

As integrated circuit technology advanced, it was feasible to manufacture more and more complex processors
on a single chip. The size of data objects became larger; allowing more transistors on a chip allowed word
sizes to increase from 4- and 8-bit words up to today's 64-bit words. Additional features were added to the
processor architecture; more on-chip registers speeded up programs, and complex instructions could be used
to make more compact programs. Floating-point arithmetic, for example, was often not available on 8-bit
microprocessors, but had to be carried out in software. Integration of the floating point unit first as a separate
integrated circuit and then as part of the same microprocessor chip, speeded up floating point calculations.

Occasionally the physical limitations of integrated circuits made such practices as a bit slice approach
necessary. Instead of processing all of a long word on one integrated circuit, multiple circuits in parallel
processed subsets of each data word. While this required extra logic to handle, for example, carry and overflow
within each slice, the result was a system that could handle, say, 32-bit words using integrated circuits with a
capacity for only 4 bits each.
With the ability to put large numbers of transistors on one chip, it becomes feaible to integrate memory on the
same die as the processor. This CPU cache has the advantage of faster access than off-chip memory, and
increases the processing speed of the system for many applications. Generally, processor speed has
increased more rapidly than external memory speed, so cache memory is necessary if the processor is not to
be delayed by slower external memory.

[edit]Firsts

Three projects delivered a microprocessor at about the same time: Intel's 4004, Texas Instruments (TI) TMS
1000, and Garrett AiResearch's Central Air Data Computer (CADC).

[edit]Intel 4004

The 4004 with cover removed (left) and as actually used (right)

Main article:  Intel 4004

The Intel 4004 is generally regarded as the first microprocessor, [6][7] and cost $60.[8] The first known
advertisement for the 4004 is dated November 15, 1971 and appeared inElectronic News.[9] The project that
produced the 4004 originated in 1969, whenBusicom, a Japanese calculator manufacturer, asked Intel to build
a chipset for high-performance desktop calculators. Busicom's original design called for a programmable chip
set consisting of seven different chips. Three of the chips were to make a special-purpose CPU with its
program stored in ROM and its data stored in shift register read-write memory. Ted Hoff, the Intel engineer
assigned to evaluate the project, believed the Busicom design could be simplified by using dynamic RAM
storage for data, rather than shift register memory, and a more traditional general-purpose CPU architecture.
Hoff came up with a four–chip architectural proposal: a ROM chip for storing the programs, a dynamic RAM
chip for storing data, a simple I/O device and a 4-bit central processing unit (CPU). Although not a chip
designer, he felt the CPU could be integrated into a single chip, but as he lacked the technical know-how the
idea remained just a wish for the time being.

While the architecture and specifications of the MCS-4 came from the interaction of Hoff with Stanley Mazor, a
software engineer reporting to him, and with Busicom engineer Masatoshi Shima, during 1969, Mazor and Hoff
moved on to other projects while in April 1970, Intel hired Federico Faggin as project leader, a move that
ultimately made the single-chip CPU final design a reality (Shima instead designed the Busicom calculator
firmware and assisted Faggin during the first six months of the implementation). Faggin, who originally
developed the silicon gate technology (SGT) in 1968 at Fairchild Semiconductor [10] and designed the world’s
first commercial integrated circuit using SGT, the Fairchild 3708, had the correct background to lead the project
into what would become the first commercial general purpose microprocessor, since it was his very own
invention, SGT in addition to his new methodology for random logic design, that made it possible to implement
a single-chip CPU with the proper speed, power dissipation and cost. The manager of Intel's MOS Design
Department was Leslie L. Vadász. at the time of the MCS-4 development, but Vadasz's attention was
completely focused on the mainstream business of semiconductor memories and he left the leadership and the
management of the MCS-4 project to Faggin, which was ultimately responsible for leading the 4004 project to
its outcome. Production units of the 4004 were first delivered to Busicom in March 1971 and shipped to other
customers in late 1971.

[edit]TMS 1000
The Smithsonian Institution says TI engineers Gary Boone and Michael Cochran succeeded in creating the first
microcontroller (also called a microcomputer) in 1971. The result of their work was the TMS 1000, which went
commercial in 1974.[11]

TI developed the 4-bit TMS 1000 and stressed pre-programmed embedded applications, introducing a version
called the TMS1802NC on September 17, 1971 which implemented a calculator on a chip.

TI filed for the patent on the microprocessor. Gary Boone was awarded U.S. Patent 3,757,306 for the single-
chip microprocessor architecture on September 4, 1973. It may never be known which company actually had
the first working microprocessor running on the lab bench. In both 1971 and 1976, Intel and TI entered into
broad patent cross-licensing agreements, with Intel paying royalties to TI for the microprocessor patent. A
history of these events is contained in court documentation from a legal dispute between Cyrix and Intel, with TI
as intervenor and owner of the microprocessor patent.

A computer-on-a-chip combines the microprocessor core (CPU), memory, and I/O (input/output) lines onto
one chip. The computer-on-a-chip patent, called the "microcomputer patent" at the time, U.S. Patent 4,074,351,
was awarded to Gary Boone and Michael J. Cochran of TI. Aside from this patent, the standard meaning
of microcomputer is a computer using one or more microprocessors as its CPU(s), while the concept defined in
the patent is more akin to a microcontroller.

[edit]Pico/General Instrument
The PICO1/GI250 chip introduced in 1971. This was designed by Pico Electronics (Glenrothes, Scotland) and manufactured by General

Instrument of Hicksville NY

In 1971 Pico Electronics[12] and General Instrument (GI) introduced their first collaboration in ICs, a complete


single chip calculator IC for the Monroe/Litton Royal Digital III calculator. This chip could also arguably lay claim
to be one of the first microprocessors or microcontrollers having ROM, RAM and a RISC instruction set on-
chip. The layout for the four layers of the PMOS process was hand drawn at x500 scale on mylar film, a
significant task at the time given the complexity of the chip.

Pico was a spinout by five GI design engineers whose vision was to create single chip calculator ICs. They had
significant previous design experience on multiple calculator chipsets with both GI and Marconi-Elliott.[13] The
key team members had originally been tasked by Elliott Automation to create an 8 bit computer in MOS and
had helped establish a MOS Research Laboratory in Glenrothes, Scotland in 1967.

Calculators were becoming the largest single market for semiconductors and Pico and GI went on to have
significant success in this burgeoning market. GI continued to innovate in microprocessors and microcontrollers
with products including the CP1600, IOB1680 and PIC1650. [14] In 1987 the GI Microelectronics business was
spun out into the Microchip PIC microcontroller business.

[edit]CADC
This section relies on references to primary sources or sources affiliated with the subject, rather
than references from independent authors and third-party publications. Please
add citations from reliable sources. (March 2010)

In 1968, Garrett AiResearch (which employed designers Ray Holt and Steve Geller) was invited to produce a
digital computer to compete with electromechanical systems then under development for the main flight control
computer in the US Navy's new F-14 Tomcat fighter. The design was complete by 1970, and used a MOS-
based chipset as the core CPU. The design was significantly (approximately 20 times) smaller and much more
reliable than the mechanical systems it competed against, and was used in all of the early Tomcat models. This
system contained "a 20-bit, pipelined, parallel multi-microprocessor". The Navy refused to allow publication of
the design until 1997. For this reason the CADC, and the MP944 chipset it used, are fairly unknown.[15] Ray
Holt graduated California Polytechnic University in 1968, and began his computer design career with the
CADC. From its inception, it was shrouded in secrecy until 1998 when at Holt's request, the US Navy allowed
the documents into the public domain. Since then several[who?] have debated if this was the first microprocessor.
Holt has stated that no one has compared this microprocessor with those that came later. [16] According to Parab
et al. (2007), "The scientific papers and literature published around 1971 reveal that the MP944  digital
processor used for the F-14 Tomcat aircraft of the US Navy qualifies as the first microprocessor. Although
interesting, it was not a single-chip processor, and was not general purpose – it was more like a set of parallel
building blocks you could use to make a special-purpose DSP form. It indicates that today’s industry theme of
converging DSP-microcontroller architectures was started in 1971." [17] This convergence of DSP and
microcontroller architectures is known as a Digital Signal Controller.[citation needed]

[edit]Gilbert Hyatt
Gilbert Hyatt was awarded a patent claiming an invention pre-dating both TI and Intel, describing a
"microcontroller".[18] The patent was later invalidated, but not before substantial royalties were paid out. [19][20]

[edit]Four-Phase Systems AL1


The Four-Phase Systems AL1 was an 8-bit bit slice chip containing eight registers and an ALU.[21] It was
designed by Lee Boysel in 1969.[22][23][24] At the time, it formed part of a nine-chip, 24-bit CPU with three AL1s,
but it was later called a microprocessor when, in response to 1990s litigation by Texas Instruments, a
demonstration system was constructed where a single AL1 formed part of a courtroom demonstration computer
system, together with RAM, ROM, and an input-output device.[25]

[edit]8-bit designs
This section and the sections below needs additional citations for verification. Please help improve
this article by adding citations to reliable sources. Unsourced material may
bechallenged and removed. (June 2011)

The Intel 4004 was followed in 1972 by the Intel 8008, the world's first 8-bit microprocessor. The 8008 was not,
however, an extension of the 4004 design, but instead the culmination of a separate design project at Intel,
arising from a contract with Computer Terminals Corporation, of San Antonio TX, for a chip for a terminal they
were designing,[26] the Datapoint 2200 — fundamental aspects of the design came not from Intel but from CTC.
In 1968, CTC's Austin O. “Gus” Roche developed the original design for the instruction set and operation of the
processor. In 1969, CTC contracted two companies, Intel and Texas Instruments, to make a single-chip
implementation, known as the CTC 1201.[27] In late 1970 or early 1971, TI dropped out being unable to make a
reliable part. In 1970, with Intel yet to deliver the part, CTC opted to use their own implementation in the
Datapoint 3300, using traditional TTL logic instead (thus the first machine to run “8008 code” was not in fact a
microprocessor at all). Intel's version of the 1201 microprocessor arrived in late 1971, but was too late, slow,
and required a number of additional support chips. CTC had no interest in using it. CTC had originally
contracted Intel for the chip, and would have owed them $50,000 for their design work. [27] To avoid paying for a
chip they did not want (and could not use), CTC released Intel from their contract and allowed them free use of
the design.[27] Intel marketed it as the 8008 in April, 1972, as the world's first 8-bit microprocessor. It was the
basis for the famous "Mark-8" computer kit advertised in the magazine Radio-Electronicsin 1974.

The 8008 was the precursor to the very successful Intel 8080 (1974), which offered much improved
performance over the 8008 and required fewer support chips, Zilog Z80 (1976), and derivative Intel 8-bit
processors. The competing Motorola 6800 was released August 1974 and the similar MOS Technology 6502 in
1975 (designed largely by the same people). The 6502 rivaled the Z80 in popularity during the 1980s.

A low overall cost, small packaging, simple computer bus requirements, and sometimes the integration of extra
circuitry (e.g. the Z80's built-in memory refresh circuitry) allowed the home computer "revolution" to accelerate
sharply in the early 1980s. This delivered such inexpensive machines as the Sinclair ZX-81, which sold
for US$99.

The Western Design Center, Inc. (WDC) introduced the CMOS 65C02 in 1982 and licensed the design to
several firms. It was used as the CPU in the Apple IIe and IIc personal computers as well as in medical
implantable grade pacemakers and defibrillators, automotive, industrial and consumer devices. WDC pioneered
the licensing of microprocessor designs, later followed by ARM and other microprocessor Intellectual
Property (IP) providers in the 1990s. A variation of the 6502, the MOS Technology 6510 was used in
theCommodore 64 and Commodore 128 home computers.

Motorola introduced the MC6809 in 1978, an ambitious and thought-through 8-bit design source


compatible with the 6800 and implemented using purely hard-wired logic. (Subsequent 16-bit microprocessors
typically used microcode to some extent, as CISC design requirements were getting too complex for purely
hard-wired logic only.)

Another early 8-bit microprocessor was the Signetics 2650, which enjoyed a brief surge of interest due to its
innovative and powerfulinstruction set architecture.

A seminal microprocessor in the world of spaceflight was RCA's RCA 1802 (aka CDP1802, RCA COSMAC)
(introduced in 1976), which was used onboard the Galileo probe to Jupiter (launched 1989, arrived 1995). RCA
COSMAC was the first to implement CMOStechnology. The CDP1802 was used because it could be run at
very low power, and because a variant was available fabricated using a special production process (Silicon on
Sapphire), providing much better protection against cosmic radiation and electrostatic dischargesthan that of
any other processor of the era. Thus, the SOS version of the 1802 was said to be the first radiation-hardened
microprocessor.
The RCA 1802 had what is called a static design, meaning that the clock frequency could be made arbitrarily
low, even to 0 Hz, a total stop condition. This let the Galileo spacecraft use minimum electric power for long
uneventful stretches of a voyage. Timers and/or sensors would awaken/improve the performance of the
processor in time for important tasks, such as navigation updates, attitude control, data acquisition, and radio
communication.

[edit]12-bit designs

The Intersil 6100 family consisted of a 12-bit microprocessor (the 6100) and a range of peripheral support and
memory ICs. The microprocessor recognised the DEC PDP-8 minicomputer instruction set. As such it was
sometimes referred to as the CMOS-PDP8. Since it was also produced by Harris Corporation, it was also
known as the Harris HM-6100. By virtue of its CMOS technology and associated benefits, the 6100 was being
incorporated into some military designs until the early 1980s.

[edit]16-bit designs

The first multi-chip 16-bit microprocessor was the National Semiconductor IMP-16, introduced in early 1973. An


8-bit version of the chipset was introduced in 1974 as the IMP-8.

Other early multi-chip 16-bit microprocessors include one used by Digital Equipment Corporation (DEC) in
the LSI-11 OEM board set and the packaged PDP 11/03 minicomputer, and the Fairchild
Semiconductor MicroFlame 9440, both of which were introduced in the 1975 to 1976 timeframe.

In 1975, National introduced the first 16-bit single-chip microprocessor, the National Semiconductor PACE,
which was later followed by an NMOS version, the INS8900.

Another early single-chip 16-bit microprocessor was TI's TMS 9900, which was also compatible with their TI-
990 line of minicomputers. The 9900 was used in the TI 990/4 minicomputer, the TI-99/4A home computer, and
the TM990 line of OEM microcomputer boards. The chip was packaged in a large ceramic 64-pin DIP package,
while most 8-bit microprocessors such as the Intel 8080 used the more common, smaller, and less expensive
plastic 40-pin DIP. A follow-on chip, the TMS 9980, was designed to compete with the Intel 8080, had the full TI
990 16-bit instruction set, used a plastic 40-pin package, moved data 8 bits at a time, but could only address
16 KB. A third chip, the TMS 9995, was a new design. The family later expanded to include the 99105 and
99110.

The Western Design Center (WDC) introduced the CMOS 65816 16-bit upgrade of the WDC CMOS 65C02 in
1984. The 65816 16-bit microprocessor was the core of the Apple IIgs and later the Super Nintendo
Entertainment System, making it one of the most popular 16-bit designs of all time.

Intel "upsized" their 8080 design into the 16-bit Intel 8086, the first member of the x86 family, which powers
most modern PC type computers. Intel introduced the 8086 as a cost effective way of porting software from the
8080 lines, and succeeded in winning much business on that premise. The 8088, a version of the 8086 that
used an 8-bit external data bus, was the microprocessor in the first IBM PC. Intel then released
the 80186 and 80188, the 80286 and, in 1985, the 32-bit 80386, cementing their PC market dominance with
the processor family's backwards compatibility. The 80186 and 80188 were essentially versions of the 8086
and 8088, enhanced with some onboard peripherals and a few new instructions; they were not used in IBM-
compatible PCs because the built-in perpherals and their locations in the memory map were incompatible with
the IBM design. The 8086 and successors had an innovative but limited method ofmemory segmentation, while
the 80286 introduced a full-featured segmented memory management unit (MMU). The 80386 introduced a flat
32-bit memory model with paged memory management.

The Intel x86 processors up to and including the 80386 do not include floating-point units (FPUs). Intel
introduced the 8087, 80287, and80387 math coprocessors to add hardware floating-point and transcendental
function capabilities to the 8086 through 80386 CPUs. The 8087 works with the 8086/8088 and 80186/80188,
[28]
 the 80187 works with the 80186/80188, the 80287 works with the 80286 and 80386, [29] and the 80387 works
with the 80386 (yielding better performance than the 80287). The combination of an x86 CPU and an x87
coprocessor forms a single multi-chip microprocessor; the two chips are programmed as a unit using a single
integrated instruction set.[30] Though the 8087 coprocessor is interfaced to the CPU through I/O ports in the
CPU's address space, this is transparent to the program, which does not need to know about or access these
I/O ports directly; the program accesses the coprocessor and its registers through normal instruction opcodes.
Starting with the successor to the 80386, the 80486, the FPU was integrated with the control unit, MMU, and
integer ALU in a pipelined design on a single chip (in the 80486DX version), or the FPU was eliminated entirely
(in the 80486SX version). An ostensible coprocessor for the 80486SX, the 80487, was actually a complete
80486DX which disabled and replaced the coprocessorless 80486SX that it was installed to upgrade.

[edit]32-bit designs

Upper interconnect layers on an Intel 80486DX2 die.


16-bit designs had only been on the market briefly when 32-bit implementations started to appear.

The most significant of the 32-bit designs is the MC68000, introduced in 1979. The 68K, as it was widely
known, had 32-bit registers in its programming model but used 16-bit internal data paths, 3 16-bit Arithmetic
Logic Units, and a 16-bit external data bus (to reduce pin count), and supported only 24-bit addresses. In PC-
based IBM-compatible mainframes the MC68000 internal microcode was modified to emulate the 32-bit
System/370 IBM mainframe.[31]Motorola generally described it as a 16-bit processor, though it clearly has 32-bit
capablearchitecture. The combination of high performance, large (16 megabytes or 224 bytes) memory space
and fairly low cost made it the most popular CPU design of its class. TheApple Lisa and Macintosh designs
made use of the 68000, as did a host of other designs in the mid-1980s, including the Atari
ST and Commodore Amiga.

The world's first single-chip fully 32-bit microprocessor, with 32-bit data paths, 32-bit buses, and 32-bit
addresses, was the AT&T Bell Labs BELLMAC-32A, with first samples in 1980, and general production in
1982[32][33] After the divestiture of AT&T in 1984, it was renamed the WE 32000 (WE for Western Electric), and
had two follow-on generations, the WE 32100 and WE 32200. These microprocessors were used in
the AT&T 3B5 and 3B15 minicomputers; in the 3B2, the world's first desktop supermicrocomputer; in the
"Companion", the world's first 32-bit laptop computer; and in "Alexander", the world's first book-sized
supermicrocomputer, featuring ROM-pack memory cartridges similar to today's gaming consoles. All these
systems ran the UNIX System V operating system.

Intel's first 32-bit microprocessor was the iAPX 432, which was introduced in 1981 but was not a commercial
success. It had an advanced capability-based object-oriented architecture, but poor performance compared to
contemporary architectures such as Intel's own 80286 (introduced 1982), which was almost four times as fast
on typical benchmark tests. However, the results for the iAPX432 was partly due to a rushed and therefore
suboptimal Ada compiler.[citation needed]

The ARM first appeared in 1985. This is a RISC processor design, which has since come to dominate the 32-
bit embedded systemsprocessor space due in large part to its power efficiency, its licensing model, and its wide
selection of system development tools. Semiconductor manufacturers generally license cores such as
the ARM11 and integrate them into their own system on a chip products; only a few such vendors are licensed
to modify the ARM cores. Most cell phones include an ARM processor, as do a wide variety of other products.
There are microcontroller-oriented ARM cores without virtual memory support, as well as SMP applications
processors with virtual memory.

Motorola's success with the 68000 led to the MC68010, which added virtual memory support. The MC68020,
introduced in 1985 added full 32-bit data and address buses. The 68020 became hugely popular in
the Unix supermicrocomputer market, and many small companies (e.g., Altos, Charles River Data Systems)
produced desktop-size systems. The MC68030 was introduced next, improving upon the previous design by
integrating the MMU into the chip. The continued success led to the MC68040, which included an FPU for
better math performance. A 68050 failed to achieve its performance goals and was not released, and the
follow-up MC68060 was released into a market saturated by much faster RISC designs. The 68K family faded
from the desktop in the early 1990s.

Other large companies designed the 68020 and follow-ons into embedded equipment. At one point, there were
more 68020s in embedded equipment than there were Intel Pentiums in PCs.[34] The ColdFire processor cores
are derivatives of the venerable 68020.

During this time (early to mid-1980s), National Semiconductor introduced a very similar 16-bit pinout, 32-bit
internal microprocessor called the NS 16032 (later renamed 32016), the full 32-bit version named the NS
32032. Later the NS 32132 was introduced which allowed two CPUs to reside on the same memory bus, with
built in arbitration. The NS32016/32 outperformed the MC68000/10 but the NS32332 which arrived at
approximately the same time the MC68020 did not have enough performance. The third generation chip, the
NS32532 was different. It had about double the performance of the MC68030 which was released around the
same time. The appearance of RISC processors like the AM29000 and MC88000 (now both dead) influenced
the architecture of the final core, the NS32764. Technically advanced, using a superscalar RISC core, internally
overclocked, with a 64 bit bus, it was still capable of executing Series 32000 instructions through real time
translation.

When National Semiconductor decided to leave the Unix market, the chip was redesigned into the Swordfish
Embedded processor with a set of on chip peripherals. The chip turned out to be too expensive for the laser
printer market and was killed. The design team went to Intel and there designed the Pentium processor which
is very similar to the NS32764 core internally The big success of the Series 32000 was in the laser printer
market, where the NS32CG16 with microcoded BitBlt instructions had very good price/performance and was
adopted by large companies like Canon. By the mid-1980s, Sequent introduced the first symmetric
multiprocessor (SMP) server-class computer using the NS 32032. This was one of the design's few wins, and it
disappeared in the late 1980s. The MIPS R2000 (1984) andR3000 (1989) were highly successful 32-bit RISC
microprocessors. They were used in high-end workstations and servers by SGI, among others. Other designs
included the interesting Zilog Z80000, which arrived too late to market to stand a chance and disappeared
quickly.

In the late 1980s, "microprocessor wars" started killing off some of the microprocessors [citation needed].
Apparently[vague], with only one major design win, Sequent, the NS 32032 just faded out of existence, and
Sequent switched to Intel microprocessors[citation needed].

From 1985 to 2003, the 32-bit x86 architectures became increasingly dominant in desktop, laptop, and server
markets, and these microprocessors became faster and more capable. Intel had licensed early versions of the
architecture to other companies, but declined to license the Pentium, so AMD and Cyrix built later versions of
the architecture based on their own designs. During this span, these processors increased in complexity
(transistor count) and capability (instructions/second) by at least three orders of magnitude. Intel's Pentium line
is probably the most famous and recognizable 32-bit processor model, at least with the public at large.

[edit]64-bit designs in personal computers

While 64-bit microprocessor designs have been in use in several markets since the early 1990s, the early
2000s saw the introduction of 64-bit microprocessors targeted at the PC market.

With AMD's introduction of a 64-bit architecture backwards-compatible with x86, x86-64 (also called AMD64),


in September 2003, followed by Intel's near fully compatible 64-bit extensions (first called IA-32e or EM64T,
later renamed Intel 64), the 64-bit desktop era began. Both versions can run 32-bit legacy applications without
any performance penalty as well as new 64-bit software. With operating systems Windows XP x64, Windows
Vista x64, Windows 7 x64, Linux, BSD and Mac OS X that run 64-bit native, the software is also geared to fully
utilize the capabilities of such processors. The move to 64 bits is more than just an increase in register size
from the IA-32 as it also doubles the number of general-purpose registers.

The move to 64 bits by PowerPC processors had been intended since the processors' design in the early 90s
and was not a major cause of incompatibility. Existing integer registers are extended as are all related data
pathways, but, as was the case with IA-32, both floating point and vector units had been operating at or above
64 bits for several years. Unlike what happened when IA-32 was extended to x86-64, no new general purpose
registers were added in 64-bit PowerPC, so any performance gained when using the 64-bit mode for
applications making no use of the larger address space is minimal.

[edit]Multicore designs

Main article:  Multi-core (computing)

A different approach to improving a computer's performance is to add extra processors, as in symmetric


multiprocessing designs, which have been popular in servers and workstations since the early 1990s. Keeping
up with Moore's Law is becoming increasingly challenging as chip-making technologies approach their physical
limits.

In response, microprocessor manufacturers look for other ways to improve performance in order to hold on to
the momentum of constant upgrades in the market.

A multi-core processor is simply a single chip containing more than one microprocessor core. This effectively
multiplies the processor's potential performance by the number of cores (as long as the operating system and
software is designed to take advantage of more than one processor core). Some components, such as bus
interface and second level cache, may be shared between cores. Because the cores are physically very close
to each other, they can communicate with each other much faster than separate processors in a multiprocessor
system, which improves overall system performance.

In 2005, the first personal computer dual-core processors were announced. As of 2009, dual-core and quad-
core processors are widely used in servers, workstations and PCs while six and eight-core processors will be
available for high-end applications in both the home and professional environments.

Sun Microsystems has released the Niagara and Niagara 2 chips, both of which feature an eight-core design.
The Niagara 2 supports more threads and operates at 1.6 GHz.

High-end Intel Xeon processors that are on the LGA771 socket are DP (dual processor) capable, as well as the
Intel Core 2 Extreme QX9775 also used in the Mac Pro by Apple and the Intel Skulltrail motherboard. With the
transition to the LGA1366 and LGA1156 socket and the Intel i7 and i5 chips, quad core is now considered
mainstream, but with the release of the i7-980x, six core processors are now well within reach.

[edit]RISC

Main article:  Reduced instruction set computing

In the mid-1980s to early-1990s, a crop of new high-performance Reduced Instruction Set Computer (RISC)
microprocessors appeared, influenced by discrete RISC-like CPU designs such as the IBM 801 and others.
RISC microprocessors were initially used in special-purpose machines and Unix workstations, but then gained
wide acceptance in other roles.

In 1986, HP released its first system with a PA-RISC CPU. The first commercial RISC microprocessor design
was released either byMIPS Computer Systems, the 32-bit R2000 (the R1000 was not released) or by Acorn
computers, the 32-bit ARM2 in 1987.[citation needed] The R3000 made the design truly practical, and
the R4000 introduced the world's first commercially available 64-bit RISC microprocessor. Competing projects
would result in the IBM POWER and Sun SPARC architectures. Soon every major vendor was releasing a
RISC design, including the AT&T CRISP, AMD 29000, Intel i860 and Intel i960, Motorola 88000, DEC Alpha.

As of 2007, two 64-bit RISC architectures are still produced in volume for non-embedded
applications: SPARC and Power ISA.

[edit]Special-purpose designs

A microprocessor is a general purpose system. Several specialized processing devices have followed from the
technology.Microcontrollers integrate a microprocessor with periphal devices for control of embedded system.
A digital signal processor (DSP) is specialized for signal processing. Graphics processing units may have no,
limited, or general programming facilities. For example, GPUs through the 1990s were mostly non-
programmable and have only recently gained limited facilities like programmable vertex shaders.
[edit]Market statistics

In 2003, about $44 billion (USD) worth of microprocessors were manufactured and sold. [35] Although about half
of that money was spent on CPUs used in desktop or laptop personal computers, those count for only about
2% of all CPUs sold.[36]

About 55% of all CPUs sold in the world are 8-bit microcontrollers, over two billion of which were sold in 1997.
[37]

As of 2002, less than 10% of all the CPUs sold in the world are 32-bit or more. Of all the 32-bit CPUs sold,
about 2% are used in desktop or laptop personal computers. Most microprocessors are used in embedded
control applications such as household appliances, automobiles, and computer peripherals. Taken as a whole,
the average price for a microprocessor, microcontroller, or DSP is just over $6.[36]

About ten billion CPUs were manufactured in 2008. About 98% of new CPUs produced each year are
embedded.[38]

microprocessor (logic chip)


 E-mail
 Print
 A
 AA
 AAA
 LinkedIn
 Facebook
 Twitter
 Share This
 Reprints
A microprocessor, sometimes called a logic chip, is a computer processor on a microchip.

The microprocessor contains all, or most of, the central processing unit (CPU) functions and is the
"engine" that goes into motion when

LEARN MORE

 Desktops and laptops

 CIO Midmarket Resources

you turn your computer on. A microprocessor is designed to perform arithmetic and logic operations
that make use of small number-holding areas called registers. Typical microprocessor operations include
adding, subtracting, comparing two numbers, and fetching numbers from one area to another. These
operations are the result of a set ofinstructions that are part of the microprocessor design.

When your computer is turned on, the microprocessor gets the first instruction from the basic
input/output system (BIOS) that comes with the computer as part of its memory. After that, either the
BIOS, or the operating system that BIOS loads into computer memory, or an application progam is
"driving" the microprocessor, giving it instructions to perform.

RELATED GLOSSARY TERMS: architecture, touch screen, DMI (Desktop Management Interface)

Microcontroller
From Wikipedia, the free encyclopedia

This article needs additional citations for verification. Please help improve this article by adding


citations to reliable sources. Unsourced material may be challenged and removed.(November 2009)

The die from an Intel 8742, an 8-bit microcontroller that includes a CPU running at 12 MHz, 128 bytes of RAM, 2048 bytes ofEPROM,

and I/O in the same chip.

A microcontroller (sometimes abbreviated µC, uC or MCU) is a small computer on a single integrated


circuit containing a processor core, memory, and programmableinput/output peripherals. Program memory in
the form of NOR flash or OTP ROM is also often included on chip, as well as a typically small amount of RAM.
Microcontrollers are designed for embedded applications, in contrast to the microprocessors used in personal
computers or other general purpose applications.

Microcontrollers are used in automatically controlled products and devices, such as automobile engine control
systems, implantable medical devices, remote controls, office machines, appliances, power tools, toys and
other embedded systems. By reducing the size and cost compared to a design that uses a separate
microprocessor, memory, and input/output devices, microcontrollers make it economical to digitally control
even more devices and processes. Mixed signal microcontrollers are common, integrating analog components
needed to control non-digital electronic systems.
Some microcontrollers may use four-bit words and operate at clock rate frequencies as low as 4 kHz, for low
power consumption (milliwatts or microwatts). They will generally have the ability to retain functionality while
waiting for an event such as a button press or other interrupt; power consumption while sleeping (CPU clock
and most peripherals off) may be just nanowatts, making many of them well suited for long lasting battery
applications. Other microcontrollers may serve performance-critical roles, where they may need to act more like
a digital signal processor (DSP), with higher clock speeds and power consumption.

Contents
  [hide] 

1 Embedded design

o 1.1 Interrupts

o 1.2 Programs

o 1.3 Other microcontroller features

2 Higher integration

3 Volumes

4 Programming environments

5 Types of microcontrollers

6 Interrupt latency

7 History

8 Microcontroller embedded memory

technology

o 8.1 Data

o 8.2 Firmware

9 See also

10 Notes

11 External links

[edit]Embedded design

A microcontroller can be considered a self-contained system with a processor, memory and peripherals and
can be used as anembedded system.[1] The majority of microcontrollers in use today are embedded in other
machinery, such as automobiles, telephones, appliances, and peripherals for computer systems. These are
called embedded systems. While some embedded systems are very sophisticated, many have minimal
requirements for memory and program length, with no operating system, and low software complexity. Typical
input and output devices include switches, relays, solenoids, LEDs, small or custom LCD displays, radio
frequency devices, and sensors for data such as temperature, humidity, light level etc. Embedded systems
usually have no keyboard, screen, disks, printers, or other recognizable I/O devices of a personal computer,
and may lack human interaction devices of any kind.

[edit]Interrupts

Microcontrollers must provide real time (predictable, though not necessarily fast) response to events in the
embedded system they are controlling. When certain events occur, an interrupt system can signal the
processor to suspend processing the current instruction sequence and to begin an interrupt service
routine (ISR, or "interrupt handler"). The ISR will perform any processing required based on the source of the
interrupt before returning to the original instruction sequence. Possible interrupt sources are device dependent,
and often include events such as an internal timer overflow, completing an analog to digital conversion, a logic
level change on an input such as from a button being pressed, and data received on a communication link.
Where power consumption is important as in battery operated devices, interrupts may also wake a
microcontroller from a low power sleep state where the processor is halted until required to do something by a
peripheral event.

[edit]Programs

Microcontroller programs must fit in the available on-chip program memory, since it would be costly to provide a
system with external, expandable, memory. Compilers and assemblers are used to convert high-level language
and assembler language codes into a compactmachine code for storage in the microcontroller's memory.
Depending on the device, the program memory may be permanent, read-only memory that can only be
programmed at the factory, or program memory may be field-alterable flash or erasable read-only memory.

[edit]Other microcontroller features


Microcontrollers usually contain from several to dozens of general purpose input/output pins (GPIO). GPIO pins
are software configurable to either an input or an output state. When GPIO pins are configured to an input
state, they are often used to read sensors or external signals. Configured to the output state, GPIO pins can
drive external devices such as LEDs or motors.

Many embedded systems need to read sensors that produce analog signals. This is the purpose of the analog-
to-digital converter (ADC). Since processors are built to interpret and process digital data, i.e. 1s and 0s, they
are not able to do anything with the analog signals that may be sent to it by a device. So the analog to digital
converter is used to convert the incoming data into a form that the processor can recognize. A less common
feature on some microcontrollers is a digital-to-analog converter (DAC) that allows the processor to output
analog signals or voltage levels.

In addition to the converters, many embedded microprocessors include a variety of timers as well. One of the
most common types of timers is the Programmable Interval Timer (PIT). A PIT may either count down from
some value to zero, or up to the capacity of the count register, overflowing to zero. Once it reaches zero, it
sends an interrupt to the processor indicating that it has finished counting. This is useful for devices such as
thermostats, which periodically test the temperature around them to see if they need to turn the air conditioner
on, the heater on, etc.

Time Processing Unit (TPU) is a sophisticated timer. In addition to counting down, the TPU can detect input
events, generate output events, and perform other useful operations.

A dedicated Pulse Width Modulation (PWM) block makes it possible for the CPU to control power
converters, resistive loads, motors, etc., without using lots of CPU resources in tight timer loops.

Universal Asynchronous Receiver/Transmitter (UART) block makes it possible to receive and transmit data
over a serial line with very little load on the CPU. Dedicated on-chip hardware also often includes capabilities to
communicate with other devices (chips) in digital formats such as I2C and Serial Peripheral Interface (SPI).

[edit]Higher integration

Micro-controllers may not implement an external address or data bus as they integrate RAM and non-volatile
memory on the same chip as the CPU. Using fewer pins, the chip can be placed in a much smaller, cheaper
package.

Integrating the memory and other peripherals on a single chip and testing them as a unit increases the cost of
that chip, but often results in decreased net cost of the embedded system as a whole. Even if the cost of a CPU
that has integrated peripherals is slightly more than the cost of a CPU and external peripherals, having fewer
chips typically allows a smaller and cheaper circuit board, and reduces the labor required to assemble and test
the circuit board.

A micro-controller is a single integrated circuit, commonly with the following features:

 central processing unit - ranging from small and simple 4-bit processors to complex 32- or 64-bit
processors

 volatile memory (RAM) for data storage

 ROM, EPROM, EEPROM or Flash memory for program and operating parameter storage

 discrete input and output bits, allowing control or detection of the logic state of an individual package
pin

 serial input/output such as serial ports (UARTs)

 other serial communications interfaces like I²C, Serial Peripheral Interface and Controller Area


Network for system interconnect

 peripherals such as timers, event counters, PWM generators, and watchdog

 clock generator - often an oscillator for a quartz timing crystal, resonator or RC circuit

 many include analog-to-digital converters, some include digital-to-analog converters


 in-circuit programming and debugging support

This integration drastically reduces the number of chips and the amount of wiring and circuit board space that
would be needed to produce equivalent systems using separate chips. Furthermore, on low pin count devices
in particular, each pin may interface to several internal peripherals, with the pin function selected by software.
This allows a part to be used in a wider variety of applications than if pins had dedicated functions. Micro-
controllers have proved to be highly popular in embedded systems since their introduction in the 1970s.

Some microcontrollers use a Harvard architecture: separate memory buses for instructions and data, allowing
accesses to take place concurrently. Where a Harvard architecture is used, instruction words for the processor
may be a different bit size than the length of internal memory and registers; for example: 12-bit instructions
used with 8-bit data registers.

The decision of which peripheral to integrate is often difficult. The microcontroller vendors often trade operating
frequencies and system design flexibility against time-to-market requirements from their customers and overall
lower system cost. Manufacturers have to balance the need to minimize the chip size against additional
functionality.

Microcontroller architectures vary widely. Some designs include general-purpose microprocessor cores, with
one or more ROM, RAM, or I/O functions integrated onto the package. Other designs are purpose built for
control applications. A micro-controller instruction set usually has many instructions intended for bit-wise
operations to make control programs more compact. [2] For example, a general purpose processor might require
several instructions to test a bit in a register and branch if the bit is set, where a micro-controller could have a
single instruction to provide that commonly-required function.

Microcontrollers typically do not have a math coprocessor, so floating point arithmetic is performed by software.

[edit]Volumes

About 55% of all CPUs sold in the world are 8-bit microcontrollers and microprocessors. According to Semico,
over four billion 8-bit microcontrollers were sold in 2006.[3]

A typical home in a developed country is likely to have only four general-purpose microprocessors but around
three dozen microcontrollers. A typical mid-range automobile has as many as 30 or more microcontrollers.
They can also be found in many electrical devices such as washing machines, microwave ovens, and
telephones.
A PIC 18F8720 microcontroller in an 80-pin TQFP package.

Manufacturers have often produced special versions of their microcontrollers in order to help the hardware
and software development of the target system. Originally these includedEPROM versions that have a
"window" on the top of the device through which program memory can be erased by ultraviolet light, ready for
reprogramming after a programming ("burn") and test cycle. Since 1998, EPROM versions are rare and have
been replaced byEEPROM and flash, which are easier to use (can be erased electronically) and cheaper to
manufacture.

Other versions may be available where the ROM is accessed as an external device rather than as internal
memory, however these are becoming increasingly rare due to the widespread availability of cheap
microcontroller programmers.

The use of field-programmable devices on a microcontroller may allow field update of thefirmware or permit late
factory revisions to products that have been assembled but not yet shipped. Programmable memory also
reduces the lead time required for deployment of a new product.

Where hundreds of thousands of identical devices are required, using parts programmed at the time of
manufacture can be an economical option. These "mask programmed" parts have the program laid down in the
same way as the logic of the chip, at the same time.

[edit]Programming environments

Microcontrollers were originally programmed only in assembly language, but various high-level programming
languages are now also in common use to target microcontrollers. These languages are either designed
specially for the purpose, or versions of general purpose languages such as the C programming
language. Compilers for general purpose languages will typically have some restrictions as well as
enhancements to better support the unique characteristics of microcontrollers. Some microcontrollers have
environments to aid developing certain types of applications. Microcontroller vendors often make tools freely
available to make it easier to adopt their hardware.

Many microcontrollers are so quirky that they effectively require their own non-standard dialects of C, such
as SDCC for the 8051, which prevent using standard tools (such as code libraries or static analysis tools) even
for code unrelated to hardware features. Interpreters are often used to hide such low level quirks.

Interpreter firmware is also available for some microcontrollers. For example, BASIC on the early
microcontrollers Intel 8052;[4] BASIC and FORTH on the Zilog Z8[5] as well as some modern devices. Typically
these interpreters support interactive programming.

Simulators are available for some microcontrollers. These allow a developer to analyze what the behavior of
the microcontroller and their program should be if they were using the actual part. A simulator will show the
internal processor state and also that of the outputs, as well as allowing input signals to be generated. While on
the one hand most simulators will be limited from being unable to simulate much other hardware in a system,
they can exercise conditions that may otherwise be hard to reproduce at will in the physical implementation,
and can be the quickest way to debug and analyze problems.

Recent microcontrollers are often integrated with on-chip debug circuitry that when accessed by an in-circuit
emulator via JTAG, allow debugging of the firmware with a debugger.

[edit]Types of microcontrollers

See also:  List of common microcontrollers

As of 2008 there are several dozen microcontroller architectures and vendors including:

 ARM processors (from many vendors) using ARM7 or Cortex-M3 cores are generally microcontrollers

 STMicroelectronics(8-bit), ST10 (16-bit) and STM32 (32-bit)

 Atmel AVR (8-bit), AVR32 (32-bit), and AT91SAM (32-bit)

 Freescale ColdFire (32-bit) and S08 (8-bit)

 Freescale 68HC11 (8-bit)

 Intel 8051

 Infineon Microcontroller: 8, 16, 32 Bit microcontrollers for automotive and industrial applications [6]

 MIPS (32-bit PIC32)

 NXP Semiconductors LPC1000, LPC2000, LPC3000, LPC4000 (32-bit), LPC900, LPC700 (8-bit)

 Microchip PIC (8-bit PIC16, PIC18, 16-bit dsPIC33 / PIC24)

 Parallax Propeller

 PowerPC ISE
 PSoC (Programmable System-on-Chip)

 Rabbit 2000 (8-bit)

 Renesas RX, V850, Hitachi H8, Hitachi SuperH (32-bit), M16C (16-bit), RL78, R8C, 78K0/78K0R (8-


bit)

 Silicon Laboratories Pipelined 8051 Microcontrollers

 Texas Instruments Microcontrollers  : TI MSP430 16-bit Microcontrollers

 Toshiba TLCS-870 (8-bit/16-bit)

and many others, some of which are used in very narrow range of applications or are more like applications
processors than microcontrollers. The microcontroller market is extremely fragmented, with numerous vendors,
technologies, and markets. Note that many vendors sell (or have sold) multiple architectures.

[edit]Interrupt latency

In contrast to general-purpose computers, microcontrollers used in embedded systems often seek to


optimize interrupt latency over instruction throughput. Issues include both reducing the latency, and making it
be more predictable (to support real-time control).

When an electronic device causes an interrupt, the intermediate results (registers) have to be saved before the
software responsible for handling the interrupt can run. They must also be restored after that software is
finished. If there are more registers, this saving and restoring process takes more time, increasing the latency.
Ways to reduce such context/restore latency include having relatively few registers in their central processing
units (undesirable because it slows down most non-interrupt processing substantially), or at least having the
hardware not save them all (this fails if the software then needs to compensate by saving the rest "manually").
Another technique involves spending silicon gates on "shadow registers": One or more duplicate registers used
only by the interrupt software, perhaps supporting a dedicated stack.

Other factors affecting interrupt latency include:

 Cycles needed to complete current CPU activities. To minimize those costs, microcontrollers tend to
have short pipelines (often three instructions or less), small write buffers, and ensure that longer
instructions are continuable or restartable. RISC design principles ensure that most instructions take the
same number of cycles, helping avoid the need for most such continuation/restart logic.

 The length of any critical section that needs to be interrupted. Entry to a critical section restricts
concurrent data structure access. When a data structure must be accessed by an interrupt handler, the
critical section must block that interrupt. Accordingly, interrupt latency is increased by however long that
interrupt is blocked. When there are hard external constraints on system latency, developers often need
tools to measure interrupt latencies and track down which critical sections cause slowdowns.
 One common technique just blocks all interrupts for the duration of the critical section. This is
easy to implement, but sometimes critical sections get uncomfortably long.

 A more complex technique just blocks the interrupts that may trigger access to that data
structure. This is often based on interrupt priorities, which tend to not correspond well to the relevant
system data structures. Accordingly, this technique is used mostly in very constrained environments.

 Processors may have hardware support for some critical sections. Examples include
supporting atomic access to bits or bytes within a word, or other atomic access primitives like
the LDREX/STREX exclusive access primitives introduced in the ARMv6architecture.

 Interrupt nesting. Some microcontrollers allow higher priority interrupts to interrupt lower priority ones.
This allows software to manage latency by giving time-critical interrupts higher priority (and thus lower and
more predictable latency) than less-critical ones.

 Trigger rate. When interrupts occur back-to-back, microcontrollers may avoid an extra context
save/restore cycle by a form of tail calloptimization.

Lower end microcontrollers tend to support fewer interrupt latency controls than higher end ones.

[edit]History

This section requires expansion.

The first single-chip microprocessor was the 4-bit Intel 4004 released in 1971, with the Intel 8008 and other
more capable microprocessors becoming available over the next several years.

These however all required external chip(s) to implement a working system, raising total system cost, and
making it impossible to economically computerize appliances.

The Smithsonian Institution says TI engineers Gary Boone and Michael Cochran succeeded in creating the first
microcontroller in 1971. The result of their work was the TMS 1000, which went commercial in 1974. It
combined read-only memory, read/write memory, processor and clock on one chip and was targeted at
embedded systems.[7]

Partly in response to the existence of the single-chip TMS 1000, [8] Intel developed a computer system on a chip
optimized for control applications, the Intel 8048, with commercial parts first shipping in 1977.[8] It
combined RAM and ROM on the same chip. This chip would find its way into over one billion PC keyboards,
and other numerous applications. At this time Intels President, Luke J. Valenter, stated that the
(Microcontroller) was one of the most successful in the companies history, and expanded the division's budget
over 25%.

Most microcontrollers at this time had two variants. One had an erasable EPROM program memory, which was
significantly more expensive than the PROM variant which was only programmable once. Erasing the EPROM
required exposure to ultraviolet light through a transparent quartz lid. One-time parts could be made in lower-
cost opaque plastic packages.

In 1993, the introduction of EEPROM memory allowed microcontrollers (beginning with the


Microchip PIC16x84) [1][citation needed] to be electrically erased quickly without an expensive package as required
for EPROM, allowing both rapid prototyping, and In System Programming.

The same year, Atmel introduced the first microcontroller using Flash memory.[9]

Other companies rapidly followed suit, with both memory types.

Cost has plummeted over time, with the cheapest 8-bit microcontrollers being available for under $0.25 in
quantity (thousands) in 2009,[citation needed] and some 32-bit microcontrollers around $1 for similar quantities.

Nowadays microcontrollers are low cost and readily available for hobbyists, with large online communities
around certain processors.

In the future, MRAM could potentially be used in microcontrollers as it has infinite endurance and its
incremental semiconductor wafer process cost is relatively low.

[edit]Microcontroller embedded memory technology

Since the emergence of microcontrollers, many different memory technologies have been used. Almost all
microcontrollers have at least two different kinds of memory, a non-volatile memory for storing firmware and a
read-write memory for temporary data.

[edit]Data

From the earliest microcontrollers to today, six-transistor SRAM is almost always used as the read/write
working memory, with a few more transistors per bit used in the register file. MRAM could potentially replace it
as it is 4-10 times denser which would make it more cost effective.

In addition to the SRAM, some microcontrollers also have internal EEPROM for data storage; and even ones
that do not have any (or not enough) are often connected to external serial EEPROM chip (such as the BASIC
Stamp) or external serial flash memory chip.

A few recent microcontrollers beginning in 2003 have "self-programmable" flash memory. [9]

[edit]Firmware

The earliest microcontrollers used mask ROM to store firmware. Later microcontrollers (such as the early
versions of the Freescale 68HC11 and early PIC microcontrollers) had quartz windows that allowed ultraviolet
light in to erase the EPROM.

The Microchip PIC16C84, introduced in 1993,[10] was the first microcontroller to use EEPROM to store firmware
Also in 1993, Atmel introduced the first microcontroller using NOR Flash memory to store firmware.[9]

PSoC microcontrollers, introduced in 2002, store firmware in SONOS flash memory.

MRAM could potentially be used to store firmware.

[edit]See also

 List of common microcontrollers

 Microarchitecture

 Microbotics

 Programmable logic controller

 Single-board microcontroller

 PIC microcontroller

Data type
From Wikipedia, the free encyclopedia

For other uses, see Data type (disambiguation).

In computer programming, a data type is a classification identifying one of various types of data, such
as floating-point, integer, orBoolean, that determines the possible values for that type; the operations that can
be done on values of that type; the meaning of the data; and the way values of that type can be stored. [1][2] Data
types are used within type systems, which offer various ways of defining, implementing and using them.
Different type systems ensure varying degrees of type safety. Formally, a type can be defined as "..any
property of a programme we can determine without executing the program". [3]

Contents

  [hide] 

1 Overview

2 Classes of data types

o 2.1 Machine data types

o 2.2 The boolean type

o 2.3 Numeric types
o 2.4 String and text types

o 2.5 Enumerations

o 2.6 Derived types

 2.6.1 Pointers and

references

 2.6.2 Composite

types

o 2.7 Abstract types

o 2.8 Utility types

3 Type systems

4 See also

5 References

6 Further reading

[edit]Overview

Almost all programming languages explicitly include the notion of data type, though different languages may
use different terminology. Common data types may include:

 integers,

 booleans,

 characters,

 floating-point numbers,

 alphanumeric strings.

For example, in the Java programming language, the "int" type represents the set of 32-bit integers ranging in
value from -2,147,483,648 to 2,147,483,647, as well as the operations that can be performed on integers, such
as addition, subtraction, and multiplication. Colors, on the other hand, are represented by three bytes denoting
the amounts each of red, green, and blue, and one string representing that color's name; allowable operations
include addition and subtraction, but not multiplication.

Most programming languages also allow the programmer to define additional data types, usually by combining
multiple elements of other types and defining the valid operations of the new data type. For example, a
programmer might create a new data type named "complex number" that would include real and imaginary
parts. A data type also represents a constraint placed upon the interpretation of data in atype system,
describing representation, interpretation and structure of values or objects stored in computer memory. The
type system uses data type information to check correctness of computer programs that access or manipulate
the data.

[edit]Classes of data types

[edit]Machine data types


All data in computers based on digital electronics is represented as bits (alternatives 0 and 1) on the lowest
level. The smallest addressable unit of data is usually a group of bits called a byte (usually an octet, which is 8
bits). The unit processed by machine codeinstructions is called a word (as of 2011, typically 32 or 64 bits). Most
instructions interpret the word as a binary number, such that a 32-bit word can represent unsigned integer
values from 0 to 232 − 1 or signed integer values from − 231 to 231 − 1. Because of two's complement, the
machine language and machine doesn't need to distinguish between these unsigned and signed data types for
the most part.

There is a specific set of arithmetic instructions that use a different interpretation of the bits in word as
a floating-point number.

Machine data types need to be exposed or made available in systems or low-level programming languages,
allowing fine-grained control over hardware. The C programming language, for instance, supplies integer types
of various widths, such as short and long. If a corresponding native type does not exist on the target

platform, the compiler will break them down into code using types that do exist. For instance, if a 32-bit integer
is requested on a 16 bit platform, the compiler will tacitly treat it as an array of two 16 bit integers.

Several languages allow binary and hexadecimal literals, for convenient manipulation of machine data.

In higher level programming, machine data types are often hidden or abstracted as am implementation detail
that would render code less portable if exposed. For instance, a generic numeric type might be supplied

instead of integers of some specific bit-width.

[edit]The boolean type


The Boolean type represents the values: true and false. Although only two values are possible, they are rarely
implemented as as single binary digit for efficiency reasons. Many programming language do not have an
explicit boolean type, instead interpreting (for instance) 0 as false and other values as true.

[edit]Numeric types
Such as:-

 The integer data types, or "whole numbers". May be subtyped according to their ability to contain
negative values (eg. unsigned in C and C++). May also have a small number of predefined subtypes
(such as short and long in C/C++); or allow users to freely define subranges such as 1..12

(eg. PASCAL/ADA).

 Floating point data types, sometimes misleadingly called reals, contain fractional values. They usually
have predefined limits on both their maximum values and their precision.

 Fixed point data types are convenient for representing monetary values. They are often implemented
internally as integers, leading to predefined limits.

 Bignum or arbitrary precision numeric types lack predefined limits. They are not primitive types, and
are used sparingly used for efficiency reasons.
[edit]String and text types
Such as

 Alphanumeric character. A letter of the alphabet, digit, blank space, punctuation mark, etc.

 Alphanumeric strings, a sequence of characters. They are typically used to represent words and text.

Character and string types can store sequences of characters from a character set such as ASCII. Since most
character sets include the digits, it is possible to have a numeric string, such as "1234". However, many
languages would still treat these as belonging to a different type to the numeric value 1234.

Character and string types can have different subtypes according to the required character "width". The original
7-bit wide ASCII was found to be limited, and superseded by 8 and 16-bit sets, which can encode a wide
variety of non-latin alphabets (Hebrew, Chinese) and other symbols. Strings may be either stretch-to-fit or of
fixed size, even in the same programming language. They may also be subtyped by their maximum size.

Note: strings are not primitive in all languages, for instance C: they may be composed from arrays of
characters.

[edit]Enumerations

The enumerated type. This has values which are different from each other, and which can be compared an
assigned, but which do not necessarily have any particular concrete representation in the computer's memory;
compilers and interpreters can represent them arbitrarily. For example, the four suits in a deck of playing cards
may be four enumerators named CLUB, DIAMOND, HEART, SPADE, belonging to an enumerated type
named suit. If a variable V is declared having suit as its data type, one can assign any of those four values to it.
Some implementations allow programmers to assign integer values to the enumeration values, or even treat
them as type-equivalent to integers.

[edit]Derived types
Types can be based on, or derived from, the basic types explained above.

In some language, such as C, functions have a type derived from the type of their return value.
[edit]Pointers and references

The main non-composite, derived type is the pointer, a data type whose value refers directly to (or "points to")
another value stored elsewhere in the computer memory using its address. It is a primitive kind of reference. (In
everyday terms, a page number in a book could be considered a piece of data that refers to another one).
Pointers are often stored in a format similar to an integer; however, attempting to dereference or "look up" a
pointer whose value was never a valid memory address would cause a programme to crash. To ameliorate this
potential problem, pointers are considered a separate type to the type of data they point to, even if the
underlying representation is the same.

[edit]Composite types

Composite types are derived from more than one primitive type. This can be done in a number of ways. The
ways they are combined are called data structures. Composing a primitive type into a compound type generally
results in a new type, eg. array-of-integer is a different type to integer.

 An array stores a number of elements of the same type in a specific order. They are accessed using
an integer to specify which element is required (although the elements may be of almost any type). Arrays
may be fixed-length or expandable.

 Record (also called tuple or struct) Records are among the simplest data structures. A record is a
value that contains other values, typically in fixed number and sequence and typically indexed by names.
The elements of records are usually called fields ormembers.

 Union. A union type definition will specify which of a number of permitted primitive types may be stored
in its instances, eg "float or long integer". Contrast with a record, which could be defined to contain a
float and an integer; whereas, in a union, there is only one value at a time.

 A tagged union (also called a variant, variant record, discriminated union, or disjoint union) contains an
additional field indicating its current type, for enhanced type safety.

 A set is an abstract data structure that can store certain values, without any particular order, and no
repeated values. Values themselves are not retrieved from sets, rather one tests a value for membership to
obtain a boolean "in" or "not in".

 An object contains a number of data fields, like a record, and also a number of programme code
fragments for accessing or modifying them. Data structures not containing code, like those above, are
called plain old data structure.

Many others are possible, but they tend to be further variations and compounds of the above.

[edit]Abstract types
Any type that does not specify an implementation is an Abstract data type. For instance, a stack (which is an
abstract type) can be implemented as an array (a contiguous block of memory containing multiple values), or
as a linked list (a set of non-contiguous memory blocks linked by pointers).

Abstract types can be handled by code that does not know or "care" what underlying types are contained in
them. Programming that is agnostic about concrete data types is called generic programming. Arrays and
records can also contain underlying types, but are considered concrete because they specify how their
contents or elements are laid out in memory.

Examples include:-

 A smart pointer is the abstract counterpart to a pointer. Both are kinds of reference

 A hash or dictionary or map or Map/Associative array/Dictionary is a more flexible variation on a


record, in which name-value pairscan be added and deleted freely.

 A queue is a first-in last-out list. Variations are Deque and Priority queue.

 A set can store certain values, without any particular order, and with no repeated values.

 A stack is a first-in, first-out list.

 A tree is a hierarchical structure.

 A graph.
[edit]Utility types
For convenience, high-level languages may supply ready-made "real world" data types, for
instance times, dates and monetary values, even where the language allows them to be built from primitive
types.

[edit]Type systems

Main article:  Type system

A type system associates types with each computed value. By examining the flow of these values, a type
system attempts to prove that no type errors can occur. The type system in question determines what
constitutes a type error, but a type system generally seeks to guarantee that operations expecting a certain
kind of value are not used with values for which that operation does not make sense.

A compiler may use the static type of a value to optimize the storage it needs and the choice of algorithms for
operations on the value. In many C compilers the float data type, for example, is represented in 32 bits, in
accord with the IEEE specification for single-precision floating point numbers. They will thus use floating-point-
specific microprocessor operations on those values (floating-point addition, multiplication, etc.).
The depth of type constraints and the manner of their evaluation affect the typing of the language.
A programming language may further associate an operation with varying concrete algorithms on each type in
the case of type polymorphism. Type theory is the study of type systems, although the concrete type systems
of programming languages originate from practical issues of computer architecture, compiler implementation,
and language design.

Type systems may be variously static or dynamic, strong or weak typing, and so forth.

You might also like