The Hardware Side - Part 1: An Introduction

Download as pptx, pdf, or txt
Download as pptx, pdf, or txt
You are on page 1of 68

The Hardware Side Part 1:

An Introduction

THINGS TO LOOK FOR

The differences between microprocessors,


microcomputers and microcontrollers
The four major functional blocks of a computer and
their interconnecting busses.
How to represent numbers, characters, addresses
and instructions in a digital system.
Different instruction formats and addressing
modes.
Data and control flow through a computer.
The instruction set architecture (ISA) level model of
a computer
The computer instruction cycle.
The register transfer level(RTL) model of a

The Hardware Side Getting Started

Hardware side of embedded systems begins with a highlevel view of the computing core of the systems.
Figure illustrates the sequence followed.
The computing core is the central hardware component in
any modern embedded applications.

Figure 2.0 Exploring Embedded


Systems

The Hardware Side Getting Started

t often appears as microprocessor,


microcomputer and microcontroller.
Occasionally it may appear as a
custom-designed VLSI circuit or FPGA.

t interacts with and utilizes the


remaining components of the system to
implement the required application.

Such actions are under the control of


the software and firmware instructions.

The Hardware Side Getting Started

Information

and data come into the system


from the surrounding environment and
from the application.

These

data are processed according to the


software instructions into signals that are
sent back out of the system to the
application.

The

software and firmware instructions, as


well as signals coming into or going out of
the system, are stored in memory.

2.2 The Core Level

began

with a model comprising four major


functional blocks depicting the embedded
hardware core and the high-level signal flow
as shown in the figure 1.1

Figure 2.1 Four major blocks of an Embedded Hardware


Core

The

2.2 The Core Level

memory block serves to hold


collections of program instructions that
we call software and firmware as well as
to provide short-term storage for input
data, output data, and intermediate
results of computations.

Data

as well as other kinds of signals


come into the system from the external
world through the input block.

Once

inside of the system, they may be


directed to any number of destinations.

2.2 The Core Level

The

output block provides the means to


send data or other signals back to
outside world.

The

datapath and control block, more


commonly known as CPU, coordinates
the activities of the system as well as
performs computations and data
manipulation operations necessary to
executing the application.

2.2 The Core Level

In performing its responsibilities, the CPU fetches


instructions from memory, interprets them, and then
performs the task indicated by the instruction.
n doing so, it may retrieve additional data from the memory
or from the input block. It will also produce information that
is sent out of the system.
he signals move into, out of, or throughout the system on
the paths called buses.
uses are simply collections of wires that carry related
electrical signals from one place to another.
us a collection or group as single entity.
epending on the type of the signals carried classified into
Three major categories address, data, and control.

2.2 The Core Level

In

performing its responsibilities, the


CPU fetches instructions from memory,
interprets them, and then performs the
task indicated by the instruction.
In doing so, it may retrieve additional
data from the memory or from the input
block. It will also produce information
that is sent out of the system.
The signals move into, out of, or
throughout the system on the paths
called buses.

2.2 The Core Level

At

hardware level, a bit may represented by


an electrical signal; a binary 0 as 0volt and
a binary 1 as 5volts.

In

an optical communications channel, a bit


may be expressed by the presence or
absence of light.

The

width of the bus, i.e. the number of


signals or bits that it can carry
simultaneously, provides an indirect
measure of how quickly information can be
moved

2.2 The Core Level

Figure

illustrates moving a set of data over


an 8-bit bus from source module to a
destination module.

Figure 2.2 Data movement over an 8-bit


bus

2.2 The Core Level

The source of the transfer is the array of eight bit


values; the destination is perhaps a display.
Figure shows the refined high-level functional
diagram to illustrate a typical bus configuration
comprising the address, data and control lines.

Figure 2.3 A Typical Bus Structure comprising Address, Data and Control
signals

2.2 The Core Level

To avoid cluttering a drawing by including all of


the signals or conducting paths that make up a
bus, it is often label the bus width using the
annotation /bus width as illustrated in figure.

Figure 2.4 Identifying the number of signals in a


bus

2.2.1 The Microprocessor

Microprocessor

is an integrated
implementation of the central
processing unit portion of the machine;
it is often simply referred to as a CPU or
Datapath.

Microprocessors

