Development of single board computer based on 32-bit 5-stage pipeline RISC processor by Koay, Boon Wooi
  
vii
 
 
 
 
 
TABLE OF CONTENTS  
 
 
 
 
CHAPTER  TITLE      PAGE 
 
  DECLARATION      ii 
DEDICATION      iii 
ACKNOWLEDGEMENT     iv 
ABSTRACT       v 
ABSTRAK       vi 
TABLE OF CONTENTS     vii 
LIST OF TABLE      x 
LIST OF FIGURES      xi 
LIST OF ABBREVIATIONS    xv 
LIST OF APPENDICES     xvi
  
 
1  INTRODUCTION      
  
1.1. Background and Research Motivation  1 
1.2. Objectives      3 
1.3. Scopes of Work       3 
1.4. Significant of Work and Research Contributions 4 
1.5. Organization of Project Report   5 
1.6. Summary of Chapter 1    6 
 
2  LITERATURE REVIEW  
2.1. RISC Architecture                          7 
2.2. Pipeline Structure                  8 
2.3. Pipeline Hazards     12 
  
viii
 
2.4. Bootstrapping      13 
2.5. Avalon® Interface     14 
2.6. Studies on I/O Protocol for I/O Controller Design 16 
2.6.1. PS/2 Keyboard Port    16 
2.6.2. LCD Display Port    19 
2.7. Summary of Chapter 2    21 
 
3  RESEARCH METHODOLOGY 
3.1. Research Flow and Methodology   22 
3.2. Design Approaches     24 
3.3. Designing with Altera Quartus II EDA Tool  25 
3.4. Hardware Selection     26 
3.5. Summary of Chapter 3    26 
 
4 RTL DESIGN AND ENHANCEMENT FOR RISC 
PROCESSOR 
4.1. RTL Design of RISC Processor   27 
4.2. Enhancement on RISC Processor Verilog HDL  36 
Coding 
4.2.1. Design of J-Type Instruction   36 
4.3. Summary of Chapter 4    42
  
 
5   DESIGN OF I/O CONTROLLERS 
5.1. Design Considerations    43 
5.2. Keyboard Controller     44 
 5.2.1. Deserializer     46 
 5.2.2. ScanCode_to_BCD Converter  50 
   5.2.3. ScanCode_to_Integer Converter  52 
   5.2.4. Operator and Operand Decoding logic 54 
  5.3 LCD Display Controller    55 
   5.3.1. LCD Controller    56 
   5.3.2. Binary_to_BCD Converter   64 
   5.3.3. BCD_to_LCD_Pattern Converter  65 
  
ix
 
  5.4 7-Segment LED Display Controller   69 
  5.5 Summary of Chapter 5    72 
 
6  SINGLE BOARD COMPUTER INTEGRATION 
  6.1. I/O Memory Arbitrator    73 
  6.2. Single Board Computer Integration   75 
  6.3. Design Practices and Limitations   79  
  6.4 Summary of Chapter 6    80 
 
7  VERIFICATION AND PERFORMANCE ANALYSIS 
7.1 RISC CPU Test Case     81 
  7.2. Basic Calculator (Single Board Computer)   88 
Test Case  
  7.3. Performance Analysis for Single Board Computer 94 
  7.4. Summary of Chapter 7    96
  
 
 
8   CONCLUSION AND FUTURE WORK   
8.1 Concluding Remarks     97 
8.2 Future Work      98 
 
REFERENCES          100 
 
APPENDIX A-D        101 
  
x
 
 
 
 
 
LIST OF TABLES 
 
 
 
 
TABLE NO.  TITLE      PAGE 
 
 
4.1  States for RISC Processor in RTL-CS table   29 
4.2  Control signal of CU      29 
4.3  ALU Operation      30 
4.4  Opcode Assignment for RISC Design   35 
5.1  RTL-CS Table for PS/2 port Deserializer   48 
5.2  Lookup Table for Scan Code to BCD Conversion  51 
5.3  RTL-CS Table for LCD Controller FSM, mLCD_st 60 
5.4  RTL-CS Table for LCD Controller FSM, st  63 
5.5  Truth Table of BCD to 7-Segment Display Decoder  69 
6.1  Primary Signals for Single Board Computer   77 
7.1  Description of Synthesis Result generated by Altera  94 
Quartus II 
7.2  Summary of Design Performance and Resource Utilization 95 
 
 
 
  
xi
 
 
 
 
 
