0

AC23  Microprocessor Based System Design
1
TYPICAL QUESTIONS & ANSWERS
PART – I
OBJECTIVE TYPE QUESTIONS
Each Question carries 2 marks.
Choose the correct or best alternative in the following:
Q.1   If the crystal oscillator is operating at 15 MHz, the PCLK output of 8284 is
(A)  2.5 MHz.  (B)5 MHz.
(C)7.5 MHz.  (D)10 MHz.
  Ans:(A)
Q.2  In which T-state does the CPU sends the address t o memory or I/O and the ALE signal
for demultiplexing
(A)  T1.  (B) T2.
(C)  T3.  (D)T4.
Ans, During the first clocking period in a bus cycle, which is called T1, the address of
the memory or I/O location is sent out and the control signals ALE, DT/R’ and IO/M’
are also output. Hence answer is (A).
Q.3  If a  1 M 1 × DRAM requires 4 ms for a refresh and has 256 rows  to be refreshed, no
more than __________ of time must pass before another row is refreshed.  
(A)  64 ms.  (B)4 ns.
(C)0.5 ns.  (D)15.625  s µ .
AnsAnswer is (B)
Q.4   In a DMA write operation the data is transferred
(A)  from I/O to memory.  (B)  from memory to I/O.
(C)from memory to memory.  (D) from I/O to I/O.
AnsA DMA writes operation transfers data from an I/O device to memory. Hence
answer is (A).
Q.5  Which type of JMP instruction assembles if the di stance is 0020 h bytes
(A)  near. (B) far.
(C)  short.  (D)  none of the above.
AnsThe three byte near jump allows a branch or jump within ± 32K bytes. Hence
answer is (A).
Q.6   A  certain  SRAM  has  0 CS = ,  0 WE =  and  1 OE = .   In  which  of  the  following
modes this SRAM is operating
(A)Read  (B) Write
AC23  Microprocessor Based System Design
2
(C)  Stand by  (D)  None of the above
AnsFor CS’=WE’=0, write operation. Hence answer is (B).
Q.7  Which of the following is true with respect to EEPROM?  
(A)  contents can be erased byte wise only.
(B)  contents of full memory can be erased together.
(C)  contents can be erased using ultra violet rays
(D)  contents can not be erased
AnsAnswer is (C).
Q.8  Pseudo instructions are basically
(A)  false instructions.
(B)  instructions that are ignored by the microprocessor.
(C)assembler directives.
(D)instructions that are treated like comments.
Ans Pseudo-instructions  are  commands  to  the  assembler. All  pseudo-operations  start
with a period. Pseudo-instructions are composed of  a pseudo-operation which may be
followed by one or more expressions. Hence answer is (C).
Q.9  Number  of  the  times  the  instruction  sequence  below  will  loop  before  coming  out  of
loop is
   MOV AL, 00h
   A1: INC AL
  JNZ A1
(A)  00  (B)  01
(C)  255  (D)256
AnsAnswer is (D)
Q.10 What will be the contents of register AL after the following has been executed
   MOV BL, 8C
   MOV AL, 7E
   ADD AL, BL
(A)  0A and carry flag is set  (B)0A and carry flag is reset
(C)6A and carry flag is set  (D)6A and carry flag is reset
  Ans, Result is 1,0A. Hence answer is (A).
Q.11 Direction flag is used with
(A)  String instructions.  (B)Stack instructions.
(C)Arithmetic instructions.  (D)Branch instructions.
  AnsThe direction flag is used only with the string instructions. Hence answer is (A).
Q.12 Ready pin of a microprocessor is used
(A)  to indicate that the microprocessor is ready to receive inputs.
(B)  to indicate that the microprocessor is ready to receive outputs.
(C)  to introduce wait states.
AC23  Microprocessor Based System Design
3
(D)  to provide direct memory access.
AnsThis input is controlled to insert wait states into the timing of the microprocessor.
Hence answer is (C).
Q.13 These are two ways in which a microprocessor can come out of Halt state.
(A)   When hold line is a logical 1.
(B)  When interrupt occurs and the interrupt system hasbeen enabled.
(C) When both (A)and (B)are true.
(D) When either (A) or (B) are true.
  AnsAnswer is (A)
Q.14 In the instruction FADD, F stands for
(A)  Far.  (B)Floppy.
(C)Floating.  (D) File.
  AnsAdds two floating point numbers. Hence answer is (C).
Q.15 SD RAM refers to
(A)  Synchronous DRAM  (B) Static DRAM
(C)Semi DRAM  (D) Second DRAM
Ans, Answer is (A)
Q.16 In case of DVD, the speed is referred in terms ofn X (for example 32 X). Here, X
refers to  
(A)  150 KB/s  (B)  300 KB/s
(C)  1.38 MB/s  (D)2.4 MB/s
 AnsAnswer is (C).
Q.17 Itanium processor of Intel is a
(A)  32 bit microprocessor.  (B)64 bit microprocessor.
(C)128 bit microprocessor.  (D)256 bit microprocessor.
  AnsThe Itanium is a 64-bit architecture microprocessor. Hence answer is (B).
Q.18   LOCK prefix is used most often
(A)  during normal execution.  (B) during DMA accesses
  (C)  during interrupt servicing.  (D) during memory accesses.
AnsLOCK is a prefix which is used to make an instruction of 8086 non-interruptable.
Hence answer is (C).
Q.19 The Pentium microprocessor has______execution units.
(A)  1 (B) 2
  (C) 3  (D) 4
AnsThe Pentium microprocessor is organized with threeexecution units. One
executes floating-point instructions, and the othertwo (U-pipe and V-pipe) execute
AC23  Microprocessor Based System Design
4
integer instructions. Hence answer is (C).
Q.20   EPROM is generally erased by using
(A) Ultraviolet rays  (B)infrared rays
(C)12 V electrical pulse  (D) 24 V electrical pulse
AnsThe EPROM is erasable if exposed to high-intensityultraviolet light for about 20
minutes or less. Hence answer is (A)
Q.21Signal voltage ranges for a logic high and for alogic low in RS-232C standard are
(A)Low = 0 volt to 1.8 volt, high = 2.0 volt to 5 volt
(B) Low =-15 volt to –3 vol, high = +3 volt to +15 volt
(D)  Low = +3 volt to +15 volt, high = -3 volt to -15 volt
(E)  Low = 2 volt to 5.0 volt, high = 0 volt to 1.8 volt
AnsAnswer is (B)
Q.22 The PCI bus is the important bus found in all the new Pentium systems because
(A)  It has plug and play characteristics
(B)  It has ability to function with a 64 bit data bus
(C)  Any Microprocessor can be interfaced to it with PCIcontroller or bridge
(D)  All of the above
  Ans, Answer is (D).
Q.23 Which of the following statement is true?  
(A)  The group of machine cycle is called a state.
(B)  A machine cycle consists of one or more instructioncycle.
(C)  An instruction cycle is made up of machine cycles and a machine cycle is
made up of number of states.
(D)  None of the above
  AnsAn instruction cycle consists of several machine cycles. Hence Answer is (B).
Q.24 8251 is a
(A)   UART
(B)  USART
(C)  Programmable Interrupt controller
(D)  Programmable interval timer/counter
  AnsThe Intel 8251 is a programmable communication interface. It is USART.
Q.25   8088 microprocessor has
(A) 16 bit data bus  (B)4 byte pre-fetch queue
  (C)  6 byte pre-fetch queue  (D) 16 bit address bus
AnsThe 8088 is a 16-bit microprocessor with an 8-bit data bus. The 16-bit address
bus. Hence answer is (D).
AC23  Microprocessor Based System Design
5
Q.26By what factor does the 8284A clock generator divide the crystal oscillator’s output
frequency?
(A)One  (B)Two
(C)Three  (D)Four
AnsWhen F/C’ is at logic 0; The oscillator output is steered through to the divideby-3 counter. Hence answer is (c).
Q.27The memory data bus width in Pentium is
(A)16 bit  (B) 32 bit
(C)64 bit  (D)None of these
AnsThe Data bus width is 64 bits. Hence answer is (C).
Q.28 When the 82C55 is reset, its I/O ports are all initializes as
(A)output port using mode 0  (B)Input port using mode 1
(C)output port using mode 1  (D)Input port using mode 0
AnsA RESET input to the 82C55 causes all ports to be set up as simple input ports
using mode 0 operations. Hence answer is (D).
Q.29 Which microprocessor pins are used to request andacknowledge a DMA transfer?
(A)reset and ready  (B) ready and wait
(C)HOLD and HLDA  (D)None o these
Ans, The HOLD pin is an input that is used request a DMA action and the HLDA
pin is an output that that acknowledges the DMA action. Hence answer is (C).
Q.30Which of the following statement is false?
(A) RTOS performs tasks in predictable amount of time
(B) Windows 98 is RTOS
(C) Interrupts are used to develop RTOS
(D)Kernel is the one of component of any OS
AnsOperating systems, like Windows, defer many tasks and do not guarantee their
execution in predictable time. Hence answer is (B).
Q.31 The VESA local bus operates at
(A)8 MHz  (B) 33 MHz
(C)16 MHz  (D)None of these
AnsThe VESA local bus operates at 33 MHz. Hence answer is (B).
Q.32The first modern computer was called_____________.
(A)FLOW-MATIC  (B) UNIVAC-I
(C)ENIAC  (D)INTEL
Ans, ENIAC (Electronic Numerical Integrator And Computer) was the first generalpurpose electronic computer. It was a Turing-complete, digital computer capable of
being  reprogrammed  to  solve  a  full  range  of  computing  problems.  ENIAC  was
AC23  Microprocessor Based System Design
6
designed  to  calculate  artillery  firing  tables  for  the  U.S.  Army’s  Ballistic  Research
Laboratory. Hence answer is (c).
Q.33Software command CLEAR MASK REGISTER in DMA
(A)Disables all channels.
(B) Enables all channels.
(C)None.
(D)Clears first/last flip-flop within 8237.
  AnsEnables all four DMA channels. Hence answer is (B).
Q.34The first task of DOS operating system after loading into the memory is to use the file
called___________.
(A)HIMEM.SYS  (B) CONFIG.SYS
(C)AUTOEXEC.BAT  (D)SYSTEM.INI
Ans, The first task of the DOS operating system, afterloading into memory, is to
use a file called the CONFIG.SYS file. This file specifies various drivers that load
into the memory, setting up or configuring the machine for operation under DOS.
Q.35   If the programmable counter timer 8254 is set in mode 1 and is to be used to count
six events, the output will remain at logic 0 for _____ number of counts
(A)5  (B)6
(C)0  (D)All of the above
  Ans. OUT continues for the total length of the count. Hence answer is (B).
Q.36 The flash memory is programmed in the system by 12 V programming pulse.
(A)TRUE  (B)FALSE
  AnsThe flash memory device requires a 12V programmingvoltage to erase and write
new data. Hence answer is (A).
Q.37A plug and play (PnP) interface is one that contains a memory that holds
configuration information of the system.
(A)TRUE  (B)FALSE
 AnsAnswer is (A)
Q.38 The accelerated graphics port (AGP) allows virtually any microprocessor to be
interfaced with PCI bus via the use of bridge interface.
(A)  TRUE  (B)FALSE
  Ans, this port probably will never be used for any devices other than the video card.
Hence answer is (B).
Q.39  A Bus cycle is equal to how many clocking periods
(A) Two   (B) Three
(C) Four   (D) Six
AC23  Microprocessor Based System Design
7
Ans Typically,  the  bus-cycle  of  the  8086  and  8088  processors  consist  of  four  clock
cycles or pulses. Thus, duration of a bus-cycle is = ‘4*T’. Hence Answer is (C).
Q.40  The time required to refresh a typical DRAM is
(A) 2 – 4 us   (B) 2 – 4 ns
(C) 2 – 4 ms   (D) 2 – 4 ps
AnsThe capacitor Cs discharges through the internal resistance of the NMOS transistor
T1. Typically Cs = 0.2 pF and the internal resistance Rin = 10
10
ohms, so:
Cs x Rin = 0.2 x 10
-12
x 10
10
x 10
3
ms = 2 ms
So the typical refresh time interval is 2 ms. HenceAnswer is (C).
Q.41  The no. of address lines required to address a memory of size 32 K is
(A) 15 lines   (B) 16 lines
(C) 18 lines   (D) 14 lines
Ans32K = 32 X 1024 bits = 2
5
X 2
10
= 2
15
Hence answer is ( A).
Q.42  The no. of wait states required to interface 8279 to 8086 with 8MHz clock are
(A) Two   (B) Three
(C) One   (D) None
AnsTwo wait states used so that device can function with an 8 MHz. Hence answers is
( A).
Q.43  NMI input is
(A) Edge sensitive    (B) Level sensitive
(C) Both edge and level triggered  (D) edge triggered and level sensitive
AnsNon-maskable interrupt (NMI) is an edge –triggeredinput that requests an
interrupt on the positive edge (0 to 1 transition).
Q.44Data rate available for use on USB is
(A)12 Mbits per second  (B)1.5 Mbits per second
   (C)  Both (A)and (B)  (D)No restriction
  AnsData transfer speeds are 12 Mbps for full speed operation and 1.5 Mbps for slow
speed operation. Hence answer is (c).
Q.45 In 80186, the timer which connects to the system clock is
(A)  timer 0  (B)timer 1
   (C)  timer 2  (D)Any one can be connected
Ans.Timer 2 is internal and clocked by the master clock. Hence answer is (c).
Q.46  Conversion of the +1000 decimal number into signed binary word results
(A) 0000 0011 1110 1000   (B) 1111 1100 0001 1000
(C) 1000 0011 1110 1000   (D) 0111 1100 0001 1000
AC23  Microprocessor Based System Design
8
Ans
1000 /2 =>500 0
  500/2=>250 0
  250/2=>125 0
  125/2=>62 1
  62/2=>31 0
  31/2=>15 1
  15/2=>7 1
  7/2=>3 1
  3/2=>1 1
  16 bit signed number is 1000,0011,1110,1000
  Hence Answer is (C).
Q.47  What do the symbols [ ] indicate?
(A) Direct addressing  (B) Register Addressing
(C) Indirect addressing  (D) None of the above
AnsAnswer is (C).
Q.48  SDRAM refers to
(A) static DRAM   (B) synchronous DRAM
(C) sequential DRAM  (D) semi DRAM
Ans, Answer is (B)
Q.49  Which pins are general purpose I/O pins during mode-2 operation of the 82C55?
(A) PA0 – PA7   (B) PB0-PB7
(C) PC3-PC7    (D) PC0-PC2
AnsIn mode 2 Port-A can be programmed to operate as bidirectional port. The mode-2
operation is only for Port-A. Hence Answer is (A)
AC23  Microprocessor Based System Design
9
PART – II
DESCRIPTIVES
Q.1  Describe the operation performed by the instruction OUT 47 h, AL.  (3)
Ans  :  It  transfers  the  content  of  AL  to  I/O  port  47h.  Notice  that  I/O  port  number
appears as 0047h on the 16 bit address bus and thatdata from AL appears on the data
bus of the microprocessor.
Q.2   How is 8255 (Programmable Peripheral Interface) configured if its control register
contains 9B h.   (3)
Ans
AC23  Microprocessor Based System Design
10
   9BH => 1001 1011 =>
   b6b5=00-> Mode0
   b4=0-> Port A as input.
   b3=1-> Port C as input (PC7-PC4)
   b2=0-> Mode 0
   b1=1-> Port B as input
   b0=1-> Port C as input (PC3-PC0).
