Basic Basic Structure Structure of
- f C
Computer
- mputer
Basic Basic Structure Structure of of C Computer omputer - - PowerPoint PPT Presentation
Basic Basic Structure Structure of of C Computer omputer Hardware and Software EduTechLearners (http s ://www.edutechlearners.com) COMPUTER ORGANISATION AND ARCHITECTURE AND ARCHITECTURE The components from which computers are built
The components from which computers are built The components from which computers are built,
In contrast computer architecture is the science In contrast, computer architecture is the science
It is as if computer organization examines the
While computer architecture looks at the design
2 http://www.edutechlearners.com
3 http://www.edutechlearners.com
1.
ENIAC
IAS
IAS
IBM
PDP-8
2.
microprocessors AND microcontrollers…
4 http://www.edutechlearners.com
Program and data reside in the same memory Program and data reside in the same memory
ALP was made used to write programs ALP was made used to write programs Vacuum tubes were used to implement the
Magnetic
Using electronic vacuum tubes, as the switching
5 http://www.edutechlearners.com
Transistor were used to design ALU & CU HLL is used (FORTRAN) HLL is used (FORTRAN) To convert HLL to MLL compiler were used Separate
Separate
Invention of the transistor which was faster,
6 http://www.edutechlearners.com
IC technology improved IC technology improved Improved IC technology helped in designing low
Multiprogramming,
DOS allowed efficient and coordinate operation
Cache
More than one circuit on a single silicon chip
7 http://www.edutechlearners.com
CPU – Termed as microprocessor CPU
INTEL,
Workstations, microprocessor (PC) & Notebook
Interconnection of different computer for better
Computational speed increased by 1000 times Specialized
8 http://www.edutechlearners.com
E Commerce E banking home office E-Commerce, E- banking, home office ARM, AMD, INTEL, MOTOROLA
High speed processor - GHz speed Because of submicron IC technology lot of
9 http://www.edutechlearners.com
Speed of operation Cost Computational power Type of application
10 http://www.edutechlearners.com
Processing & storage units, visual display &audio units,
Storage media-Hard disks, CD-ROMs Eg: Personal computers which is used in homes and
Advantage: Cost effective, easy to operate, suitable for
Compact form of personal computer (laptop) Advantage is portability
11 http://www.edutechlearners.com
12 http://www.edutechlearners.com
13 http://www.edutechlearners.com
Also called a PDA (Personal
A computer that fits into a
Typically used as an Typically used as an
Can be synchronized with a
14 http://www.edutechlearners.com
Computer
Software
A device that accepts input, processes data, stores data, and produces output, all according to a series of stored
A computer program that tells the computer how to perform particular tasks. g instructions.
Hardware
Network
Two or more computers and
Includes the electronic and mechanical devices that process the data; refers to the computer as well as peripheral connected, for the purpose of sharing data and programs.
P i h l d i
p p p devices.
Peripheral devices
Used to expand the computer’s input, output and storage capabilities. g p
15 http://www.edutechlearners.com
Input
Whatever is put into a computer system
Whatever is put into a computer system.
Data
Refers to the symbols that represent facts, objects, or ideas.
Information
The results of the computer storing data as bits and bytes; the words, numbers, sounds, and graphics.
Output
Consists of the processing results produced by a computer
Consists of the processing results produced by a computer.
Processing
Manipulation of the data in many ways.
Memory
Area of the computer that temporarily holds data waiting to be processed, stored, or output.
Storage
Area of the computer that holds data on a permanent basis when it is not
Area of the computer that holds data on a permanent basis when it is not immediately needed for processing.
16 http://www.edutechlearners.com
17
18 http://www.edutechlearners.com
ALL computer functions are:
Data PROCESSING
Data STORAGE Data MOVEMENT
NOTHING ELSE!
20 http://www.edutechlearners.com
Input and Arithmetic logic Output Memory Control I/O Processor Output Control I/O Processor System Interconnections
Figure 1.1. Basic functional units of a computer.
21 http://www.edutechlearners.com
22 http://www.edutechlearners.com
A computer handles two types of information : A computer handles two types of information : Instruction :
computer and its I/O devices and also within the computer.
program, which is stored in the memory.
desired program.
except any external interrupts comes from any I/O device.
23 http://www.edutechlearners.com
Data : Data :
for a program. S d t b b h t
data if it is processed by another high-level program.
The most well-known input device is the keyboard,
beside this, there are many other kinds of input bes de s, e e a e a y o e ds o pu devices are available, i.e., mouses, joysticks etc.
24 http://www.edutechlearners.com
25 http://www.edutechlearners.com
Composed of large array of bytes Composed of large array of bytes. Store programs and data . Parts of the memory subsystem Parts of the memory subsystem Fetch/store controller
Fetch: Retrieve a value from memory Store: Store a value into memory Memory address register (MAR) Memory data register (MDR) Memory cells with decoder(s) to select individual
26 http://www.edutechlearners.com
Fast and Direct Access Programs must be stored in memory while they
Large number of semiconductor storage cells.
RAM and ROM
used for bulk storage or mass storage used for bulk storage or mass storage. Indirect Access and slow. Magnetic Harddisks CDs Etc Magnetic Harddisks,CDs. Etc.
27 http://www.edutechlearners.com
Memory access is much slower than processing Memory access is much slower than processing
Faster memory is too expensive to use for all
Small size, fast memory just for values currently
System Performance improved using this buffer
28 http://www.edutechlearners.com
Most computer operations are executed in
Load the operands into memory – bring them
Registers Registers Fast control of ALU
29 http://www.edutechlearners.com
Actual computations are performed Actual computations are performed Primitive operation circuits
Arithmetic (ADD) Comparison (CE) Comparison (CE) Logic (AND)
Data inputs and results stored in registers Multiplexor selects desired output
30 http://www.edutechlearners.com
ALU process
Values for operations copied into ALU’s input Values for operations copied into ALU s input
All circuits compute results for those inputs All circuits compute results for those inputs Multiplexor selects the one desired result from all
Result value copied to desired result register
31 http://www.edutechlearners.com
Using a Multiplexor Circuit to Select the Proper ALU Result Using a Multiplexor Circuit to Select the Proper ALU Result
32 http://www.edutechlearners.com
Manages stored program execution. The timing signals that govern the I/O transfers are also
Task Fetch from memory the next instruction to be
Decode it: Determine what is to be done Execute it: Issue appropriate command to ALU,
33
http://www.edutechlearners.com
The total operation of the computer is
1
1.
2
2.
3.
34 http://www.edutechlearners.com
4
4.
5.
5.
35 http://www.edutechlearners.com
There are many ways to connect different
A group of lines or wires that serves as a
Address/data/control
36 http://www.edutechlearners.com
Connecting CPU and memory using three buses
37 http://www.edutechlearners.com
An interrupt is a request from I/O device for An interrupt is a request from I/O device for
Processor provides requested service by Processor provides requested service by
Contents of PC, general registers, and some
When ISR completed, processor restored, so
38 http://www.edutechlearners.com
Shift Mi ti
39 http://www.edutechlearners.com
Combinational and sequential circuits can be
These are the low-level building blocks of a
Simple digital systems are frequently
the registers they contain, and
the operations that they perform.
40 http://www.edutechlearners.com
The operations on the data in registers are called micro-
The functions built into registers are examples of micro-
Shift
Shift
Load
Clear
Increment
41 http://www.edutechlearners.com
An elementary operation performed (during
in one or more registers in one or more registers
ALU Registers ALU (f) Registers (R) 1 clock cycle
R f(R, R) f: shift, load, clear, increment, add, subtract, complement, and, or, xor, …
42 http://www.edutechlearners.com
Set of allowable microoperations provided by the organization of the computer
microoperations (to perform the functions)
43 http://www.edutechlearners.com
Viewing a computer, or any digital system,
This is because we’re focusing on
The system’s registers The data transformations in them, and The data transfers between them.
44 http://www.edutechlearners.com
Rather than specifying a digital system in words, a specific notation is used register transfer language is used, register transfer language
For any function of the computer, the register transfer language can be used to describe the (sequence of) microoperations can be used to describe the (sequence of) microoperations
Register transfer language
A b li l
A symbolic language
A convenient tool for describing the internal organization of digital computers
Can also be used to facilitate the design process of digital systems.
45 http://www.edutechlearners.com
Registers are designated by capital letters, sometimes followed by numbers (e g A R13 IR) numbers (e.g., A, R13, IR)
Often the names indicate function:
MAR
PC
PC program counter
IR- instruction register
Registers and their contents can be viewed and represented in g p various ways
A register can be viewed as a single entity: MAR
Registers may also be represented showing the bits of data they contain MAR
46 http://www.edutechlearners.com
portion of a register
R1
Register Showing individual bits
PC(H) PC(L)
15 8 7
7 6 5 4 3 2 1 0 R2
15 Numbering of bits Subfields
PC(H) PC(L) R2
47 http://www.edutechlearners.com
Copying the contents of one register to another is a register transfer
A register transfer is indicated as
In this case the contents of register R1 are
A simultaneous transfer of all bits from the
Note that this is a non-destructive; i.e. the
48
A register transfer such as
the data lines from the source register (R5) to the
Parallel load in the destination register (R3) Control lines to perform the action
49 http://www.edutechlearners.com
Often actions need to only occur if a certain condition is true
This is similar to an “if” statement in a programming language In digital s stems this is often done ia a control signal called a
In digital systems, this is often done via a control signal, called a control function
If the signal is 1, the action takes place
This is represented as:
50 http://www.edutechlearners.com
Implementation of controlled transfer P: R2 R1 Block diagram
Clock
R2 Control
Load
P
Timing diagram
Clock
R2 R1 Circuit
n
t t+1
Timing diagram
T f h Clock Load t t+1 Transfer occurs here
and the destination register and the destination register
51 http://www.edutechlearners.com
If two or more operations are to occur simultaneously, they are separated with commas P: R3 R5, MAR IR
Here, if the control function P = 1, load the contents of R5 into R3, and at the same time (clock), load the f contents of register IR into register MAR
52 http://www.edutechlearners.com
Capital letters Denotes a register MAR, R2
Symbols Description Examples
Capital letters Denotes a register MAR, R2 & numerals Parentheses () Denotes a part of a register R2(0-7), R2(L) A
D t t f f i f ti R2 R1 Arrow Denotes transfer of information R2 R1 Colon : Denotes termination of control function P: Comma , Separates two micro-operations A B, B A
53 http://www.edutechlearners.com
In a digital system with many registers, it is impractical to have data and control lines to directly allow each register to be loaded with the contents of every possible other registers loaded with the contents of every possible other registers
To completely connect n registers n(n-1) lines O(n2) cost
O(n2) cost
This is not a realistic approach to use in a large digital system
Instead take a different approach
Instead, take a different approach
Have one centralized set of circuits for data transfer – the bus
Have control circuits to select which register is the source, and hi h i th d ti ti which is the destination
54 http://www.edutechlearners.com
Bus is a path(of a group of wires) over which information is transferred, from any of several sources to any of several destinations. From a register to bus: BUS R From a register to bus: BUS R
Register A Register B Register C Register D Register A Register B Register C Register D Bus lines 1 2 3 4 1 2 3 4 1 2 3 4 1 2 3 4 g g g g B C D 1 1 1 B C D 2 2 2 B C D 3 3 3 B C D 4 4 4 4 x1 MUX 4 x1 MUX 4 x1 MUX 4 x1 MUX x y select 4-line bus y
55
Bus lines Load 2 x 4 Decoder D0 D1 D2 D3 z w Select E (enable)
Three-State Bus Buffers
Output Y=A if C=1 High-impedence if C=0 Normal input A Control input C
Bus line with three-state buffers
Control input C A0 Bus line for bit 0 S0 B0 C0 D0 Select Enable 1 2 3 S0 S1
56
Depending on whether the bus is to be mentioned explicitly or not, register transfer can be indicated as either , g
R2 R1
In the former case the bus is implicit, but in the latter, it is li itl i di t d BUS R1, R2 BUS explicitly indicated
57 http://www.edutechlearners.com
Memory (RAM) can be thought as a sequential circuits containing some number of registers
These registers hold the words of memory g y
Each of the r registers is indicated by an address
These addresses range from 0 to r-1
Each register (word) can hold n bits of data
Each register (word) can hold n bits of data
Assume the RAM contains r = 2k words. It needs the following
n data input lines n data output lines
data input lines
n data output lines
k address lines
A Read control line
A Write control line
data input lines n address lines k Read Write
RAM unit
data output lines n
58 http://www.edutechlearners.com
Collectively, the memory is viewed at the register level as a device, M.
Since it contains multiple locations, we must specify which p , p y address in memory we will be using
This is done by indexing memory references
Memory is usually accessed in computer systems by putting the desired address in a special register, the Memory Address Register (MAR or AR) Register (MAR, or AR)
When memory is accessed, the contents of the MAR get sent to the memory unit’s address lines
M
AR Memory unit Read Write
M
Data in Data out
59 http://www.edutechlearners.com
To read a value from a location in memory and load it into a register, the register transfer language notation looks like this:
This causes the following to occur
Th t t f th MAR t t t th dd li
R1 M[MAR]
The contents of the MAR get sent to the memory address lines
A Read (= 1) gets sent to the memory unit
The contents of the specified address are put on the memory’s output data lines
These get sent over the bus to be loaded into register R1
60 http://www.edutechlearners.com
To write a value from a register to a location in memory looks like this in register transfer language:
This causes the following to occur
Th t t f th MAR t t t th dd li
M[MAR] R1
The contents of the MAR get sent to the memory address lines
A Write (= 1) gets sent to the memory unit
The values in register R1 get sent over the bus to the data input lines of the memory
The values get loaded into the specified address in the memory
61 http://www.edutechlearners.com
A B Transfer content of reg. B into reg. A AR DR(AD) Transfer content of AD portion of reg. DR into reg. AR ( ) p g g A constantTransfer a binary constant into reg. A ABUS R1, Transfer content of R1 into bus A and, at the same time, R2 ABUS t f t t f b A i t R2 R2 ABUS transfer content of bus A into R2 AR Address register DR Data register M[R] Memory word specified by reg R M[R] Memory word specified by reg. R M Equivalent to M[AR] DR M Memory read operation: transfers content of memory word specified by AR into DR memory word specified by AR into DR M DR Memory write operation: transfers content of DR into memory word specified by AR
62 http://www.edutechlearners.com
p y p yp
Arithmetic microoperations
63 http://www.edutechlearners.com
The basic arithmetic micro-operations are
Addition
Subtraction
Increment
Decrement
The additional arithmetic micro-operations are
Add with carry S bt t ith b
Subtract with borrow
Transfer/Load
Summary of Typical Arithmetic Micro-Operations
R3 R1 + R2 Contents of R1 plus R2 transferred to R3 R3 R1 - R2 Contents of R1 minus R2 transferred to R3 R2 R2’ Complement the contents of R2 R2 R2’+ 1 2's complement the contents of R2 (negate) R3 R1 + R2’+ 1 subtraction R1 R1 + 1 Increment R1 R1 - 1 Decrement
64
FA B0 A0 C0 FA B1 A1 C1 FA B2 A2 C2 FA B3 A3 C3
Binary Adder
S0 S1 S2 S3 C4
Binary Adder-Subtractor
B0 A0 B1 A1 B2 A2 B3 A3 C0 C1 C2 C3
M FA S0
C0 C1
FA S1
C2
FA S2
C3
FA S3
C4
Binary Incrementer
A0 1 A1 A2 A3
y
HA
x y C S
HA
x y C S
HA
x y C S
HA
x y C S S0 S1 S2 S3 C4
65
S1 Cin S1 S0 1 2 3 4x1
MUX
X0 Y0 C0 C1 D0
FA
A0 B0 S0 S1 Cin S1 S0 1 2 3 4x1
MUX
X1 Y1 C1 C2 D1
FA
S1 X2 C2 D2 A1 B1 A2 S1 S0 1 2 3 4x1
MUX
Y2 C3 D2
FA
S1 S0 0 4 1 X3 Y3 C3 C4 D3
FA
B2 A3 B3 1 2 3 4x1
MUX
Y3 C4 Cout B3 1
S1 S0 Cin Y Output Microoperation 0 0 B D = A + B Add 0 0 1 B D = A + B + 1 Add with carry 1 B’ D = A + B’ Subtract with borrow 0 1 1 B’ D = A + B’+ 1 Subtract 1 D = A Transfer A 1 0 D A Transfer A 1 0 1 D = A + 1 Increment A 1 1 1 D = A - 1 Decrement A 1 1 1 1 D = A Transfer A
66
Specify binary operations on the strings of bits in registers
Logic microoperations are bit-wise operations, i.e., they work on the individual bits of data
useful for bit manipulations on binary data
useful for making logical decisions based on the bit value
There are, in principle, 16 different logic functions that can be d fi d t bi i t i bl defined over two binary input variables
0 0 0 0 0 … 1 1 1 1 1 1 1 A B F0 F1 F2 … F13 F14 F15 0 1 0 0 0 … 1 1 1 1 0 0 0 1 … 0 1 1 1 1 0 1 0 … 1 0 1
However, most systems only implement four of these
AND (), OR (), XOR (), Complement/NOT
The others can be created from combination of these
The others can be created from combination of these
67 http://www.edutechlearners.com
List of Logic Microoperations
functions
2 2 n
corresponding 16 logic micro-operations
Boolean F ti Micro- Operations Name x 0 0 1 1 y 0 1 0 1 Function Operations y 0 1 0 1 0 0 0 0 F0 = 0 F 0 Clear 0 0 0 1 F1 = xy F A B AND 0 0 1 0 F2 = xy' F A B’ 0 0 1 1 F3 = x F A Transfer A 0 1 0 0 F4 = x'y F A’ B 0 1 0 1 F5 = y F B Transfer B 0 1 1 0 F6 = x y F A B Exclusive-OR 0 1 1 1 F7 = x + y F A B OR 1 0 0 0 F8 = (x + y)' F A B)’ NOR 1 0 0 0 F8 = (x + y) F A B) NOR 1 0 0 1 F9 = (x y)' F (A B)’ Exclusive-NOR 1 0 1 0 F10 = y' F B’ Complement B 1 0 1 1 F11 = x + y' F A B 1 1 0 0 F12 = x' F A’ Complement A 1 1 0 1 F13 = x' + y F A’ B 1 1 1 0 F14 = (xy)' F (A B)’ NAND 1 1 1 1 F15 = 1 F all 1's Set to all 1's
68
HARDWARE IMPLEMENTATION OF LOGIC MICRO-OPERATIONS C O O O S
B A Fi i i 1 4 X 1 MUX S1 2 3 MUX Select S S 1
0 0 F = A B AND S1 S0 Output -operation
Function table
0 1 F = AB OR 1 0 F = A B XOR 1 1 F = A’ Complement
69 http://www.edutechlearners.com
Logic micro-operations can be used to manipulate individual bits or a portions of a word in a register
Consider the data in a register A. In another register, B, is bit data that will be used to modify the contents of A
Selective-set
Selective set
Selective-complement
Selective-clear
Selective clear
Mask (Delete)
Clear
Insert
Compare
70 http://www.edutechlearners.com
I l ti t ti th bit tt i B i d t t
In a selective set operation, the bit pattern in B is used to set certain bits in A 1 1 0 0 A 1 1 0 0 At 1 0 1 0 B 1 1 1 0 At+1 (A A + B)
If a bit in B is set to 1, that same position in A gets set to 1,
71 http://www.edutechlearners.com
I l ti l t ti th bit tt i B i d
In a selective complement operation, the bit pattern in B is used to complement certain bits in A 1 1 0 0 A 1 1 0 0 At 1 0 1 0 B 0 1 1 0 A (A A B) 0 1 1 0 At+1 (A A B)
If a bit in B is set to 1, that same position in A gets complemented from its original value otherwise it is unchanged from its original value, otherwise it is unchanged
72 http://www.edutechlearners.com
I l ti l ti th bit tt i B i d t l
In a selective clear operation, the bit pattern in B is used to clear certain bits in A 1 1 0 0 A 1 1 0 0 At 1 0 1 0 B 0 1 0 0 A (A A B’) 0 1 0 0 At+1 (A A B )
If a bit in B is set to 1, that same position in A gets set to 0,
73 http://www.edutechlearners.com
I k ti th bit tt i B i d t l t i
In a mask operation, the bit pattern in B is used to clear certain bits in A 1 1 0 0 A 1 1 0 0 At 1 0 1 0 B 1 0 0 0 A (A A B) 1 0 0 0 At+1 (A A B)
If a bit in B is set to 0, that same position in A gets set to 0,
74 http://www.edutechlearners.com
I l ti if th bit i th iti i A d B
In a clear operation, if the bits in the same position in A and B are the same, they are cleared in A, otherwise they are set in A 1 1 0 0 A 1 1 0 0 At 1 0 1 0 B 0 1 1 0 A (A A B) 0 1 1 0 At+1 (A A B)
75 http://www.edutechlearners.com
An insert operation is used to introduce a specific bit pattern into A register, leaving the other bit positions unchanged
This is done as
A mask operation to clear the desired bit positions, followed by
An OR operation to introduce the new bits into the desired positions
Example p
Suppose you wanted to introduce 1010 into the low order four bits
1101 1000 1011 0001 A (Original) 1101 1000 1011 1010 A (Desired)
1101 1000 1011 0001
A (Original) 1111 1111 1111 0000 Mask 1101 1000 1011 0000 A (Intermediate) 0000 0000 0000 1010 Added bits 1101 1000 1011 1010 A (Desired)
76
In a logical shift the serial input to the shift is a 0.
A right logical shift operation: g g p
A left logical shift operation:
In a Register Transfer Language, the following notation is used g g g , g
shl for a logical shift left
shr for a logical shift right
Examples:
R2 shr R2
R3 shl R3
77 http://www.edutechlearners.com
I i l hift th i l i t i th bit th t i hift d t f
In a circular shift the serial input is the bit that is shifted out of the other end of the register.
A right circular shift operation:
A right circular shift operation:
A left circular shift operation:
In a RTL, the following notation is used
cil for a circular shift left cirfor a circular shift right
cirfor a circular shift right
Examples:
R2 cir R2
R3 cil R3
78 http://www.edutechlearners.com
A logical shift fills the newly created bit
CF
CF 79 http://www.edutechlearners.com
– ashl for an arithmetic shift left – ashr for an arithmetic shift right – Examples: » R2 ashr R2 » R3 ashl R3 » R3 ashl R3
80 http://www.edutechlearners.com
Select 0 for shift right (down) 1 for shift left (up) Serial input (IR) S 1 H0 MUX A0 S 1 H1 MUX A0 A1 A2 S 1 H2 MUX A3 S 1 H3 MUX Serial input (IL)
81 http://www.edutechlearners.com
S3
Arithmetic Circuit
C S3 S2 S1 S0 i Di
Circuit
C
4 x 1 MUX
Select 1 2 3 F E i+1 i
Logic Circuit
B A A A E shr shl i i i+1 i-1 i
S3 S2 S1 S0 Cin Operation Function 0 0 0 F = A Transfer A 0 0 0 0 1 F = A + 1 Increment A 0 0 0 1 F = A + B Addition 0 0 0 1 1 F = A + B + 1 Add with carry 1 F = A + B’ Subtract with borrow 0 0 1 F = A + B Subtract with borrow 0 0 1 1 F = A + B’+ 1 Subtraction 0 0 1 1 F = A - 1 Decrement A 0 0 1 1 1 F = A TransferA 0 1 0 X F = A B AND 0 1 0 1 X F = A B OR 1 1 X F = A B XOR 0 1 1 X F = A B XOR 0 1 1 1 X F = A’ Complement A 1 0 X X X F = shr A Shift right A into F 1 1 X X X F = shl A Shift left A into F
82
How is “information” represented in a computer How is information represented in a computer
What are the different types of information What are the different types of information
Text Numbers Numbers Images
Video Photographic
Audio
83 http://www.edutechlearners.com
Computers are digital devices - they can only
Easy to represent 1 and 0 in electronic, magnetic and
Only need two states
High/low On/off On/off Up/down etc
All information in a computer system is All information in a computer system is
Processed in binary form Stored in binary form Transmitted in binary form
84
Transmitted in binary form
http://www.edutechlearners.com
I/O and Storage Devices are digital I/O and Storage Devices are digital I/O devices convert information to/from binary
A keyboard converts the character “A” you type A keyboard converts the character A you type
E.g. “A” is represented by the binary code
Monitor converts 01000001 to the “A” that you
85 http://www.edutechlearners.com
One binary digit i.e. 1 or 0 is called a bit A group of 8 bits is one byte
Byte is the unit of storage measurement
http://www.edutechlearners.com 86
Textual information is made up of individual Textual information is made up of individual
Letters: Letters:
Lowercase: a,b,c,..z Uppercase: A,B,C..Z
Digits: 0,1,2,..9 Punctuation characters:
Other symbols: -, +, &, %, #, /,\,£, etc.).
http://www.edutechlearners.com 87
Each character is represented by a unique binary code.
ASCII is one international standard that specifies the
American Standard Code for Information Interchange
It is a 7-bit code - every character is represented by 7 bits There are other standards such as EBCDIC but these are
ASCII is being superceded by Unicode of which ASCII is
88 http://www.edutechlearners.com
Char ASCII Decimal Char ASCII Decimal
NUL 000 0000 00 BEL 000 0111 07 LF 000 1010 10 CR 000 1011 13 LF 000 1010 10 CR 000 1011 13 011 0000 48 SP 010 0000 20 1 011 0001 49 ! 010 0001 21 2 011 0010 50 “ 010 0010 22 9 011 1001 57 A 100 0001 65 a 110 0001 97 B 100 0010 66 b 110 0010 98 C 100 0011 67 c 110 0011 99 Y 101 1001 89 y 111 1001 121 Z 101 1010 90 z 111 1010 122
89 http://www.edutechlearners.com
Codes for A to Z and a to z form collating sequences
A is 65, B is 66, C is 67 and so on A is 97 b is 98 c is 99 and so on
A is 97, b is 98, c is 99 and so on
Lowercase code is 32 greater than Uppercase equivalent Note that digit ‘0’ is not the same as number 0
ASCII is used for characters
Not used to represent numbers (See later)
Codes 0 to 30 are typically for Control Characters
Bel - causes speaker to beep !
Carriage Return (CR); LineFeed (LF) g ( ) ( )
Others used to control communication between devices
SYN, ACK, NAK, DLE etc
90 http://www.edutechlearners.com
All information stored/transmitted in binary Devices convert to/from binary to other forms
Bits and Bytes KB, Mb, GB, TB and PB are storage metrics ASCII code is a 7-bit code to represent text
Text “numbers” not the same as “math's”
Do not add phone numbers or get average of PPS numbers
91 http://www.edutechlearners.com
Humans use Decimal Number System
Computers use Binary Number System
Important to understand Decimal system before looking at binary system
Decimal Numbers - Base 10
10 digits: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9
Positional number system: the position of a digit in a number determines its value
Take the number 1649
Take the number 1649
The 1 is worth 1000
The 9 is worth 9 units
Formally, the digits in a decimal number are weighted by increasing powers of 10 i.e. they use the base 10. We can write 1649 in the following form:
1*103 + 6*102 + 4*101 + 9*100
http://www.edutechlearners.com 92
1 10 + 6 10 + 4 10 + 9 10
weighting: 103 102 101 100
Digits 1 6 4 9
1649 = 1*103 + 6*102 + 4*101 + 9*100
Least Significant Digit: rightmost one - 9 above
Lowest power of 10 weighting
Digits on the right hand side are called the low-order digits (lower powers of 10).
Most Significant Digit: leftmost one - 1 above
Highest power of 10 weighting
The digits on the left hand side are called the high-order digits (higher The digits on the left hand side are called the high order digits (higher powers of 10)
http://www.edutechlearners.com 93
Largest n-digit number ?
Made up of n consecutive 9’s (= 10n-1 )
Largest 4-digit number if 9999
9999 is 104-1
Distinguishing Decimal from other number systems such as Binary,
Distinguishing Decimal from other number systems such as Binary, Hexadecimal (base 16) and Octal (base 8)
How do we know whether the number 111 is decimal or binary
One convention is to use subscripts
Decimal: 11110 Binary:1112 Hex: 11116 Octal: 1118
Difficult to write use keyboard
Another convention is to append a letter (D, B, H, O)
Decimal: 111D Binary:111B Hex: 111H Octal: 111O
http://www.edutechlearners.com 94
Binary numbers are Base 2 numbers
Only 2 digits: 0 and 1
Formally the digits in a binary number are weighted by increasing powers
Formally, the digits in a binary number are weighted by increasing powers
They operate as decimal numbers do in all other respects
Consider the binary number 0101 1100
W i h 27 26 25 24 23 22 21 20
Weight 27 26 25 24 23 22 21 20
bits 1 1 1 1
01011100 = 0*27 + 1*26 + 0*25 + 1*24 + 1*23 + 1*22 + 0*21 + 0*20 = 0 + 6410 + 0 + 1610 + 810 + 410 + 0 + = 9210
http://www.edutechlearners.com 95
Leftmost bit is the most significant bit (MSB).
The leftmost bits in a binary number are referred to as the
Rightmost bit is the least significant bit (LSB).
The rightmost bits in a binary number are referred to as the
Largest n-bit binary number ?
Made up of n consecutive 1’s (= 2n -1) Made up of n consecutive 1 s ( 2
1)
e.g. largest 4-bit number: 1111 = 24 -1 = 15
http://www.edutechlearners.com 96
Exercises
Convert the following binary numbers to decimal:
(i) 1000 1000 (ii) 1000 1001 (iii) 1000 0111 ( ) ( ) ( )
(iv) 0100 0001 (v) 0111 1111 (vi) 0110 0001
Joe Carty Formatting Convention
In these notes we insert a space after every 4 bits to make the numbers easier to read
http://www.edutechlearners.com 97
To convert from one number base to another:
you repeatedly divide the number to be converted by the new base
the remainder of the division at each stage becomes a digit in the new base g g
until the result of the division is 0.
Example: To convert decimal 35 to binary we do the following: p y g
Remainder
35 / 2 1 17 / 2 1
17 / 2 1
8 / 2
4 / 2
2 / 2
1 / 2 1
The result is read upwards giving 3510 = 1000112.
98 http://www.edutechlearners.com
Exercise: Convert the following decimal numbers to binary
(1) 64(2) 65 (3) 32 (4) 16 (5) 48
Shortcuts
To convert any decimal number which is a power
2, to binary, y p , y, simply write 1 followed by the number of zeros given by the power of 2.
For example, 32 is 25, so we write it as 1 followed by 5 zeros, i.e. 10000; 128 is 27 so we write it as 1 followed by 7 zeros i e 100 0000 128 is 2 so we write it as 1 followed by 7 zeros, i.e. 100 0000.
Remember that the largest binary number that can be stored in a given number of bits is made up of n 1’s made up of n 1 s.
An easy way to convert this to decimal, is to note that this is 2n - 1.
For example, if we are using 4-bit numbers, the largest value we can represent is 1111 which is 24-1, i.e. 15
99 http://www.edutechlearners.com
Binary Numbers that you should remember because they
100 http://www.edutechlearners.com
1
2 http://www.edutechlearners.com
3 http://www.edutechlearners.com
4 http://www.edutechlearners.com
5
http://www.edutechlearners.com
6
http://www.edutechlearners.com
7 http://www.edutechlearners.com
8 http://www.edutechlearners.com
9 http://www.edutechlearners.com
10 http://www.edutechlearners.com
11 http://www.edutechlearners.com
12 http://www.edutechlearners.com
13 http://www.edutechlearners.com
14 http://www.edutechlearners.com
15 http://www.edutechlearners.com
Note: The result of a binary operation
is implicitly stored
stack!
16 http://www.edutechlearners.com
Contains less no of
Contains less no. of instructions.
17
http://www.edutechlearners.com
18 http://www.edutechlearners.com
Arithmetic Logical g Shift
19 http://www.edutechlearners.com
Name Mnemonic Load LD Store ST Store ST Move MOV Exchange XCH Input IN Output OUT Push PUSH Pop POP
20 http://www.edutechlearners.com
Name Mnemonics Increment INC Increment INC Decrement DEC Add ADD Subtract SUB Multiply MUL Divide DIV Add with Carry ADDC Subtract with borrow SUBB Negate(2’s compliment) NEG
21
Negate(2 s compliment) NEG
http://www.edutechlearners.com
Name Mnemonics Clear CLR Clear CLR Compliment COM AND AND OR OR EXOR XOR Clear carry CLRC y Set carry SETC Compliment carry COMPC Enable and Disable Interrupt EI & DI
22
Enable and Disable Interrupt EI & DI
http://www.edutechlearners.com
Name Mnemonics Logical shift Right SHR Logical shift Right SHR Logical shift Left SHL Arithmetic Shift Right SHRA Arithmetic Shift Left SHLA Rotate Right ROR Rotate Left ROL Rotate Right with carry RORC Rotate Left with carry ROLC
23 http://www.edutechlearners.com
Name Mnemonics Branch BR Jump JMP Jump JMP Skip SKP Call CALL Return RET Compare(by subtraction) CMP Test(by ANDing) TST ( y g)
24 http://www.edutechlearners.com
Name Mnemonics Tested Conditions Branch if zero BZ Z=1 Branch if not zero BNZ Z=0 Branch if not zero BNZ Z 0 Branch if carry BC C=1 Branch if not carry BNC C=0 Branch if overflow OR not overflow BV or BNV V=1 OR 0 Branch if greater than BGT A>B Branch if less than BLT A<B Branch if equal BE A=B Branch if not equal BNE A not equal to B q q Branch if higher BHI A>B Branch if lower BLO A<B
25
26 http://www.edutechlearners.com
27
Address A Op-code Instruction Memory Operand
28
Address A Op-code Instruction Pointer to operand
extra memory access. The address specified in the instruction is not the address of the in the instruction is not the address of the
location that contains the address of the
Memory
content of memory location 5, say 10, and then CPU goes to location 10, reads the content (20) of that location and loads the data into the CPU data into the CPU
29 http://www.edutechlearners.com
Register Address R Opcode Instruction Registers Operand Operand
30
Register Address R Opcode Instruction
Pointer to
Operand
R i
Memory Registers
31
32 http://www.edutechlearners.com
33 http://www.edutechlearners.com
Register R
Opcode
Instruction Address A Instruction
Pointer to
+
Operand
Operand
Registers
+
A b l
Memory
– A = base value – R = register that holds displacement – or vice versa
34
35 http://www.edutechlearners.com
36 http://www.edutechlearners.com
37 http://www.edutechlearners.com
38 http://www.edutechlearners.com
39 http://www.edutechlearners.com
40 http://www.edutechlearners.com
41 http://www.edutechlearners.com
42 http://www.edutechlearners.com
43 http://www.edutechlearners.com
44
45 http://www.edutechlearners.com