differs in complexity,
power consumption, and cost.

Todays

microprocessors contains 5 to
10 million transistor and cost of few
dollars.

2.2.1 The Microprocessor

Microprocessors

also differs in the


internal architecture of the machine,
including the number of internal
register, the overall control structure
of the machine, and Internal bus
structure.

Registers

are small amounts of highspeed memory that are used to


temporarily store frequently used
values such as loop index or index of a

2.2.1 The Microprocessor

Increasingly, the internal single-memory scheme


that characterizes the von Neumann machine is
giving way to Harvard architecture and the
benefits of simultaneous instruction and data
access.

To implement a complete computer system, we


must still include the input/output subsystems and
the external system.

Also include a clock or timing reference as the


basis for timing, scheduling, or measuring elapsed
time.

All components are connected via a system bus or

2.2.1 The Microprocessor

Figure 2.5 A Block Diagram for a microprocessor based


system

2.2.2 The Microcomputer

The microcomputer is a complete computer


system that uses a microprocessor as its
computational core.

microcomputer will also utilize numerous other


large-scale integrated (LSI) circuits to provide
necessary peripheral functionality.

As with p, the complexity of microcomputers


varies from simple units that are implemented an
a single chip along with a small amount of onchip memory and elementary I/O system to the
complex that will augment the p with a wide
array of powerful peripheral support circuitry.

2.2.3 The Microcontroller

Figure 2.6 A Block Diagram for a microcontroller based


system

2.2.3 The Microcontroller

Brings

together the microprocessor core


and a rich collection of peripherals and I/O
capability into a single IC.

Additions

include timers, ADC, DAC, serial


and parallel communication channels, DMA,
etc.

memory

subsystem may or may not be


included.

If

the memory is not included, the designer


must add such capability outside of the

2.2.4 The DSP

Used

in conjunction with a general


purpose processor to perform specialized
tasks such as image, speech, audio, or
video processing.

Figure

shows the block diagram of DSP.

The

Task performed by the DSP often


require it to interface with the analog
world.

Real-world

signals are captured through


an ADC, processed and returned through
DAC.

2.2.4 The DSP

One

of the major strength of the DSP is its


ability to perform basic arithmetic
computations such as multiply, add, shift
at the rate of millions of operations per
second.

support

high-speed arithmetic, the device


will often implement a multiplyaccumulate(MAC) primitive in which a
multiply and add to the accumulator is
performed in a single operation, which is
useful in matrix operations.

2.2.4 The DSP

Figure 2.7 A Block Diagram for a digital signal


processor

2.2.4 The DSP

Its

arithmetic operations often utilize


saturation arithmetic in which overflows
(underflows) remain at the maximum
(minimum) value rather than wrapping
around.

DSP

device is architected as Harvard


rather than von-Neumann machine and
incorporates
multiple
computational
units, a large number of registers, and a
wide high-bandwidth data busses.

2.3. Representing Information

Word

size term use to characterize a


microprocessor.

Word

size in a microprocessor refers to


the size of an integer.

The

bits can be interpreted so as to place


the most significant byte on the left and
the least significant on the right, or viceversa.

Here

after we are working with a


microprocessor of 32 bits size.

2.3. Representing Information

Big endian format

Little endian formt

Figure 2.11 Expressing


Addresses

2.4. Understanding Numbers


Within

a p, we dont have an unbounded


number of bits with which to express the
various kinds of numeric information that
we will be working with in an embedded
application.

The

limitations of finite word size can have


unintended consequences for the results of
any mathematical operations that we need
to perform.

Lets

examine the effect of finite word size


on resolution, accuracy, errors, and the

2.4. Understanding
Numbers

RESOULTION

Lets consider a four-bit word.


ord is used to hold a number, the bits comprising the
word can be interpreted in several ways as presented
in Table 1.0.

2.4. Understanding Numbers

RESOULTION
To

represent a number 2.3 using 4-bit


binary number with two bits of
resolution, the best one can write is
either (10.10) 2.5 or ( 10.01) 2.25.
The error in the expression will be either
+0.2 or -0.05.
ll that can be resolved is 0.25.

2.4. Understanding Numbers

Figure 2.9 Truncation vs Rounding

Truncation vs Rounding
error following the operation is

ER = Nrounded
computed
as