Q.3 Write a control word for counter 1 of 8253 / 8254that selects the following options:
load least significant byte only, mode 5 of operation and binary counting. Then write
an instruction sequence that will load the control word into 8253 / 8254 that is located
at address 01000 h of memory address space. Assumethat 8253 / 8254 is attached to
the I/O bus of the CPU and the address inputs
0
A and
1
A are supplied by
2
A and
3
A
respectively.   (5)
 Ans
AC23  Microprocessor Based System Design
11
  Based on the above given conditions and assuming  counter 0 is used. The control
word becomes 0001 1010h.
  Identify the port address
  – The CS is enabled when A7=1
  – The Control Register is selected when A1 and A0 =1
  – Assuming unused address lines A6 to A2 are at logic 0,
  Then port address will be as follows
   Control Register = 83H
   Counter 2 = 82H
   MVI A,B0H
   OUT 83H
   MVI A, LOWBYTE
   OUT 82H
   MVI A,HIGHBYTE
   OUT 82H
  LOOP:MVI A,80H
   OUT 83H
   IN 82H
   MOV D,A
   IN 82H
   ORA D
   JNZ LOOP
   RET
 Q.4 ‘Pentium  processor  has  a  superscalar  architecture’.   Explain  the  meaning  of  the
statement.   (4)
Ans
The Pentium microprocessor is organized with three  execution units. One executes
floating-point  instructions,  and  the  other  two  (U-pipe  and  V-pipe)  execute  integer
instructions.  This  means  that  it  is  possible  to  execute  three  instructions
simultaneously.
Q.5 Write a short note on RS-232-C.   (8)
  Ans
 The RS-232 standard is a collection of connectionstandards between different pieces
of  equipment.  The  EIA  RS-232  serial  communication  standard  is  a  universal
standard,  originally  used  to  connect  teletype  terminals  to  modem  devices.  In  a
modern PC the RS-232 interface is referred to as a COM port. The COM port uses a
9-pin D-type connector (Refer Fig (a)) to attach to the RS-232 cable. The RS-232
standard  defines a  25-pin  D-type  connector (Refer Fig   (b))  but  IBM reduced  this
connector to a 9-pin device so as to reduce cost and size.
AC23  Microprocessor Based System Design
12
Fig (a) Female & Male “DB-9” Connector
  Fig 1(b) Female & Male “DB-25” Connector
Q.6 Explain the terms: simplex, half duplex and full duplex.  (6)
Ans
Simplex Transmission
Data in a simplex channel is always one way. Simplex channels are not often used
because it is not possible to send back error or control signals to the transmit end.
An example of a simplex channel in a computer system is the interface between the
keyboard and the computer, in that key codes need only be sent one way from the
keyboard to the computer system.
Half Duplex Transmission
A half duplex channel can send and receive, but notat the same time. It’s like a onelane bridge where two-way traffic must give way in order to cross. Only one end
transmits at a time, the other end receives.
Full Duplex Transmission
Data can travel in both directions simultaneously. There is no need to switch from
transmit to receive mode like in half duplex. It’s like a two lane bridge on a twolane highway.
 Q.7 How  DRAM’s  are  different  from  SRAM’s?   Why  DRAMs  are  said  to  employ
address multiplexing?   (4)
Ans
   Dynamic RAM (DRAM) is essentially the same as SRAM, except that it retains
data for only 2 or 4 ms on an internal capacitor. After 2 or 4 ms, the contents of the
DRAM  must  be  completely  rewritten  (refreshed)  because  the  capacitors,  which
store  logic  1  or  logic  0,  lose  their  charges.  The  entire  content  of  the  memory  is
refreshed with 256 reads in a 2-to-4 ms interval. Refreshing also occurs during a
write, a read or during a special refresh cycle.
AC23  Microprocessor Based System Design
13
Q.8Explain the operation of 8279. Explain thefollowing terms:
(i)  N key Roll over.
(ii)  Key board debounce.
(iii)  FIFO RAM.  (9)
Ans
   The 8279 is a programmable keyboard and display  interfacing component that
scans  and  encodes  up  to  a  64-key  keyboard  and  controls  up  to  a  16-digit
numerical display. The keyboard interface has builtin first-in first-out (FIFO)
buffer that allows it store up to eight keystrokes before the microprocessor must
retrieve a character. The display section controls up to 16 numeric displays from
an internal 16 X 8 RAM that stores the coded display information.
   The  keyboard  section  consists  of  eight  lines  that  can  be  connected  to  eight
columns  of  a  keyboard,  plus  two  additional  lines  as well  as  to  shift  and
CNTL/STB  keys.  The  key  pressed  are  automatically  debounced  and  the
keyboard can operate in two modes two –key lock outor n-key rollover. If two
keys in the two –key lock out mode are pressed simultaneously, only first key is
recognized. In the N-key roll over mode, simultaneous key are recognized and
their codes are stored in the internal buffer.
Q.9    What are the differences between CGA and VGA graphics adapters?  (4)
Ans
   The  Color  Graphics  Adapter  (CGA),  originally also called the  Color/Graphics
Adapter  or  IBM  Color/Graphics  Monitor  Adapter  introduced  in  1981,  was
IBM’s first color graphics card, and the first color computer display standard for
the IBM PC.
   The standard IBM CGA graphics card was equipped  with 16 kilobytes of video
memory, and could be connected either to a NTSC-compatible monitor or TV
via an RCA jack, or to a dedicated 4-bit “RBGI” interface CRT monitor, such as
the IBM 5153 color display.
   The  term  Video  Graphics  Array  (VGA)  refers  specifically  to  the  display
hardware  first  introduced  with  the  IBM  PS/2  line  of computers  in  1987,  but
through  its  widespread  adoption  has  also  come  to  mean  either  an  analog
computer  display  standard,  the  15-pin  D-subminiature  VGA  connector  or  the
640×480  resolution  itself.  While  this  resolution  has been  superseded  in  the
personal  computer  market,  it  is  becoming  a  popular  resolution  on  mobile
devices.
   VGA  was  officially  superseded  by  IBM’s  XGA  standard,  but  in  reality  it was
superseded  by  numerous  slightly  different  extensions  to  VGA  made  by  clone
manufacturers that came to be known collectively as”Super VGA”.
Q.10  What do you mean by A/D conversion? Explain anyone of the following A/D
techniques:
(i)  Successive approximation.
(ii)  Parallel / flash converter.
(5)
Ans
The electronic circuit, which translates an analogsignal into a digital signal, is
known as Analog – to – Digital converter (ADC).
AC23  Microprocessor Based System Design
14
(i)  Successive approximation ADC
   One method of addressing the digital ramp ADC’s  shortcomings is the so-called
successive approximation ADC. The only change in this design is a very special
counter  circuit  known  as  a  successive-approximation register.  Instead  of
counting up in binary sequence, this register counts by trying all values of bits
starting  with  the  most  significant  bit  and  finishing  at  the  least-significant  bit.
Throughout the count process, the register monitorsthe comparator’s output to
see  if  the  binary  count  is  less  than  or  greater  than  the  analog  signal  input,
adjusting the bit values accordingly. The way the register counts is identical to
the  “trial-and-fit”  method  of  decimal-to-binary  conversion,  whereby  different
values of bits are tried from MSB to LSB to get a binary number that equals the
original decimal number. The advantage to this counting strategy is much faster
results:  the  DAC  output  converges  on  the  analog  signal  input  in  much  larger
steps than with the 0-to-full count sequence of a regular counter.
   Without  showing  the  inner  workings  of  the  successive-approximation  register
(SAR), the circuit looks like this:
   Fig: Successive Approximation ADC Circuit
AC23  Microprocessor Based System Design
15
   It  should  be  noted  that  the  SAR  is  generally  capable  of  outputting  the  binary
number in serial (one bit at a time) format, thus eliminating the need for a shift
register.  Plotted  over  time,  the  operation  of  a  successive-approximation  ADC
looks like this:
Fig: Successive Approximation ADC Circuit Input andoutput Waveforms
ii.  Parallel / flash converter.
   Also called the parallel A/D converter, this circuit is the simplest to understand.
It is formed of a series of comparators, each one comparing the input signal to a
unique  reference  voltage.  The  comparator  outputs  connect  to  the  inputs  of  a
priority  encoder  circuit,  which  then  produces  a  binary  output.  The  following
illustration shows a 3-bit flash ADC circuit:
AC23  Microprocessor Based System Design
16
Fig: FLASH ADC Circuit
   Vref is a stable reference voltage provided by aprecision voltage regulator as
part  of  the converter  circuit, not  shown  in the  schematic.  As the analog  input
voltage  exceeds  the  reference  voltage  at  each  comparator,  the  comparator
outputs will sequentially saturate to a high state.The priority encoder generates
a  binary  number  based  on  the  highest-order  active  input,  ignoring  all  other
active inputs.
Q.11  What do you mean by external and internal data bus? How are these two related
in 8088 processor.   (2)
AnsInternal Data Bus: A bus that operates only withinthe internal circuitry of
the CPU, communicating among the internal caches ofmemory that are part of
the CPU chip’s design. This bus is typically ratherquick and is independent of
the rest of the computer’s operations.
   External Data Bus: A bus that connects a computer to peripheral devices. The
8088  microprocessor  has  16-bit  registers,  16-bit  internal  data  bus  and  20-bit
address bus, which allows the processor address up to 1 MB of memory.
AC23  Microprocessor Based System Design
17
Q.12  What is the difference between XT and AT computer system?  (2)
Ans
   XT ->extended and AT->Advanced Technology
   Some  differences  between  the  PC  and  XT  include  the  type  of  power  supply
originally  included–63  vs  135  watts;  the  number  and  spacing  of  expansion
slots–5 vs 8; the PC has a cassette tape interfaceconnector on the back.
Q.13  What are program-invisible registers?  (2)
Ansthe global and local descriptor tables are found in the memory system. In
order  to  access  and  specify  the  address  of  these  tables,  the  program  invisible
registers  used.  The  program  invisible  registers  are not  directly  addressed  by
software so they are given name.
   The  GDTR  (global  descriptor  table  register)  and  IDTR  (interrupt  descriptor
table  register)  contain  the  base  addresses  of  the  descriptor  table  and  its  limit.
The limit of each descriptor table is 16 bits because the maximum table length is
64  Kbytes.  When  the  protected  mode  operation  is  desired,  the  address  of  the
global descriptor table and its limit are loaded into the GDTR.
Q.14   The interrupt vector table is always created in thefirst 1K area of the memory.
Justify the statement.   (2)
AnsWhen the CPU receives an interrupt type number from the PIC, it uses this
number to look up the corresponding interrupt vector in memory. There are 256
interrupt types. Each interrupt vector occupies 4 bytes. Therefore, a total of 4 x
256 = 1K bytes of memory is reserved at the beginning of the processor memory
address space for storing interrupt vectors.
Q.15  What is the purpose of carry (c) flag and zero (z) flag?  (2)
   AnsCarry flag holds the carry after addition or the borrow after subtraction. The
carry  flag  also  indicates  error  conditions,  as  dictated  by  some  programs  and
procedures.
   The Zero flag shows that the result of an arithmetic or logical operation is zero.
If Z=1, the result is zero; if Z=0, the result is notzero.
Q.16  What is 16-bit ISA? Compare it with 8-bit ISA bus.  (6)
AnsThe only difference between the 8 and 16-bit ISA bus is that an additional
connector is attached behind the 8-bit connector. 16-bit ISA card contains two
edge connectors. One plugs into the original 8-bit connector and other plugs into
the  16-bit  connector.  The  added  features  that  are  most  often  used  are  the
additional  interrupt  request  inputs  and  DMA  request signals.  Interfaces  found
for the ISA bus are modems and sound cards.
Q.17  Compare memory mapped I/O with I/O mapped I/O.  (4)
Ans Memory  Mapped  I/O  Scheme:  In  this  scheme  there  is  only  one  address
space.  Address  space  is  defined  as  all  possible  addresses  that  microprocessor
AC23  Microprocessor Based System Design
18
can generate. Some addresses are assigned to memories and some addresses to
I/O devices. An I/O device is also treated as a memory location and one address
is  assigned  to  it.  In  this  scheme  all  the  data  transfer  instructions  of  the
microprocessor can be used for both memory as well as I/O device. This scheme
is suitable for a small system.
In I/O mapped I/O scheme the addresses assigned to  memory locations can also
be  assigned  to  I/O  devices.  Since  the  same  address  may  be  assigned  to  a
memory  location  or  an  I/O  device,  the  microprocessor  must  issue  a  signal  to
distinguish whether the address on the address bus  is for a memory location or
an I/O device.
Q.18  Explain in brief the functions of the clock gener ator chip, 8284.  (4)
Ans, 8284 Clock generator:
The  8284  is  an  ancillary  component  to  the  microprocessors.  Without  clock
generator,  many  additional  circuits  are  required  to generate  the  clock  in  an
microprocessor based system. A 8284 provides the following basic functions or
signals:  Clock  generation,  RESET  synchronization,  READY  synchronization,
and a TTL-level peripheral clock signal.
Q.19  Write a brief note on MMX technology.  (4)
   Ans, MMX (Multimedia extensions) technology adds 57 new instructions to the
instruction set of the Pentium – 4 microprocessors.The MMX technology also
introduces  new  general  purpose  instructions.  The  new  MMX  instructions  are
designed for application such as motion video, combined graphics with video,
image  processing,  audio  synthesis,  speech  synthesis and  compression,
telephony,  video  conferencing,  2D  graphics,  and  3D  graphics.  These  new
instructions  operate  in  parallel  with  other  operations  as  the  instruction for  the
arithmetic coprocessor.
   The  MMX  architecture  introduces  new  packed  data  types.  The  data  types  are
eight  packed,  consecutive  8-bit  bytes;  four  packed, consecutive  16-bit  words;
and two packed, consecutive 32-bit double words.
Q.20  What are the different modes in which 8255 Programmable Peripheral Interface
(PPI)  can  operate?   Write  the  8086  initialisation  routine  required  to  program
8255 for mode 1 with Port A and Port B as output Ports and Port C as an input
port. Indicate all the relevant signals.  (6)
 Ans
•  24 I/O lines in 3 8-bit port groups – A, B, C
•  A, B can be 8-bit input or output ports
•  C can serve as 2 4-bit input or output ports
•  3 modes of operation:
–  Mode 0:A, B, C simple input or output level sensitive ports
–  Mode 1:A, B input or output ports with strobe control in C
–  Mode 2:A is bidirectional with control/handshake inB and C
•  A, B can only change 1 byte at a time
•  C has individual bit set/reset capability
•  Advantage  is  non-dedicated  circuit  can  change  port  configuration  with
software and no “glue logic”
AC23  Microprocessor Based System Design
19
•  Ports A, B, and C are used for I/O data.
•  The control register is programmed to select the operation mode of the three
ports A, B, and C.
•  Mode 0 : simple I/O mode
•  Any of the ports A, B, CL and CU can be programmed as input or output.
•  No control of individual bits (all bits are out or all bits are in)
  Mode0:
  Mode1:
