KEMBAR78
8 Bit Microprocessor: Mayank Bhatnagar Vaibhav Mahimkar Dominic Alphonse | PDF | Microprocessor | Input/Output
0% found this document useful (0 votes)
248 views25 pages

8 Bit Microprocessor: Mayank Bhatnagar Vaibhav Mahimkar Dominic Alphonse

This document describes the design of an 8-bit microprocessor. It includes the architecture, which has 6 registers, an ALU, and a control unit. The ALU was designed using a ripple adder to minimize area and can perform addition, comparison, and logical operations. The registers and control unit are also described. The microprocessor was designed, simulated, and sent for fabrication as part of a university program.

Uploaded by

kartish8999
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOC, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
248 views25 pages

8 Bit Microprocessor: Mayank Bhatnagar Vaibhav Mahimkar Dominic Alphonse

This document describes the design of an 8-bit microprocessor. It includes the architecture, which has 6 registers, an ALU, and a control unit. The ALU was designed using a ripple adder to minimize area and can perform addition, comparison, and logical operations. The registers and control unit are also described. The microprocessor was designed, simulated, and sent for fabrication as part of a university program.

Uploaded by

kartish8999
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOC, PDF, TXT or read online on Scribd
You are on page 1/ 25

8 bit Microprocessor

Mayank Bhatnagar
Vaibhav Mahimkar
Dominic Alphonse
Syracuse University
M.S Electrical Engineering

Table of Contents

Sr No. Section Page No.

1 Abstract 2

2 Architecture and pin configuration 3

3 The Arithmetic and logic Unit 5

4 The Registers 8

5 The Control Unit 15

6 Results 20

7 Conclusions 21

8 References 22
Abstract

This report describes the semi custom design of an 8 bit Microprocessor, built with the
aid of EDA tools such as Cadence ICFB, Cadence Build gates, Encounter & Hardware
descriptive Language –Verilog, having the following specifications:

Technology
0.6µm AMI CMOS technology.
Die Area
1.5mmX 1.5mm
Package
40-pin Dual In Line Package

The Architecture of the microprocessor comprises of 6 Registers, an ALU and a


Control unit. The Processor was designed in modules. The functionality of the individual
modules & the Microprocessor on the whole, was verified in Modelsim & Cadence
analog environment. The processor was also designed for testing by including a test
mode. The processor design fulfils the requirements of fabrication & has been sent for the
same, to MOSIS, as a part of funding received by Syracuse University from MOSIS
educational program.

The project helped in improving our skills of Design budgeting, floor planning &
design integration. The remaining part of the report covers the logic design of each of the
sub modules and the results after various simulations. The conclusions and inferences
that have been drawn after this enriching experience have been stated at the end.

2
Architecture

3
DATA_OUT

LOADA

Reg A

ALU ZF
SEL A

SelALU
Reg B
LOADIR
LOADB Reset
SR
CF
SL
ZF
SELMEM
DATA_IN MDR BGA
SELA
RD
INCR
WR CONTROL
LOADMDR SELALU
A2B UNIT
LOADA
UZF
LOADB
UCF
CS
PC CLK
MRESET

LOADPC
LOADPC RESET
INC_PC LOADMAR
ADDR
DATA_IO
D
MAR

IR LoadIR

SelMEM LoadMAR

Pins Descriptions
1 Serial_out (For testing of registers )
2 A7 ( data out lines )
3 A6 “

4
4 A5 “
5 A4 “
6 GND
7 D7 ( Data in lines )
8 D6 “
9 D5 “
10 D4 “
11 VDD
12 D3 ( Data in lines )
13 D2 “
14 D1 “
15 D0 “
16 A0 ( Data out lines )
17 A1 “
18 A2 “
19 A3 “
20 Serial in ( For testing of registers )
21 VDD
22 AD0 ( Address lines )
23 AD1 “
24 AD2 “
25 AD3 “
26 RESET
27 CLK
28 RD’
29 TEST_MODE ( Ckt in test mode when ‘1’)
30 ZF ( Zero Flag )
31 GND
32 TEST_RESET_OUT
33 WR’
34 DATA_OUT ( For direction of Data )
35 VDD
36 AD7 ( Address lines )
37 AD6 “
38 AD5 “
39 AD4 “
40 GND