N ET = Ntruncate

2.4. Understanding Numbers

2.4.2 Propagation Error

Let consider Two Perfect number N1 & N2, Under


truncation,the error is less than 1 LSB

2.4.2 Propagation Error

The magnitude of the error now depends on the size of the number

2.4.2 Propagation of Error

To illustrate the propagation of error in basic calculations.


consider the measurement system in figure 2.10, That is designed to
determine power in a resistive load.

Figure 2.10 A Simple Measurement


system

power in the resistor is computed from measurement of


the voltage drop across the resistor and current flow
through the part.
measurements are given as:

2.4.2 Propagation of Error


o

The power in the resistor, R can be calculated in three


ways. In theory, they should produce identical results.

The result of the three calculations not only yield three


different answers, but depending on which formula is
used, have substantially differing error magnitude as well.

By this illustration, when one is performing mathematical


computations, it is important to understand where error
can arise, how they can propagate under mathematical
operations, and how such phenomena can affect any
calculations.

such errors can have serious consequences for the safety


of any applications, if we are not careful.

2.5. Addresses

Each

memory location in memory has an


associated address much like an index in
an array.

If

a memory have 16 locations, it will have


16 addresses.

Information

is accessed in memory by
giving its address.

Addresses

begin at binary 0 and range to


the maximum value the word size will
permit.

2.5. Addresses

For

a word size of 32-bit, the addresses will


range from 00000000 to FFFFFFFF.
We have up to 4,294,967,296 unique
combinations.

Fig

2.11 illustrates how a word might look if


the bits are interpreted as expressing an
address.

address is an unsigned integer, p does


not support negative address.

2.5. Addresses

Figure 2.11 Expressing


Addresses

Figure 2.12 Using the value of one variable to


hold the address of another
variable

2.6. Instructions

An

instruction is used to direct the


hardware of the microprocessor to perform
a series of actions or operations.

Actions

are like perform an arithmetic or


logical calculation, assign or read the value
of a variable, or move data from one place
to another place such as from input to
memory or from memory to output.

2.6. Instructions

The

entities that instructions operate on


are denoted operands.

The

number of operands that an


instruction operates on at anytime is called
the arity of the operation.

2.6. Instructions

Example

code fragment
x=y+z;

Here

we have two operations, the addition


and the assignment operation.
First the addition operation : that
operation is performed on two operands, y
and z.

2.6. Instructions

The

addition operator is said to be a


binary operator its arity is two.

The

assignment operator : the


operation is performed by giving x the
value returned by the addition
operation.

It

is also performed on two operands,


the result of the addition and the
operand x its arity is two as well.

2.6. Instructions

In

C/C++,
Operators taking two operands are referred
to as binary operators.
Operators taking only a single operand have
an arity of one and are referred to as unary
operators.

An

instruction must contain at least two


components, the operation and the operands.

Depending

on the arity of the operation, the


instruction may have one or two operands.

2.6. Instructions

Examples

x=y;
Basic C/C++ assignment operation in
which the value of the operand
Operators taking y is assigned to
operand x .
It has two operands, making the
operator a binary operator.
Such an instruction is referred to as a
two-operand or two-address
instruction.

2.6. Instructions

EXAMPLE
z=x+y;
Adding

the two operands, x and y ; the result


is assigned to the operand z.

we

have two operations: an addition


operation and an assignment operation.

Both
For

are binary.

addition operation, the operands x and y


are the sources, and the (temporary) result is
the destination..

2.6. Instructions

For

the assignment operation, the result of


addition is the source and operand z is the
destination.

If

we ignore the transient intermediate


result, we see that for the code fragment,
we have three operands, x and y are
sources and z is a destination.

Such

an instruction is referred to as a
three-operand or three-address
instruction.

2.6. Instructions

x=x+y;
Adding the two operands, x and y ; the
result is assigned to the operand x.
We have two operations: an addition
operation and an assignment operation.
Both are binary.
For addition operation, the operands x and
y are the sources, and the (temporary)
result is the destination.

2.6. Instructions

For

the assignment operation, the result of


addition is the source and operand x is the
destination.

One

operand serves the dual role of source and


destination.

value

held at the source is lost as a result of


assignment.

If

we ignore the transient intermediate result, we


see that for the code fragment, we have three
operands, x and y are sources and z is a
destination.