AC23  Microprocessor Based System Design
20
   Mode2:
Q.21   Explain the operation of IRET instruction. What memory locations contain the
vector for an INT 34 instruction?  (4)
Ans
 The Interrupt return (IRET) instruction is used only with software or hardware
interrupt service procedures. Whenever an IRET instruction executes, it stores
the contents of I and T from the stack. This is important because it preserves the
state  of  the  flag  bits.  If  interrupts  were  enabled  before  an  interrupt  service
procedure,  they  automatically  re-enabled  by  the  IRET  instruction  because  it
restores the flag register.
 Interrupt Number 20-FF are stored at an address 80 – 3FFH.
Q.22   Explain the following terms:
i.  Branch prediction logic.
ii.  Paging.
iii.  Assembler.
iv.  Microprocessor development system.  (8)
Ans
(i)  Branch  prediction  logic  in  Pentium:  The  Pentium  microprocessor  uses
branch  prediction  logic  to  reduce  the  time  required for  a  branch  caused  by
internal delays. These delays are minimized becausewhen a branch instruction is
encountered,  the  microprocessor  begins  pre-fetch  instruction  at  the  branch
address.  The  instructions  are  loaded  into  the  instruction  cache,  so  when  the
branch occurs, the instructions are present and allow the branch to execute in one
clocking period. If for any reason the branch prediction logic errors, the branch
requires  an  extra  three  clocking  periods  to  execute.  In  most  cases,  the  branch
prediction is correct and no delay ensues.
AC23  Microprocessor Based System Design
21
(ii) Paging  Unit: The  paging  mechanism  functions  with  4K  –  byte  memory
pages or with a new extension available to the Pentium with 4M byte-memory
pages.  In  the  Pentium,  with  the  new  4M-byte  paging  feature  memory  for  the
page-table reduced to single page table.
(iii)  Assembler:An assembler or macro-assembler generally forms a part of the
operating system. Which translates a assembly language program into machine
language program.
(iv)  Microprocessor development system:Computer systems have undergone
many changes recently. Machines that once filled large areas have been reduced
to  small  desktop  computer  systems  because  of  the  microprocessor.  Although
these  desktop  computers  are  compact,  they  possess  computing  power  that  was
only dreamed of a few years ago.
The blocks of the microprocessor based system are
1.  The Memory and I/O System
2.  The DOS Operating System
3.  The Microprocessor
Q.23  Explain the following instructions:
(i) TEST (ii) NEG (iii) CMP (iv) DAA.  (8)
 Ans
(i)  TEST: The TEST instruction performs the AND operation. The difference is
that  the  AND  instruction  changes  the  destination  operand,  while  the  TEST
instruction  does  not.  A  TEST  only  affects  the  condition  of  the  flag  register,
which indicates the result of the test.
(ii) NEG:  Arithmetic  sign  inversion  or  two’s  complement  (NEG).  The  NEG
instruction two’s complements a number, which meansthat the arithmetic sign of
a signed number changes from positive to negative or from negative to positive.
(iii)CMP: The comparison instruction (CMP) is a subtraction that changes only
the flag bits; the destination operand never changes. A comparison is useful for
checking the entire contents of a register or a memory location against another
value.  A  CMP  is  normally  followed  by  a  conditional  jump  instruction,  which
tests the condition of the flag bits
(iv)  DAA: The DAA instruction follows the ADD or ADC instruction to adjust
the result into a BCD result. The DAA instruction functions only with the AL
register, this addition must occur eight bits at a time.
Q.24  With respect to serial communication define the following:
   (i) baud rate.  (ii) asynchronous communication.
   (iii) parity.  (iv) half duplex.  (4)
AC23  Microprocessor Based System Design
22
Ans
   Half Duplex Transmission: A half duplex channel  can send and receive, but not
at the  same  time.  It’s  like  a  one-lane  bridge  where two-way traffic  must  give
way in order to cross. Only one end transmits at a time, the other end receives.
   Asynchronous  means “no  synchronization”,  and thus  does  not  require sending
and receiving idle characters. However, the beginning and end of each byte of
data must be identified by start and stop bits. Thestart bit indicates when the
data  byte  is  about  to  begin  and  the  stop  bit  signals  when  it  ends.  The
requirement  to  send  these  additional  two  bits  causes  asynchronous
communication  to  be  slightly  slower  than  synchronous  however  it  has  the
advantage  that  the  processor  does  not  have  to  deal  with  the  additional  idle
characters.
   The rate of data transfer in serial data communication is denoted in bps. Bits per
second (bps) is the rate of transfer of informationbits. Baud is the number of
signal level changes per second in a line, regardless of the information content
of those signals. The baud and bps rates are not necessarily equal. The ratio of
BPS to baud depends on the information-coding scheme that you are using. For
example,  each  character  in  asynchronous  RS-232  coding  includes  a  start  and
stop bit that are not counted as information bits,  so the BPS rate is actually less
than the baud rate.
   Besides  the  synchronization  provided  by  the  use  of  start  and  stop  bits,  an
additional  bit  called  a  parity  bit  may  optionally be  transmitted  along  with  the
data.  Figure  shows  the  inclusion  of  an  additional  parity  bit  for  error  control
purposes. A parity bit affords a small amount of error checking, to help detect
data  corruption  that  might  occur  during  transmission.  You  can  choose  even
parity, odd parity, mark parity, space parity or none at all. When even or odd
parity is being used, the numbers of marks (logical1 bit) in each data byte are
counted,  and  a  single  bit  is  transmitted  following  the  data  bits  to  indicate
whether the number of 1 bit just sent is even or odd.
Fig. Framed data including a parity bit
For  example,  when  even  parity  is  chosen,  the  parity bit  is  transmitted  with  a
value of 0 if the number of preceding marks is an even number. For the binary
value of 0110 0011 the parity bit would be 0. If even parity were in effect and
the binary number 1101 0110 were sent, then the parity bit would be 1.
Q.25  What  is  the  importance  of  RS232-C  in  serial  communication?   Name  some
application where you see its use.   (4)
‘B’
D7 D6 D5 D4 D3 D2 D1 D0
‘C’ ‘A’
Stop
bit
Start
bit
Character frame,11 bits in total
Parity
bit
P
AC23  Microprocessor Based System Design
23
Ans RS-232  stands  for  Recommend  Standard  number  232  and  C  is  the  latest
revision of the standard. The serial ports on most  computers use a subset of the
RS-232C standard. The full RS-232C standard specifies a 25-pin “D” connector
of  which  22  pins  are  used.  Most  of  these  pins  are  not  needed  for  normal  PC
communications,  and  indeed,  most  new  PCs  are  equipped  with  male  D  type
connectors having only 9 pins. In the world of serial communications, there are
two different kinds of equipment:
•  DTE – Data Terminal Equipment
•  DCE – Data Communications Equipment
Q.26  Write short notes on (Any FOUR):-
(i)  8259.
(ii)  Real time clock.
(iii)  Real and protected mode.
(iv)  Super scalar architecture.
(v)  Comparison between Motorola processors and INTEL processors.
(4 x 4 = 16)
Ans
(i)  8259:
The 8259A adds 8 vectored priority encoded interrupts to the microprocessor. It can
be expanded to 64 interrupt requests by using one master 8259A and 8 slave units.
CS and WR must be decoded. Other connections are direct to microprocessor.
The pins D7 – D0: the bidirectional data connection, IR7 – IR0: Interrupt request,
used to request an interrupt & connect to a slave in a system with multiple 8259A.
WR :-Connects to a write strobe signal (lower or upper in a 16 bit system) , RD :-
Connects  to  the  IORC  signal  ,   INT  :-  Connects  to  the  INTR  pin  on  the
microprocessor from the master and is connected to a IR pin on a slave and INTA
:-  Connects  to  the  INTA  pin  on  the  microprocessor.  In  a  system  only  the  master
INTA signal is connected
A0  :-  Selects  different  command  words  with  in  the  8259A,   CS  :-  Chip  select  –
enables the 8259A for programming and control, SP/EN :- Slave Program (1 for
master,  0  for  slave)/Enable  Buffer  (controls  the  data  bus  transceivers  in  a  large
microprocessor based system when in buffered mode) and CAS2-CAS0 :- Used as
outputs from the master to the slaves in cascaded systems.
Fig : 8259 Block Diagram
AC23  Microprocessor Based System Design
24
(ii)  Real time clock:
A real-time clock keeps the time in real time – that is, in hours and minutes. The
software for the real-time clock contains an interrupt service procedure that is
called 60 times per second and a procedure that updates the count located in four
memory locations.
Assembler directives:
An  assembler  directive  is  a  statement  to  give  direction  to  the  assembler  to
perform  the  task  of  assembly  process.  The  assembler directives  control
organization of the program and provide necessary information to the assembler
to  understand  assembly  language  programs  to  generate  machine  codes.  They
indicate  how  an  operand  or  section  of  a  program  is  to  be  processed  by  the
assembler.  An  assembler  supports  directives  to  define  data,  to  organize
segments to control procedures, to define macros etc.
(iii)  Real and protected mode:
   Operation  of  Real  mode  interrupt:  When  the  microprocessor  completes
executing the current instruction, it determines whether an interrupt is active by
checking (1) instruction execution, (2) single –step, (3) NMI, (4) co-processor
segment  overrun,  (5)  INTR,  and  (6)  INT  instruction  in  the  order  presented.  If
one or more of these interrupt conditions are present, the following sequence of
events occurs:
1.  The contents of the flag register are pushed onto the stack
2.  Both the interrupt (IF) and trap (TF) flags are cleared. This disables the
INTR pin and the trap or single-step feature.
3.  The  contents  of  the  code  segment  register  (CS)  are  pushed  onto  the
stack.
4.  The contents of the instruction pointer (IP) are pushed onto the stack.
5.  The interrupt vector contents are fetched, and thenplaced into both IP
and  CS  so  that  the  next  instruction  executes  at  the interrupt  service
procedure addressed by the vector.
  Protected mode interrupt:
   In the protected mode, interrupts have exactly the same assignments as in real
mode,  but  the  interrupt  vector  table  is  different.  In  place  of  interrupt  vectors,
protected  mode  uses  a  set  of  256  interrupt  descriptors  that  are  stored  in  an
interrupt descriptor table (IDT).
(iv).  Super scalar architecture:
The  Pentium  microprocessor  is  organized  with  three  execution  units.  One
executes  floating-point  instructions,  and  the  other two  (U-pipe  and  V-pipe)
execute  integer  instructions.  This  means  that  it  is possible  to  execute  three
instructions simultaneously.
(v).  Comparison between Motorola processors and INTEL processors:
AMD/Intel  processors  are  really  about  the  same  thing.   They  run  the  same
software  and  operate  in a  very  similar  manner.  AMD is  often less expensive
than Intel, and depending on what you use a computer for one may be somewhat
faster than the other.
Motorola  has  been  largely  relegated  to  the  “also-ran”  category  of
microprocessor manufactures since Apple computer stopped using them in favor
of the IBM Power PC processor (Apple has since switched to Intel).
AC23  Microprocessor Based System Design
25
Motorola  had  an  excellent  32  bit  processor  design  years  before  Intel.
Furthermore,  the  design  of  the  Motorola  68000  processor  line  (from  a
programmer’s perspective) was immensely better. The two major features of the
68000 line that made this true were
1) Orthogonality of register access and
2) Number of registers available.
These features made writing code for Motorola CPUs much simpler.
Q.27    What is (i) USB (ii) AGP (iii) XMS (iv) EMS (v) TSR (vi) EDO RAM  (6)
 Ans
(i).  USB:The USB (UNIVERSAL SERIAL BUS) is intended to connect
peripheral  devices  such as  keyboards,  a mouse, modems, and sound cards  to
the microprocessor through a serial data path and atwisted pair of wires. The
main idea is to reduce system cost by reducing the  number of wires. Another
advantage is that the sound system can have a separate power supply from the
PC,  which  means  less  noise.  The  data  transfer  rates through the  USB are  12
Mbps at present.
(ii).  AGP:The latest addition to many computer systems is the inclusion
of the  accelerated graphics port(AGP). The AGP operates at the bus clock
frequency of the microprocessor. It is designed so  that a transfer between the
video  card  and  the  system  memory  can  progress  at  a  maximum  speed.  The
AGP can transfer data at a maximum rate of 528M bytes per second. This port
probably will never be used for any devices other than the video card.
(iii).  XMS:The  memory  system  is  divided  into  three  main  parts. TPA
(transient  program  area), system  area,  and  XMS  (extended  memory
system). The type of microprocessor in your computer determines whether an
extended memory system exists.
(iv).  EMS:The  area  at  location  C8000H-DFFFFFH  is  often  open  or  free.
This area is used for the expanded memory systemin a PC or XT system, or
for the upper memory system in an AT system. The EMS allows a 64K-byte
page frame of memory to be used by application programs.
(v).  TSR:The TPA also holds TSR (terminate and stay resident) programs
that remain in memory in an active state until activated by a hot-key sequence
or another event such as an interrupt.
(vi).  EDO RAM:A  slight  modification  to  the  structure  of  the  DRAM
changes the device into an EDO (extended data output) DRAM device. In the
EDO  memory,  any  memory  access,  including  a  refresh, stores  the  256  bits
selected  by  RAS’  into  latches.  These  latches  hold  the  next  256  bits  of
information,  so  in  most programs,  which  are  sequentially executed,  that  data
are available without any wait states.
Q.28  What are program invisible registers? Explain the purpose of the GDTR. If the
microprocessor  sends  linear  address  00200000H  to  the  paging  mechanism,
which paging directory entry and which page table entry is accessed?  (3)
AC23  Microprocessor Based System Design
26
 Ans, the global and local descriptor tables are found  in the memory system. In
order  to  access  and  specify  the  address  of  these  tables,  the  program  invisible
registers  used.  The  program  invisible  registers  are not  directly  addressed  by
software so they are given name.
   The  GDTR  (global  descriptor  table  register)  and  IDTR  (interrupt  descriptor
table  register)  contain  the  base  addresses  of  the  descriptor  table  and  its  limit.
The limit of each descriptor table is 16 bits because the maximum table length is
64  Kbytes.  When  the  protected  mode  operation  is  desired,  the  address  of  the
global descriptor table and its limit are loaded into the GDTR.
   For  linear  address  00000000H  –  003FFFFFH,  the  first  entry  of  the  page
directory is accessed. Each page directory entry represents or repages a 4-Mbyte
section of the memory system. The contents of the page directory select a page
table that is indexed by the next 10 bits of the linear address. This means that
address 00000000H – 00000FFFH selects page directory entry 0 and page table
entry 0.
Q.29  Discuss the salient features of a parallel programmable interface, 8255.  (4)
 Ans