The ALU

Requirements:-
The basic functions the A.L.U needed to perform were
• Addition

5
• Comparison
• Logical AND
• Logical OR
• Logical NOT

These operations are to be performed on 8-bit wide operands A and B. The operation to
be performed is selected using select lines.

Design flow:-
The first step needed to take was to select an appropriate adder. The alternatives analyzed
were:-

Manchester Adder
Ripple adder
Carry select adder
Transmission Gate adders

For an 8 bit adder the speed for the various adders was found to be almost the same.
Hence area optimization became a greater concern. The design of Ripple adder used the
least number of transistors. The Manchester adder and carry select adder were faster
options, but only came at the expense of area. Hence it was decided to use a ripple adder
for implementing the sum operation.

Sum (i) = Ai xor Bi xor Cin


Cout (i) = AiBi +B.Cin+Ai.Cin

The 8 bit comparator designed checks for:


• Equality
• B>A
• and hence A>B

Equality = ( Ai XNOR Bi).Equality(i-1)

Bga = Ai’.Bi+ Bga(i-1).Equality (i) …………..(1)

As seen from the above equations gates could be reused for minimizing area. For eg the
A’ could be obtained from the comparator. Xnor could be obtained by inverting the Ai
Xor Bi term from the adder. In this way the logic was minimized to the least.
An 8 bit ALU was made by bit slicing 1 bit ALU. The first bit ie. bit 0 of ALU was
modified later .

For selection of the function to be carried out by the ALU a 4:1 Multiplexer was
implemented using three 2:1 multiplexers and 2 select lines as shown below.

6
AND(i) SUM(i) A’(i) OR(i)

SEL(0) SEL(0)

SEL(1) output(i)

Here Sel(0) and Sel(1) are the last bits of the opcode.

Sel(1) Sel(0) Function


0 0 OR
0 1 A’
1 0 Sum
1 1 AND

As seen above all the operations are carried out simultaneously and depending on the
select lines the respective result is sent as output.

Design Considerations:

A safe amount of distance was left between each bit slice of ALU for future possible
routing.

For efficient routing in the design certain norms were implemented as follows:
Metal 1 runs horizontally as far as possible.
Metal 2 run vertically as far as possible.
Metal 3 would be used the least within modules and more for inter module connections.

7
The equation of A>B is A(i).B’(i).Equality(i+1) + Agb(i+1) .The signal A’ could be
readily tapped from the function A<B( seen in equation 1.)
Hence instead of designing a signal A>B, a signal A<B was designed.

Carry in for bit 0 of the ALU was not removed so as to implement an “add with carry”
Instruction in the future.

Precautions & Concerns for future modules .


While bit slicing the adder, the create instance option was used. This did not allow sizing
or moving different layers in the imported instance for the purpose of routing. Hence
copy and paste was considered as a better option.

The design of ALU has a greater length which could be a potential problem when the
VDD and ground Rings are placed along the perimeter of the pad frame.

Every operation is being carried out irrespective of the select lines. The select lines select
the particular output depending on the opcode. Hence continuous power dissipation takes
place. Enable signals could be a solution for avoiding such redundant operations. Also as
all operations are being carried out continuously, the circuit is heavily loaded which may
cause voltage drops. A possible solution could be use of level restorers.

Register A (Accumulator)

This register has the following features:


 Parallel Loading data from Reg B, MDR, MAR
 Shift Right
 Shift Left
 Preset and Clear

8
Each bit of this register has been implemented using a D-Flip Flop and five 2:1
Multiplexers.

B A

