MC68HC08GR32A MC68HC08GR16A Data Sheet, Rev. 0
Freescale Semiconductor
95
Chapter 9
Keyboard Interrupt Module (KBI)
9.1 Introduction
The keyboard interrupt module (KBI) provides eight independently maskable external interrupts which are
accessible via PTA0–PTA7. When a port pin is enabled for keyboard interrupt function, an internal
pullup/pulldown device is also enabled on the pin.
9.2 Features
Features include:
Eight keyboard interrupt pins with separate keyboard interrupt enable bits and one keyboard
interrupt mask
Hysteresis buffers
Programmable edge-only or edge- and level- interrupt sensitivity
Edge detect programmable for rising or falling edges
Level detect programmable for high or low levels
Exit from low-power modes
Pullup/pulldown device automatically configured based on polarity of edge/level selection
9.3 Functional Description
Writing to the KBIE7–KBIE0 bits in the keyboard interrupt enable register independently enables or
disables each port A pin as a keyboard interrupt pin. Enabling a keyboard interrupt pin also enables its
internal pullup/pulldown device. On falling edge or low level selection a pullup device is configured. On
rising edge or high level selection a pulldown device is configured.
A falling edge is detected when an enabled keyboard input signal is seen as a logic 1 (the
deasserted level) during one bus cycle and then a logic 0 (the asserted level) during the next cycle.
A rising edge is detected when the input signal is seen as a logic 0 during one bus cycle and then
a logic 1 during the next cycle.
A keyboard interrupt is latched when one or more keyboard pins are asserted. The MODEK bit in the
keyboard status and control register controls the triggering mode of the keyboard interrupt.
The KBIP7–KBIP0 bits determine the polarity of the keyboard pin detection. These bits along with the
MODEK bit determine whether a logic level (0 or 1) and/or a falling (or rising) edge is being detected.
If the keyboard interrupt is edge-sensitive only, a falling (or rising) edge on a keyboard pin does not
latch an interrupt request if another keyboard pin is already asserted. To prevent losing an interrupt
request on one pin because another pin is still asserted, software can disable the latter pin while it
is asserted.
If the keyboard interrupt is edge and level sensitive, an interrupt request is present as long as any
keyboard interrupt pin is asserted and the pin is keyboard interrupt enabled.