Keyboard - smart card reader controller using VHDL / Mohd Zuwairi Lani by Mohd Zuwairi, Lani
Keyboard - Smart Card Reader 
Controller using VHDL 
By 
MOHO ZUWAIRI B. LANI 
WEK 98169 
A final year project as a partial fulfillment of the 
requirement for Degree of Bachelor of Computer 
Science 
Faculty of Computer Science and Information Technology 
University Malaya 
Kuala Lumpur 
Session 2000/2001 
Un
ive
rsi
ty 
of 
Ma
lay
a
Abstract 
As the time fly by the technology of computers has improves and much security is 
needed in every transaction of data that being done. In this project, designing a 
microcontroller for keyboard and smart card reader terminal integration is being done. 
At first stage, the architecture of the controller will analyze and studied. This will need 
some practice of knowledge in computer organization and architecture, as well as 
microprocessors architecture designs. Then the architecture is design using hardware 
prototyping. This is by using the VHSIC Hardware Description Language (VHDL). 
The codes done using the language then being simulate to get the result of a proper 
working design. The reports will consists of analysis, designs, simulation results and the 
final outcome of the project which is the microcontroller itself. It will also cover some 
survey on books, websites and other sources that related to the project. In a way this 
project is one of many steps in making a better secure protection in the network for the 
coming future. 
Un
ive
rsi
ty 
of 
Ma
lay
a
Acknowledgement 
First and foremost 'alhamdulillah' to Allah, my supervisor Encik Noor Zaily for the 
guidance and advices given in making this project a success. I also would like to thank 
you my moderator, Dr Rosli Salleh for his evaluation on the project. In the way, morale 
support from family is deeply appreciated, Aizan Fareena (for the patience), Mohd 
Azfeezal (for the sources given), housemates (for laughs and jokes) and colleague (for 
the time spent). In the end, all of this cannot be real if not all the support that I get in 
making this project a success. 
ii 
Un
ive
rsi
ty 
of 
Ma
lay
a
Table of Contents 
Abstract 
Acknowledgement 
Table of Contents 
List of Figures 
List of T abies 
1 .0 Introduction 
1 .1 Objectives 
1 .2 Scope and Limitation 
1.3 Works Plan and Scheduling 
2.0 Literature Review 
2.1 Smart Card 
2.1.1 Introduction 
2.1.2 What is Smart Card? 
2.1.3 How it works? 
2.2 Keyboard Interfacing 
2.2.1 How the keyboard communicates with 
the systems? 
ii 
iii 
vii 
viii 
2 
3 
4 
5 
7 
7 
7 
8 
10 
17 
17 
Ill 
Un
ive
rsi
ty 
of 
Ma
lay
a
3.0 VHDL 22 
3.1 What is VHDL? 22 
3.2 The Advantages 23 
3.3 New Design Methodology 25 
3.4 Hardware Abstraction 26 
3.5 Elements 27' 
3.6 Basic Concept 28 
3.6.1 Timing 28 
3.6.2 Concurrency 28 
3.7 Objects and Classes 29 
3.8 Signals Assignment 30 
3.9 Signal Driver 30 
3.10 Packages 30 
4.0 Design and Development 32 
4.1 Microcontroller Design Steps 32 
4.2 Analysis of Designs 32 
4.2.1 Top-Down Design 32 
4.2.2 Designing with VHDL 33 
4.2.3 Design Scenarios 35 
4.2.4 Final Step 36 
4.3 Design Idea 36 
IV 
Un
ive
rsi
ty 
of 
Ma
lay
a
4.4 Keyboard Controller Design 
4.4.1 Keyboard to System Protocol 
4.4.2 System to Keyboard Protocol 
4.5 Smart Card Reader Controller Design 
4.6 The Final Controller Design 
5.0 Development and Testing 
5.1 Introduction 
5.2 Module Development 
5.2.1 Module Description 
5.2.2 Development of Top Level 
5.3 Synthesis 
5.4 Test and Simulation 
5.4.1 Introduction 
5.4.2 Error Checking I Syntax Checking 
5.4.3 Functional Simulation 
5.4.4 Implementation 
5.5 VHDL Design Verification 
5.6 Testing 
6.0 Discussion 
6.1 Problems 
37 
39 
39 
40 
42 
45 
45 
46 
46 
53 
53 
54 
54 
54 
54 
55 
55 
56 
58 
58 
v 
Un
ive
rsi
ty 
of 
Ma
lay
a
7.0 
6.2 
6.3 
Solutions and Recommendations 
Future Enhancement 
Conclusion 
Appendix 
Appendix A- Waveform Results 
Appendix B- Optimized Version Results 
Appendix C -Source Code 
Appendix D - Controller Layout 
References 
59 
60 
63 
Vl 
Un
ive
rsi
ty 
of 
Ma
lay
a
List of Figures 
Figure 2. J The reader reset sequence 
Figure 4. J Top-down design and bottom-up implementation 
Figure 4.2 Block diagram of a keyboard controller 
Figure 4.3 ASCII hexadecimal to binary decoder 
Figure 4.4 Location, size, and shape of contacts 
Figure 4.5 The computer element of the smart card 
Figure 4.6 Microcontroller proposed pin diagrams 
Figure 5. J Block diagram of counter8 module 
Figure 5.2 Block diagram of parity module 
Figure 5.3 Block diagram of shiftregPISO module 
Figure 5.4 Block diagram of SIPOshiftreg module 
Figure 5.5 Block diagram of devsync module 
Figure 5.6 Block diagram of mux_2_to_1 module 
Figure 5. 7 Block diagram of ps2dcdr module 
13 
33 
38 
38 
41 
41 
42 
46 
47 
48 
49 
50 
51 
52 
Vll 
Un
ive
r i
ty 
of 
Ma
lay
a
List of Tables 
Table 2.l Contact definition for smart cards 
Table 2.2 Contact states prior to card reset 
11 
13 
Vlll 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 1 
Introduction 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 1 - Introduction 
1.0 Introduction 
The needs for security in the era of information technology nowadays have 
increased for the past year. Although the problem already started since the beginning of 
Internet, many ways of protecting the data from being exposed or manipulated has been 
implemented but still it just not enough. 
A few years ago, a technology called integrated-circuit cards is introduced. This 
technology offers more security protection than other technology such as passwords. 
Smart cards gready improve the convenience and security of any transaction. 
Since the data stored are tamper-proof, this can be the vital component of data 
exchange through networks. 
In the ways of making the convenience of security during transaction or getting 
access, the idea of making a smart card reader that integrated with keyboards came to 
mind. This is because in any transaction a keyboard is needed and to insure the data 
exchange is safe a smart card can be a solution. 
Using the normal keyboard port or PS/2 or Universal Serial Bus (USB), the 
reader will be integrated with the keyboard by a micro controller with handle the tasks 
of a keyboard and the smart card reader as well. The task of designing the micro 
2 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 1 - Introduction 
controller is done on a Very High Speed Integrated Circuit Hardware Description 
Language (VHDL) simulator. 
1.1 Objectives 
The main goals are to improve the design of the keyboard-smart card reader 
integration that already existed in the market. These will includes the task of to find out 
how the keyboard can be integrated with the reader, and then design the controller that 
can do the integration. Using a VHSIC Hardware Description Language (VHDL) 
simulator the design of the controller will be done. 
The controller will work as processor for the keyboard as well as the reader also. 
It can interface with PC as an ordinary keyboard and a smart card reader in a single 
communication line such as through the PS/2 port or the usual keyboard port. 
As the goals of improving the hardware that already exist, the improvement will 
target to these areas: 
• Makes it low cost 
• Simplicity of design 
• Ease of use 
• Compatibility 
• Provide better security 
3 
Un
ive
rsi
ty 
of 
Ma
l y
a
Chapter 1 - Introduction 
1.2 Scopes and Limitation 
The researches will mainly concentrate on the design of a micro controller that 
will integrate these two devices. The micro controller that integrates the reader and 
keyboard should handle both device functions. Beside that it has to support several 
standard and protocol such as T=O and T=l and IS07816-1. Standard such as 
IS07816-1 is an international standard for integrated-circuit cards (commonly known as 
smart cards) that use electrical contacts. 
The keyboard also needs to interface with PC using single PS/2 interface. With 
that the design should also lowered the cost of the existence keyboard. 
Although some limitation can be expected in designing the controller, because 
some standard need to be familiarize so it can be implemented. Standard such as 
IS07816 only can be obtained from American National Standards Institute (ANSI). 
Obtaining these document can be a problems and can limit the probability that the 
controller can support these standard once it implemented. 
Beside that the needs for development tools are limited. Tools such as VHDL 
simulator and test or demo board to download the design are hard to obtain. Hence, 
due to these limitations the some of the feature maybe can't be implemented fully. 
4 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 1 - Introduction 
1.3 Work plans and Scheduling 
The works done were based on the planning and timetable that I've created. This 
important because each work must be done in time and careful planning will make it 
possible. 
Research 
VHDL 
Design 
Simulation 
Report 
June July August Sept Oct Nov Dec Jan Feb 
5 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 2 
Literature Review 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 2 - Literature Review 
2.0 Literature Review 
2.1 Smart Card 
2.1.1 Introduction 
A smart card is a type of card that embedded with a computer chip that stores 
and transacts data between users. This data may associated with either value, 
information or both and stored and processed within the card's chip, either memory or 
microprocessor. The data is transacted via a reader that is a part of a computing system. 
Nowadays, the smart card-enhanced systems are in use in several key applications such 
as healthcare, banking, entertainment and transportation. These applications benefit the 
added features and security that smart card provide. 
The first smart card was actually produced by CII-Honeywell-Bull with 
Motorola in 1979 but didn't become popular until the European countries discover the 
benefit this technology in 1985. French implement the technology for public phones pre 
payment card. Germany implemented it for the country health care plan. 
As time passed by, smart card gained popularity more than the rather 
conventional magnetic stripe card. The reason is that smart cards can store about 80 
times storage capacity than conventional magnetic stripe card. They provide advanced 
hardware I software security features and multiple function cards. 
7 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 2 - Literature Review 
2.1.2 What Is Smart Card? 
Smart card has a variety of type, depending primarily on the type of integrated 
circuit chip embedded in the plastic card and the physical form of the connection 
mechanism between the card and the reader. Three such variants are:-
• Cards with surface contacts leading to a memory-only integrated circuit chip 
• Cards with an electromagnetic connection to a microprocessor-integrated circuit 
chip 
• Cards with surface contacts leading to a microprocessor-integrated circuit chip. 
But the very earliest smart cards were memory cards containing an integrated circuit 
chip comprised of only nonvolatile memory and the necessary circuitry to read and write 
that memory. Nowadays, such still exists, beside inexpensive but provide a modest 
security protection for a variety applications. 
A memory card, as its name implies, is a card that contains an embedded integrated 
circuit chip providing nonvolatile memory for storing information in a permanent or 
semi-permanent fashion. The circuitry of the smart card exposes, through a standard 
electrical connector, the control lines for addressing selected memory locations as well 
as for reading and writing those memory locations through the electrical connectors on 
the face of the card. There is no on-board processor to support a high-level 
communications protocol between the reader and the card. Rather, memory cards use a 
8 
U
ive
rsi
ty 
of 
Ma
lay
Chapter 2 - Literature Review 
synchronous communication mechanism between the reader and the card. Essentially, 
the communication channel is always under the direct control of the reader side. The 
card circuitry responds in a direct (synchronous) way to the very low-level commands 
issued by the reader for addressing memory locations and for reading from or writing to 
the selected locations. In some recent memory cards, security enhancements have been 
incorporated through the provision of memory addressing circuitry within the chip that 
requires a shared secret between the terminal (which is writing to the card chip) and the 
chip 1tself. These are often called logic cards. 
A contact-less card has an integrated circuit chip embedded within the card; 
however, it makes use of an electromagnetic signal to facilitate communication between 
the card and the reader. With these cards, the power necessary to run the chip on the 
card is transmitted at microwave frequencies from the reader into the card. The 
separation allowed between the reader and the card is quite small--on the order of a 
few millimeters. However, these cards offer a greater ease of use than cards that must be 
inserted into a reader. This ease of use can be mitigated by other factors. 
With the current technology, the transfer data rate between the reader and the 
contact less card is restricted by the power level that it achieve in the card. Because of 
the card does not have internal power supply; the reader must derived power to the card 
so it can run on-board processor from the signal the being transmitted. 
9 
Un
ive
rsi
ty 
f M
ala
ya
Chapter 2 - Literature Review 
There not much different between the contact-based and contact- less 
architecture beside the physical mechanism the used to transfer between reader and 
card. The microprocessor used integrates both memory and central processing unit into 
single integrated circuit chip. 
2.1.3 How it works? 
First of all a smart card has to be embedded with the circuit that consists of 
central processing unit, memory, and 1/0 electronics. With the integrated circuit, it can 
conceal all the interconnection and will give a better security of what going on in or 
what's stored in the computer. 
Communicating With Smart Card 
Intelligent smart card are depending on how their communicating with the reader or 
terminal. Contact card used gold plated six or eight contact on the face of the card. 
Functions of it vary depending on the card configuration and application but all must 
has connection for power, reset, clock and data I/0. The specific definitions for the 
contact are shown in Table 2.1. 
10 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 2 - Literature Review 
Contact Designation Use 
Cl vee Power connection through which operating power is supplied to the 
microprocessor chip in the card. 
C2 RST Reset line through which the IFD can signal to the smart card's 
microprocessor chip to initiate its reset sequence of instructions. 
C3 CLK Clock signal line through which a clock signal can be provided to the 
smart card's microprocessor chip to control the speed at which it 
operates and to provide a common framework for data 
communication between the reader and the smart card. 
C4 RFU Reserved for future use. 
cs GND Ground line providing a common electrical ground between the 
reader and the smart card. 
C6 vpp Programming power connection providing a separate source of 
electrical power (from the operating power) that can be used to 
program the nonvolatile memory on the microprocessor chip. 
C7 1/0 Input/ output line that provides a half-duplex communication channel 
between the reader and the smart card. 
C8 RFU Reserved for future use. 
Table 2.1 Contact definition for smart cards 
To show how smart card communicates, we take a look on using smart card through a 
terminal or reader. To illustrate how this works in a real application the following shows 
how a typical security transaction occurs for access to a locked door: 
Door Card Reader Smart Card 
Reset --> 
<-- Answer reset 
Request card authenticate --> 
<-- Send random number 
Request authentication data --> 
<-- Authenticate reader 
Authenticate card --> 
<-- Transmit reader authentication data 
Open access file to read --> 
<-- Open access file 
11 
Un
ive
rsi
ty 
of 
Ma
lay
a
Open 
door <--
Chapter 2 - Literature Review 
Request read access file --> 
Write date and time 
transaction to access file 
Request unload 
Send authorized command 
of 
<-- Transmit access code 
--> 
<-- Acknowledge 
--> 
<-- Acknowledge 
The transmission characteristics of most smart card ICs are based on an asynchronous 
half duplex mode. The T=O protocol involves the transmission of bytes while the T=1 
protocol defines a block mode of operation. Note that two 1/0 signal connectors are 
required for full duplex operation so that transmission can take place in both directions 
at the same time. ISO defines only a single line for interchange of data between the IC 
and the interface device. In this mode of operation the line must change direction 
depending on whether the IC is transmitting or receiving. 
Once the card is inserted into the reader, no power is applied to any of the 
contacts. When the reader detects that the card is properly inserted, power is applied to 
the card. First, the contacts are brought to a coherent idle state, as shown in Table 2.2. A 
reset signal is then sent to the card via the RST contact line. The idle state is 
characterized as being when the power (VCC) contact is brought up to a normal, stable 
operating voltage of Sv. An initial power setting of Sv is always applied first, even 
though some microprocessor chips being introduced operate at 3v when in an 1/0 
12 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 2 - Literature Review 
state. The I/ 0 contact is set to a reception mode on the reader: side and a stable clock 
(CLK) is applied. The reset line is in a low state. It must remain in a low state for: at least 
40,000 CLK cycles before a valid reset sequence can be started by the reader:, raising the 
reset line to a high state. 
Contact 
V ee 
Vpp 
RST 
CLK 
I/ 0 
State 
Powered and stable 
Stable at idle state 
State-low 
Suitable and stable clock signal applied 
Reception mode in interface device 
Table 2.2Contact states prior: to card reset 
Cont.,ct~ 
pt-op e .-ly 
position ed 
C..'">.t-.:1 ! To inserted t G ND t 
vee 
I: 
I 
C LK I 
I 
I~ 
AS T 
l/ 0 
t 3 ... , 
R e.:. d e.r n c •t 
l i:Mte ning 
t3 = 4 0 ,000 clock cyci ~!O. 
ATR tYJ.Jst ~e i~st.1 ed l:y card bet ,•Jee n 4 .:0 c lc·ck cycl es 
and 40.000 •olock cycf"'c. a lt6 r RS T Qoes hiQh. 
Figure 2.1 The reader: reset sequence 
13 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 2 - Literature Review 
Data transfer between the reader and the card occurs through the concerted 
action of two of the contact lines: CLK and 1/0. The 1/0 line conveys a single bit of 
information per unit of time as defined by the CLK depending on its voltage relative to 
GND. A 1 bit can be conveyed either through a +5 v value or through a 0 v value. The 
actual convention used is determined by the card and is conveyed to the reader through 
the "initial character'' of the A TR, which is referenced as TS. To transfer 1 byte of 
information, 10 bits are actually moved across the 1/0 line; the first is always a "start 
bit" and the last is always a parity bit used to convey even parity. Considering that the 
1/0 line can be (m one bit period) either in a high (H) state or a low (L) state, the TS 
character of the form HLHHUJJJ.LH signals that the card wants to use the "inverse 
convention," meaning that H corresponds to a 0 and L corresponds to a 1. A TS 
character of the form HLHHLHHHLLH signals that the card wants to use the "direct 
convention," meaning that H corresponds to a 1 and L corresponds to a 0. 
The direct convention and the inverse convention also control the bit ordering 
with each byte transferred between the card and the reader. In the direct convention, the 
first bit following the start bit is the low-order bit of the byte. Successively higher-order 
bits follow in sequence. In the inverse convention, the first bit following the start bit is 
the high-order bit of the byte. Successively lower-order bits follow in sequence. Parity 
for each byte transferred should be even; this means that the total number of 1 bit in the 
byte, including the parity bit, must be an even number. 
14 
Un
ive
rsi
ty 
of 
Ma
lay
Protocols Used in Smart Card Communications 
T=O protocols 
Chapter 2 - Literature Review 
T=O is an asynchronous protocol, meaning there is no strict timing connection between 
one command sent from the reader to the card and the next command sent from the 
reader to the card. When the card receives a command from the reader, it performs the 
requested operations and sends back to the reader a response relative to that command. 
The reader is then free to send the next command to the card whenever it needs to. 
T= 1 protocols 
The T=1 protocol ts a block-oriented protocol This means that a well-defined 
collection of information--or block~s moved as a single unit between the reader and 
the card. Embedded within this block structure may be an APD U defined for a specific 
application. This facility is a good illustration that the T=1 protocol provides excellent 
layering between the link protocol layer and the application protocol layer. Moving 
information in a block, however, requires that the block be transferred (between the 
reader and the card) error free, or else the protocol can easily get lost. The error 
detection and correction, then, is a sigoificandy more complex operation than was the 
case with the T=O protocol. 
Error detection in the T= 1 protocol is done by using either a longit1tdinal n:dundanry 
character, which is essentially a slighdy more complex form of parity checking than was 
done in the T=O protocol, or by using a ryclic n:dundanry check character, which is 
guaranteed to detect any single-bit errors in a transmitted block. The specific CRC 
15 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 2 - Literature Review 
algorithm used is deftned in detail in the ISO 3309 standard. When an error is detected 
within a block by the received end of the channel, it signals the transmitting end to 
repeat sending the block received in error. 
The T= 1 protocol makes use of three different types of blocks, as illustrated in Figure 
2.5. 
Each has the same structure, but serves a different purpose: 
• Itiformation block-this block is used to convey information between application 
software in the card and application software on the reader-side of the channel 
• Receive reatfy block-this block is used to convey either positive or negative 
acknowledgments from one end of the channel to the other. A positive 
acknowledgment indicates that a block was correcdy received while a negative 
acknowledgment indicates that an error was detected (via checking the LRC or 
CRQ in the received block. 
• Superoisory block-this block is used to convey control information between the 
card and the reader. 
Each T= 1 block comprises three ftelds: 
• Prologue fteld-a mandatory fteld in the block which ts 3 bytes 10 
length. It includes the following three elements: 
1. NAD-Node address 
16 
Un
ive
rsi
ty 
of 
Ma
lay
Chapter 2 - Literature Review 
2. PCB--Protocol control byte 
3. LEN-Length 
• Information field--an optional field in the block that may be up to 254 
bytes in length. 
• Epilogue field-a mandatory field in the block that is either 1 or 2 bytes 
in length. 
2.2 Keyboard Interfacing 
In this segment, we will find out how the keyboard interfaces with the computer and 
how it can be integrated with the smart card. 
2.2.1 How the keyboard communicates with the system? 
The keyboard communicates on a character-by-character basis. Each key, 
including SHIFT, CTRL and ALT, sends a specific code when depressed and another 
code when it is released (the break code is the make code proceeded by FOh). ASCII is 
impractical for communication with a keyboard (especially with special features such as 
typematic rate) so special scan codes are used and converted to ASCII by the BIOS. 
Certain keys produce series of scan codes called scan sets. There are 3 scan sets 
in use with set 2 being the most common. (Sets 2 & 3 used on AT keyboards.) 
17 
Un
v
rsi
ty 
of 
Ma
lay
a
Chapter :Z - Literature Review 
The 101 /102 keyboard is laid in a 16 row by 8 column matrix. With set 1 or 2, 
for cursor control keys: ALT, CTRL, DEL, PgUp, PgDn, Ins, Home, End, the 
keyboard issues a series of codes dependant on shift keys (alt, ctrl, shift) and on the 
status of the indicator of the Num lock key. Since these keys are duplicated, the basic 
scan codes are identical- to identify the alternate key, an extra code EOh is added to the 
basic code. With set 3, each key generates just one code unaffected by the status of 
other keys. 
With set 1, the up code is obtained by adding 80h to the down code. For set 2 
and 3, the 1st byte is FOh and the 2nd byte is the down code for that key. 
If a key is pressed, the keyboard acknowledges the key and issues the down key 
code. If a 2nd key is pressed while the 1st is still depressed, the 2nd key is acknowledged 
and it's down code sent. If the 2nd key is released before the first, the 1st key is 
deactivated. To reactivate the 1st key, it must first be released. 
If two or more keys are pressed simultaneously, all are validated and all codes 
are sent (no error is generated). 
With the exception of the pause key, all keys when held down for a certain time, 
auto-repeat. The down code is repeated until the key is released. If two or more are 
pressed together, only the last key pressed is repeated. The repeat stops when the last 
18 
Un
ive
rsi
t  
of
Ma
lay
a
Chapter 2 - Literature Review 
key pressed is released, even if the other keys are still depressed. The delay is usually 
500ms and the repeat 10 Is and can be modified. 
The interface is serial, using the KBCLK (generated by the keyboard) and 
KBDT A lines. KBDT A is bidirectional! Data format is 11 bits for scan sets 2 & 3 - 1 
start bit, 8 data bits (LSB 1st), 1 odd parity bit and 1 stop bit. 
Data from controller to keyboard always has priority. As long as the keyboard 
has not yet transmitted the 1Oth bit, the controller can take over the interface, which it 
does by pulling KBCLK low for 1 OOms. Within Sms the keyboard will start sending low 
clock pulses on KBCLK KBDTA must be set to the relevant logic level each time 
KBCLK is low and must remain there until KBCLK goes high then low again. The 
keyboard reads this data bit when the clock pulse is high. If there is no clock within 
20ms or transmission takes more than 2ms assume a transmit time-out and send a 
resend command to the keyboard (FEh). 
For the keyboard to send the controller data, both KBCLK and KBDTA must 
be high. The keyboard begins by pulling KBDTA low and then starts sending clock 
pulses on KBCLK The data bit is output while the clock is high and remains while it 
goes low then high again. The controller should read the data while the clock is low. If 
the controller holds the clock low the transmission will be aborted and retried once the 
line is free. 
19 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 2 - Literature Review 
After the POST (power on self test) the keyboard issues an AAh to the system 
(FCh if failure). The signals source is open-collector TTI... Qow <0.8V high>2.4V). 
Signals are on a 6-pin DIN or SDL (PS/2) connector (5 wires- 1 supply, 2 gnd, dta and 
elk): 
1. Data In/Out 
2. N/C 
3. Gnd 
4. +5V 
5. Clock 
6. Test (not used / Gnd) 
AT pin out diagram 
(2) 1 CLOCK 
(5) (4) 2 DATA 
(3) (1) 3 not used 
4GND 
55V 
PS/2 pin out diagrams 
(5) 
(3) 
(1) 
(6) 
(2) 
(4) 
tDATA 
2 not used 
3GND 
4+5V 
5CLOCK 
20 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 3 
VHDL 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 3- VHDL 
3.0 VHSIC Hardware Description Language 
In this project, all the design will be done by using a hardware description language or 
better known as VHDL VHDL stand for Very high-speed integrated drcuit Hardware 
Description Langttage. The language now is the most used design and modeling language 
for digital systems. This leads to systems design and synthesis. It has been used in field 
of robotics and development of microprocessor. Beside that it is useful for describing 
hardware for simulation, testing, design, modeling and documentation. In the sense of 
hierarchical representation for functional and wiring details of digital systems, it 
provides the most convenient and compact format. 
3.1 What Is VHDL? 
It is a language that can be used for modeling a digital system at many level of 
abstraction, from algorithmic level to the gate level. The complexity could vary from a 
simple gate to a complete digital electronic system, or anything in between. VHDL 
always regarded as integrated amalgamation of some languages, which is: -
)o> S equentiallanguage + 
)o> Concurrent language + 
)o> Net-list language + 
)o> Timing specification 
)o> Waviform generation langttage 
22 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 3 - VHDL 
The language has feature or constructs that enable users to express the 
concurrent or sequential behavior of a digital system with or without timing. It also can 
model the system as an interconnection of components. By using this constructs, test 
waveforms can be generated. In the end, the constructs can provide a comprehensive 
description of the system in a single model. 
Not only it defines syntax but also clearly defines simulation semantics for each 
construct. Thus all the models written can be verified using the VHDL simulator. Since 
it is a strong typed language, it is often verbose to write. VHDL inherits the sequential 
language part features from ADA programming language. Because of the language 
provide an extensive range of modeling capabilities; it is often very difficult to 
understand. However it is possible to assimilate a core subset of the language that is 
both easy and simple to understand without learning the more complex features. The 
subset is sufficient to model most applications. The complete language however has 
sufficient power to capture the descriptions of the most complex chip to a complete 
electronic system. 
3.2 The Advantages 
The advantages that the VHDL offers are: -
•!• Standard: VHDL is like an EKE standard. Just like any standard, it reduces 
confusion and makes interfaces between tools, companies and products easier. 
23 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 3- VHDL 
Development to the standard will give better chance to lasts longer and less 
chance of being obsolete due to incompatibility with others. 
•:• Industry support. It has became tools for the industry and supported by the 
electronic industry 
•:• Portability: Because of the codes used can be simulated and used in many design 
tools and in different stages, it reduces dependency for the set of tools whose 
limited in capability. The VHDL standard also transforms design data much 
easier than a design database of a proprietary design tool. 
•:• Modeling capability: It is developed to model all level of designs, from electronic 
boxes to transistors. It can accommodate behavioral constructs and 
mathematical routines that describe complex models, such as queuing network 
and analog circuits. It allows use of multiple architectures and associates with 
the same design during various stages of the design process. 
•:• Reusability: Designs can be described, verified, and modified for future use. This 
eliminates reading and marking changes to schematics pages that are time 
consuming beside subject to error. 
24 
Un
ive
rsi
ty 
f M
ala
ya
Chapter 3- VHDL 
•:• Technology and foundry independence: The functionality and behavior of the design 
can be described with VHDL and verified, making it foundry and technology 
independent. This frees the designer to proceed without having to wait for the 
foundry and technology to be selected. 
•:• Documentation: VHDL is a description language, which allows documentation to 
be located in single place by embedding it in the code. The combining of 
comments and the code actually dictates what the design should do reduces the 
ambiguity between specification and implementation. 
•:• New design methodology: Using VHDL and synthesis creates a new methodology 
that increases the design productivity, shortens the design cycle, and lower costs. 
It amount to a revolution comparable to that introduced by the automatic semi-
custom layout synthesis tools of the last few years. 
3.3 New Design Methodology 
The introduction of VHDL and synthesis enables the design community to 
explore a new design methodology. With the traditional approach, starts with schematics 
drawing and then performs functional and timing simulation based on the same 
schematics. If occur errors it back to update the schematics again. After the layout, 
function and back-annotated timing are verified again with the same schematics. With 
VHDL, the design is functionally described. 
25 
Un
ive
rsi
ty 
f M
ala
ya
Chapter 3 - VHDL 
VHDL simulation is used to verify the functionality of the design. In general 
modifying VHDL source code much faster then changing schematics. This allows 
designers to make faster functionally correct designs, to explore more architecture trade-
offs and to have more impact on the designs. After the functions meet the requirement, 
the code then synthesized to generate schematics (or equivalent net lists). These net lists 
can be used to layout the circuit and to verify the timing requirement (both before and 
after the layout). Changes can be made by modifying the code or the constraints 
(timing, area and so on) in the synthesis. This new design approach and methodology 
has improved the design process by shortening design time, reducing the number of 
design iterations, and increasing the design complexity that designers can manage. 
3.4 Hardware Abstraction 
VHDL is used to describe a model for a digital hardware device, which specifies 
the external view of the device and one or more internal views. The internal view 
specifies the functionality or structure, while the external view specifies the interface of 
the device through which it communicates with the other models in its environment. 
The device-to-device model mapping is stricdy one-to-many. For example, a 
device modeled at high level of abstraction may not have a clock as one of it inputs, 
since the clock may not have been used in the description. Also, the data transfer at the 
interface may be treated in terms of integer values, instead of logical values. In VHDL, 
26 
Un
iv
rsi
ty 
of 
Ma
lay
a
Chapter 3 - VHDL 
each device model is treated as a distinct representation of a unique device, called an 
entity in this text. 
3.5 Elements 
Constructs of the VHDL language are designed for describing hardware component, 
packing parts and utilities, and use of libraries. It also designed for specifying design 
libraries and parameters. In simplest form, the description of component in VHDL 
consists of an interface specification and architecture specification. 
o/ Interface speajication begins with the ENTITY keyword and contains the input-
output ports of the component. The external characteristic of a component, 
such as time and temperature dependencies, can also be included in the interface 
description. 
o/ Architectural specification begins with the keyword ARCHITECTURE, which 
describe the functionality of a component. This functionality depends on the 
input-output signals and other parameters that are specified in the interface 
description. Several architectural specification with different identifiers can exist 
with one component with a given interface description. 
27 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 3 - VHDL 
3.6 Basic Concept 
Since VHDL is a hardware description language, it has features which are conceptually 
different than other languages. These represents special characteristic of hardware 
components and carries. These are timing and concurrency. 
3.6.1 Timing 
Timing is associated with the values that are assigned to the hardware carriers. Signal 
represents real wires, where the delays of the transfer through wire are concern, thus the 
assignment to signal in VHDL, involve timing. Consider the assignments in software as 
shown below: 
a= x; 
b = x; 
These assignment only consider the values transfer from x to a and b, ignore the timing 
of such transfer. 
3.6.2 Concurrency 
The terms refer to the simultaneous operation of various components. The VHDL has 
constructs that allow a virtually concurrent environment to be created. These constructs 
satisfy concurrency required for the description of the hardware. Through the use of 
concurrent constructs, timing of the interconnecting signals and order of the simulation 
28 
Un
ive
rsi
ty 
of 
Ma
lay
Chapter 3 - VHDL 
construct or components, a VHDL simulator makes us think that the execution is being 
done concurrently. 
3. 7 Objects and Classes 
An object is an entity that has a value of a given type. Some of the object in VHDL is 
port signals, loops index, variables, and signals for interconnecting components, 
temporary variables and files. In VHDL there a four classes in VHDL and an object 
may be one of these classes:-
)ii> Signal class- object in this class represent the hardware wires and have timing 
associated with them. Value assigned to the signals is placed on the signal driver 
and will appear on the signal after a specified delay value. 
)ii> Variable class- objects are for storage of temporary values and have no hardware 
significance. The variables can only be declared or have values assigned to them 
in sequential bodies ofVHDL. 
)ii> Constant class- object represent the values of a given type. Can be declared and 
used in concurrent and sequential bodies. These values cannot be changed. 
)ii> File class - objects contain data of the same type. Also can be declared and be 
used in both concurrent and sequential bodies. 
29 
Un
ive
rsi
ty 
of 
Ma
lay
Chapter 3 - VHDL 
3.8 Signals Assignment 
One of the important issues in VHDL, in it simplest form it consist of a target signal on 
the left-hand side of a left arrow and expression for defining a waveform on the right-
hand side. An assignment can include an AFTER clause specifying that a physical time 
delay occurs before the assignment to the left-hand side takes place. Signal assignment 
can have inertial, inertial with reject and transport mechanism. 
3.9 Signal Driver 
A signal has driving value and there may be several pending transactions on this signal 
waiting to become current. When a transaction become current, its value becomes the 
driving value of the signal. Assignments to a signal in multiple concurrent bodies create 
multiple drivers to the signal. Such a signal must be resolved and a resolution function 
must exist to resolve the value from the multiple driving values. 
3.10 Packages 
Often, in a hardware design environment it becomes necessary to group components or 
utilities used for description of components. Examples of VHDL constructs for 
describing utilities and environments are type definitions and subprograms. 
Components and such utilities can be grouped by used of packages. 
30 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 4 
Design 
Development 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 4 - Design Development 
4.0 Design Development 
4.1 Microcontroller Design Steps 
The microcontroller design will incorporate some design that will be able to control the 
two devices. Initially will start with the design idea, a complete and thorough definition 
of the intended hardware must then be developed from the initial design idea. This stage 
will determine overall functionality of the input to output mapping and the functional 
specification will be decided. Then, the data path of the interconnected components is 
designed and developed. Later the logic design then is done by using primitive gates. 
Finally if the design is successful then the physical hardware components are wired and 
manufactured which are will be done on this thesis. The work will only focus on the 
designs. 
4.2 Analysis of Designs 
To make the design is a success two methodologies being implemented which is typical 
digital system design and top-down design with VHDL. 
4.2.1 Top-Down Design 
Top-down design technique is recursively partitions a system into its sub-
components until all sub-components become manageable design parts. Design became 
manageable when the component is available as part of the library. It can be 
implemented by modifying an already available part. 
32 
Un
iv
rsi
ty 
of
Ma
lay
a
Chapter 4 - Design Development 
Mapping to hardware depends on target technology, available libraries and tools. 
Generally, a system can be further partitioned into its simpler components. Figure 4.1 
shows the implementation of top-down and bottom-up design. 
SCl 
SUD - system under design 
sse - system sub-{;omponent 
SUD 
SC2 
Shaded areas designate sub-components with hardware implementation 
SC3 
Figure 4.1Top-down design and bottom-up implementation 
4.2.2 Designing with VHDL 
When designing with VHDL, synthesis tools, complex library elements and a set of 
configurable parts are available as the manageable parts. 
Synthesis tools- Current tools are capable of translating high-level description into 
an interconnection of logic cells or FPGA (Field Programmable Gate Arrays) layouts. 
Such examples are combinatorial circuits. 
33 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 4 - Design Development 
Libraries - Prepackaged libraries are available in most technologies. In fact, libraries 
consist of pre-designed, tested and commonly used functional units. Such examples are 
multiplexer, flip-flop and ICs. 
~ Interface Description - At the top level, a system can be described by its interface 
description which can be the input and output ports as well as the physical 
characteristic of the system. 
~ Architecture Description - The architectural bodies of VHDL describe the 
functionality of a component. It can be in term of other components or in the 
form definition that speciftes the flow of data from inputs to the output of the 
circuit (I/ 0 mapping). Datciflow is referred to the description where functionality 
of a hardware component is mainly described in term of data flow through 
buses, logic units and registers. 
~ Behavioral Description - In this level, assigning appropriate value to circuit is the 
concern. The structure and details of the hardware are out of concern; instead 
I/ 0 mapping and functionality are main concern. At this level also whereas 
ports of models correspond to the actual inputs and outputs of the actual circuit. 
Configurable Parts - Pre-designed parts in the previous design can be used in the 
current design by reconftguring them. 
34 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 4 - Design Development 
4.2.3 Design Scenarios 
t. Analyzing the requirement 
Design begins with analyzing the requirement and developing an implantable 
model of the system. In this stage, interface and behavioral description are 
developed. Before any next step is taken, the behavioral description must be 
simulated. 
u. Recursive partitioning 
After simulating the behavioral description, the code is studied for generating 
the general layout. Specify the functionality that can be implemented by a 
correspondence hardware. 
• First-level of partitioning 
Every terminal must be checked so it can be synthesize, availability of 
libraries, or as a pre-designed parts. After that, the VHDL description 
will be developed to study way of designing them. 
• 5 econd-leve/ of partitioning 
If there is sub-component that cannot be synthesized, second-level of 
partitioning will be performed. The design is not complete until all 
terminals have corresponding hardware. 
35 
Un
i e
rsi
ty 
of 
Ma
lay
a
Chapter 4 - Design Development 
111. Design implementation 
Bottom-up implementation consists of wmng all the elements that have 
hardware correspondence or that appear as the terminal nodes of the fmal 
partition. 
4.2.4 Final Step 
After that the final layout from the final partitioning is produced. 
4.3 Design Idea 
The main purpose here is to design a microcontroller that will integrate two devices 
which is a keyboard and smart card reader. The final out come is a microcontroller that 
capable to handle these device so both of it can works properly in the same time. When 
it completed, it can be used with any keyboard and any smart card reader for any 
computer because it will interfaced with the computer through the normal AT keyboard 
port or the P /S2 port. The controller should able to: 
../ Interface with the computer without any problem 
../ Handle the task as a terminal for the smart card 
../ Functions as a normal keyboard 
../ Interface the reader with the computer 
36 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 4 - Design Development 
4.4 Keyboard Controller Design 
As we all know the keyboard interfaces with the computer using binary code. But the 
keys are assigned with hexadecimal numbers according to the ASCII code. Therefore to 
enables the computer to understand what the user type in, there must be a decoder for 
decode the hexadecimal value to binary value. With each transmission is clocked serial 
(with the keyboard as clock source or 'master') and 11 bits in length. These bits consists 
of one start bit (logic 0), 8 data bits (LSB ftrst), one odd parity bit and one stop bit (logic 
1 ). The clock rate is approx. 10-20 KHz and can vary from keyboard to keyboard. The 
keyboard data format resembles 8-odd-1 asynchronous transmission format. However, 
the bit rate from keyboard to keyboard can vary signiftcandy so it is necessary to use a 
clocked serial interface (SPI in Motorola parlance) or a O-!Jnc (SCI) interface with a 1x 
receive clock input. 
37 
Un
ive
rsi
ty 
of 
Ma
l y
a
Chapter 4 - Design Development 
MCU l 
(IRQ) Data In KbdData 
Clock In KbdClock 
Keyboard 
Controller 
Data Out 
ClockOu 
Figure 4.2Block diagram of a keyboard controller 
ASCII 
Hexadecimal 
... 
Hexadecimal 
-to-binary 
decoder 
Binary Numbers 
(8 bits) 
Figure 4.3 ASCII hexadecimal to binary decoder 
38 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 4 - Design Development 
4.4.1 Keyboard to System Protocol 
The keyboard will transmit keystroke data to the host system as soon as a key is 
pressed (or released) ifboth the DATA and CLOCK lines are HIGH. If the CLOCK 
line is LOW, the keyboard will buffer keystroke data until the CLOCK line goes HIGH 
again (the clock line acts as a-RTS signal). If the DATA line is LOW, the keyboard 
prepares to accept an 11-bit control message from the host (see below). 
If the CLOCK line is pulled LOW by the host while the keyboard is 
transmitting data (up to the 1Oth bit) for at least 60uS, the keyboard will suspend 
transmission and prepare to receive a system message. The keyboard will eventually re-
transmit the data byte that was interrupted, unless the keyboard was successful in 
transmitting the 1Oth bit, in which case the keyboard considers the data byte as 
successfully sent. It is generally a bad idea to interrupt keyboard transfers this way. 
4.4.2 System to Keyboard Protocol 
AT-style keyboards are capable of accepting control messages from the system 
in addition to sending scan code information to the host. In this way, the status LEDs 
may be controlled and the keyboard typematic parameters (repeat delay and rate) can be 
set. Command transmission to the keyboard is initiated by bringing the keyboard 
CLOCK line LOW for at least 60uS. After the 60uS delay, the DATA line should be 
brought LOW and the CLOCK line released (HIGH). Make sure to bring the DATA 
line LOW before releasing the CLOCK line. Some time later (up to 10 milliseconds) the 
39 
U
ive
rsi
ty 
of 
Ma
lay
a
Chapter 4 - Design Development 
keyboard will start to generate clock signals. At each HIGH to LOW clock transition 
the keyboard will clock in a new bit. The data stream from the system (on the DATA 
line) should conform to the serial protocol described above. 
After the parity bit has been clocked out, the host should release (bring HIGH) 
the DATA line and wait for the keyboard to send another CLOCK pulse (this will be 
the 10th HIGH to LOW transition, not counting the initial H->L transition generated 
by the host). The KEYBOARD will then bring the DATA line LOW sometime before 
the 11th HIGH to LOW transition of the CLOCK line to acknowledge reception of 
the command byte. If the DATA line is not released (allowed to go HIGH) after the 
10th CLOCK bit then the keyboard will continue to issue clock pulses until the DATA 
line is released. In this event, the keyboard will (after some delay) pull the DATA line 
LOW and transmit a RESEND status byte (FEh). 
4.5 Smart Card Reader Controller Design 
For interfacing the smart card, the reader terminal firstly must detect is the card is 
inserted properly. This is because if it not inserted properly when the power is applied, it 
can and will damage the card. 
40 
Un
iv
rsi
ty 
of 
Ma
lay
a
RST 
CLK 
1/0 
vee 
Chapter 4 - Design Development 
Figure 4.4 Location, size, and shape of contacts 
~-----------------------------------------, 
I 
I 
I 
I 
I 
I 
I 
. 
I 
I 
I 
. 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
1/0 
control 
ROM 
... 
""' 
CPU INM 
,.,. 
, 
RAM Volatile memory 
'-----------------------------------------~ 
Figure 4.5The computer element of the smart card 
41 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 4 - Design Development 
From the Figure 4.5, the smart card controller should have these input and output: 
• RST 
• CLK 
• 1/0 
• vee 
4.6 The Final Controller Design 
After studying the element that involved in the system, the final design of the controller 
is figured out. The controller will integrate the two device controller into single 
microcontroller. It will function as the normal device controller but at the same time 
also handle the next device function also. Figure 4.6 shows how the final design looks 
like. 
RST 
-
~ 
- ~ Q 
-
Data Out 
.. 
= Q Data In 
CJ Q 
.. 
-
CJ 
.... CLKin f---+ CLKOut 
~ 
I/0 .. 
Figure 4.6Microcontroller proposed pin diagrams 
42 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 4 - Design Development 
Some modification will be done in the next stage before the implementation, if the 
design is not working properly. Testing of the design will be done after all the designs 
correspond correctly. This to make sure there will be no glitch in the design prior the 
implementation. 
43 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 5 
Development and 
Testing 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 5 - Development and Testing 
5.0 Development and Testing 
5.1 Introduction 
In this phase the design will be used to develop the controller. The design will be 
develop using the Xilinx Fotmdation Series software. From the design there will be several 
modules to be developed. By using the software we can develop, compile, simulate and 
test the design. Each module will be develop and tested individually before being 
compiled together with the other module as the top level design. The controller will 
consist of 7 modules that are: 
1. counterS 
u. pari!J 
tu. shiftregPISO 
tV. SIPOshiftreg 
v. ps2dcdr 
Vl. dev[JnC 
vu. mttx_2_to_ 1 
45 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 5 - Development and Testing 
5.2 Module Development 
In this section each function of the module are described accordingly. This is for more 
understanding of the design of the controller itsel£ Therefore the development process 
will be fewer problems to the programmer. 
5.2.1 Module Description 
In the controller there will be consist of 7 modules, each has it own function and these 
are: 
a) counter8.vhd 
count 
CounterS 
7.tlf0 
elk 
rstn 
Figure 5.1 Block diagram of cottnter8 module 
Function: 
Mod 8 counter with an output indicating when the value stored is zero. 
46 
Un
ive
rsi
ty 
of 
Ma
lay
Chapter 5 - Development and Testing 
Input I Output Description: 
count 
elk 
rstn 
zero 
b) parity. vhd 
Function: 
dataln 
set 
assert to count clock 
clock 
asynchronous active low reset 
indicates counter = 0 
parity 
Figure 5.2Block diagram of panty module 
Manages the parity bit of the ps/2 device 
Input I Output Description: 
parout 
datafn 
set 
data can be passed serial to calculate parity 
assert to initialize parity (to 1) 
parotll calculated parity 
47 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 5 - Development and Testing 
c) shiftregPISO.vhd 
shift 
dataln shiftregPISO serial Out 
elk 
rstn 
t 
Figure 5.3Block diagram of shiftregPISO module 
Function: 
Parallel in / serial out shift register which shift right, shifting out the LSB ( Least 
Significant Bit ) 
Input / Description: 
shift-
dataln 
elk 
rstn-
serialout 
when asserted, shifts the register from MSB to LSB 
parallel data in bus 
clock 
asynchronous active low reset 
serial out line 
48 
Un
ive
rsi
ty
of 
Ma
lay
a
Chapter 5 - Development and Testing 
d) SIPOshiftreg. vhd 
SI 
SIPOshiftreg ~ ~ PO shift 
resetn 
elk 
j 
Figure 5.4Block diagram of SJPOshiftreg module 
Function: 
Implements a SIPO shift register which shift right, shifting into the MSB ( Most 
Significant Bit). 
Input / Output Description: 
Sl serial Input 
shift- assert to shift data 
resetn asynchronous active low reset 
elk clock 
PO parallel output 
49 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 5 - Development and Testing 
e) devsync.vhd 
elk 
devsync sync 
rstn 
ps2clk i 
Figure 5.5Block diagram of devsync module 
Function: 
Works as device synchronizer, this is when falling edge is seen on the ps/2 clock, 
sync is held high for one clock cycle. 
Input / Output Description: 
elk clock 
rstn-
ps2clk 
[Jnc-
asynchronous active low reset 
ps/2 clock line 
falling edge detected indicator 
50 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 5 - Development and Testing 
f) mux_2_to_1.vhd 
ps2data 
MUX 2 to 1 f----~.. dataout 
scdata 
reset 
Figure 5.6Block diagram of mux_2_to_1 module 
Function: 
Works as multiplexor, which depends on the reset signal to give the line between the 
two device. 
Input / Output Description: 
ps2data data from the ps/2 device 
scdata data from the smart card reader 
reset asynchronous active low reset 
dataout data that will be sent 
51 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 5 - Development and Testing 
g) ps2dcdr.vhd 
ps2sync 
.. shift 
ps2data 
Ps2dcdr .. shiftdata 
rstn 
zero ,.. count 
elk f 
Figure 5.7Block diagram of ps2dcdrmodule 
Function: 
State machine which converts serial data from ps/2 device into bytes and adds them 
into queue. Also control the sending of information to the ps/2 device. 
Input / Output Description: 
ps2!JnC 
ps2data 
rstn 
zero 
elk 
count 
indicates falling edge of ps2 clock line 
bidirectional ps2 data line 
asynchronous active low .reset 
output of modS counter 
clock 
increment modS counter 
52 
Un
ive
rsi
ty 
of 
Ma
lay
a
shiftdata 
shift 
Chapter 5 - Development and Testing 
data to shift to receive shift register 
shifts data into receive shift register, LSB first 
5.2.2 Development of the Top Level Design 
After the modules are tested, the developments of the top level design are initiated. 
These comprised of linking the modules together to form one working top level module 
and compiling it so there will be no syntax error or what so ever problem that may 
encounter during the development stage of the controller. The layout of the top level 
design can be referred in the appendices section. 
5.3 Synthesis 
After the modules or entities are described, the next step is to synthesize the entities. It 
is a process of translation and optimization in digital design. For example, layout 
synthesis is a process of taking design netlist and translating it into a form of data that 
facilitates placement and routing, resulting in optimizing timing and I or chip size. Logic 
synthesis, in other hand, is the process of taking a form of input (VHDL), translating it 
into a form (a Boolean equations and synthesis tool specific), and then optimizing in 
propagation delay and I or area. 
After the VHDL code is translated, the optimization process can be performed 
based on constraints such as speed, area, power, and so on. After the synthesis process 
53 
Un
ive
rsi
y o
f M
ala
ya
Chapter 5 - Development and Testing 
completed, the whole modules will be simulated to testify that behavior of the controller 
is correct. Simulation and tests done will be discussed in the section. 
5.4 Tests and Simulation 
5.4.1 Introduction 
Tests and simulation are carried out in the next stage of development. Test is conducted 
on each module to determine the workability according to their codes. The test 
comprised of few steps which is syntax checking, functional simulation and timing 
verification. 
5.4.2 Error Checking I Syntax Checking 
The coding is check for any syntax error, starting from the design entry which in form 
of HDL (Hardware Description Language). This checking is done with all the modules by 
using Xilinx Foundation Series HDL Editor. After syntax checking return no error, 
the HDL code then being added to the project. From this we can conclude the steps 
and move on to the next step of development that is synthesizing the codes. 
5.4.3 Functional Simulation 
The simulation is done after the synthesis process is completed. The simulation tests at 
the functional level to testify the behavior of the controller is correct. Thus, simulation 
is done by using event driven stimulator. 
54 
Un
iv
rsi
ty 
of 
Ma
l y
a
Chapter 5 - Development and Testing 
5.4.4 Implementation 
In the implementation stage / phase, verification of timing accuracy is done by using 
static timing analysis tool and this is important at gate -level timing stage. 
5.5 VHDL Design Verification 
The next step is simulation and it is done after the model description is successfully 
compiled. A simulation can be done on either one of the following: 
• An entity declaration and architecture body pair 
• A configuration 
Then actual simulation commence on two phase: 
1. Elaboration phase 
The entity is expanded and linked according to its hierarchy, components are 
bound to entities in a library and the top - level is built as a network of 
behavioral models is ready to be simulated. 
2. Initialization phase 
Driving and effective values for all explicidy declared signals are computed, 
implicit signals are assigned values, processes are executed until they suspend, 
and simulation time is set to 0 ns. 
55 
Un
ve
rsi
ty
of 
Ma
lay
a
Chapter 5 - Development and Testing 
In this design step, the VHDL description for each module of the controller had been 
created and ready to be simulated to insure proper logic functionality. By using script 
file, that can be generated from Xilinx's script editor, in order to do the simulation. It 
uses text file as input which contains the header information for the VHDL files such as 
port maps. 
5.6 Testing 
In order to determine that the hardware developed really works, a set of test were done 
to each module or entities that involve. To get the expected result, a set of data were 
chosen to be assign as the input values. The data will determine whether the entity 
working as it should be or not. 
56 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 6 
Discussion 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 6 - Discussion 
6.0 Discussion 
6.1 Problems 
During the development stage of the pro;ect, there are several problems faced and each 
will be described as below: 
1. Learningprocess 
The problem faced here is learning the VHDL language itsel£ For a new user 
learning a new language will take time to familiarize with the syntax and so on. 
Thus, learning VHDL took much of the time than expected in developing the 
controller. Much time spent on referring to manual on using VHDL instead 
starting writing the codes. The cause of this problem is lack of time to study the 
language properly, limited references available that time and not having the good 
foundation in programming language also contributes to this problem. 
2. Codingproblems 
Because of many modules that involve, sometime syntax error always occurs 
during writing the codes. This is due to the lacks of VHDL programming 
knowledge and references. One ma;o:r syntax error that occurs is 'netlist loaded 
with warning'. This is cause by type mismatch of entity name with the declared 
name in the component part of other entity. This problem easily solved by 
changing the name so it is identicaL 
58 
U
ive
rsi
ty 
of 
Ma
lay
a
Chapter 6 - Discussion 
3. Limited resources and references 
As we all know that VHDL is a new language that getting much support from 
the industry. It's a tool that makes modeling hardware much simpler and easier. 
Thus, resources are very limited on the VHDL and its standard. There not much 
reference book that available in store and library. If it available, the user level are 
for the advance users. This causes problem for the beginner users. Beside that, 
VHDL are taught in the faculty syllabus then although now the faculty just made 
it as one of the compulsory subject for the student. 
4. Hardware and software limitation 
From the experience that I've been through, developing VHDL require much 
RAM size of the computer. Sadly the workstation that I've the opportunity to 
work with is low in memory, therefore making the development quite limited. 
This problem worsen when came to the synthesis process which took longer 
time if not with a bigger RAM size. 
6.2 Solutions and Recommendations 
To solve the problem faced, several of these solutions and recommendations should be 
considered: 
a) Making VHDL as an tools for developing hardware in the faculty, encourage 
students to developed hardware using this tools for broaden their knowledge of 
computers hardware. 
59 
Un
ive
rsi
ty 
f M
ala
ya
Chapter 6 - Discussion 
b) Improve the facilities of the laboratory or set-up a proper laboratory for 
hardware development in near future so there will be no shortage in skilled 
computer engineering students in future to come. 
c) Lecturer should always encourage student to involve in computer hardware 
projects then more to software side, because it proven that nearly half of student 
doesn't know the computer hardware and it architecture very well. 
d) Improve the information gathering systems so fmding resource much eas1er 
such having own faculty library instead of a small document room. 
e) Try to buy a new VHDL tools so the development not limited to a certain 
constraint, buying software like Aldec Active HDL would be an advantage 
because this software can do simulation and synthesis much faster than the 
Xilinx Foundation Series Project Manager. 
6.3 Future Enhancement 
The design of this controller is not perfect. For future enhancement, there are few 
feature can be added such as: 
i) More compatible for other hardware also, such as thumb reader. 
60 
U
ive
rsi
ty 
of 
Ma
lay
a
Chapter 6 - Discussion 
ii) Modify the controller so it can support other hardware or peripherals so it 
can function as one. 
iii) Clean up the coding so there will be no delays created due to the imperfect 
codes. 
iv) Try to implementing it by downloading into a FPGA chip and test it to 
determine the functionality of the chip. 
However, future development of the controller should not only constraint to this design 
only but depend on the needs. 
61 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 7 
Conclusion 
Un
ive
rsi
ty 
of 
Ma
lay
a
Chapter 7 - Condusion 
7.0 Conclusion 
In conclusion, the project had taught me a lot. Starting with the proposal of 
such project and managing in how to conduct the project so it covers all the objectives 
within the given time. Second, time management, without proper time management this 
project would never be completed on time but I've made it with little trouble. 
Experiencing the use of VHDL in modeling a controller leaves me with much 
benefit for the future to come. The language is a tool that made the simulation of model 
behavior much easier for user through the graphical output, which easier to trace any 
fault in the design. 
With the help of friends that always around, every problem encountered being 
resolve through discussion. This problem will be discussed in the next section with 
solution and recommendations for future use. 
Here I've learned that developing source code for certain hardware are more 
complex then software such as a multimedia package because it involve every situation 
that involve an electronic circuit. Though the result from are true, but not in real life. 
This is because it depends on the circuit in the hardware that can effects the output 
data. 
63 
U
ive
rsi
ty 
of 
Ma
lay
a
Chapter 7 - Conclusion 
In whole, development of the Kryboard- Smart Card Reader Controller gave me one 
useful experience for me. I've learned the technique of designing and developing 
hardware that I cannot learn in my majoring in general. With this I can apply the 
knowledge of electronic that I've learned in class to develop such hardware. 
64 
Un
ive
rsi
ty 
of 
Ma
lay
a
Appendix 
Un
ive
rsi
ty 
of 
Ma
lay
a
Appendix A 
Un
ive
rsi
ty 
of 
Ma
lay
a
~~'t.Th~{;,~:i ·•i ·~·H "'"''''- F.5ns r.o~· ·r.o;;" ~-·· ~IJns ~OOns - ""frzo~,s •· ~40;;s '"' fO'~s ~ r,eons r.oons r.zons F.40ns . i.6tlns ·~~za-o~s - r.oons 
;~-"UNT. · .• . ·· ... r;~ B LK ...... ... Cl -- ------- ----- --·- ----- ------ ----- ----- ----- ---- - ----· ---- ----- ------ ----- ----- ----- ------ ----- ---- ----- ------ ---- ----- ----- ------ -
B TN ........ Fl -· --··· .............................................................................................................................................. ..... . .. .. 
o ERO . . . . . . . . - ------- -------------------------------------------------------------------------------------------------------------------------------------------------------
Waveform 1: counter8.vhd 
~"··~ ~~L~~; ~ (, -"·1' __ ,spns f.OPJ:lS '" r;so;n$ .. r.oOns ·;~SCM r,ot)~s r.so'h~ r.oons h50ns ~OOns IS SOns -. r.oon~ rson~ ~ r.oons 
~~: ······~~ B PS2CLK ...... C2 -- --------- ............................ -------- --------- --------- ......... --------- -------- --------- -------·- ------------------ --------
B RSTN 0 -- -........ -------------------------·--·-- ................................................................. .................... . .................. .. .~:;:.:: . :-J 
Waveform 2: devsync. vhd 
Un
ive
rsi
ty 
of 
Ma
lay
a
~:- J.,~ldi~- ,~""'': ,._foo;.,;- roo;;; toons-"'f.ti~ns- lsoofii..,.,. ~oo~~--roh'; r.oons ~oon;·-f,u; - (~~~'""' 1. -Z~ot~ (~s f.·4u~ '"'f· su;-'" ~~;~,:· .. ··. _. ~~~ 
ET 2 -- ------- ------- ------- ------- ------- ------- ------- ------- ------- ------- ------- ------- ------- ------- ------- ------- ------- ------- ------- -------
AOOUT::::: : ·- ... --~----~~------~--~----~ ·-----------···-·-··· 
Waveform 3: parity.vhd 
Waveform 4: pisoshiftreg. vhd 
Un
ive
rs
ty 
of 
Ma
lay
a
!fhltutj ~/diV 
. . . (hex)#B 
Waveform 5: siposhiftreg. vhd 
lljllllftJ ,,, ~,s/4:f.v "' 11' 11- ., - ~On~ . p.oons I:I.SO~: \. ~OOns jZsons poons psons 1400ns r.sons JSOOns JSSOns (600ns J650ns pMns rsons 
- - . ,, - 0. 0 1111 h llll l t~tlll l duttlt 111 111.! n t d 11 ulut rl1111 lt~ultll.llllllttlllllll If nh ttl 1 lttltntlnulllnlnniHttlllllllltt h IHin11lt "'''".I tlr.lun 
~~~::: (;::fl:?:~!t---r,; -~-::~~~ ----- ----- --- m : ______________ : - ~---- --- --- --- ---------------------- ----: - u u : 
Waveform 6: top/eve/. vhd 
Un
ive
rsi
ty 
of 
Ma
lay
a
AppendixB 
Un
ive
rsi
ty 
of 
Ma
lay
a
Appendix B: Optimized Version Reports 
=================== 
Chip ver1-0ptimized 
=================== 
Summary Information : 
Type: Optimized implementation 
Source: ver1, up to date 
Appendix 8- Optimized Version Reports 
Status: 0 errors , 0 warnings , 1 messages 
Export: exported after last optimization 
Target Information : 
Vendor: Xilinx 
Family : XC4000XL 
Device : 4002XLPC84 
Speed: xl-3 
Chip Parameters: 
Optimize for: Speed 
Optimization effort: Low 
Frequency: 50 MHz 
Is module : No 
Keep io pads: No 
Number of flip-flops: 16 
Number of latches : 0 
Chip Design Hierarchy : 
ps2keyboard: defined in 
c:\fndtn\active\projects\wai\toplevel\ps2keyboard.vhd 
Primitive reference count: 
--------------------------
BUFG 1 
DFF 16 
FMAP 23 
HMAP 5 
IBUF 3 
OBUFT 1 
STARTUP 1 
Un
ive
rsi
ty 
of 
Ma
lay
a
Appendix B - Optimized Version Reports 
Clocks: 
Period 
(ns) 
Rise 
(ns) 
Fall 
(ns) 
Required 
Freq 
(MHZ) 
Estimated 
Freq 
(MHZ) 
Signal 
............................................................... 
20 
-1 
0 
-1 
Timing Groups: 
Name 
10 
-1 
50.00 -1.00 
-1000.00 100.00 
Description 
default 
elk BUFGed 
............................................................ 
(I) 
(0) 
(RC,clk_BUFGed) 
Timing Path Groups: 
-------------------
From 
Input ports 
Output ports 
Clocked by rising edge of clk_BUFGed 
To 
Required 
Delay 
(ns) 
Estimated 
Delay 
(ns) 
............................................................ 
(I) 
(I) 
(RC,clk_BUFGed) 
(RC,clk_BUFGed) 
Input Port Timing: 
------------------
Port 
Name 
(0) 
(RC, clk_BUFGed) 
(0) 
(RC, clk_BUFGed) 
Estimated 
Slack 
20.00 
20.00 
20.00 
20.00 
Required 
Delay 
(ns) (ns) To-Group 
0.00 
3.40 
9.00 
6.80 
............................................................ 
elk 
rstn 
ps2data 
ps2data 
ps2data 
ps2data 
ps2clk 
ps2clk 
ps2clk 
ps2clk 
19.90 
n/a 
16.60 
16.60 
20.00 
20.00 
16.60 
16.60 
n/a 
n/a 
19.90 
n/a 
16.60 
16.60 
11.00 
11.00 
16.60 
16.60 
n/a 
n/a 
(RC, clk_BUFGed) 
(RC,clk_BUFGed) 
(RC,clk BUFGed) 
( RC, c lk ~)UFGed) 
(RC, clk_BUFGed) 
(RC, elk BUFGed) 
(RC,clk-BUFGed) 
(RC, clk~)UFGed) 
(RC,clk_BUFGed) 
(RC,clk_BUFGed) 
Un
ive
rsi
ty 
of 
Ma
lay
a
Output Port Timing: 
Port 
Name 
Required 
Delay 
(ns) 
Appendix 8 - Optimized Version Reports 
Estimated 
Slack 
(ns) From-Group 
............................................................ 
ps2data 16.60 16.60 (RC, clk_BUFGed) 
ps2data 16.60 16.60 (RC, clk_BUFGed) 
ps2data 20.00 11.00 (RC,clk_BUFGed) 
ps2data 20.00 11.00 (RC,clk_BUFGed) 
ps2clk 16.60 16.60 (RC, clk_BUFGed) 
ps2clk 16.60 16.60 (RC,clk_BUFGed) 
PS2clk n/a n/a (RC, clk_BUFGed) 
Ps2clk n/a n/a (RC,clk_BUFGed) 
Critical Path Timing: 
---------------------
Arrival Required 
Cell Time Time Fanout 
Type (ns) (ns) Count Pin-Name 
......................................................... 
port 9.00 20.00 1 /ver1-0ptimized/ps2da 
OBUFT 9.00 20.00 1 /ver1-0ptimized/C130/ 
OBUFT 1. 90 12.90 1 /ver1-0ptimized/C130/ 
DFF 1. 90 12.90 1 /ver1-0ptimized/decod 
DFF 0.00 11.00 16 /ver1-0ptimized/decod 
Un
ive
rsi
ty 
of 
Ma
lay
a
Delavs Report 
File: toplevel.dly 
The 20 Worst Net Delays are: 
I Max Delay (ns) I Netname 
4.129 N82 
3.968 decoder_presState<5> 
3.618 decoder_presState<1> 
3.478 syn560 
3.478 syn193 
3.427 counter value<2> 
3.390 ps2sync 
2.951 syn570 
2.888 count 
2.837 decoder _presState<3> 
2.782 decoder_presState<4> 
2.662 decoder_ps2Dataint 
2.550 decoder_presState<O> 
2.256 counter value<O> 
2.188 decoder_presState<2> 
2.082 counter value<1> 
2.079 syn683 
2.036 N_ps2data 
1 . 999 elk BUFGed 
1. 914 N_ps2clk 
Net Delays 
N19 
rstn.I1 
1. 535 N82. F1 
N82 
N82.X 
4.129 
N_ps2clk 
ps2clk.Il 
1. 914 
1.914 
N_ps2data 
ps2data.I2 
2.036 
1.531 
elk 
C54.GSR 
edgeDetect_presstate.F2 
count.G4 
decoder_presState<O>.G4 
decoder_presState<O>.C3 
Appendix B - Optimized Version Reports 
Un
ive
rsi
ty 
of 
Ma
lay
a
2.860 
2.770 
1. 361 
decoder_presState<2>.F4 
decoder_ps2Dataint.F1 
decoder_presState<O>.G3 
decoder presState<2> 
decoder_presstate<2>.YQ 
2.163 syn193.F1 
1.011 decoder_presState<2>.F3 
1.011 decoder_presState<2> . G3 
2.188 decoder_ps2Dataint . F3 
decoder presState<3> 
decoder_presState<2>.XQ 
2.837 decoder_presState<O> . F4 
2.809 decoder_ps2Dataint.F2 
2.809 decoder_presstate<2>.G4 
decoder_presState<4> 
decoder_presState<4>.XQ 
2 . 264 count.F4 
1.083 decoder_presState<4>.F2 
1.089 decoder_presState<4>.G2 
2.782 decoder_ps2Dataint.G1 
decoder_presState<5> 
decoder_presState<4>.YQ 
3.567 syn193.F4 
3.112 
3.654 
3.968 
1.771 
decoder_presState<6>.F1 
syn560.F4 
syn558.F4 
decoder_presState<4>.G3 
decoder_presState<6> 
decoder_presState<6>.YQ 
1. 872 syn683. F4 
1.872 decoder_presState<6>.F4 
1.872 decoder_presState<6>.G4 
decoder presState<7> 
decoder_presState<6>.XQ 
1. 834 syn683. F2 
1.573 decoder_presState<O>.F3 
0.609 decoder_presState<6> . G2 
decoder ps2Dataint 
decoder_ps2Dataint.XQ 
2.662 ps2data.T 
edgeDetect_presstate 
edgeDetect presstate.XQ 
1. 78S count.G1 
ps2sync 
count.YQ 
3.390 
3.208 
syn558.C2 
syn560.G4 
Appendix B- Optimized Version Reports 
Un
ive
rsi
ty 
of 
Ma
lay
a
3.191 
0.997 
2.443 
2.443 
3.328 
3.328 
2.443 
2.443 
2.389 
2.389 
2.215 
syn186 
syn186.X 
1. 796 
syn193 
syn193.X 
3.478 
syn558 
syn558.Y 
1.824 
syn560 
syn560.X 
3.478 
syn570 
syn560.Y 
2.436 
2.436 
2.847 
2.951 
syn683 
syn683.X 
2.079 
syn560.C4 
count.C3 
decoder_presState<O>.Fl 
decoder_presState<O>.Gl 
decoder_presstate<2>.F2 
decoder_presState<2>.G2 
decoder_presState<4>.F1 
decoder_presState<4>.Gl 
decoder presstate<6>.F3 
decoder=presState<6>.G3 
decoder_ps2Dataint.G2 
count.F3 
count.F1 
syn683.F3 
syn683.Fl 
decoder_presState<2>.Fl 
decoder_presstate<2>.G1 
decoder_presState<6>.F2 
decoder_presState<4>.G4 
decoder_ps2Dataint.C4 
Appendix B - Optimized Version Reports 
Un
ive
rsi
ty 
of 
Ma
lay
a
Appendix B - Optimiz.cl Version Reports 
Place and Route Reports 
PAR: Xilinx Place And Route C.l6. 
Copyright (c) 1995-1999 Xilinx, Inc. All rights reserved. 
Xilinx PAD Specification File 
***************************** 
Input file: 
Output file: 
Part type: 
Speed grade: 
Package: 
map.ncd 
toplevel.ncd 
xc4002xl 
-3 
pc84 
Pinout by Pin Name: 
+------------------------------------------------+-----------+--------------+ 
I Pin Name I Direction I Pin Number I 
+------------------------------------------------+-----------+--------------+ 
elk I INPUT P13 
ps2clk I INPUT Pl8 
ps2data I BIDIR P84 
rstn I INPUT P47 
+------------------------------------------------+-----------+--------------+ 
I Dedicated or Special Pin Name 1 Pin Number 
+------------------------------------------------------------+--------------+ 
I /PROGRAM I P55 I 
I CCLK I P73 I 
I DONE I P53 I 
I GND I P21 I 
I GND I P64 I 
I GND I P76 I 
I GND I P52 I 
I GND I P43 I 
GND Pl2 
GND P31 
GND Pl 
TOO P75 
vee P2 
vee P74 
vee P63 
vee P54 
vee Pll 
vee P42 
vee P22 
vee P33 
+------------------------------------------------------------+--------------+ 
Pinout by Pin Number: 
+--------------+-----------------------------------+-----------+------------+ 
Pin Number Pin Name I Direction I Constraint I 
+--------------+-----------------------------------+-----------+------------+ 
Pl (GND) 
P2 (VCC) 
P3 UNUSED 
P4 UNUSED 
PS UNUSED 
P6 UNUSED 
P7 UNUSED 
PS UNUSED 
P9 UNUSED 
PlO UNUSED 
Pll (VCC) 
Pl2 (GND) 
P13 elk INPUT 
Un
ive
rsi
ty 
of 
Ma
lay
a
Appendix B - Optimized Version Reports 
I Pl4 I I UNUSED I I 
I Pl5 I I UNUSED I I 
I Pl6 I I UNUSED I I 
I Pl7 I I UNUSED I I 
I Pl8 I ps2clk I INPUT I I 
I Pl9 I I UNUSED I I 
I P20 I I UNUSED I I 
I P21 I (GND) I I I 
I P22 I (VCC) I I I 
I P23 I I UNUSED I I 
I P24 I I UNUSED I I 
I P25 I I UNUSED I I 
I P26 I I UNUSED I I 
I P27 I I UNUSED I I 
I P28 I I UNUSED I I 
I P29 I I UNUSED I I 
I P31 I (GND) I I I 
I P33 I (VCC) I I I 
I P35 I I UNUSED I I 
I P36 I I UNUSED I I 
I P37 I I UNUSED I I 
I P38 I I UNUSED I I 
I P39 I I UNUSED I I 
I P40 I I UNUSED I I 
I P41 I I UNUSED I I 
I P42 I (VCC) I I I 
I P43 I (GND) I I I 
I P44 I I UNUSED I I 
I P45 I I UNUSED I I 
I P46 I I UNUSED I I 
I P47 I rstn I INPUT I I 
I P48 I I UNUSED I I 
I P49 I I UNUSED I I 
I PSO I I UNUSED I I 
I PSl I I UNUSED I I 
I P52 I (GND) I I I 
I P53 I (DONE) I I I 
I P54 I (VCC) I I I 
I PSS I (/PROGRAM) I I I 
I P56 I I UNUSED I I 
I P57 I I UNUSED I I 
I P58 I I UNUSED I I 
I P59 I I UNUSED I I 
I P60 I I UNUSED I I 
I P61 I I UNUSED I I 
I P62 I I UNUSED I I 
I P63 I (VCC) I I I 
I P64 I (GND) I I I 
I P65 I I UNUSED I I 
I P66 I I UNUSED I I 
I P67 I I UNUSED I I 
I P68 I I UNUSED I I 
I P69 I I UNUSED I I 
I P70 I I UNUSED I I 
I P71 I I UNUSED I I 
I P72 I I UNUSED I I 
I P73 I (CCLK) I I I 
I P74 I (VCC) I I I 
I P75 I (TDO) I I I 
I P76 I (GND) I I I 
I P77 I I UNUSED I I 
I P78 I I UNUSED I I 
I P79 I I UNUSED I I 
I P80 I I UNUSED I I 
I P81 I I UNUSED I I 
I P82 I I UNUSED I I 
Un
ive
rsi
ty 
of 
Ma
lay
a
Appendix B - Optimized Ver8ion Reporu 
I P8 3 I --- UNUSED I 
I P84 I ps2data BIDIR I 
+--------------+-----------------------------------+-----------+------------+ 
t 
t To preserve the pinout above for future design iterations, 
t simply run "Lock Pins ... " from the Design Manager's Design 
t menu, or invoke PIN2UCF from the command line. The location constraints 
t above will be written into your specified UCF file . (The constraints 
t listed below are in PCF format and cannot be directly used in the UCF file). 
# 
COMP "elk" LOCATE = SITE "P13" ; 
COMP "ps2c1k" LOCATE = SITE "P18" 
COMP "ps2data" LOCATE = SITE "P84" 
COMP "rstn" LOCATE = SITE "P47" ; 
* 
PAR: Xilinx Place And Route C.16. 
Copyright (c) 1995-1999 Xilinx, Inc. All rights reserved. 
par -w -ol 2 -d 0 map.ncd top1evel.ncd toplevel.pcf 
Constraints file: toplevel.pcf 
Loading device database for application par from file "map.ncd". 
"toplevel" is an NCD, version 2.28, device xc4002xl, package pc84, speed -3 
Loading device for application par from file '4002xl.nph' in environment 
C:/Fndtn. 
Device speed data version: C 1.1.2.2 PRELIMINARY. 
Device utilization summary: 
Number of External IOBs 3 out of 61 
Flops: 0 
Latches: 0 
Number of Global Buffer IOBs 1 out of 8 
Flops: 
Latches: 
Number of CLBs 
Total Latches: 
Total CLB Flops: 
4 input LUTs: 
3 input LUTs: 
Number of BUFGLSs 
Number of STARTUPs 
Overall effort level (-ol): 
Placer effort level (-pl): 
Placer cost table entry (-t): 
Router effort level (-rl): 
0 
0 
14 out 
0 out 
15 out 
23 out 
5 out 
1 out 
1 out 
2 (set by user) 
2 (set by user) 
1 
2 (set by user) 
of 64 
of 128 
of 128 
of 128 
of 64 
of 8 
of 1 
Starting initial Placement phase. 
Fini shed initial Placement phase. 
REAL time: 3 sees 
REAL time: 3 sees 
Starting Constructive Placer. REAL time: 3 sees 
4% 
12% 
21% 
0% 
11% 
17% 
7% 
12% 
100% 
Un
ive
rsi
ty 
of 
Ma
lay
a
Appendix 8 - Optimized Version Reporta 
Placer score = 5190 
Placer score = 3960 
Finished Constructive Placer. REAL time: 3 sees 
Writing design to file "toplevel.ncd". 
Starting Optimizing Placer. REAL time: 3 sees 
Optimizing 
Swapped 38 comps. 
Xilinx Placer [1] 2070 REAL time: 3 sees 
Finished Optimizing Placer. REAL time: 3 sees 
Writing design to file "toplevel.ncd". 
Total REAL time to Placer completion: 3 sees 
Total CPU time to Placer completion: 3 sees 
0 connection(s) routed; 90 unrouted. 
Starting router resource preassignment 
Completed router resource preassignment. REAL time: 3 sees 
Starting iterative routing. 
Routing active signals. 
End of iteration 1 
90 successful; 0 unrouted; (0) REAL time: 3 sees 
Constraints are met. 
Routing PWR/GND nets. 
Power and ground nets completely routed. 
Writing design to file "toplevel.ncd". 
Starting cleanup 
Improving routing. 
End of cleanup iteration 1 
90 successful; 0 unrouted; (0) REAL time: 3 sees 
Writing design to file "toplevel.ncd". 
Total REAL time: 4 sees 
Total CPU time: 4 sees 
End of route. 90 routed (100.00%); 0 unrouted. 
No errors found. 
Completely routed. 
This design was run without timing constraints. It is likely that much better 
circuit performance can be obtained by trying either or both of the following: 
- Enabling the Delay Based Cleanup router pass, if not already enabled 
- Supplying timing constraints in the input design 
Total REAL time to Router completion: 4 sees 
Total CPU time to Router completion: 4 sees 
Generating PAR statistics. 
The Delay Summary Report 
The Score for this design is: 281 
The Number of signals not completely routed for 
The Average Connection Delay for this design 
The Maximum Pin Delay is: 
The Average Connection Delay on the 10 Worst 
this 
is: 
Nets 
design is: 0 
2.153 ns 
4. 129 ns 
is: 3.297 ns 
Un
ive
rsi
ty 
of 
Ma
lay
a
Appendix 8 - Optimized Version Report8 
Listing Pin Delays by value: (ns) 
d < 1.00 < d < 2.00 < d < 3.00 < d < 4.00 < d < 5.00 d >= 5.00 
10 32 33 14 1 0 
Writing design to file "toplevel.ncd". 
All signals are completely routed. 
Total REAL time to PAR completion: 4 sees 
Total CPU time to PAR completion: 4 sees 
PAR done. 
Un
ive
rsi
ty 
of 
Ma
lay
a
AppendixC 
Un
ive
rsi
ty 
of 
Ma
lay
a
Appendix C: Source Code 
Description: Code for the ps/2 keyboard top level 
library IEEE; 
use IEEE.std_logic_1164.all; 
entity ps2keyboard is 
port ( 
) ; 
elk: in STD LOGIC; 
rstn: in STD LOGIC; 
ps2data: inout STD_LOGIC; 
ps2clk: inout STD LOGIC 
end ps2keyboard; 
architecture ps2keyboard_arch of ps2keyboard is 
SIGNAL shiftData: STD LOGIC; 
SIGNAL shift: STD LOGIC; 
SIGNAL count: STD_LOGIC; 
SIGNAL zero: STD_LOGIC; 
SIGNAL latch: STD_LOGIC; 
SIGNAL ps2sync: STD_LOGIC; 
SIGNAL valid: STD_LOGIC; 
SIGNAL read: STD_LOGIC; 
Appendix C - Source Code 
SIGNAL latchedData: STD_LOGIC VECTOR (7 downto 0); 
SIGNAL unlatchedData: STD LOGIC VECTOR (7 downto 0); 
component SIPOshiftreg 
port ( 
) ; 
resetn: in STD LOGIC; 
SI: in STD LOGIC; 
PO: out STD LOGIC VECTOR (7 downto 0); 
Shift: in STD LOGIC; 
elk: in STD LOGIC 
end component; 
component counterS 
port ( 
) ; 
count: in STD LOGIC; 
elk: in STD LOGIC; 
rstn: in STD LOGIC; 
zero: out STD LOGIC 
end component; 
component devsync 
port ( 
elk: in STD LOGIC; 
Un
ive
rsi
ty 
of 
Ma
lay
a
) ; 
rstn: in STD LOGIC; 
ps2clk: in STD_LOGIC; 
sync: out STD LOGIC 
end component; 
component ps2dcdr 
port ( 
) ; 
ps2sync: in STD LOGIC; 
ps2data: in STD LOGIC; 
elk: in STD LOGIC; 
rstn: in STD LOGIC; 
zero: in STD LOGIC; 
shift: out STD LOGIC; 
shiftData: out STD LOGIC; 
latch: out STD LOGIC; 
count: out STD LOGIC 
end component; 
begin 
) ; 
) ; 
) ; 
shiftReg: SIPOshiftreg PORT MAP( 
resetn => rstn, 
SI => shiftData, 
PO => unlatchedData, 
Shift => shift, 
elk => elk 
counter: counterS PORT MAP( 
count => count, 
elk => elk, 
rstn => rstn, 
zero => zero 
edgeDetect: devsync PORT MAP( 
elk => elk, 
rstn => rstn, 
ps2clk => ps2clk, 
sync => ps2sync 
decoder: ps2dcdr PORT MAP( 
ps2sync => ps2sync, 
ps2data => ps2data, 
elk => elk, 
rstn => rstn, 
zero => zero, 
shift => shift, 
shiftData => shiftData, 
latch => latch, 
Appendix C - Source Code 
Un
ive
rsi
ty 
of 
Ma
lay
a
Appendix C - Source Code 
count => count 
) ; 
end ps2keyboard_arch ; 
Un
ive
rsi
ty 
of 
Ma
lay
a
AppendixD 
Un
ive
rsi
ty 
of 
Ma
lay
a
iU 
ff: 
" 
g 
* 
6 
\1' ~ 
"' ~! 
"' rl 
"' 
[:2 
~J 
~ 
"' :r ;::< j_ 
l 
L----jr-------
' '" ~} ~~ ·;\. 
"' 
0 •n q ~ * f.l 
" "' ~ ,. 
!}.! '< ., 
·i ,, 
g ., 
• ~ 
r 
•n 
,ji i~ ,. 
"' ~t 
'" 
l 
'.' 
'" 
i'·-~ 
l;J_ 
'·' ~ 
"' f, t !JI ~ lll ':r 
~~ fj, n (-: 
'" ;;; .,. 
r 
l 
" l_tl /'-.i 
" u :-!.! 
'" 
'" Ill 
1,; 
c 
~ 
'·' l'.l 
"' '< ., 
" 
'" 'T 
J 
~~ 
c 
I "' I~ 
I ·~ 
trt 
~ ;: 
r..J "l" 
''! , 
t!• 
I 
I 
~-· n ~ 
"' 
Un
ive
rsi
ty 
of 
Ma
lay
a
References 
Un
ive
rsi
ty 
of 
Ma
lay
a
References 
Books 
1 . Digital Design - Principles and Practices 
Wakerly, John F., 2000 Prentice Hall, Inc 
2. A VHDL Primer- Revised edition 
Bhasker, J., 1995 Prentice Hall, Inc 
3. The Designer's Guide to VHDL 
Ashenden, Peter J., 1996 Morgan Kaufmann Publishers, Inc 
4. Logic and Computer Design Fundamentals 
Mono, M. Morris and Kime, Charles R., 2000 Prentice Hall, Inc 
5. Computer Architecture and Organization: Designing For 
Performance 
Stallings, Williams, 5th Edition, Prentice Hall, Inc 
Websites 
1) http:/ /www.smartcardbasic.com 
2) http:/ /www.eduard-rhein-foundation.de/html/t96.html 
3) http:/ /www.smartcard.co.uk/finance l.html. 
4) http:/ /library.cs.tuiasi.ro/hardware/smart-card-developer-
kit/ch03/www.visa.com 
Un
ive
rsi
ty 
of 
Ma
lay
a
5) http:/ /library.cs. tuiasi.ro/hardware/smart-card-developer-
kit/ch03/www.opengroup.org 
6) http:/ /www.interesting-devices.com/smart.htm 
Un
ive
rsi
ty 
of 
Ma
lay
a