•  24 I/O lines in 3 8-bit port groups – A, B, C
•  A, B can be 8-bit input or output ports
•  C can serve as 2 4-bit input or output ports
•  3 modes of operation:
–  Mode 0:A, B, C simple input or output level sensitive ports
–  Mode 1:A, B input or output ports with strobe control in C
–  Mode 2:A is bidirectional with control/handshake inB and C
•  A, B can only change 1 byte at a time
•  C has individual bit set/reset capability
•  Advantage  is  non-dedicated  circuit  can  change  port  configuration  with
software and no “glue logic”
•  Ports A, B, and C are used for I/O data.
•  The control register is programmed to select the operation mode of the three
ports A, B, and C.
•  Mode 0 : simple I/O mode
•  Any of the ports A, B, CL and CU can be programmed as input or output.
•  No control of individual bits (all bits are out or all bits are in)
•  Mode  1:  Ports  A  and  B  can  be  used  as  input  or  output  ports  with
handshaking.
•  Mode 2 : Port A can be used as bidirectional I/O port with handshaking
Q.30  What  do  you  understand  by  assembler  directives?  What  do  the  following
assembler directives do?
(i)  ASSUME
(ii)  SEGMENT
(iii)  DB
(iv)  PUBLIC   (8)
Ans
(i)  ASSUME: This directive will be used to map the segment register names
with memory addresses.
The Syntax is as follows:
AC23  Microprocessor Based System Design
27
ASSUME  SS: Stackseg, DS : Dataseg, CS:Codeseg
The ASSUME will tell the assembler to use the SS register with the address of the stack
segment whose name is stackseg.
(ii) SEGMENT:  This  directive  defines  to the assembler the  start  of  a  segment  with
name segment-name. The segment name should be unique and follows the rules of the
assembler
The Syntax is as follows:
Segment Name SEGMENT  {Operand (Optional)} ; Comment
.
.
.
Segment Name  ENDS.
(iii)  DB  (Define  Byte): The  DB  directive  defines  a  byte-type  variable  (i.e.  a
variable which occupies one byte of memory space).  In a given directive statement,
there may be single initial value or multiple values of the defined variable. If there is
one initial value, one byte of memory space is reserved. If there are multiple values,
one byte of memory space is reserved for each value. The general format is:
  Name of Variable DB Initial value or values.
(iv)  The  PUBLIC and  EXTRN  directives  are  very  important  to  modular
programming. PUBLIC used to declare that labels of  code, data, or entire segments
are available to other program modules. EXTRN (external) declares that labels are
external to modules. Without these statements, modules could not be linked together
to create a program by using modular programming techniques. They might link, but
one module would not be able to communicate to another.
  The  PUBLIC  directive  is  placed  in  the  opcode  field  of  an  assembly  language
statement to define a label as public, so that the label can be used by other modules.
Q.31  Discuss the role of a bus arbiter in a multiprocessor configuration.  (4)
Ans,  Bus  arbiter:  Which  functions  to  resolve  priority  between  bus  masters  and
allows  only  one  device  at  a  time  to  access  the  shared  bus.  The  8289  bus  arbiter
controls the interface of a bus master to a shared  bus. This is designed to function
with the 8086/8088 microprocessors. Each bus masteror microprocessor requires an
arbiter for the interface to the shared bus, which Intel calls the MULTIBUS and IBM
calls the MICRO CHANNEL.
The shared bus used only to pass information from one microprocessor to another;
otherwise, the bus master function in their own local bus modes by using their own
local programs, memory, and I/O space. Microprocessors connected in this kind of
system are often called parallel or distributed processors because they can execute
software and perform tasks in parallel.
Q.32  Show  how  a  typical  DMA  controller  can  be  interfac ed  to  an  8086/8085  based
maximum mode system.   (8)
Ans, For 8088 in maximum mode:
AC23  Microprocessor Based System Design
28
The  RQ/GT1  and  RQ/GT0  pins  are  used  to  issue  DMA  request  and  receive
acknowledge signals. Sequence of events of a typical DMA process
 1) Peripheral asserts one of the request pins, e.g. RQ/GT1 or RQ/GT0 (RQ/GT0 has
higher priority)
  2) 8088 completes its current bus cycle and enters into a HOLD state
3) 8088 grants the right of bus control by asserting a grant signal via the same pin as
the request signal.
  4) DMA operation starts
5) Upon completion of the DMA operation, the peripheral asserts the request/grant
pin again to relinquish bus control.
Q.33     What  is  a  co-processor?  What  is  its  use  in  a  typical  microprocessor  based
system.  (8)
 Ans8087 NDP (numerical data processor) is also known  as math co-processor
which  is  used  in  parallel  with  the  main  processor  for  number  crunching
applications,  which  would  otherwise  require  complex programming.  It  is  also
faster than 8086/8088 processor in performing mathematical computation. It has
its own specialized instruction sets to handle mathematical programs.
 It is a processor which works in parallel with the main processor. It has its own
set  of  specialized  instructions.  The  number  crunching  part  of  the  program  is
executed  by  8087.  Instruction  for  8087  are  written  in  the  main  program
interspersed  with  the  8086  instructions.  All  the  8087  instruction  codes  have
11011 as the most significant bits of their first code byte.
Q.34   What  is  segmentation?  What  are  its  advantages?  How is  segmentation
implemented in typical microprocessors?  (8)
AC23  Microprocessor Based System Design
29
Ans
Segment memory addressing divides the memory into many segments. Each of these
segments  can  be  considered  as  a  linear  memory  space.  Each  of  these  segment  is
addressed by a segment register.
However since the segment register is 16 bit wide and the memory needs 20 bits for
an  address  the  8086  appends  four  bits  segment  register  to  obtain  the  segment
address. Therefore, to address the segment 10000H by , say the SS register, the SS
must contain 1000H.
The first advantage that memory segmentation has isthat only 16 bit registers are
required both to store segment base address as wellas offset address. This makes the
internal circuitry easier to built as it removes the requirement for 20 bits register in
case the linear addressing method is used. The second advantage is relocatability.
Q.35 What is a PCI bus? Discuss its features and usage.  (6)
Ans
  Peripheral  Component  Interconnect  (PCI):  This  bus was  developed  by  Intel  and
introduced in 1993. It is geared specifically to fifth- and sixth-generation systems,
although the latest generation 486 motherboards usePCI as well.
PCI bus has plug – and – play characteristics and the ability to function with a 64-bit
data bus. A PCI interface contains series of registers, located in a small memory device
on the PCI interface that contains information about the board.
Q.36   How is EISA bus different from ISA bus?  (4)
Ans
The Extended Industry Standard Architecture (EISA) is a 32 bit modification to the ISA
bus. As computers became larger and had wider data buses, a new bus was needed that
would transfer 32-bit data. The clocking speed limited up to 8MHz. The most common
application for the EISA bus is a disk controller or as a video graphics adapter. These
applications  benefit  from  the  wider  data  bus  width  because  the  data  transfer  rate  for
these devices are high.
Q.37   Differentiate between synchronous and asynchronoustypes of serial communication.
(6)
Ans Serial  data  communication  uses  two  basic  types,  synchronous  and
asynchronous.  With  synchronous  communications,  the  two  devices  initially
synchronize themselves to each other, and then continually send characters to stay in
sync. Even when data is not really being sent, a constant flow of bits allows each
device to know where the other is at any given time. That is, each character that is
sent is either actual data or an idle character.
Asynchronous  means  “no  synchronization”,  and  thus  does  not  require  sending  and
receiving idle characters. However, the beginning and end of each byte of data must be
identified by start and stop bits. The start bit indicates when the data byte is about to
begin and the stop bit signals when it ends. The requirement to send these additional
two  bits  causes asynchronous  communication  to  be  slightly slower  than synchronous
however  it  has  the  advantage  that  the  processor  does  not  have  to  deal  with  the
additional idle characters.
AC23  Microprocessor Based System Design
30
Q.38   Draw and explain the block diagram of programmable interrupt controller 8259.
(8)
Ans The  8259A  adds  8  vectored  priority  encoded  interrupts  to  the
microprocessor. It can be expanded to 64 interrupt requests by using one master
8259A and 8 slave units. CS and WR must be decoded.Other connections are
direct to microprocessor.
The pins D7 – D0: the bidirectional data connection, IR7 – IR0: Interrupt request,
used to request an interrupt & connect to a slave in a system with multiple 8259A.
WR :-Connects to a write strobe signal (lower or upper in a 16 bit system) , RD :-
Connects  to  the  IORC  signal  ,   INT  :-  Connects  to  the  INTR  pin  on  the
microprocessor from the master and is connected to a IR pin on a slave and INTA
:-  Connects  to  the  INTA  pin  on  the  microprocessor.  In  a  system  only  the  master
INTA signal is connected
A0  :-  Selects  different  command  words  with  in  the  8259A,   CS  :-  Chip  select  –
enables the 8259A for programming and control, SP/EN :- Slave Program (1 for
master,  0  for  slave)/Enable  Buffer  (controls  the  data  bus  transceivers  in  a  large
microprocessor based system when in buffered mode) and CAS2-CAS0 :- Used as
outputs from the master to the slaves in cascaded systems.
Fig : 8259 Block Diagram
Q.39   Discuss the various types of memory devices that you are familiar with.  (8)
 Ans
All  of  the  memory  used  as  main  store  in  a  modern  computer  is implemented as
semiconductors fabricated on wafers of silicon. Semiconductor memory is fast and
easy  to  use.  To  fulfil  the  needs  of  modern  computer systems  it  is  becoming
increasingly dense (more bits per chip) and cheap.
A semiconductor memory chip consists of a large number of cells organized into
an  array,  and  the  logic  necessary  to  access  any  array  in  the  cell  easily.  Semiconductor memory may be classed according to the mechanism used by each cell
to  store  data.  The  simplest  type  of  memory  is  called  static  memory.  In  static
AC23  Microprocessor Based System Design
31
memory each cell uses a flip-flop made from four orsix transistors. The data in
each cell is remembered until the power is switchedoff. Static memory is easy to
use  and  reliable,  but  is  relatively  bulky,  slow  and expensive.  Most  computer
systems therefore use dynamic memory as their main store. Dynamic memory uses
just  a  single  transistor  per  cell,  and  is  therefore denser,  faster  and  cheaper.
Unfortunately each cell gradually forgets the data stored in it, and so extra circuitry
must be used to continually refresh the cells.
Memory,  with  regard  to  computers,  most  commonly  refers  to  semiconductor
devices whose contents can be accessed (i.e., read and written to) at extremely high
speeds. The main characteristics of semiconductor memory are based on capacity,
organization  and  access  time.  In  microprocessor-based  systems  semiconductor
memories are used as primary storage for code and data.
In  contrasts  with  storage,  which  (1)  retains  programs  and  data  regardless  of
whether  they  are  currently  in  use  or  not,  (2)  retains  programs  and  data  after  the
power supply has been disconnected, (3) has much slower access speeds and (4)
has a much larger capacity (and a much lower cost).Examples of storage devices
are  hard  disk  drives  (HDD),  floppy  disks,  optical  disks  (e.g.,  CDROMS  and
DVDs) and magnetic tape.
The term memory as used in a computer context originally referred to the magnetic
core memory devices that were used beginning in the1950s. It was subsequently
applied to the semiconductor memory devices that replaced core memories in the
1970s.
Computer  memory  today  consists  mainly  of  dynamic  random  access  memory
(DRAM)  chips  that  have  been  built  into  multi-chip  modules  that  are,  in  turn,
plugged  into  slots  on  the  motherboard  (the  main  circuit  board  on  personal
computers  and  workstations).  This  DRAM  is  commonly  referred  to  as  RAM
(random access memory), and it constitutes the mainmemory of a computer.
The random in random access memory refers to the fact that any location in such
memory  can  be  addressed  directly  at  any  time.  This  contrasts  with  sequential
access  media,  such  as  magnetic  tape,  which  must  be  read  partially  in  sequence
regardless of the desired content.
There  are  three  basic  kinds  of  memory  used  in  microprocessor  systems  –
commonly  called  ROM,  RAM,  and  hybrid.  ROM  and  RAM  are   –  “Read  Only
Memory” and “Random Access Memory”. The program maybe stored in ROM or
RAM  –  the  program  does  not  normally  change  while  it executes  –  while  data  is
stored in the registers and RAM. Of course, if you  turn off the chip and turn it on
again, you have lost all the contents of the registers, and RAM.
In  a  typical  computer,  as  much  as  possible  is  in  RAM,  to  give  the  maximum
possible  flexibility;  you  have  basic  programmes  allowing  you  to  interact  with
discs, keyboards and the display in ROM, and load in as much of the software as
possible when you run the programs.
Q.40  Write explanatory notes on Microprocessor development system.  (16)
 Ans,
 Microprocessor development system:
Computer  systems  have  undergone  many  changes  recently.  Machines  that  once
filled large areas have been reduced to small desktop computer systems because of
AC23  Microprocessor Based System Design
32
the microprocessor. Although these desktop computers are compact, they possess
computing power that was only dreamed of a few years ago.
The blocks of the microprocessor based system are
1.  The Memory and I/O System
2.  The DOS Operating System
3.  The Microprocessor
Q.41    Discuss DOS function call and BIOS function call with one example of each.  (5)
Ans
DOS function call:
In order to use DOS function calls, always place the function number into register
AH and load all other pertinent information into registers, as described in the entry
data  table  (Refer  Text1-page  no  809).  Once  this  is  accomplished,  follow  with  an
INT 21H to execute the DOS function.
Example: MOV AH, 6
  MOV DL, ‘A’
  INT 21H.
Example shows how to display an ASCII A on the CRT screen at the current cursor
position with a DOS function call.
  BIO stands for Basic Input Output System. It is aset of programs to provide most
basic low-level services such as services keyboard,disks, serial port, printer, display,
and  bootstrap.  BIOS  programs  are  stored  in  a  ROM.  When  power  is  switched  on
ROM-BIOS takes the control of a computer. First of  all, ROM-BIOS programs for
power-on-self test are executed. These tests check  that whether the computer is in
proper working order after this test, the process of loading the operating system into
main  memory  is  called  booting.  ROM-BIOS  contains  a  program  called  bootstrap
loader, this directs CPU to read from the disk a specific program called boot and to
load it into main memory.
BIOS function callsare found stored in the system and video BIOS ROMs. These
BIOS ROM function directly control the I/O devices,with or without DOS loaded
into a system.
  INT10H: This is a BIOS interrupt is often called the video services interrupt because
it  directly  controls  the  video  display  in  a  system. The  INT10H  instruction  uses  a
register  AH  to  select  video  services  provided  by  this  interrupt.  The  video  BIOS
ROM is located on the video board and varies from one video card to another.
  INT11H:  This  function  used  to  determine  the  type  of  equipment  installed  in  the
system.
  INT12H: The memory size is returned by the INT 12H instructions.
  INT13H: This call controls the diskettes and alsofixed or hard disk drives attached
to the system.
  INT14H: This call controls the serial COM ports attached to the computer.
Q.42  Differentiate between real and protected modes of an Intel microprocessor. Discuss
protected mode memory addressing in brief.  (7)
Ans  Operation  of  Real  mode  interrupt:  When  the  microprocessor  completes
executing  the  current  instruction,  it  determines  whether  an  interrupt  is  active  by
checking  (1)  instruction  execution,  (2)  single  –step,  (3)  NMI,  (4)  co-processor
segment overrun, (5) INTR, and (6) INT instruction in the order presented. If one or
AC23  Microprocessor Based System Design
33
more  of  these  interrupt  conditions  are  present,  the following  sequence  of  events
occurs:
1.  The contents of the flag register are pushed onto the stack
2.  Both the interrupt (IF) and trap (TF) flags are cleared. This disables the
INTR pin and the trap or single-step feature.
3.  The  contents  of  the  code  segment  register  (CS)  are  pushed  onto  the
stack.
4.  The contents of the instruction pointer (IP) are pushed onto the stack.
5.  The interrupt vector contents are fetched, and thenplaced into both IP
and  CS  so  that  the  next  instruction  executes  at  the interrupt  service
procedure addressed by the vector.
  Protected mode interrupt:
   In the protected mode, interrupts have exactly the same assignments as in real