LIST OF FIGURES 
 
 
 
 
FIGURE NO.  TITLE      PAGE 
 
 
2.1  Basic five stage pipeline in RISC architecture  9 
2.2  RISC Pipeline Architecture by Jurij Silc   10 
2.3  RISC Pipeline Architecture by Heurings   11 
2.4  Pipeline Control Hazard     13 
2.5  Bootstrapping Algorithm in Assembly Code   14 
2.6  Typical Avalon Interfaces in a System Design with DMA 15 
Controller and NIOS II Processor 
2.7  The Pinouts for each connector of PS/2 port   16 
2.8  General Open-Collector PS/2 Interface   17 
2.9  PS/2 Device-to-Host Communication   18 
2.10  PS/2 Host-to-Device Communication   18 
2.11  General Pinouts for LCD Display    19 
2.12  General Pin Assignment for Character LCD Display   20 
2.13  Character set for LCD Display based on [D7:D0] settings   20 
3.1  Summary of Project Flow and Methodology   23 
3.2  Top Level block diagram for RISC Single Board   23 
Computer via Altera DE2 Board 
3.3 CAD flow for Verilog Design of FPGA-Based Single  26 
Board Computer 
4.1  Top Level Architecture for RISC Processor   28 
4.2  Interconnection within DU     30 
4.3  On-Chip Memory      31 
4.4  5-Stage Pipeline RISC Processor Data Flow Diagram 32 
4.5  ISA design for RISC Processor    33 
  
xii
 
4.6  ISA design for Instruction Format    33 
4.7  Instruction Format for Memory Instruction   34 
4.8  Instruction Format for Register Instruction   34 
4.9  Instruction Format for Control Instruction   34 
4.10  Instruction Format for Other Instruction   34 
4.11  Instruction Format for newly coded J-Type Instruction 36 
4.12  Verilog design of control logic for  Jump, Branch and  37 
Conditional Branching instructions – generation of load  
signal ldPC 
4.13 Verilog design of control logic for  Jump, Branch and  38 
Conditional Branching instructions – generation of ALU  
select signal  in CU 
4.14  Simulation result for Jump Instruction verification  39 
4.15  Simulation result for Branch Instruction verification  40 
4.16  Simulation result for Conditional Branching Instruction  41 
verification 
5.1  IO Block Diagram of Keyboard Controller   45 
5.2  Functional Block Diagram of Keyboard Controller  46 
5.3  Timing Characteristic of PS2 DATA and PS2 CLK  46 
5.4  ASM Flowchart for PS/2 port Deserializer   47 
5.5  State Transition Description for PS/2 port Deserializer 48 
5.6  IO Block Diagram for PS/2 port Deserializer  48 
5.7  Functional Block Diagram of combinational logic for 49 
scan_ready  
5.8  Functional Block Diagram of combinational logic for 49 
oneshot 
5.9 Keyboard Command and Scan Code when Key ‘1’ on  50 
main keyboard is pressed and released. 
5.10  Flowchart for ScanCode_to_BCD Conversion Algorithm 51 
5.11  IO Block Diagram for ScanCode_to_BCD converter 52 
5.12  Flowchart for ScanCode_to_Integer Conversion Algorithm 53 
5.13  IO Block Diagram for ScanCode_to_Integer Converter 53 
5.14  IO Block Diagram of LCD Display Controller  55 
5.15  Functional Block Diagram of LCD Display Controller 56 
  
xiii
 