Such

an instruction is referred to as a two-operand

2.6. Instructions

++x or x++;
Operation is to increment the value of the variable.

variable x is both the source and the destination of the


operation.

We have only one operand.

Such an instruction is referred to as a one-operand or oneaddress instruction.

The interpretation of these three classes of instructions in


32-bit word format is as shown in figure 2.13.

Any such interpretation will have to support the ability to


express both operands and operations as seen in figure

2.6. Instructions

Figure 2.13 Expressing


Instructions

2.6. Instructions

As

shown in figure, within 32-bit word, the


bits are aggregated into groups or fields.

Some

of the fields are interpreted as the


operation to be performed, and others are
seen as the operands involved in the
operation.

At

this juncture, not specified how many


bits comprise each field.

2.6. Instructions

The field used to identify the operation is the


easiest one to specify the size of. The first step in
specifying the size is to decide how many
different instructions the p is to support. Such
instructions can include arithmetic operations,
logical, data movement, or flow control.

Once the number of instructions is determined,


then each is assigned a unique code. Such a
code is called operation code or op-code.
If a p is to support 128 instructions, a
minimum of 7-bits will be necessary.

2.7. Registers A First Look

The size of the fields allocated to the operands


is not much more complex.

Before answering the question, however, we


must make a slight digression.

We have been discussing how we can interpret


a 32-bit word as various types of data
(operands) that can be operated on by user
selected operations.

If an instruction, containing even a single


operand, in addition to the op-code, is 32 bit
piece of data will not fit into any of the field(s)
allocated to hold the operand.

2.7. Registers A First Look


To

solve this seemingly intractable


problem, we utilize a hardware component
that is called a register.

register

is a special kind of memory that is


large enough to hold a single data word.

register

is a piece of short-term memory


that temporarily holds the operands
during the execution of an instruction.

2.7. Registers A First Look


Prior

to executing the instruction, the


operand(s) are moved from memory into
register and then back to memory if the
data value is not going to be needed in the
immediate future.

While

such continual movement of data


words into and out of memory and into and
out of registers seems to involve a lot of
extra work, the higher speed of registers
compared with the memory we have
discussed so far can significantly improve

2.7. Registers A First Look


Depending

on the architecture of
microprocessor
ISC Complex Instruction Set Computer
ISC Reduced Instruction Set Computer

ISC,

may contain registers 16 to 256 or

so.
ISC,

it may have over 1000.

2.7. Registers A First Look

Figure 2.14 Expressing


Instructions

2.7. Registers A First Look

Figure 2.15 Possible Interpretation of a set of Bits as Big Endian representation Little
Endian follows similarly

Embedded Systems An Instruction Set View


The

software (firmware) in an embedded


system is generally written in a high-level
language such as C or C++ or it may
written in assembly language.

Sometimes
When

combinations of both are used.

working with assembly language, we


are working one step removed from the
microprocessors machine language the
collection of 0s and 1s that control the
hardware components in the execution of
an instruction.

Embedded Systems An Instruction Set View


Instruction

set the set of instructions that


the machine supports.

Instruction

Set Architecture (ISA) set of


instruction that drives the architecture.

At

the assembly language level, mnemonic


names are given to binary patterns
expressed by the op-codes to make them
easier to work with.

Embedded Systems An Instruction Set View


Assembler

a software tool used to


translate assembly language into
machine code.

The

assembly language instructions are


taken from the IEEE Standard for
Microprocessor Assembly Language
694-1985 machine language.

Instruction Set Instruction Types


microprocessors

instruction set specifies


the basic operations supported by the
machine.

Such

operations are to transfer or store


data, to operate on the data, and to make
decisions based on the data values or
outcome of the operations.

Classification

of instructions
Data transfer
Flow of control
Athmetic and Logic

Data Transfer Instructions

Provides the means and mechanism for moving


data within the system and for executing exchanges
with external devices, including memory.

Each instructions must have three pieces of


information:
The data
The location of data the source of the transfer,
and
Where the data is to be sent - the destination of
the transfer.

Data Transfer Instructions


The

source and destination can be any of the


following:

register
Memory
input or output port

as shown in figure 2.16


Some of the common instructions used in
support of data transfer include those
presented in figure 2.17

You might also like