mode,  but  the  interrupt  vector  table  is  different.  In  place  of  interrupt  vectors,
protected  mode  uses  a  set  of  256  interrupt  descriptors  that  are  stored  in  an
interrupt descriptor table (IDT).
Q.43What  do  you  mean by the  term  procedure? What is  the  difference  between  near
call and far call?   (4)
Ans
PROC:  The  PROC and  ENDP  directives  indicate  the  start  and  end  of a procedure.
These directives force structure because the procedure is clearly defined. The PROC
directive indicates the start of a procedure, must  also be followed with a NEAR or
FAR.  A  NEAR  procedure  is  one  that  resides  in  the  same  code  segment  as  the
program. A FAR procedure may reside at any locationin the memory system.
Q.44  Design an address decoding logic using a 3:8 decoder (74138) to interface a total of
64k  memory  locations  in  the  address  range  from  F0000  to  FFFFF.   Divide  64k
memory locations in eight blocks of 8 k locations each and generate eight chip select
signals.  (8)
  Ans
  Text1-page 350
Q.45   Draw  and  explain  the  block  diagram  of  DMA  controller.  Also  explain  the  various
modes in which DMAC works.  (8)
Ans
Direct memory access (DMA)  is a process in which an external device takes over
the  control  of  system  bus  from  the  CPU.DMA  is  for  high-speed  data  transfer
from/to mass storage peripherals, e.g. hard disk drive, magnetic tape, CD-ROM, and
sometimes video controllers. For example, a hard disk may boasts a transfer rate of 5
M bytes per second, i.e.1 byte transmission every 200 ns. To make such data transfer
via the CPU is both undesirable and unnecessary.
The basic idea of DMA is to transfer blocks of data directly between memory and
peripherals. The data don’t go through the microprocessor but the data bus is occupied.
“Normal” transfer of one data byte takes up to 29 clock cycles. The DMA  transfer
requires only 5 clock cycles.
AC23  Microprocessor Based System Design
34
The  modes  of  operation  include  demand  mode,  single  mode,  block  mode,  and
cascade mode. Demand mode transfers data until an external EOP is input or until
the DREQ input becomes inactive. Single mode releases the HOLD after each byte
of  data  transferred.  Block  mode  automatically  transfers  the  number  of  bytes
indicated  by  the count  register  for the  channel.  Cascade  mode  is  used  when  more
than one 8237 is present in a system.
 Q.46 What is DRAM? What do you understand by DRAM refreshing? With the help of a
block diagram, show how DRAM can be interfaced to amicroprocessor.  (6)
  Ans Dynamic RAM (DRAM) is essentially the same as SRAM,except that it retains
data for only 2 or 4 ms on an internal capacitor. After 2 or 4 ms, the contents of the
DRAM must be completely rewritten (refreshed) because the capacitors, which store
logic 1 or logic 0, lose their charges. The entire  content of the memory is refreshed
with 256 reads in a 2-to-4 ms interval. Refreshing also occurs during a write, a read
or during a special refresh cycle.
  Text 1 – Fig (page 342).
Q.47  Discuss  mode  –2  (bi-directional  mode)  of  8255  (Programmable  Peripheral
Interface).   (6)
AC23  Microprocessor Based System Design
35
Ans
Q.48   Discuss the following: (ANY THREE)  (12)
(i)  Some features of Pentium series of microprocessors.
(ii)  Virtual memory.
(iii)  MMX Technology.
(iv)  Graphics adapters.
Ans
(i).  Some features of Pentium series of microprocessors:
The Pentium is a 32-bit superscalar, CISC microprocessor. The term superscalar is
used for the processor which contains more than onepipeline to execute more than
one instruction simultaneously in parallel.
The main features of Pentium are, it has two ALU’s,one floating-point unit, two 8
KB cache, pre-fetch buffers, a branch target buffer. Two ALU’s means that there are
two pipelines. Each ALU contains five functional units. The two pipelines are integer
pipelines. They are named U and V pipeline.
When Pentium was introduced, its operating frequency was 60 MHz. gradually; the
operating frequency was raised to 233 MHz. The Pentium uses 0.6 micron Bi-CMOS
process technology. It uses power management feature.
The  memory  management  is  improved  by  adding  paging  unit  and  a  new  system
memory-management mode.
Paging Unit: The paging mechanism functions with 4K– byte memory pages or with
a  new  extension  available  to  the  Pentium  with  4M  byte-memory  pages.  In  the
Pentium, with the new 4M-byte paging feature memoryfor the page-table reduced to
single page table.
Memory – management mode: The system memory-management mode (SMM) is on
the same level as protected mode, real mode, and virtual mode, but it is provided to
function as a manager. The SMM is not intended to be used as an application or a
system  level  feature.  It  is  intended  for  high-level system  functions  such  as  power
management.
AC23  Microprocessor Based System Design
36
(ii).  Virtual memory:
  The  term  virtual  memory  refers  to  something  which appears  to  be  present  but
actually it is not. The virtual memory technique allows users to use more memory
for  a  program  than  the  real  memory  of  a  computer.  A programmer  can  write  a
program  which  requires  more  memory  space  than  the  capacity  of  the  main
memory. Such a program is executed by virtual memory technique. The program is
stored in the secondary memory. The memory management unit (MMU) transfers
the currently needed part of the program from the secondary memory to the main
memory for execution. This part of the program is executed by the processor. After
execution this part of the program is sent back to  the secondary memory together
with the immediate results. Thereafter, the CPU takes another part of the program
for execution. Thus the main memory always keeps only the currently needed part
of the program. This type of ‘to and fro’ movement  instructions and data between
the  main  memory  and  secondary  memory  is  called  swapping.  Thus  a  program
requiring more memory space than the capacity of the main memory can executed
using a swapping technique. This concept is known avirtual memory technique.
(iii).  MMX Technology:
   MMX  (Multimedia  extensions)  technology  adds  57  new  instructions  to  the
instruction  set  of  the  Pentium  –  4  microprocessors. The  MMX  technology  also
introduces  new  general  purpose  instructions.  The  new  MMX  instructions  are
designed  for  application  such  as  motion  video,  combined  graphics  with  video,
image processing, audio synthesis, speech synthesisand compression, telephony,
video conferencing, 2D graphics, and 3D graphics. These new instructions operate
in parallel with other operations as the instruction for the arithmetic coprocessor.
  The MMX architecture introduces new packed data types. The data types are eight
packed,  consecutive  8-bit  bytes;  four  packed, consecutive  16-bit  words;  and  two
packed, consecutive 32-bit double words.
(iv)  Graphics adapters:
Video card converts digital output from the computer into an analog video signal
and sends the signal through a cable to the monitoralso called a graphics card.
•  The number of colours a video card displays is determined by its bit depth
•  The video card’s bit depth, also called the color depth, is the number of bits it
uses to store information about each pixel
•  i.e. 8-bit video card uses 8 bits to store information about each pixel; this video
card can display 256 colors (2x2x2x2x2x2x2x2)
•  i.e. 24-bit video card uses 24 bits to store information about each pixel and can
display 16.7 million colors
•  The greater the number of bits, the better the resulting image
Video Electronics Standards Association (VESA),  which consists of video card
and  monitor  manufacturers,  develops  video  stands  to define  the  resolution,
number of colors, and other display properties.
a.  Monochrome Display Adapter (MDA)
b.  Hercules Graphics Card
c.  Colour Graphics Adapter (CGA)
d.  Enhanced Graphics Adapter (EGA)
e.  Video Graphics Adapter (VGA)
f.  Super VGA (SVGA) and Other Standards Beyond VGA
AC23  Microprocessor Based System Design
37
Q.49  Write explanatory notes on (ANY FOUR)
(i)  Paging
(ii)  8284 Clock generator
(iii)  Assembler Directives
(iv)  Hard disk drive controller  (16)
Ans
(i)  Paging:
   The  memory  paging  mechanism  located  within  the  80386  and  above  allows  any
physical memory location to be assigned to any linear address. The linear address is
defined as the address generated by a program.  Withthe memory paging unit, the
linear  address  is  invisibly  translated  into  any  physical  address,  which  allows  an
application written to function at a specific address to be located through the paging
mechanism. It also allows memory to be placed into areas where no memory exists.
(ii)  8284 Clock generator:
The 8284 is an ancillary component to the microprocessors. Without clock generator,
many  additional  circuits  are  required  to  generate  the  clock  in  an  microprocessor
based  system.  A  8284  provides  the  following  basic  functions  or  signals:  Clock
generation,  RESET  synchronization,  READY  synchronization,  and  a  TTL-level
peripheral clock signal.
(iii)  Assembler Directives:
An assembler directive is a statement to give direction to the assembler to perform
the  task  of  assembly  process.  The assembler  directives  control  organization  of  the
program and provide necessary information to the assembler to understand assembly
language  programs  to  generate  machine  codes.  They  indicate  how  an  operand  or
section  of  a  program  is  to  be  processed  by  the  assembler.  An  assembler  supports
directives  to  define  data,  to  organize  segments  to  control  procedures,  to  define
macros etc.
(iv)  Hard disk drive controller:  This converts instructions from software running
on  the  computer  to  the  electrical  signals  required  to  operate  the  hard  disk.  The
function of a disk controller is disk drive selection, track and sector selection, head
loading, to parallel and parallel to serial conversion of data, error checking etc. The
data  recorded  on  a  magnetic  disk  is  the  combination of  clock  and  data.  Therefore,
data read must be separated from the clock information. The data processed by a CPU
or  stored  in  the  main  memory  is  in  the  byte  form.  The  bytes  to  be  recorded  on  a
magnetic disk must be converted into serial format.
Q.50  What  do  you  mean  by  Macro?  Discuss  merits  and  dem erits  of  Macro  over
procedures  .  (6)
   Ans MACRO:A sequence of instructions to which a name is assigned is called
macro. Macros and subroutines are similar. Macros are used for short sequence
of instructions whereas subroutines for longer ones. Macros executes faster than
subroutines.
AC23  Microprocessor Based System Design
38
The MACRO directive informs assembler the beginningof a macro This is used
with  ENDM  directive  to  enclose  a  macro.  The  general format  of  the  MACRO
directive is :
Macro Name  MACRO  ARG1, ARG2 , …..,ARG N.
The  difference  is  that  a  procedure  is  accesses  via  a  CALL  instruction,  while  a
macro and all the instructions defined in the macro, are inserted in the program at
the point of usage. Creating macro is very similar  to creating a new op-code that
can be used in the program.
Q.51   Draw and discuss power failure detection circuit interrupt NMI.  (6)
   Ans
   The  non-maskable  interrupt  (NMI)  is  an  edge-triggered  input  that  requests  an
interrupt  on  the  positive-edge.  After  a  positive  edge,  the  NMI  pin  must  remain
logic 1 until it is recognized by the microprocessor.
   The NMI input is often used for parity errors and other major system faults, such as
power failures. Power failure is easily detected bymonitoring the AC power line
and causing an NMI interrupt whenever AC power drops out. In response to this
type of interrupt, the microprocessor stores all ofthe internal register in a battery
backed-up-memory  or  an  EEPROM.  The  below  fig  shows  a  power  failure
detection circuit that provides a logic 1 to the NMI input when ever AC power is
interrupted.
Q.52   Interfaced 2k X 8 (i.e 2716) EPROM using multiple input NAND gate decoder for
memory locations FF800H-FFFFFH.   (4)
 Ans
Simple  NAND  gate  Decoder:  When  the  2k  x  8  EPROM  is  used,  address
connection A10 – A0 of the 8088 are connected to address inputs A10-A0 of the
EPROM. The remaining nine address pins (A19-A11) are connected to the inputs
of a NAND gate decoder. The decoder selects the EPROM from one of the many
2Kbyte sections of the entire 1Mbyte address range of the 8088 microprocessor.
AC23  Microprocessor Based System Design
39
   In this circuit, a single NAND gate decodes the memory address. The output of the
NAND gate is logic 0 whenever the 8088 address pinsattached to its inputs (A19-A11) are all logic 1s. The active low , logic 0 output of the NAND gate decoder is
connected to the CE’ input pin that selects (enables) the EPROM.
Q.53  Explain the functions of the following:
   (i) Debugger  (ii) Assembler
   (iii) Linker   (6)
   Ans
(i)  Debugger: It is a program which allows user to testand debug programs. All
computers including microprocessor kits provide debugging facility. To detect
errors  a  program  can  be  tested  in  single  steps.  Each  step  of  the  program  is
executed and tested. The debugger allows the user to examine the contents of
registers and memory locations after each step of execution. This also provides
facility to insert breakpoint in the programs.
(ii)  Assembler:  An  assembler  or  macro-assembler  generally  forms  a  part  of  the
operating system. Which translates a assembly language program into machine
language program.
(iii)  Linker: A large program is divided in smaller programs known as modules. A
linker  is  a  program  which  links  smaller  programs  together  to  form  a  large
program. While developing a program subroutines, which are stored in library
file, are frequently used in the program. The linker also links these subroutines
with the main program.
AC23  Microprocessor Based System Design
40
Q.54   Discuss DMA definition and operation in brief  (4)
   Ans
Direct memory access (DMA) is a process in which an external device takes over
the  control  of  system  bus  from  the  CPU.DMA  is  for  high-speed  data  transfer
from/to  mass  storage  peripherals,  e.g.  harddisk  drive,  magnetic  tape,  CD-ROM,
and sometimes video controllers. For example, a hard disk may boasts a transfer
rate of 5 M bytes per second, i.e.1 byte transmission every 200 ns. To make such
data transfer via the CPU is
both undesirable and unnecessary.
The basic idea of DMA is to transfer blocks of data directly between memory and
peripherals.  The  data  don’t  go  through  the  microprocessor  but  the  data  bus  is
occupied.  “Normal”  transfer  of  one  data  byte  takes  up  to  29  clock  cycles.  The
DMA transfer requires only 5 clock cycles.
Nowadays, DMA can transfer data as fast as 60 M byte per second. The transfer
rate is limited by the speed of memory and peripheral devices.
Q.55  Write an assembly language program to find average of ‘n’ integers.  (6)
Ans
MOV AX, 0000 ; Initial sum 0000
MOV BX, 0000
MOV SI , 0201H
MOV CX, [SI]
BACK: INC SI
INC SI
ADD AX, [SI]
JAE  GO
AC23  Microprocessor Based System Design
41
INC BX
GO: LOOP BACK
MOV [0401], AX
MOV [0403], BX
INT 3
Q.56 Explain following instructions in 8086 family with example and their effect on flag.
   (i) CWD  (ii) IDIV  (iii) AAS  (iv) SAR
   (v) LOOP  (vi) SAHF  (vii) BOUND  (viii) IMUL  (12)