5.16  LCD Module Initialization      57 
5.17  Address Counter and DDRAM address for 2 x 16   58 
Character of LCD 
5.18  ASM Flowchart for LCD Controller FSM, mLCD_st  59 
5.19  LCD Controller FSM, mLCD_st State Transition   60 
Description 
5.20  Timing Characteristics for LCD Module Write Operation 61 
5.21  ASM Flowchart for LCD Controller FSM, st   62 
5.22  LCD Controller FSM, st State Transition Description 63 
5.23  Flowchart for Binary_to_BCD Conversion Algorithm 64 
5.24  Verilog Design Binary_ to_BCD converter   65 
5.25  Flowchart for BCD_to_LCD_Pattern Conversion   66 
Algorithm 
5.26  Verilog Design of LCD Pattern Lookup for BCD module 67 
5.27  Verilog Design BCD_ to_LCD_Pattern converter – part 1 67 
5.28  Verilog Design BCD_ to_LCD_Pattern converter – part 2 68 
5.29  IO Block Diagram for 7-Segment LED Display Controller 70 
5.30  Functional Block Diagram for 7-Segment LED Display  70 
Controller 
5.31 Functional Block Diagram for individual 7-Segment LED  71 
Display Decoder 
6.1  Flowchart for I/O Memory Arbitration Algorithm  74 
6.2  I/O Block Diagram of I/O Memory Arbitrator  75 
6.3  Functional Block Diagram of Single Board Computer 76 
6.4  Design Hierarchy of Single Board Computer , mycpu 78 
6.5  Resource Utilization      78 
7.1  Sequence of Instructions in RISC CPU Test Case  82 
7.2  Instruction Memory Content for RISC CPU Test Case 82 
7.3  Data Memory Content for RISC CPU Test Case  83 
7.4  Vector Source File for RISC CPU Test Case   83 
7.5  Timing Simulation result of RISC CPU Test Case   84 
for 0 to 0.65us 
7.6  Timing Simulation result of RISC CPU Test Case for  85 
  
xiv
 
 a) 0.65 to 1us and b) 1 to 1.35us 
7.7  Actual Hardware Result when Reset Button is pressed 86 
7.8  Actual Hardware Result for RISC CPU Test Case    87 
(0x000068AC) 
7.9 Actual Hardware Result for RISC CPU Test Case   87 
(0xFFFFA988) 
7.10  Sequence of Instructions in Basic Calculator Test Case 88 
7.11  Instruction Memory Content for Basic Calculator Test  89 
Case 
7.12  Data Memory Content for Basic Calculator Test Case 89 
7.13  Memory Map for Data Memory Content in Basic   89 
Calculator Test Case 
7.14 Timing Simulation result of Basic Calculator Test Case  90 
(Zoom Out) 
7.15  Timing Simulation result of Basic Calculator Test Case  91 
(Zoom Out) 
7.16  Hardware Setup of Single Board Computer on Altera  93 
DE2 Board    
7.17  Actual Hardware Result for Basic Calculator Test Case   93 
  
 
 
 
  
xv
 
 
 
 
 
LIST OF ABBREVIATIONS 
 
 
 
 
ALU  -  Arithmetic logic unit 
CU  -   Control Unit 
DU  -   Datapath Unit 
FPGA  -   Field programmable gate array 
FSM  -  Finite State Machine 
HDL  -   Hardware Description Language 
IR  -   Instruction Register 
ISA  -   Instruction Set Architecture 
LED  -   Light emitting diode 
NOP  -   No operation 
MAR  -   Memory address register 
PC  -  Program Counter 
RAM  -   Random access memory 
ROM  -   Read only memory 
RTL  -   Register Transfer Level 
I/O  -  Input and Output 
SBC  -   Single Board Computer 
RISC  -   Reduced Instruction Set Computer 
USB  -   Universal Serial Bus 
VGA  -  Video Graphic Array 
BCD  -   Binary coded decimal 
 
  
xvi
 
 
 
 
 
LIST OF APPENDICES 
 
 
 
 
APPENDIX  TITLE      PAGE 
 
 
A  PIN ASSINGMENT OF CYCLONE II FPGA   101 
 
B  SCAN CODE AND COMMAND FOR PS/2   104 
KEYBOARD    
 
C  DATA SHEET FOR CFAH1602B-TMC-JP LCD   106 
MODULE    
 
D  VERILOG SOURCE CODE FOR SINGLE BOARD  110 
COMPUTER  
 