A
Pre
ALU B A
Qn
SelA[1] B D
SET
Q
MDR
B
SelA[0]
CLR Q

Qn-1 Load
A Clk Clr

Qn+1 A
B

B
SR
SL

Eight such blocks have been cascaded for forming an Eight bit universal 8 bit shift
register.

The working of the register can be demonstrated for the following tables

Load = 1
Operation: Register Data Load
SelA[1] SelA[0] D
0 0
MDR
1 0
0 1 9 ALU
1 1 B
Load = 0
Operation: Shifting
SL SR D Action
0 0 Qn Retain Sate
x 1 Qn-1 Shift Right
1 0 Qn+1 Shift Leftt

SL: Shifts data from bit Qn+1 to Qn


SR: Shifts data from bit Qn-1 to Qn

10
Registers B, MDR, IR, MAR

These register has the following features:


 Parallel Loading data from Data Bus
 Shift Right
 Preset and Clear

Pre
B
Qn
SET
D Q
Pi A
A
CLR Q
B SL
Qn-1
Clk Clr

Placement:
Each of the registers B, MDR, IR, MAR are similar is construction and are formed using
the eight such sub units. However the placement each of the subunits of these registers is
not identical but is as shown below. The figure below shows one bit structure of Reg B,

11
MDR, MAR, IR. Eight such blocks have been cascaded to form Register B, MDR, MAR,
IR in one block.

MUX_b D F/F_b

MUX_b D F/F_ir

MUX_mdr MUX_mdr MUX_ir MUX_ir

D F/F_mdr MUX_mar

D F/F_mar MUX_mar

Signals:

Signal Description
Pi7:Pi0 Parallel input data to be loaded
Qn-1_b, Qn-1_mar, Qn-1_mdr, Qn-1_ir Serial inputs for registers
Clk Common clock for registers

SL_b, SL_mar, SL_ir, SL_mdr Shift command for registers


L_b, L_mar, L_ir, L_mdr Load command for registers

12
Clr_b, Clr _mar, Clr _ir, Clr _mdr Clear command for registers
Pre_b, Pre_mar, Pre_ir, Pre_mdr Preset command for registers

Do_b7:Do_b0, Do_ ir 7:Do_ ir 0,


Do_ mar 7:Do_ mar 0, Do_ mdr 7:Do_ mdr Parallel outputs of the registers
0

Operation:

Action L (Load) SL (Shift)


Parallel load 1 1
Shift from Qn-1 to Qn 0 1
Retain State x 0

13
Program counter

The program counter is a 8 bit synchronous counter which increments its value whenever
the Increment signal is high. The load signal can be used to load the PC with any
required value. In the increment mode the input to each of the flip flops depends on the
previous states of the flip flops. The exact logical relation is given below:

Di+1 = Qi+1 (Qi.Qi-1.Qi-2…..Q1.Q0)’ + (Qi+1)’. Qi.Qi-1.Qi-2…..Q1.Q0


As seen the counter can be incremented when load signal is low.

Pre
data A
SET
Qn
D Q

Increment logic
CLR Q
Load
A Clk Clr

incr

14
15
DISP2
DISP1
V1
CP1 Q1 4321
CP2 Q2 S1 4321

c
0V

U1
D Q
_
CP Q

U4A U2
D Q
_
CP Q
U8A
U4B U3
D Q
_
CP Q

U6A
U4C
U5
D Q
_
CP Q

U8B
U4D
U7
D Q
_
CP Q

U6B
U9A
U10
D Q
_
CP Q

U8C
U9B
U11
D Q
_
CP Q

U6C
U9C
U12
D Q
_
CP Q

fig:-Increment logic

16
The Control unit

The Control unit was designed by developing the behavioural model in Verilog code &
then synthesizing the same with cadence Build Gates. Placement and routing was carried
out with Encounter. The controller is basically a Moore state machine having a total of
23 states namely;