Ans
(i)  CWD (Convert signed word to signed double word): CWD instruction extends
the sign bit of a word in AX register to all the bits of the DX register. It is used
before  a  signed  word  in  AX  is  to  be  divided  by  another  signed  word  using
IDIV instruction. No flags are affected.
(ii)  IDIV  :  This  instruction  is  used  to  divide a  16-bit  signed  number  by  an  8-bit
signed number or 32 bit signed number by a 16-bit signed number. The 32 bit
dividend is placed in DX and AX registers. The 16 bit divisor is placed in a
specified 16-bit register or memory locations. No flags are affected.
(iii)  AAS: (ASCII adjust after subtraction) It is used toadjust the AX register after a
subtraction operation.
(iv)  SAR:  (Shift  each  bit  of  operand  right  by  specified  number  of  bits),  this
instruction shifts each bit of the operand which iscontained in an 8-bit or 16-bit
register or memory locations, right by the specified number of bits. The LSB of
the operand is shifted into carry flag. The MSB which is a sign bit for the sign
operand is retained in MSB position.
Flags affected are: OF, SF, ZF, PF and CF.
(v)  LOOP: (Jump to specified label until CX = 0) this isused to repeat a sequence
of  instructions  for  the  specified  number  of  times.  The  number  of  times  the
specified  sequence  is  to  be  repeated  is  stored  in  CX  register.  No  flags  are
affected.
(vi)  SAHF: (Store AH register into flag register) It is  an instruction used to store
the data in the AH register into the lower eight bits of the flag register.
(vii)  BOUND:  The  BOUND  instruction,  which  has  two  operands,  compares  a
register with two words of memory data.
(viii) IMUL: This is an instruction for multiplication of  two signed numbers. The
result is a signed numbers. The OF (Over flow) andCF (Carry flag) are get
affected.
Q.57  Explain keyboard interfacing to 8088 through 8279.  (8)
AC23  Microprocessor Based System Design
42
Ans
   The 8279 is a programmable keyboard and display  interfacing component that scans
and encodes up to a 64-key keyboard and controls upto a 16-digit numerical display.
The keyboard interface has built in first-in first-out (FIFO) buffer that allows it store
up  to  eight  keystrokes  before  the  microprocessor  must  retrieve  a  character.  The
display section controls up to 16 numeric displays from an internal 16 X 8 RAM that
stores the coded display information.
The keyboard section consists of eight lines that can be connected to eight columns
of a keyboard, plus two additional lines as well asto shift and CNTL/STB keys. The
key pressed are automatically debounced and the keyboard can operate in two modes
two –key lock out or n-key rollover. If two keys inthe two –key lock out mode are
pressed  simultaneously,  only first  key  is  recognized.  In  the  N-key roll  over  mode,
simultaneous key are recognized and their codes arestored in the internal buffer.
  Control Word: 000DDMMM – Mode set is command withan op-code of 000 and
two fields programmed to select the mode of operation for the 8279. The DD field
selects the mode of operation for the display and the MMM field selects the mode of
operation for the keyboard.
D7  D6  D5  Function  Purpose
0  0  0  Mode Set
Selects the number of display
positions, left or right entry,
and type of keyboard scan.
0  0  1  Clock
Programs the internal clock
and sets the scan and debounce times
0  1  0  Read FIFO
Selects the type of FIFO read
and the address of the read
0  1  1  Read display
Selects the type of display
read and address of the read
1  0  0  Write display
Selects the type of write and
address of the write
1  0  1
Display write
inhibit
Allows half-bytes to be
blanked
1  1  0  Clear  Clears the display of FIFO
1  1  1  End interrupt
Clears the IRQ signal to the
microprocessor
The 8279 control word summary
Q.58  Discuss the operation of a real mode interrupt and protected mode interrupt.  (6)
  Ans   Operation  of  Real  mode  interrupt:  When  the  microprocessor  completes
executing  the  current  instruction,  it  determines  whether  an  interrupt  is  active  by
checking  (1)  instruction  execution,  (2)  single  –step,  (3)  NMI,  (4)  co-processor
segment overrun, (5) INTR, and (6) INT instruction in the order presented. If one or
more  of  these  interrupt  conditions  are  present,  the following  sequence  of  events
occurs:
AC23  Microprocessor Based System Design
43
1.  The contents of the flag register are pushed onto the stack
2.  Both the interrupt (IF) and trap (TF) flags are cleared. This disables the
INTR pin and the trap or single-step feature.
3.  The  contents  of  the  code  segment  register  (CS)  are  pushed  onto  the
stack.
4.  The contents of the instruction pointer (IP) are pushed onto the stack.
5.  The interrupt vector contents are fetched, and thenplaced into both IP
and  CS  so  that  the  next  instruction  executes  at  the interrupt  service
procedure addressed by the vector.
  Protected mode interrupt:
  In the protected mode, interrupts have exactly the same assignments as in real mode,
but  the  interrupt  vector  table  is  different.  In  place  of  interrupt  vectors,  protected
mode uses a set of 256 interrupt descriptors that are stored in an interrupt descriptor
table (IDT).
Q.59  Write  an  assembly  language  program  to  find  one’s  complement  and  two’s
complement of an 8-bit number   (4)
Ans
  One’s complement of an 8-bit number
  LDA 2501H
  CMA
  STA 2502H
  HLT.
  Two’s complement of an 8-bit number
  LDA 2501H
  CMA
  INR A
  STA 2502H
  HLT.
Q.60  Discuss the following terms: (Any six)
(i) Branch prediction logic in Pentium
(ii) Cache structure in Pentium
(iii) Threaded system
(iv) Super scalar architecture
(v)  Real time operating system
(vi)  D/A conversion   (12)
Ans,
(i)  Branch  prediction  logic  in  Pentium:  The  Pentium  microprocessor  uses  branch
prediction  logic  to  reduce  the  time  required  for  a  branch  caused  by  internal  delays.
These  delays  are  minimized  because  when  a  branch  instruction  is  encountered,  the
microprocessor begins pre-fetch instruction at the branch address. The instructions are
loaded  into  the  instruction  cache,  so  when  the  branch  occurs,  the  instructions  are
present and allow the branch to execute in one clocking period. If for any reason the
branch  prediction logic  errors,  the  branch  requires an  extra  three  clocking  periods  to
execute. In most cases, the branch prediction is correct and no delay ensues.
(ii)  Cache structure in Pentium:The cache in the Pentium has been changed from
the one found in the 80486 microprocessor. The Pentium contains two 8K-byte cache
AC23  Microprocessor Based System Design
44
memories instead of one as in the 80486. There is an 8K-byte data cache and an 8Kbyte  instruction  cache.  The  instruction  cache  stores  only  instructions,  while  the  data
cache stores data used by instructions.
(iii)  Threaded system:At times we need to implement an operating system that can
process multiple threads. Multiple threads are handled by the kernel using a real-time
clock interrupt. One method for scheduling processes in a small RTOS is to use a
time  slice  to  switch  between  various  processes.  The basic  time  slice  can  be  any
duration and is some what dependent on the execution speed of the microprocessor.
Each time slice is activated by a timer interrupt. The interrupt service procedure must
look to a queue to see whether a task is available to execute, and if it is, it must start
execution of the new task. If no new task is present, it must continue executing an
old task or enter an idle state and wait for a new  task to be queued. The queue is
circular and may contain any number of tasks for the system up to some finite limit.
(iv)  Super  scalar  architecture: The  Pentium  microprocessor  is  organized  with
three execution units. One executes floating-point instructions, and the other two (Upipe  and  V-pipe)  execute  integer  instructions.  This means  that  it  is  possible  to
execute three instructions simultaneously.
(v)  Real time operating system (RTOS):The RTOS is an operating system used
in embedded applications that performs tasks in a predictable amount of time. RTOS
much like any other operating system in that it contains the same basic sections.
There are three components to all operating systems: (1) initialization, (2) the kernel,
(3) data and procedures. The initialization sectionis used to program all hardware
components  in  the  system,  load  drivers  specific  to  a  system,  and  program  the
contents  of  the  microprocessor’s  registers.   The  kernel  performs  the  basic  system
task, provides system calls or functions, and comprises the embedded system. The
data  and  procedure  section  holds  all  procedures  and any  static  data  used  by  the
operating system.
(vi)  D/A  conversion:  Digital-to-analog  and  analog-to-digital  conversions  are  two
very  important  aspects  of  digital  data  processing.  Digital-to-analog  involves
conversion of digital data into equivalent analog data. For example, the output of a
digital system might be converted to analog form using a D/A converter for driving a
servomotor,  which  drives  the  cursor  arm  of  a  plotter  or  a  pen  recorder.  It  clearly
shows in this example DAC emulating decoding deviceaction.
Q.61 Explain explanatory notes on (Any four)
(i)  Comparison of RS232C and RS422A standards
(ii)  8259 programmable interrupt controller
(iii)  A/D conversion   (16)
  Ans
(i)  Comparison of RS232C and RS422A standards:
AC23  Microprocessor Based System Design
45
RS232C  RS422A
1.  Standard defined for
asynchronous
communications, where there
is specified timing between
data bits and no fixed timing
between the characters that the
bits form.
2.  This standard defined 25
signal lines and 50ft is the
maximum guaranteed distance.
3.  This standard defines a serial
system with just a single wire
for each direction.
4.  Signal levels are : -25 to -3V
and +3 to +25V.
1.  Date Rate : 10 Mbits/s
2.  Driving ability upto 4000ft
and 10 receivers
3.  It is Differential standard i.e –
Each signal is represented by a
pair of wires and voltage
difference across these wires is
what is sensed at the receiver.
This minimizes the effect of
ground noise or the voltage
drop along the signal leads.
4.  Signal levels are : -2 to -6V
and +2 to +6V
(ii)  8259 programmable interrupt controller:
The 8259A adds 8 vectored priority encoded interrupts to the microprocessor. It can
be expanded to 64 interrupt requests by using one master 8259A and 8 slave units.
CS and WR must be decoded. Other connections are direct to microprocessor.
The pins D7 – D0: the bidirectional data connection, IR7 – IR0: Interrupt request,
used to request an interrupt & connect to a slave in a system with multiple 8259A.
WR :-Connects to a write strobe signal (lower or upper in a 16 bit system) , RD :-
Connects  to  the  IORC  signal  ,   INT  :-  Connects  to  the  INTR  pin  on  the
microprocessor from the master and is connected to a IR pin on a slave and INTA
:-  Connects  to  the  INTA  pin  on  the  microprocessor.  In  a  system  only  the  master
INTA signal is connected
A0  :-  Selects  different  command  words  with  in  the  8259A,   CS  :-  Chip  select  –
enables the 8259A for programming and control, SP/EN :- Slave Program (1 for
master,  0  for  slave)/Enable  Buffer  (controls  the  data  bus  transceivers  in  a  large
microprocessor based system when in buffered mode) and CAS2-CAS0 :- Used as
outputs from the master to the slaves in cascaded systems.
AC23  Microprocessor Based System Design
46
Fig : 8259 Block Diagram
(iii)  A/D conversion:
Fig : Block Diagram Representation of ADC Operation
The  digital  inventory  are  working  a  revolution  in  the  field  of  technology,
microcontrollers,  microprocessors  are  used  more  effectively  than  those  of  analog
circuitry.  But  the  output  of  any  sensors,  which  deals  with  physical  equality  like
temperature, humidity, pressure, viscosity, velocity, which are, used most of the data
acquisition  flat  forms  are  in  the  form  of  analog  signals  or  continuous  signals.
Microcontrollers and microprocessors are do nothingwith these signals. Because they
require the signal in the form of binary numbers. So we should convert these analog
signals  into  digital  format.  The  following  popular  methods  are  used  for  Analog  to
Digital conversion.
1.  Flash ADC
2.  Digital Ramp ADC
AC23  Microprocessor Based System Design
47
3.  Successive Approximation ADC
4.  Tracking ADC
5.  Slope (Integration) ADC.
Q.62  Explain with proper diagram all the six modes of  operation of programmable
interval timer 8254.   (8)
Ans
Mode 0 – Interrupt on terminal count
Mode 1 – Programmable one-shot
Mode 2 – Rate Generator
Mode 3 – Square wave rate generator
Mode 4 – Software triggered strobe
Mode 5 – Hardware trigger strobe
Mode 0: The output in this mode is initially low, and will remain low for the
duration of the count if GATE = 1.
Width of low pulse = N×T
Where N is the the clock count loaded into counter, and T is the clock period of
the CLK input.
When  the  terminal  count  is  reached,  the  output  will go  high  and  remain  high
until a new control word or new count number is loaded. In this mode, if GATE
input becomes low at the middle of the count, the count will stop and the output
will  be  low.  The  count  resumes  when  the  gate  becomes  high  again.  This  in
effect adds to the total time the output is low.
Mode 1: This mode is also called hardware triggerable one-shot.The triggering
must  be  done  through  the  GATE  input  by  sending  a  0-to-1  pulse  to  it.  The
following two steps must be performed:
•  Load the count registers.
•  A 0-to-1 pulse must be sent to the GATE input to trigger the counter.
Contrast  this  with  mode  0,  in  which  the  counter  produces  the  output
immediately after the counter is loaded as long as  GATE = 1.In mode 1 after
sending  the  0-to-1  pulse  to  GATE,  OUT  becomes  low  and  stays  low  for  a
duration of N×T, then becomes high and stays high until the gate  is triggered
again.
Mode 2: This mode is also called divide-by-N counter. In this mode, if GATE =
1,  OUT  will  be  high  for  the  N×T  clock  period,  goes  low  for  only  one  clock
pulse,  then  the  count  is  reloaded  automatically,  and  the  process  continues
indefinitely.
Mode 3: In this mode if GATE = 1, OUT is a square wave where the high pulse
is equal to the low pulse if N is an even number. In this case the high part and
low  part  of the  pulse  have the  same  duration  and are  equal  to (N/2)×T  (50%
duty cycle). If N is an odd number, the high pulse  is one clock pulse longer.
This mode is widely used as a frequency divider andaudio-tone generator.
Mode 4: In this mode if GATE = 1, the output will gohigh upon loading the count.
It will stay high for the duration of N×T. After the count reaches zero (terminal
AC23  Microprocessor Based System Design
48
count), it becomes low for one clock pulse, then goes high again and stays high
until a new command word or new count is loaded. Torepeat the strobe, the count
must be reloaded again. Mode 4 is similar to mode 2, except that the counter is not
reloaded  automatically.  In  this  mode,  the  count  starts  the  moment  the  count  is
written into the counter.
Mode 5: This mode is similar to mode 4 except that the trigger must be done with
the GATE input. In this mode after the count is loaded, we must send a low-tohigh pulse to the gate to start the counter.
Q.63   What  is  a  macro?  Discuss  different  conditional  constructs/statements  used  while
programming a macro.   (4)
   Ans MACRO:A sequence of instructions to which a name is assigned is called
macro. Macros and subroutines are similar. Macros are used for short sequence of
instructions  whereas  subroutines  for  longer  ones.  Macros  executes  faster  than
subroutines.
The MACRO directive informs assembler the beginningof a macro This is used
with  ENDM  directive  to  enclose  a  macro.  The  general format  of  the  MACRO
directive is :
 Macro Name  MACRO  ARG1, ARG2 , …..,ARG N.
Conditional  assembly  language  statements  are  available  for  use  in  the  assembly
process and in macro sequences. The conditional statements create instructions that
control  the  flow  of  the  program  and  are  variations  of  the  IF-THEN,  IF-THENELSE, DO-WHILE, and REPEAT-UNTIL constructs used inhigh-level language
programming languages.
; assembled portion with WIDT = TRUE and LENGT=TRUE;
IF WIDT
WIDE  DB 72
  ELSE
  ENDIF
  IF LENGT
LONG  DB -1
  ELSE
  ENDIF
Q.64   A 450 ns EPROM won’t work directly with a 5MHz 8088.Why? Explain.  (2)
AnsWhen the 8088 is operated with a 5 MHz clock, it allows 460 ns for the
memory to access data. Because of the decoder’s added time delay 12ns, it is
impossible for this memory to function within 460 ns.
Q.65   What is an interrupt? Discuss all the five software interrupt instructions.  (6)
Ans An  interrupt  is  either  a  hardware-generated  CALL  or  software-generated
CALL.
   The  INTEL  family  microprocessor  has  software  interrupts  INT,  INT0,  INT3
,BOUND and IRET. Out of these five interrupts INT and INT3 are very similar,
BOUND  and  INT0  are  conditional,  and  IRET  is  special interrupt  return
instruction.
AC23  Microprocessor Based System Design
49
   The BOUND instruction, which has two operands, compares a register with two
words of memory data.
   INT0  instruction  checks  the  overflow  flag  (OF).  If  OF=1,  the  INT0  instruction
calls the procedure whose address is stored in interrupt vector type number 4. If
OF=0,  then  the  INT0  instruction  performs  no  operation  and  next  sequential
instruction in the program executes.
   INT  n  instruction  calls  the interrupt  service  procedure  that  begins at  the address
represented  in  vector number  n.  For example, an  INT 80H  or  INT  128  calls  the
interrupt service procedure whose address is storedin vector type 80H (000200H –
000203H). To determine the vector address, just multiply the vector number (n) by
4,  which  gives  the  beginning  address  of  the  4-byte  long  interrupt  vector.  For
example,  an  INT  5  =  4  x  5  =  20  (14H).  The  vector  for INT5  begins  at  address
000014H and continues to 000017H. The only exception is the INT3 instruction, a
1-byte instruction.
   The IRET instruction is a special return instruction used to return for both software
and  hardware  interrupts.  The  IRET  instruction  is  much  like  a  RET,  because  it
retrieves the return address from the stack.
Q.66  Discuss  programmable  keyboard  and  display  interface  -8279  control  word
summary.   (8)
Ans,
   The  8279  is  a  programmable  keyboard  and  display  interfacing  component  that
scans up to 64-key keyboard and controls up to a 16-digit numerical display. This
interface has a built-in FIFO (First-In-First-Out)  buffer that allows it to store up to
eight keystrokes before the microprocessor must retrieve a character. The display
section controls up to 16 numeric displays from an internal 16 x 8 RAM that stores
the coded display information.
 Control Word: 000DDMMM – Mode set is command with  an op-code of 000 and
two fields programmed to select the mode of operation for the 8279. The DD field
selects the mode of operation for the display and the MMM field selects the mode
of operation for the keyboard.
D7  D6  D5  Function  Purpose
0  0  0  Mode Set
Selects the number of display
positions, left or right entry, and
type of keyboard scan.
0  0  1  Clock
Programs the internal clock and
sets the scan and de-bounce
times
0  1  0  Read FIFO
Selects the type of FIFO read
and the address of the read
0  1  1  Read display
Selects the type of display read
and address of the read
1  0  0  Write display
Selects the type of write and
address of the write
AC23  Microprocessor Based System Design
50
1  0  1
Display write
inhibit
Allows half-bytes to be blanked
1  1  0  Clear  Clears the display of FIFO
1  1  1  End interrupt
Clears the IRQ signal to the
microprocessor
The 8279 control word summary
Q.67   State the importance of PUBLIC, EXTRN directives in modular programming.  (4)
Ans The  PUBLIC  and  EXTRN  directives  are  very  important to  modular
programming. PUBLIC used to declare that labels of  code, data, or entire segments
are  available to  other  program  modules.  EXTRN  (external)  declares  that  labels  are
external to modules. Without these statements, modules could not be linked together
to create a program by using modular programming techniques. They might link, but
one module would not be able to communicate to another.
   The  PUBLIC directive  is  placed  in  the  op-code  field  of  an  assembly  language
statement to define a label as public, so that the label can be used by other modules.
  The  EXTRN statement  appears  in  both  data  and  code  segments  to  define  labels  as
external to the segment. If data are defined as external, their sizes must be defined as
BYTE, WORD or DWORD.
Q.68  What is the main difference between 16 bit and 32 bit versions of C/C++ while using
in line assembler.   (4)
Ans The  32-bit  applications  are  written  using  Microsoft  Visual  C/C++  for
windows and the 16-bit applications are written using Microsoft C/C++ for DOS. The
main difference is that Visual C/C++ for windows is  more common today, but does
not easily call DOS functions such as INT21H.
Q.69   Explain how memory management is improved in Pentium processors?  (4)
  Ans  The memory management is improved by adding paging  unit and a new system
memory-management mode.
  Paging Unit: The paging mechanism functions with4K – byte memory pages or with a
new extension available to the Pentium with 4M byte-memory pages. In the Pentium,
with  the  new  4M-byte  paging  feature  memory  for  the  page-table  reduced  to  single
page table.
  Memory – management mode: The system memory-management mode (SMM) is on
the same level as protected mode, real mode, and virtual mode, but it is provided to
function as a manager. The SMM is not intended to be used as an application or a
system  level  feature.  It  is  intended  for  high-level system  functions  such  as  power
management and security, which most Pentiums use during operation.
Q.70  Mention how do the following instructions differ in their functionality-  (4)
(i)  NEG & NOT  (ii) DIV & IDIV
 (iii) AND & TEST  (iv) CMP & SUB
AC23  Microprocessor Based System Design
51
Ans,  NOT:  Logical  inversion  or  the  one’s  complement  and  NEG:  arithmetic
sign inversion or the two’s complement.
   DIV: Unsigned numbers division and IDIV: Signed number division.
   AND: Performs the AND operation and changes the  destination operand. TEST:
Test  instruction  performs  the  AND  operation  and  it  wont  changes  destination
operand but it only affects the condition of the flag register.
   SUB: Performs the subtraction operation and changes the destination operand.
CMP: Comparison instruction is a subtraction that changes only the flag bits; the
destination operand never changes.
Q.71   Why memory decoding is required? Describe 74LS139 memory decoder  (4)
AnsIn order to attach a memory device to the microprocessor, it is necessary to
decode the address sent from the microprocessor. Decoding makes the memory
function at a unique section or partition of the memory map. Without an address
decoder, only one memory device can be connected toa microprocessor, which
would make it virtually useless.
   The 74LS139 is a dual 2-to-4 line decoder. It contains two separate 2-to-4 line
decoders – each with its own address, enable, and output connections.
The Pin-out of the 74LS139
Q.72  Explain data addressing modes (with examples) ava ilable in microprocessors.(8)
Ans, Direct Mode:
•  Instruction includes memory access.
•  CPU accesses that location in memory.
Example:
LDAC 5
AC23  Microprocessor Based System Design
52
Reads the data from memory location 5, and stores the data in the CPU’s
accumulator.
Indirect Mode:
•  Address specified in instruction contains address where the operand resides.
Example:
LDAC @5 or LDAC (5)
Retrieves contents of location 5, uses it to accessmemory address.
Register Direct and Register Indirect Modes
•  Does not specify a memory address. Instead specifies a register.
Example:
LDAC R
Where R is a register containing the value 5.The instruction copies the value 5 from
register and into the CPU’s accumulator.
Immediate Mode
•  The operand specified in this mode is the actual data it self.
Example:
LDAC #5
Moves the value 5 into the accumulator.
Implicit Mode
•  Does not exactly specify an operand. Instruction implicitly specifies the
operand because it always applies to a specific register.
Example:
CLAC
Clears the accumulator, and sets value to zero. Nooperands needed.
Relative Mode
•  Operand supplied is an offset, not the actual address. Added to the contents
of the CPU’s program counter register to generate the required address.
Example:
LDAC $5 is located at memory location 10, and it takes up two blocks of memory.
Thus the value retrieved for this instruction will be 12 + 5, and will be stored in the
accumulator
Index Mode and Base Address Mode
•  Address supplied by the instruction is added to thecontents of an index
register.
•  Base address mode is similar except, the index register is replaced by a base
address register.
Example:
LDAC 5(X) where X = 10
Reads data from location (5 + 10) = 15 and stores it in the accumulator.
Q.73  What is the use of these assembler directives-?
 (i) .MODEL  (ii) PROC  (2)
Ans
MACRO:A sequence of instructions to which a name is assigned is called macro.
Macros  and  subroutines  are  similar.  Macros  are  used for  short  sequence  of
instructions  whereas  subroutines  for  longer  ones.  Macros  executes  faster  than
subroutines.
The MACRO directive informs assembler the beginningof a macro This is used with
ENDM directive to enclose a macro. The general format of the MACRO directive is:
AC23  Microprocessor Based System Design
53
 Macro Name  MACRO  ARG1, ARG2 , …..,ARG N.
PROC:  The  PROC and  ENDP  directives  indicate  the  start  and  end  of a procedure.
These directives force structure because the procedure is clearly defined. The PROC
directive indicates the start of a procedure, must  also be followed with a NEAR or
FAR.  A  NEAR  procedure  is  one  that  resides  in  the  same  code  segment  as  the
program. A FAR procedure may reside at any locationin the memory system.
Q.74   (i) Convert binary number in two’s compliment form0100 1000
 (ii) Convert hexadecimal BCH to decimal  (2)
Ans.
 01001000 => 10111000
BCH =>1011 1100 => 188.
Q.75 What is TPA (transient program area)? Draw the memory map of TPA in a personal
computer and explain different areas.  (6)
Ans
  The memory system is divided into three main parts : TPA, System are and XMS (
extended memory system).
  The  TPA  holds  the  DOS  operating  system  and  other programs  that  control  the
computer  system.  The  TPA  also  stores  any  currently  active  or  inactive  DOS
application programs. The length of the TPA is 640Kbytes.
9FFFF  MSDOS Program
9FFF0
Free TPA
.
.
.
.
.
.
08E30  COMMAND.COM
08490
Device drivers such
as MOUSE.SYS
02530  MSDOS Program
01160  IO.SYS Program
00700
DOS Communication
area
00500
BIOS
Communication area
00400
Interrupt Vectors
00000
The memory map of the TPA in a Personal Computer
Q.76  What is memory paging? Explain how it is used for memory addressing.  (6)
AC23  Microprocessor Based System Design
54
Ans
   The  memory  paging  mechanism  located  within  the  80386  and  above  allows  any
physical memory location to be assigned to any linear address. The linear address is
defined  as  the  address  generated  by  a  program.  With the  memory  paging  unit,  the
linear  address  is  invisibly  translated  into  any  physical  address,  which  allows  an
application written to function at a specific address to be located through the paging
mechanism. It also allows memory to be placed into areas where no memory exists.
Q.77  Describe in detail the software interrupts available in INTEL family. How interrupts
are executed in real and protected mode.  (8)
  Ans
The INTEL family microprocessor has software interrupts INT, INT0, INT3 ,BOUND
and IRET. Out of these five interrupts INT and INT3are very similar, BOUND and
INT0 are conditional, and IRET is special interruptreturn instruction.
The BOUND instruction, which has two operands, compares a register with two words
of memory data.
INT0 instruction checks the overflow flag (OF). If  OF=1, the INT0 instruction calls
the procedure whose address is stored in interrupt vector type number 4. If OF=0, then
the  INT0  instruction  performs  no  operation  and  next sequential  instruction  in  the
program executes.
INT  n  instruction  calls  the  interrupt  service  procedure  that  begins  at  the  address
represented  in  vector  number  n.  For  example,  an  INT 80H  or  INT  128  calls  the
interrupt  service  procedure  whose  address  is  stored in  vector  type  80H  (000200H  –
000203H). To determine the vector address, just multiply the vector number (n) by 4,
which gives the beginning address of the 4-byte long interrupt vector. For example, an
INT  5  =  4  x  5  =  20  (14H).  The  vector  for  INT5  begins  at  address  000014H  and
continues to 000017H. The only exception is the INT3 instruction, a 1-byte instruction.
The IRET instruction is a special return instruction used to return for both software and
hardware interrupts. The IRET instruction is much like a RET, because it retrieves the
return address from the stack.
Q.78 Explain  the  necessity  of  decoding  when  memory  device  is  attached  to  a
microprocessor? With neat diagram indicate how a simple NAND gate decoder is used
to select a 2716 EPROM memory component for memory  locations FF800H-FFFFFH.
(5)
Ans
  In order to attach a memory device to the microprocessor, it is necessary to decode the
address  sent  from  the  microprocessor.  Decoding  makes  the  memory  function  at  a
unique section or partition of the memory map. Without an address decoder, only one
memory device can be connected to a microprocessor,which would make it virtually
useless.
  Simple NAND gate Decoder:  When the 2k x 8 EPROM is used, address connection
A10  –  A0  of  the 8088 are  connected to  address inputs A10-A0  of  the  EPROM.  The
remaining nine address pins (A19-A11) are connectedto the inputs of a NAND  gate
AC23  Microprocessor Based System Design
55
decoder. The decoder selects the EPROM from one of the many 2Kbyte sections of the
entire  1Mbyte  address  range  of  the  8088  microprocessor.
  In  this circuit, a  single NAND gate  decodes  the  memory  address. The  output  of  the
NAND gate is logic 0 whenever the 8088 address pinsattached to its inputs (A19-A11)
are all logic 1s. The active low , logic 0 output of the NAND gate decoder is connected
to the CE’ input pin that selects (enables) the EPROM.
Q.79  Write a Program in assembly language to find the largest of n numbers stored in the
memory.   (8)
   Ans
   MOV AX, 0000
   MOV SI, 0200
   MOV CX, [SI]
   BACK : INC SI
   INC SI
   CMP AX, [SI]
   JAE GO
   MOV AX, [SI]
   GO: LOOP BACK
   MOV [0251], AX
   INT 3.
Q.80   Define the following   (3)
(i) Isolated I/O  (ii) memory mapped I/O
   (iii) Hand shaking
Ans
   There  are  two  schemes  for  the  allocation  of  addresses  to  memories  and  input  /