S,S0,S1,S2,S3,S4,S5,S6,S8,S9,S10,S11,S12,S13,S14,S15,S16,S17,S18,S19,SE,SE1,SE2

The operation being performed in the states are:-

S = reset
S0 = opcode fetch
Se = opcode decode
Se1 = evaluation of ZF=1 true
Se2 = evaluation of ZF=1 fails
S1 = Mov A, B
S2 = Mov B, A
S3 = LDA,#address & ST #addr, A
S4 = LDA,#address
S5 = ST #addr, A
S6 = Jmp unconditional
S8 = Shift left
S9 = shift right
S10 = Jmp A<B condition true and jumping to new PC
S11 = add A,B
S12 = AND A,B
S13 = OR A,B
S14 = NOT
S15 = ADC add with carry
S16 = Jmp A<B condition fails
S17 = comparision true
S18 = Jump if carry condition true.
S19 = Jump if carry condition fails.

17
Instruction Set
Mnemonic Opcode Description
MOV A,B 00H B:=A
MOV B,A 01H A:=B
LD A,#ADDR 02H:ADDR A:=[ADDR]
ST #ADDR,A 03H:ADDR [ADDR]:=A
ADD A,B 10H A:=A+B
CMP A,B 20H ZF:=1 IF A=B
JMP #ADDR 30H PC:=ADDR
JZ #ADDR 31H PC:=ADDR if
A=B
JL #ADDR 32H PC:=ADDR if
A<B
AND A,B 11H A:= A AND B
OR A,B 12H A:=A OR B
NOT A 13H A:=(~A)
ADC 14 A:=A+B+Carry
SL 40H Shift A 1bit Left
SR 41H Shift A 1bit Right

18
Inputs/Outputs

Name Active I/O Description


RD Low Output Memory Read
WR Low Output Memory Write
Load A High Output
Load B High Output Load Respective
Registers
Load MAR High Output
Load PC High Output
Reset Low Input Reset i/p
UCF High Output
Update Flags
UZF High Output
CLK High Input SYSTEM CLOCK
Mreset ( clr ) Low Output Like a clear pin
Connect o/p of A reg
A2B High Output to Register i/p lines
SL,SR High Output Shift signals for A
Selection of Address
Sel_MEM High Output on Address line
IR[0:7] High Input Instruction bits

19
Design for Testing

The test pin was added to enable a test for the registers by serially shifting the data into a
register and connecting all the registers to enable long serial shift. The registers
connected for this test were

A -> B-> IR->MDR->MAR

INPUT => Qn-1 ( The input to A register)


OUTPUT => Do_Mar7 ( Data output of Memory address register.)

The Registers needed to be modified for enabling the test pin. This was done as follows

The Shift Right operation

20
1
A
SR
B
FROM CONTROL
UNIT SR
accumulator

TEST

The Load of Register A

The accumulator is loaded now in a different way.

0
A
load
B
FROM CONTROL
UNIT SR
Accumulator

The Reset for Control Unit

21
EReset
Mreset clr
A Reset in
A A
B
0 B B
1
1
Control
TEST Unit

Results

22
Current Area utilization:-
The ALU uses 7.4% of the entire workable chip area.
Register A utilised 4.6 % of the area.
Registers B, MDR, IR, MAR taken together occupy 10.3 %
Program counter 3.3%

Propagation Delays :-
The worst case delay for the adder is approximately 7ns.
The worst case delay for generating B>A and equality is approximately 5.5ns.

For the Registers time taken by the output to stabilize after active edge of clock
THL: 1.43n sec
TLH: 1.815n sec

Conclusions

23
It is advisable to spend more of the design time in planning and checking the
functionality of the logic design. Using techniques mentioned earlier where selectively
metals are used for routing helps save time while routing.

References

24
Principles of CMOS VLSI Design – Neil H.E Weste, Kamran Eshraghian

Digital Integrated Circuits – Jan M Rabaey, Anantha Chandrakasan, Brivoje Nikolic

25

You might also like