output devices.
AC23  Microprocessor Based System Design
56
(i).  Memory  Mapped  I/O  Scheme:  In  this  scheme  there  is  only  one  address
space. Address space is defined as all possible addresses that microprocessor can
generate.  Some  addresses  are  assigned  to  memories  and  some  addresses  to  I/O
devices. An I/O device is also treated as a memory  location and one address is
assigned  to  it.  In  this  scheme  all  the  data  transfer  instructions  of  the
microprocessor can be used for both memory as well as I/O device. This scheme
is suitable for a small system.
(ii).  In I/O mapped I/O scheme the addresses assigned to  memory locations can
also  be  assigned  to  I/O  devices.  Since  the  same  address  may  be  assigned  to  a
memory  location  or  an  I/O  device,  the  microprocessor  must  issue  a  signal  to
distinguish whether the address on the address bus is for a memory location or an
I/O device.
(iii).  Hand  shaking:  In  an  ASYNCHRONOUS  data  transfer  is  not  based  on
predetermined  timing  pattern.  This  technique  of  data  transfer  is  used  when  the
speed of an I/O device does not match the speed of  the microprocessor, and the
timing characteristic of I/O device is not predictable. In this technique the status
of  the  I/O  device  i.e.  whether  the  device  is  ready  or  not,  is  checked  by  the
microprocessor  before  the  data  are  transferred. The microprocessor  initiates  the
I/O device to get ready and then continuously checks the status of the I/O device
till  the  I/O  device  becomes  ready  to  transfer  data. When  I/O  device  becomes
ready, the microprocessor sends instructions to transfer data. This mode of data
transfer  is  also  called  handshaking  mode  of  data  transfer.  The  microprocessor
issues  an  initiating  signal  to  the  I/O  device  to  get  ready.  When  I/O  device
becomes ready it sends signals to the processor to  indicate that it is ready. Such
signals are calledhandshake signals.
Q.81  Explain in detail the operation of 8255 in mode1 taking suitable example.  (8)
Ans
  In mode1, Ports A and B are programmed as input or output ports and Port C is used
for handshaking.
Example:
PA[7:0
]
STB
A
IBF
A
INTR
A
PC
3
PC
5
PC
4
PB[7:0
]
STB
B
IBF
B
INTR
B
PC
0
PC
1
PC
2
PC6,
7
8255
PA[7:0
]
OBFA
ACKA
INTR
A
PC
3
PC
6
PC
7
PB[7:0
]
OBFB
ACKB
INTR
B
PC
0
PC
1
PC
2
PC4,
5
8255
AC23  Microprocessor Based System Design
57
Q.82   What is the function of 8254 Programmable IntervalTimer? Discuss any one of its
applications in detail.   (8)
AC23  Microprocessor Based System Design
58
Ans
•  8253/54 Timer Description and Initialization
•  PTI (programmable Interval Timer/Counter)
•  8253 and 8254 have exactly the same pin-out.
•  8254 is a superset of the 8253.
•  It Generates accurate time delays
•  It  can  be  used  for  applications  such  as  a  real-time clock,  an  event
counter,  a  digital  one  shot,  a  square  wave  generator  and  a  complex
waveform generator
8254 Functional Description:
8254 Programming:
AC23  Microprocessor Based System Design
59
8254 Mode1 Operation:
Q.83  Discuss the control words (ICWS) of IC8259.  (5)
Ans
  The Programmable interrupt controller is used when several I/O devices transfer data
using  interrupt  and  they  are  connected  to  the  same  interrupt  line  of  the
microprocessor.
  The Intel 8259 is a single chip programmable interrupt controller. It is compatible
with 8086, 8088 and 8085 microprocessor. It is a 28–pin DIP I.C package and uses
N-MOS technology.
8259 Control Word Initialization
AC23  Microprocessor Based System Design
60
AC23  Microprocessor Based System Design
61
Q.84 Write short note on “ANY FOUR” of the following  (16)
   (i)  ISA BUS
(ii).  Graphic Adapter and MONITOR
(iii).  DMA controller
(iv).  Protected mode addressing
Ans
    (i)  The ISA or Industry Standard Architecture,  bus has been around since the
very start  of  the  IBM-compatible personal computer  system. In fact,  any card
from the very first personal computer will plug into and function in any of the
modern Pentium 4-based computers. This is all made  possible by the ISA bus
interface found in  all  these machines,  which  is still  compatible  with  the  early
personal computers.
    ISA bus has evolved from its original 8-bit standard to the 16-bit standard found
in  most  systems  today.  The  ISA  bus  connector  contains  the  entire  demultiplexed address bus (A19-A0) for the 1M byte 8088 system, the 8-bit data
bus (D7-D0), and the four control signals MEMR’, MEMW’, IOR’ and IOW’
for controlling I/O and any memory that might be placed on the printed circuit
card. ISA Card only operates at 8 MHz rate.
(ii)  Video card converts digital output from the computer into an analog video
signal and sends the signal through a cable to the monitor also called a graphics
card.
•  The number of colors a video card displays is determined by its bit depth
•  The video card’s bit depth, also called the color depth, is the number of bits
it uses to store information about each pixel
•  i.e.  8-bit  video card  uses  8  bits  to store information  about  each  pixel;  this
video card can display 256 colors (2x2x2x2x2x2x2x2)
•  i.e. 24-bit video card uses 24 bits to store information about each pixel and
can display 16.7 million colors
•  The greater the number of bits, the better the resulting image
Video Electronics Standards Association (VESA),  which consists of video card
and  monitor  manufacturers,  develops  video  stands  to define  the  resolution,
number of colors, and other display properties.
g.  Monochrome Display Adapter (MDA)
h.  Hercules Graphics Card
i.  Color Graphics Adapter (CGA)
j.  Enhanced Graphics Adapter (EGA)
k.  Video Graphics Adapter (VGA)
l.  Super VGA (SVGA) and Other Standards Beyond VGA
   (iii)  A  DMA  controller  interfaces  with  several  peripherals  that  may  request
DMA.  The  controller  decides  the  priority  of  simultaneous  DMA  requests
communicates with the peripheral and the CPU, and provides memory addresses
for  data  transfer.  DMA  controller  commonly  used  with  8088  is  the  8237
programmable device.
The  8237  is  in  fact  a  special-purpose  microprocessor.  Normally  it  appears  as
part  of  the  system  controller  chip-sets.  The  8237  is  a  4-channel  device.  Each
AC23  Microprocessor Based System Design
62
channel is dedicated to a specific peripheral device and capable of addressing 64
K bytes section of memory.
(iv).  This addressing allows access to data and programs located above the first
1M byte of memory, as well as within the first 1M byte of memory. Addressing
this  extended  section  of  the  memory  system  requires a  change  to  the  segment
plus an offset addressing scheme used with real mode memory addressing. When
data and programs are addressed in extended memory,the offset address is still
used to access information located within the memory segment.
The  segment  register  contains  a  selector  that  selects  a  descriptor  from  a
descriptor  table.  The  descriptor  describes  the  memory  segment’s  location,
length, and access rights.
Q.85   Compare RS232C and RS422A standards.
   Ans
RS232C  RS422A
1.  Standard defined for
asynchronous communications,
where there is specified timing
between data bits and no fixed
timing between the characters
that the bits form.
2.  This standard defined 25
signal lines and 50ft is the
maximum guaranteed distance.
3.  This standard defines a serial
system with just a single wire for
each direction.
4.  Signal levels are : -25 to -3V
and +3 to +25V.
1.  Date Rate : 10 Mbits/s
2.  Driving ability upto 4000ft
and 10 receivers
3.  It is Differential standard
i.e – Each signal is represented by
a pair of wires and voltage
difference across these wires is
what is sensed at the receiver.
This minimizes the effect of
ground noise or the voltage drop
along the signal leads.
4.  Signal levels are : -2 to -6V and +2 to +6V
Q.86   Discuss the feature of Pentium in brief.
HRQ
HLDA
DRQ
DACK
PI/E
Controler DMA Dispozitiv Periferic
Memoria
principala
HOLD
U C P
MA
MD
MC
HOLDA
Magistrala de adrese
Magistrala de date
Magistrala de comenzi
AC23  Microprocessor Based System Design
63
   Ans
The Pentium is a 32-bit superscalar, CISC microprocessor. The term superscalar is
used for the processor which contains more than onepipeline to execute more than
one instruction simultaneously in parallel.
The main features of Pentium are, it has two ALU’s,one floating-point unit, two 8
KB cache, pre-fetch buffers, a branch target buffer. Two ALU’s means that there
are two pipelines. Each ALU contains five functional units. The two pipelines are
integer pipelines. They are named U and V pipeline.
When Pentium was introduced, its operating frequency was 60 MHz. gradually; the
operating  frequency  was  raised  to  233  MHz.  The  Pentium  uses  0.6  micron  BiCMOS process technology. It uses power management feature.
Q.87   Discuss the following assembler directives with example
i.  DWORD
ii.  OFFSET
iii.  SEGMENT
iv.  MACRO
v.  ASSUME
vi.  ENDP
   Ans
(i).  DWORD:It defines word type variable. The defined variable may have one or
more initial values in the directive statement. If there is one value, two bytes of
memory space are reserved. The general format is
Name of variable  DW  Initial value or values.
(ii).  OFFSET: It is an operator to determine the offset (displacement) of a variable
or procedure with respect to the base of the segment which contains the named
variable or procedure. The operator can be used to load a register with the offset
of a variable.
The operator can be used as follows :
MOV SI, OFFSET ARRAY
(iii).  SEGMENT  :   This  directive  defines  to  the  assembler  the  start  of  a
segment with name segment-name. The segment name should be unique and
follows the rules of the assembler
The Syntax is as follows:
Segment Name SEGMENT  {Operand (Optional)} ; Comment
.
.
.
Segment Name  ENDS.
(iv).  MACRO: A  sequence  of  instructions  to  which  a  name  is  assigned  is
called  macro.  Macros  and  subroutines  are  similar.  Macros  are  used  for  short
sequence  of  instructions  whereas  subroutines  for  longer  ones.  Macros  executes
faster than subroutines.
AC23  Microprocessor Based System Design
64
The  MACRO  directive  informs  assembler  the  beginning of  a  macro  This  is  used
with  ENDM  directive  to  enclose  a  macro.  The  general format  of  the  MACRO
directive is :
 Macro Name  MACRO  ARG1, ARG2 , …..,ARG N.
(v).  ASSUME: This directive will be used to map the segment register names with
memory addresses.
The Syntax is as follows:
ASSUME  SS: Stackseg, DS : Dataseg, CS:Codeseg
The ASSUME will tell the assembler to use the SS register with the address of the
stack segment whose name is stackseg.
(vi).  ENDP: (End Procedure) It informs assembler the end of a procedure. In
assembly  language  programming,  subroutines  are  called  procedures.  A  procedure
may be an independent program module to give certain result or the required value
to  the  calling  program.  This  directive  is  used  together  with  PROC  directive  to
enclose procedure. The general format of ENDP directive is:
Procedure Name   ENDP
Q.88   Discuss Stepper motor interfaced to the 82C55.
   Ans
A stepper motor rotates in steps in response to digital pulse input. The shaft of the
motor rotates in equal increments when a train of input pulses is applied. To control
direction, numbers of steps to appropriate pulses are applied to the stator windings
of the motor.
12 V supply is used to energize the poles. Pulses sent by the microprocessor switch
on  rated  voltage  to  the  windings  of  the  desired  poles.  A  delay  subroutine  is
incorporated in the program. After energizing one set of pole windings some delay
is provided, then the power supply is switched ontothe other set of pole windings.
This delay governs the speed of motor.
AC23  Microprocessor Based System Design
65
Q.89   Discuss the EISA bus and need of PCI bus.
   Ans
The Extended Industry Standard Architecture (EISA) is a 32 bit modification to the
ISA  bus.  As  computers  became  larger  and  had  wider  data  buses,  a  new  bus  was
needed  that  would  transfer  32-bit  data.  The  clocking  speed  limited  up  to  8MHz.
The most common application for the EISA bus is a disk controller or as a video
graphics adapter. These applications benefit from the wider data bus width because
the data transfer rate for these devices are high.
Peripheral  Component  Interconnect  (PCI):  This  bus  was  developed  by  Intel  and
introduced in 1993. It is geared specifically to fifth- and sixth-generation systems,
although the latest generation 486 motherboards usePCI as well.
PCI bus has plug – and – play characteristics and the ability to function with a 64-bit data bus. A PCI interface contains series of registers, located in a small memory
device on the PCI interface, that contains information about the board.
Q.90   Explain cascading of multiple PIC 8259.
   Ans
The 8259A adds 8 vectored priority encoded interrupts to the microprocessor. It can
be expanded to 64 interrupt requests by using one master 8259A and 8 slave units.
CS and WR must be decoded. Other connections are direct to microprocessor.
The pins D7 – D0: the bidirectional data connection, IR7 – IR0: Interrupt request,
used to request an interrupt & connect to a slave in a system with multiple 8259A.
WR :-Connects to a write strobe signal (lower or upper in a 16 bit system) , RD :-
Connects  to  the  IORC  signal  ,   INT  :-  Connects  to  the  INTR  pin  on  the
microprocessor from the master and is connected to a IR pin on a slave and INTA
:-  Connects  to  the  INTA  pin  on  the  microprocessor.  In  a  system  only  the  master
INTA signal is connected
Fig: 8259 Pin Diagram
AC23  Microprocessor Based System Design
66
A0:-  Selects  different  command  words  with  in  the  8259A,   CS  :-  Chip  select  –
enables the 8259A for programming and control, SP/EN :- Slave Program (1 for
master,  0  for  slave)/Enable  Buffer  (controls  the  data  bus  transceivers  in  a  large
microprocessor based system when in buffered mode) and CAS2-CAS0 :- Used as
outputs from the master to the slaves in cascaded systems.
Fig: cascading multiple 8259
Q.91   Discuss need of Pipelining and Caches.
AC23  Microprocessor Based System Design
67
   Ans
The simplest technique for improving performance through hardware parallelism is
pipelining. Pipelining consists of breaking up the  operations to be performed into
simpler  independent  operations,  sort  of  like  the  breaking  up  the  operations  of
assembling  a  car  in  an  assembly  line.  A  typical  processor  pipeline  consists  of  4
pipeline stages (1) Instruction fetch, (2) Instruction decode (3) Instruction execute
and  (4)  Register  file  write-back/memory  access.  In  practice  however,  real
architectures  have  many  more  physical  pipeline  stages,  with  multiple  physical
stages  corresponding  to  one  of  the  above  stages.  For  example  the  execute  stage
might occupy 4 physical pipeline stages
The primary advantages of pipelining are
– Parallelism
– Smaller cycles time
Caches are the other big thing done in the last 2 decades to improve performance.
Keep things locally if they are going to be used soon. From a physics point of view,
an access to memory which is almost exclusively offchip will mean signals have to
travel that much further in one cycle. In practice,since we do not want to make the
system  as  slow  as  its  slowest  component  (memory),  and  the  cycle  time  is  not
determined by the memory access time, and rather memory takes several cycles to
complete.
Q.92   Explain  in  brief  steps  to  develop  a  Microprocessor  based  computer  system
   Ans
The  design  of  a  microcomputer  system  must  begin  with  the  CPU  module. This
module establishes the basic system timing, providean orderly means of starting up
the processor, and provide access to the system buses.
The second step is adding Memory, it is essential to the stored program computer.
From this unit that the CPU fetches instructions directing it in some task. But within
a particular computer system there may be several types of memories each with its
own hierarchy.
The  third  step  is  adding  input  /  output:  This  is  also  known  has  user  interface.
There  are  basically  two  hardware  techniques  for  getting  data  into  and  out  of  a
computer.  The  first  is  the  parallel  interface  and  is  the  most  natural  for
microprocessor. The second technique is the serial interface.

LEAVE A REPLY

Please enter your comment!
Please enter your name here