MK68901 MULTI–FUNCTION PERIPHERAL . . . . .. 8 INPUT/OUTPUT PINS • Individually programmable direction • Individual interrupt source capability - Programmable edge selection 16 SOURCE INTERRUPT CONTROLLER • 8 Internal sources • 8 External sources • Individual source enable • Individual source masking • Programmable interrupt service modes - Polling - Vector generation - Optional In-service status • Daisy chaining capability FOUR TIMERS WITH INDIVIDUALLY PROGRAMMABLE PRESCALING • Two multimode timers - Delay mode - Pulse width measurement mode - Event counter mode • Two delay mode timers • Independent clock input • Time out output option SINGLE CHANNEL USART • Full Duplex • Asynchronous to 65 kbps • Byte synchronous to 1 Mbps • Internal/External baud rate generation • DMA handshake signals • Modem control • Loop back mode 68000 BUS COMPATIBLE 48 PIN DIP OR 52 PIN PLCC DESCRIPTION The MK68901 MFP (Multi-Function Peripheral) is a combination of many of the necessary peripheral functions in a microprocessor system. Included are : 1 DPIP48 PLCC52 Figure 1 : Pin connections. MFP Eight parallel I/O lines Interrrupt controller for 16 sources Four timers Single channel full duplex USART The use of the MFP in a system can significantly reduce chip count, thereby reducing system cost. The MFP is completely 68000 bus compatible, and 24 directly addressable internal registers provide the neDecember 1988 1/33 MK68901 necessary control and status interface to the programmer. The MFP is a derivative of the MK3801 STI, a Z80 family peripheral. PIN DESCRIPTION GND : Ground VCC : +5 volts (± 5%) Chip Select (input, active, low). CS is used to select the MK68901 MFP for accesses to the internal registers. CS and IACK must not be asserted at the same time. DS : Data Strobe (input, active low). DS is used as part of the chip select and interrupt acknowledge functions. R/W : Read/Write (input). R/W is the signal from the bus master indicating whether the current bus cycle is a Read (High) or Write (Low) cycle. DTACK : Data Transfer Acknowledge. (output, active low, tri-stateable) DTACK is used to signal the bus master that data is ready, or that data has been accepted by the MK68901 MFP. knowledge cycle or by clearing the pending interrupt(s) through software. IACK : Interrupt Acknowledge (input, active low). IACK is used to signal the MK68901 MFP that the CPU is acknowledging an interrupt. CS and IACk must not be asserted at the same time. IEI : Interrupt Enable In (input, active low). IEI is used to signal the MK68901 MFP that no higher priority device is requesting interrupt service. IEO : Interrupt Enable Out (output, active low). IEO is used to signal lower priority peripherals that neither the MK68901 MFP nor another higher priority peripheral is requesting interrupt service. General Purpose Interrupt I/O lines. These lines may be used as interrupt inputs and/or I/O lines. When used as interrupt inputs, their active edge is programmable. A data direction register is used to define which lines are to be Hi-Z inputs and which lines are to be push-pull TTL compatible outputs. CS : A1-A5 : D0-D7 : CLK : Address Bus (inputs). The adress bus is used to adress one of the internal registers during a read or write cycle. Data Bus (bi-directional, tri-stateable). The data bus is used to receive data from or transmit data to one of the internal registers during a read or write cycle. It is also used to pass a vector during an interrupt acknowledge cycle. Clock (input). This input is used to provide the internal timing for the MK68901 MFP. RESET : Device reset. (input, active low). Reset disables the USART receiver and transmitter, stops all timers and forces the timer outputs low, disables all interrupt channels and clears any pending interrupts. The General Purpose Interrupt/I/O lines will be placed in the tri-state input mode. All internal registers (except the timer, USART data registers, and transmit status register) will be cleared. INTR : Interrupt Request (output, active low, open drain). INTR is asserted when the MK68901 MFP is requesting an interrupt. INTR is negated during an interrupt ac2/33 10-17 : SO : Serial Output. This is the output of the USART transmitter. SI : Serial Input. This is the input to the USART receiver. RC : Receiver Clock. This input controls the serial bit rate of the USART receiver. Transmitter Clock. This input controls the serial bit rate of the USART transmitter. TC : RR : Receiver Ready. (output, active low) DMA output for receiver, which reflects the status of Buffer Full in port number 15. TR : Transmitter Ready. (output, active low) DMA output for transmitter, which reflects the status of Buffer Empty in port number 16. TAO,TBO, Timer Outputs. Each of the four timers TCO,TDO: has an output which can produce a square wave. The output will change states each timer cycle ; thus one full period of the timer out signal is equal to two timer cycles. TAO or TBO can be reset (logic ”O”) by a write to TACR, or TBCR respectively. XTAL1, XTAL2 : Timer Clock inputs. A crystal can be connected between XTAL1 and XTAL2, or XTAL1 can be driven with a TTL level clock. When driving XTAL1 with a TTL le- MK68901 vel clock, XTAL2 must be allowed to float. When using a crystal, external capacitors are required. See figure 33. All chip accesses are independent of the timer clock. TAI,TBI : Timer A, B inputs. Used when running the timers in the event count or the pulse width measurement mode. The interrupt channels associated with 14 and 13 are used for TAI and TBI, respectively. Thus, when running a timer in the pulse width V000351 3/33 MK68901 Figure 4 : Register Map. Address Port N°. Abbreviation Register N ame 0 1 2 GPIP AER DDR GENERAL PURPOSE I/O ACTIVE EDGE REGISTER DATA DIRECTION REGISTER 3 4 5 6 7 8 9 A B IERA IERB IPRA IPRB ISRA ISRB IMRA IMRB VR INTERRUPT ENABLE REGISTER A INTERRUPT ENABLE REGISTER B INTERRUPT PENDING REGISTER A INTERRUPT PENDING REGISTER B INTERRUPT IN-SERVICE REGISTER A INTERRUPT IN-SERVICE REGISTER B INTERRUPT MASK REGISTER A INTERRUPT MASK REGISTER B VECTOR REGISTER C D E F 10 11 12 TACR TBCR TCDCR TADR TBDR TCDR TDDR 13 14 15 16 17 SCR UCR RSR TSR UDR TIMER A CONTROL REGISTER TIMER B CONTROL REGISTER TIMERS C AND D CONTROL REGISTER TIMER A DATA REGISTER TIMER B DATA REGISTER TIMER C DATA REGISTER TIMER D DATA REGISTER SYNC CHARACTER REGISTER USART CONTROL REGISTER RECEIVER STATUS REGISTER TRANSMITTER STATUS REGISTER USART DATA REGISTER INTERRUPTS The General Purpose I/O-Interrupt Port (GPIP) provides eight I/O lines that may be operated either as inputs or outputs under software control. In addition, each line may generate an interrupt in either a positive going edge or a negative going edge of the input signal. The GPIP has three associated registers. One allows the programmer to specify the Active Edge for each bit that will trigger an interrupt. Another register specifies the Data Direction (input or output) associated with each bit. The third register is the actual data I/O register used to input or output data to the port. These three registers are illstrated in figure 5. The Active Edge Register (AER) allows each of the General Purpose Interrupts to provide an interrupt on either a 1-0 transition or a 0-1 transition. Writing a zero to the appropriate bit of the AER causes the associated input to produce an interrupt on the 1-0 transition. The edge bit is simply one input to an exclusive-or gate, with the other input coming from the input buffer ant the output going to a 1-0 transition detector. Thus, depending upon the state of the input, writing the AER can cause an interrupt-producing transition, which will cause an interrupt on the associated channel, if that channel is enabled. One 4/33 would then normally configure the AER before enabling interrupts via IERA and IERB. Note : Changing the edge bit, with the interrupt enabled, may cause an interrupt on that channel. The Data Direction Register (DDR) is used to define 10-17 as inputs or as outputs on a bit by bit basis. Writing a zero into a bit of the DDR causes the corresponding Interrupt-I/O pin to be a Hi-Z input. Writing a one into a bit of the DDR causes the corresponding pin to be configured as a push-pull output. When data is written into the GPIP, those pins defined as inputs will remain in the Hi-Z state while those pins defined as outputs will assume the state (high or low) of their corresponding bit in the GPIP. When the GPIP is read, the data read will come directly from the corresponding bit of the GPIPregister for all pins defined as output, while the data read on all pins defined as inputs will come from the input buffers. Each individual function in the MK68901 is provided with a unique interrupt vector that is presented to the system during the interrupt acknowledge cycle. The interrupt vector returned during the interrupt acknowledge cycle is shown in figure 6, while the vector register is shown in figure 7. MK68901 There are 16 vector addresses generated internally by the MK68901, one for each of the 16 interrupt channels. The Interrupt Control Registers (figure 8) provide control of interrupt processing for all I/O facilities of the MK68901. These registers allow the program- mer to enable or disable any or all of the 16 interrupts, providing masking for any interrupt, and provide access to the pending and in-service status of the interrupt. Optional end-of-interrupt modes are available under software control. All the interrupts are prioritized as shown in figure 9. Figure 5 : General Purpose I/O Registers. V000352 Figure 6 : Interrupt Vector. V000353 5/33 MK68901 Figure 7 : Vector Register. V000354 Figure 8 : Interrupt Control Registers. V000355 6/33 MK68901 Figure 9 : Interrupt Control Register Definitions Priority Channel HIGHEST 1111 1110 1101 1100 1011 1010 1001 1000 0111 0110 0101 0100 0011 0010 0001 0000 LOWEST Description General Purpose Interrupt General Purpose Interrupt Timer A Receive Buffer Full Receive Error Transmit Buffer Empty Transmit Error Timer B General Purpose Interrupt General Purpose Interrupt Timer C Timer D General Purpose Interrupt General Purpose Interrupt General Purpose Interrupt General Purpose Interrupt Interrupts may be either polled or vectored. Each channel may be individual enabled or disabled by writing a one or a zero in the appropriate bit of Interrupt Enable Registers (IERA, IERB - see figure 8 for all registers in this section). When disabled, an interrupt channel is completely inactive. Any internal or external action which would normally produce an interrupt on that channel is ignored and any pending interrupt on that channel will be cleared by disabling that channel. Disabling an interrupt channel has no effect on the corresponding bit in Interrupt In-Service Registers (ISRA, ISRB) ; thus, if the In-service Registers are used and an interrupt is in service on that channel when the channel is disabled, it will remain in service until cleared in the normal manner. IERA and IERB are also readable. 7(I7) 6(I6) 5(I5) 4(I4) 3(I3) 2(I2) 1(I1) 0(I0) The interrupt mask registers (IMRA and IMRB) may be used to block a channel from making an interrupt request. Writing a zero into the corresponding bit of the mask register will still allow the channel to receive an interrupt and latch it into its pending bit (if that channel is enabled), but will prevent that channel from making an interrupt request. If that channel is causing an interrupt request at the time the corresponding bit in the mask register is cleared, the request will cease. If no other channel is making a request, INTR will go inactive. If the mask bit is re-enabled, any pending interrupt is now free to resume its request unless blocked by a higher priority request for service. IMRA and IMRB are also readable . A conceptual circuit of an interrupt channel is shown in figure 10. When an interrupt is received on an enabled channel, its corresponding bit in the pending register will be set. When that channel is acknowledged it will pass its vector, and the corresponding bit in the Interrupt Pending Register (IPRA or IRPB) will be cleared. IPRA and IPRB are readable ; thus by polling IPRA and IPRB, it can be determined whether a channel has a pending interrupt. IPRA and IPRB are also writeable and a pending interrupt can be cleared without going through the acknowledge sequence by writing a zero to the appropriate bit. This allows any one bit to be cleared, without altering any other bits, simply by writing all ones except for the bit position to be cleared to IPRA or IPRB. Thus a fully polled interrupt scheme is possible. Note : writing a one to IPRA, IPRB has no effect on the interrupt pending register. 7/33 MK68901 Figure 10 : A Conceptual Circuit of an Interrupt Channel. V000356 There are two end-of-interrupt modes : the automatic end-of-interrupt mode and the software end-of-interrupt mode. The mode is selected by writing a one or a zero to the S bit of the Vector Register (VR). If the S bit of the VR is a one, all channels operate in the software end-of-interrupt mode. If the S bit is a zero, all channels operate in the automatic end-ofinterrupt mode, and a reset is held on all in-service bits. In the automatic end-of-interrupt mode, the pending bit is cleared when that channel passes its vector. At that point, no further history of that interrupt remains in the MK68901 MFP. In the software end-of-interrupt mode, the in-service bit is set and the pending bit is cleared when the channel passes its vector. With the in-service bit set, no lower priority channel is allowed to request an interrupt or to pass its vector during an acknowledge sequence ; however, a lower priority channel may still receive an interrupt and latch it into the pending bit. A higher priority channel may still request an interrupt and be ac- knowledged. The in-service bit of a particular channel may be cleared by writing a zero to the corresponding bit in ISRA or ISRB. Typically, this will be done at the conclusion of the interrupt routine just before the return. Thus no lower priority channel will be allowed to request service until the higher priority channel is complete, while channels of still higher priority will be allowed to request service. While the in-service bit is set, a second interrupt on that channel maybe received and latched into the pending bit, though no service request will be made in response to the second interrupt until the in-service bit is cleared. ISRA and ISRB may be read at any time. Only a zero may be written into any bit of ISRA and ISRB ; thus the in-service bits may be cleared in software but cannot be set in software. This allows any one bit to be cleared, without altering any other bits, simply by writing all ones except for the bit position to be cleared to ISRA or ISRB, as with IPRA and IPRB. Figure 11 a : A Conceptual Circuit of the MK68901 MFP Daisy Chaining. V000357 8/33 MK68901 Figure 11 b : Daisy Chaining. V000358 Each interrupt channel responds with a discrete 8bit vector when acknowledged. The upper four bits of the vector are set by writing the upper four bits of the VR. The four low order bits (bit 3-bit 0) are generated by the interrupting channel. To acknowledge an interrupt, IACK goes low, the IEI input must go low (or be tied low) and the MK68901 MFP must have an acknowledgeable interrupt pending. The Daisy Chaining capability (figure 11) requires that all parts in a chain have a common IACK. When the common IACK goes low, all parts freeze and prioritize interrupts in parallel. Then priority is passed down the chain, via IEI and IEO, until a part which has a pending interrupt is reached. The part with the pending interrupt, passes a vector, does not propagate IEO, and generates DTACK. Figure 9 describes the 16 prioritized interrupt channels. As chown, General Purpose Interrupt 7 has the highest priority, while General Purpose Interrupt 0 is assigned the lowest priority. Each of these channels may be reprioritized, in effect, by selectively masking interrupts under software control. The binary numbers under ”channel” correspond to the modified bits IV3, IV2, IV1 and IV0, respectively, of the Interrupt Vector for each channel (see figure 6). Each channel has an enable bit contained in IERA or IERB, a pending latch contained in IPRA or IPRB, a mask bit contained in IMRA or IMRB, and an in– service latch contained in ISRA or ISRB. Additionally, the eight General Purpose Interrupts each have an edge bit contained in the Active Edge Register (AER), a bit to define the line as input or output contained in the Data Direction Register (DDR) and an I/O bit in the General Purpose Interrupt-I/O Port (GPIP). TIMERS There are four timers on the MK68901 MFP. Two of the timers (Timer A and Timer B) are full function timers which can perform the basic delay function and can also perform event counting, pulse width measurement, and waveform generation. The other two timers (Timer C and Timer D) are delay timers only. One or both of these timers canbe used to supply the baud rate clocks for the USART. All timers are prescaler/counter timers with a common independent clock input (XTAL1, XTAL2). In addition, all timers have a time-out output, function that toggles each time the timer times out. The four timers are programmed via three Timer Control Registers and four Timer Data Registers. Timers A and B are controlled by the control registers TACR and TBCR, respectively (see figure 12), and by the data registers TADR and TBDR (figure 13). Timers C and D are controlled by the control register TCDCR (see figure 14) and two data registers TCDR and TDDR. Bits in the control registers allow the selection of operational mode, prescale, and control white the data registers are used to read the timer or write into the time constant register. Timer A and B input pins TAI and TBI, are used for the event and pulse width modes for timers A and B. With the timer stopped, no counting can occur. The timer contents will remain unaltered while the timer is stopped (unless reloaded by writing the Timer Data Register), but any residual count in the prescaler will be lost. 9/33 MK68901 Figure 12 : Timer A and B Control Registers. V000359 * Unused bits : read as zeros. In the delay mode, the prescaler is always active. A count pulse will be applied to the main timer unit each time the prescribed number of timer clock cycles has elapsed. Thus, if the prescaler is programmed to divide by ten, a count pulse will be applied to the main counter every ten cycles of the timer clock. Each time a count pulse is applied to the main counter, it will decrement its contents. The main counter is initially loaded by writing to the Timer Data Register. Each count pulse will cause the current count to decrement. When the timer has decremented down to ”01” , the next count pulse will not cause it to decrement to ”00”. Instead, the next count pulse will cause the timer to be reloaded from the Timer Data Register. Additionally, a ”Time out” pulse will be produced. This Time Out pulse is coupled to the timer interrupt channel, and, if that channel is enabled, an interrupt will be produced. The Time Out pulse is also coupled to the timer output pin and will cause the pin to change states. The output will remain in this new state until the next Time Out pulse occurs. Thus the output will complete one full cycle for each two Time Out pulses. If, for example, the prescaler were programmed to divide by ten, and the Timer Data Register were loa- 10/33 ded with 100 (decimal), the main counter would decrement once for every ten cycles of the timer clock. A Time Out pulse will occur (hence an interrupt if that channel is enabled) every 1000 cycles of the timer clock, and the timer output will complete one full cycle every 2000 cycles of the timer clock. The main counter is an 8-bit binary down counter. It may be read at any time by reading the Timer Data Register. The information read is the information last clocked into the timer read register when the DS pin had last gone high prior to the current read cycle. When written, data is loaded into the Timer Data Register, and the main counter, if the timer is stopped. If the Timer Data Register is written while the timer is running, the new word is not loaded into the timer until it counts through H”01”. However, if the timer is written while it is counting through H”01”, an indeterminate value will be written into the timer constant register. This may be circumvented by ensuring that the data register is not written when the count is H”01”. If the main counter is loaded with ”01”, a Time Out Pulse will occur every time the prescaler presents a count pulse to the main counter. If loaded with ”00”, a Time Out pulse will occur every 256 count pulses. MK68901 Figure 13 : Timer Data Registers (A, B, C, and D). V000360 Figure 14 : Timer C and D Register. V000361 * Unused bi ts : read as zeros. 11/33 MK68901 Figure 15 : A Conceptual Circuit of the MFP Timers in the Pulse Width Measurement Mode. V000332 Changing the prescale value with the timer running can cause the first Time Out pulse to occur at an indeterminate time, (no less than one nor more than 200 timer clock cycles times the number in the time constant register), but subsequent Time Out pulses will then occur at the correct interval. In addition to the delay mode described above, Timers A and B can also function in the Pulse Width Measurement mode or in the Event Count mode. In either of these two modes, an auxiliary control signal is required. The auxiliary control input for Timer A is TAI, and for Timer B,TBI is used. The interrupt channels associated with 14 and 13 are used for TAI and TBI, respectively, in Pulse Width mode. See Figure 15. The pulse width measurement mode functions much like the delay mode. However, in this mode, the auxiliary control signal on TAI or TBI acts as an enable to the timer. When the control signal on TAI or TBI is inactive, the timer will be stopped. When it is active,the prescaler andmain counter are allowed to run. Thus the width of the active pulse on TAI or TBI is determined by the number of timer counts which occur while the pulse allows the timer to run. The active state of the signal on TAI or TBI is dependent upon the associated Interrupt Channel’s edge bit (GPIP 4 for TAI and GPIP 3 for TBI : see Active Edge Register in figure 5). If the edge bit as12/33 sociated with the TAI or TBI input is a one, it will be active high ; thus the timer will be allowed to run when the input is at a high level. If the edge bit is a zero, the TAI or TBI input will be active low. As previously stated, the interrupt channel (13 or 14) associated with the input still functions when the timer is used in the pulse width measurement mode. However, if the timer is programmed for the pulse width measurement mode, the interrupt caused by tran-sitions on the associated TAI or TBI input will occur on the opposite transition. For example, if the edge bit associated with the TAI input (AER-GPIP 4) is as one, an interrupt would normally be generated on the 0-1 transition of the 14 input signal. If the timer associated with this input (Timer A) is placed in the pulse width measurement mode, the interrupt will occur on the 1-0 tran-sition of the TAI signal instead. Because the edge bit (AER-GPIP 4) is a one, Timer A will be allowed to count while the input is high. When the TAI input makes the high to low transition, Timer A will stop, and it is at this point that the interrupt will occur (assuming that the channel is enabled). This allows the interrupt to signal the CPU that the pulse being measured has terminated ; thus Timer A may now be read to determine the pulse width. (Again note that 13 and 14 may still be used for I/O when the timer is in the pulse width measurement mode). If Timer MK68901 A is reprogrammed for another mode, interrupts will again occur on the transition, as normally defined by the edge bit. Note that, like changing the edge bit, placing the timer into or taking it out of the pulse width mode can produce a transition on the signal to the interrupt channel and may cause an interrupt. If measuring consecutive pulses, it is obvious that one must read the contents of the timer and then reinitialize the main counter by writing to the timer data register. If the timer data register is written while the pulse is going to the active state, the write operation may result in an indeterminate value being written into the main counter. If the timer is written after the pulse goes active, the timer counts from the previous contents, and when it counts through H”01”, the correct value is written into the timer. The pulse width then includes counts from before the timer was reloaded. In the event count mode, the prescaler is disabled. Each time the control input on TAI or TBi makes an active transition as defined by the associated Interrupt Channel’s edge bit, a count pulse will be generated, and the main counter will decrement. In all other respects, the timer functions as previously described. Altering the edge bit while the timer is in the event count mode can produce a count pulse. The interrupt channel associated with the input (I3 for I4 for TAI) is allowed to function normally. To count transitions reliably, the input must remain in each state (1/O) for a length of time equal to four periods of the timer clock ; thus signals of a frequency up to one fourth of the timer clock can be counted. The manner in which the timer output pins toggle states has previously been described. All timer outputs will be forced low by a device RESET. The output associated with Timers A and B will toggle on each Time Out pulse regardless of the mode the timers are programmed to. In addition, the outputs from Timers A and B can be forced low at any time by writing a ”1” to the reset location in TACR and TBCR, respectively. The output will be forced to the low state during the WRITE operation, and at the conclusion of the operation, the output will again be free to toggle each time a Time Out pulse occurs. This feature will allow waveform generation. During reset, the Timer Data Registers and the main counters are not reset. Also, if using the reset option on Timers A or B, one must make sure to keep the other bits in the correct state so as not to affect the operation of Timers A and B. USART Serial Communication is provided by a full-duplex double-buffered USART, which is capable of either asynchronous or synchronous operation. Variable word length and start/stop bit configurations are available under software control for asynchronous operation. For synchronous operation, a Sync Word is provided to establish synchronization during receive operations. The Sync Word will also be repeatedly transmitted when no other data is available for transmission. Moreover, the MK68901 allows stripping of all Sync Words received in synchronous operation. The handshake control lines RR (Receiver Ready) and TR (Transmitter Ready) allow DMA operation. Separate receive and transmit clocks are available, and separate receive and transmit status and data bytes allow independent operation of the transmit and receive sections. The USART is provided with three Control/Status Registers and a Data Register. The USART Data Register form is illustrated in figure 16. The programmer may specify operational parameters for the USART via the Control Register, as shown in figure 17. Status of both the Receiver and Transmitter sections is accessed by means of the two Status Registers, as shown in figures 18 and 19. Data written to the Data Register is passed to the transmitter, while reading the Data Register will access data received by the USART. Figure 16 : USART Data Register. V000362 13/33 MK68901 Figure 17 : USART Control Register (UCR). V000363 ÷ 16/÷ 1 : When this bit is zero, data will be clocked into and out of the receiver and transmitter at the frequency of their respective clocks. When this bit is loaded with a one, data will be clocked into and out of the receiver and transmitter at one sixteenth the frequency of their respective clocks. Additionally, when placed in the divide by sixteen mode, the receiver data transition resynchronization logic will be enabled. WL0-WL1 :Word Length Control. These two bits set the length of the data word (exclusive of start bits, stop bits, and parity bits as follows: WL1 W L0 0 0 1 1 Word Length 0 1 0 1 8 7 6 5 Bits Bits Bits Bits ST0-ST1 : Start/stop bit control (format control). These two bits set the format as follows ST1 ST0 Start Bits StopBits 0 0 †1 1 0 1 0 1 0 1 1 1 0 1 11/2 2 Format SYNC ASYNC ASYNC ASYNC : PARITY : Parity Enabled. When set (”1”), parity will be checked by the receiver, parity will be calculated, and a parity bit will be inserted by the transmitter. When cleared (”0”) no parity check will be made and no parity bit will be inserted for transmission. 14/33 For a word length of 8 the MFP calculates the parity and appends it when transmitting a sync character. For shorter lengths, the parity must be stored in the Sync Character Register (SCR) along with the sync character. E/O : Even-Odd. When set (”1”), even parity will be used if parity is enabled. When cleared (”0”), odd parity will be used if parity is enabled. Note that the synchronous or asynchronous format may be selected independently of a ÷ 1 or ÷ 16 clock. Thus it is possible to clock data synchronously into the device but still use start and stop bits. In this mode, all normal asynchronous format features still apply. Data will be shifted in after a start bit is encountered, and a stop bit will be checked to determine proper framing. If a transmit underrun condition occurs, the output will be placed in a marking state, etc. It is conversely possible to clock data in asynchronously using a synchronous format. There is data transition detection logic built into the receive clock circuitry which will re-synchronize the internal shift clock on each data transition so that, with sufficienty frequent data transitions, start bits are not required. In this mode, all other common synchronous features function normally. This re-synchronization logic is only active in ÷ 16 clock mode. RECEIVER The receiver section of the USART is configured by the UCR as previously described. The status of the receiver can be determined by reading and writing to the Receiver Status Register (RSR). The RSR is configured as follows : MK68901 Figure 18 : Receiver Status Register (RSR). V000364 BF : OE : PE : FE : F/S : Buffer Full. This bit is set when the incoming word is transferred to the receive buffer. The bit is cleared when the receive buffer is read by reading the UDR. This bit of the RSR is read only. Overrun Error. This flag is set if the incoming word is completely received and due to be tranferred to the receive buf-fer, but the last word in the receive buf-fer has not yet been read. When this condition occurs, the word in the receive buffer is not overwritten by the new word. Note that the status flags always reflect the status of the data word currently in the receive buffer. As such, the OE flag is not actually set until the good word currently in the buffer has been read. The interrupt associated with this error will also not be generated unti the old word in the receive buffer has been read. OE flag is cleared by reading the receiver status register, and new data words cannot be shifted to the receive buffer until this is done. Parity Error. This flag is set if the word received has a parity error. The flag is set when the received word is tranferred from the shift register to the receive buffer if the error condition exists. The flag is cleared when the next word which does not have a parity error is tranferred to the receive buffer. Frame Error. This flag only applies to the asynchronous format. A frame error is defined as a non-zero data word which is not followed by a stop bit. Like the PE flag, the FE flag is set or cleared when a word is transferred to the receive buffer. Found/Search. This combination control bit and flag bit is only used with the synchronous format. It can be set or cleared by writing to this bit of the RSR. When this bit is cleared, the receiver is placed in the search mode. In this mode, a bit by bit comparison of the incoming data to the character in the Sync Character Register (SCR) is made. The word length counter is disabled. When a match is found, this bit will be set automatically, and the word length counter will start as sync has not been achieved. An interrupt will be generated on the receive error channel when the match occurs. The word just shifted in will, or necessity, be equal to the sync character, and it will not be transferred to the receive buffer. B: M/CIP : SS : RE : Break. This flag is used only when the asynchronous format is selected. This flag will be set when an all zero data word, followed by no stop bit, is received. The flag will stay set until both a non-zero bit is received and the RSR has been read at least once since the flag was set. Break indication will not occur if the receive buffer is full. Match/Character in Progress. If the synchronous format is selected, this flag is the Match flag. It will be set each time the word transferred to the receive buffer matches the sync character. It will be reset each time the word transferred to the receive buffer does not match the sync character. If the asynchronous format is selected, this flag represents Character in Progress. It will be set upon a start bit detect and cleared at the end of the word. Sync Strip Enable. If this bit is set to a one, data words that match the sync character will not be loaded into the receive buffer, and no buffer full signal will be generated. Receiver Enable. This control bit is used to enable or disable the receiver. If a zero is written to this bit of the RSR, the receiver will turn off immediately. All flags including the F/S bit will be cleared. If a one is written to this bit, normal receiver operation is enabled. The receive clock has to be running before the receiver is enabled. 15/33 MK68901 There are two interrupt channels associated with the receiver. One channel is used for the normal Buffer Full condition, while the other channel is used whenever an error condition occurs. Only one interrupt is generated per word received, but dedicating two channels allows separate vectors : one for the normal condition, and one for an error condition. If the error channel is disabled, an interrupt will be gen-erated via the Butter Full Channel, whether the word received is normal or in error. Those conditions which produce an interrupt via the error channel are : Overrun, Parity Error, Frame Error, Sync Found, and Break. If a received word has an error associated with it, and the error interrupt channel is enabled, an interrupt will occur on the error channel only. Each time a word is transferred into the receive buffer, a corresponding set of flags is latched into the RSR. No flags (except CIP) are allowed to change until the data word has been read from the receive buffer. Reading the receive buffer allows a new data word to be transferred to the receive buffer when it is received. Thus one should first read the RSR then read the receive buffer (UDR) to ensure that the flags just read match the data word just read. If done in the reverse order, it is possible that subsequent to reading the data word from the receive buffer, but prior to reading the RSR, a new word may be received and transferred to the receive buffer and, with it, its associated flags latched into the RSR. Thus, when the RSR is read, those flags may actually correspond to a different data word. It is good practice, also to read the RSR prior to a data read as, when an overrun error occurs, the receiver will not assemble new characters until the RSR has been read. As previously stated, when overrun occurs, the OE flag will not be set and the associated interrupt will not be generated until the receive buffer has been read. If a break occurs, and the receive buffer has not yet been read, only the B flag will be set (OE will not be set). Again, this flag will not be set until the last valid word has been read from the receive buffer. If the break condition ends and another whole data word is received before the receive buffer is read, both the B and OE flags will be set once the receive buffer is read. If a break occurs while the OE flag is set, the B flag will also be set. A break generates an interrupt when the condition occurs and again when the condition ends. If the break condition ends before it is acknowledged by reading the RSR, the receiver error interrupt indicating end of break will be generated once the RSR is read. Anytime the asynchronous format is selected, start bit detection is enabled. New data is not shifted into the shift register until a zero bit is detected. If a ÷ 16 clock is selected, along with the asynchronous format, false start bit detection is also enabled. Any transition has to be stable for 3 positive going edges of the receive clock to be called a valid transition. For a start bit to be good, a valid 0-1 transition must not occur for 8 positive clock transitions after the initial valid 1-0 transition. After a good start bit has been detected, valid transitions in the data are checked for continously. When a valid transition is detected, the counter is forced to state zero, andno more transition checking is started until state four. At state eight, the ”previous state” of the transition checking logic is clocked into the receiver. As a result of this resynchronization logic, it is possible to run with asynchronous clocks without start and stop bits if there are sufficient valid transitions in the data stream. This logic also makes the unit more tolerant of clock skew for normal asynchronous communications than a device which employs only start bit synchronization. Figure 19 : Transmitter Status Register (TSR). V000365 16/33 MK68901 TRANSMITTER The transmitter section of the USART is configured as to format, word length, etc. by the UCR, as previously described. The status of the transmitter can be determined by reading or writing the Transmitter Status Register (TSR). The TRS is configured as follows : BE : Buffer Empty. This status bit is set when the word in the transmit buffer is transferred to the output shift register and thus the transmit buffer may be reloaded with the next data word. The flag is cleared when the transmit buffer is reloaded. The transmit buffer is loaded by writing to the UDR. UE : This bit is set when the last word has been shifted out of the transmit shift register before a new word has been loaded into the transmit buffer. It is not necessary to clear this bit before loading the UDR. This bit may be cleared by either reading the TSR or by disabling the transmitter. After the setting of the UE bit, one full transmitter clock cycle is required before this bit can be cleared by a read. The timing in some systems may allow a read of the TSR before the required clock cycle has been completed. This would result in the UE bit not being cleared until the following read. To avoid this problem, a dummy read of the TSR should be performed at the end of he UE service routine. Only one underrun error may be generated between loads of the UDR regardless of the number of transmitter clock cycles between UDR loads. AT : END : This bit causes the receiver to be enabled at the end of the transmission of the last word in the transmitter if the transmitter has been disabled. End or Transmission. When the transmitter is turned off with a character still in the output shift register, transmission will continue until that character is shifted out. Once it has cleared the output register, the END bit will be set. If no character is being transmitted when the transmitter is disabled, the transmitter will stop at the next rising edge of the internal shift clock, and END will immediately be set. The END bit is cleared by re-enabling the transmitter. B: H,L : Break. This control bit will cause a break to be transmitted. When a ”1” is written to the B bit of the TSR, a break will be transmitted upon completion of the character (if any) currently being transmitted. A break will continue to be transmitted until the B bit is cleared by writing a ”0” tot his bit of the TSR. At that time, normal transmission will resume. The B bit has no function in the synchronous format. Setting the ”B” bit to a one keeps the ”BE” bit from being set to a one. So, if there were a word in the buffer at the start of break, it would remain there until the end of break, at which time it would be transmitted (if the transmitter is still enabled). If the buffer were not full at the start of break, it could be written at any time during the break. If the buffer is empty at the end of break, the underrun flag will be set (unless the transmitter is disabled). The BREAK bit cannot be set until the transmitter has been enabled and the transmitter has had sufficient time (one clock cycle) to perform the internal reset and initialization functions. High and Low. These two control bits are used to configure the transmitter output, when the transmitter is disabled, as follows : H L Output State 0 0 Hi-Z 0 1 Low (”0”) 1 0 High 1 1 Loop-Connects transmitter output to receiver input, and TC to Receiver Clock (RC and SI are not used ; they are bypassed internally). In loop back mode, transmitter output goes high when disabled. Altering these two bits after Transmitter 17/33 MK68901 Figure 20 : SYNC Character Register. V000366 Enable (XE) is set will alter the output state until END is false. These bits should be set prior to enabling the transmitter. The state of these bits determine the state of the first transmitted character after the transmitter is enabled. If the high impedance mode was selected prior to the transmitter being enabled, the first bit transmitted is indeterminate. XE : Transmitter Enable. This control bit is used to enable or disable the transmitter. When set, the transmitter is enabled. When cleared, the transmitter will be disabled. If disabled, any word currently in the output register will continue to be transmitted when XE is cleared, the transmitter will turn off at the end of the break character boundary, and no end of break stop bit is transmitted. The transmit clock must be running before the transmitter is enabled A ”one” bit always precedes the first word out of the transmitter after the transmitter is enabled. There is a delay between the time the transmitter enable bit is written an when the transmitter reset goes low ; therefore, the H & L bits should be written with the desired state prior to enabling the transmitter. Like the receiver section, there are two separate interrupt channels associated with the transmitter. The buffer Empty condition causes an interrupt via one channel, while the Underrun and END conditions will cause an interrupt via the second channel. When underrun occurs in the synchronous format, the character in the SCR will be transmitted until a new words is loaded into the transmit buffer. In the asynchronous format, a ”Mark” will be continuously transmitted when underrun occurs. The transmit buffer can be loaded prior to enabling the transmitter. When the transmitter is disabled, any character currently in the process of being transmitted will continue to conclusion, but any character in the transmit buffer will not be transmitted and will remain in the buffer. Thus no buffer empty interrupt will occur nor will the BE flag be ste. If the buffer were already empty, the BE flag would be set and would remain set. When the transmitter is disabled with a character in the output register but with no character 18/33 in the transmit buffer, an Underrun Error will not occur when the character in progress concludes. Often it is necessary to send a break for some particular period. To aid in timing a break transmission, a transmission, a transmit error interrupt will be generated at every normal character boundary time during a break transmission. The status register information is unaffected by this error condition interrupt. It should be noted that an underrun error, if present, must be cleared from the TSR, and the interrupt pending register must be cleared of pending transmitter errors at the beginning of the break transmission or no interrupts will be generated at the character boundary time. It the synchronous format is selected, the sync character should be loaded into the Sync Character Register (SCR) as shouwn in figure 20. This character is compared to the received serial data during a Search, and will be continuously transmitted during an underrun condition. All flags in the RSR or TSR will continue to function as described whether their associated interrupt channel is disabled or enabled. All interrupt channels are edge triggered and, in many cases, it is the actual output of a flag bit or flag bits which is coupled to the interrupt channel. thus, if a normal interrupt producing condition occurs while the interrupt channel is disabled, no interrupt would be produced even if the channel was subsequently enabled, because a transition did not occur while the interrupt channel was enabled. that particular flag bit would have to occur a second time before another ”edge” was produced, causing an interrupt to be generated. Error conditions in the USART are determined by monitoring the Receive Status Register and the Transmitter Status Register. These error conditions are only valid for each word boundary and are not latched. When executing block tranfers or data, it is necessary to save any errors so that they can be checked at the end of a block. In order to save error conditions during data transfer, the MK68901 MFP interrupt controller may be used by enabling error interrupt for the desired channel (Receive error or Transmit error) and by masking these bits off. Once the tranfer is complete, the Interrupt Pending Register can be polled, to determine the precence of a pending error interrupt, and therefore an error. MK68901 Unused bits in the sync character register are zeroed out ; therefore, word length should be set up prior to writing the sync word in some cases. Sync word length is the word length plus one when parity is enabled. The user has to determine the parity of the sync word when the word length is not 8 bits. The MK68901 MFP does not add a parity bit to the sync word if the word length is less than 8 bits. The extra bit in the sync word is transmitted as the parity bit. With a word length of eight, and parity selected, the parity bit for the sync word is computed an added on by the MK68901 MFP. RR RECEIVER READY RR is asserted when the Buffer Full bit is set in the RSR unless a parity error or frame error is detected by the receiver. TR TRANSMITTER READY TR is asserted when the Buffer Empty bit is set in the TSR unless a break is currently being transmitted. REGISTER ACCESSES All register accesses are dependent on CLK as shown in the timing diagrams. To read a register, CS and DS must be asserted, and R/W must by high. The internal read control signal is essentially the combination of CS, DS, and RD/WR. Thus, the read ope- ration will begin when CS and DS go active and will end when either CS or DS goes inactive. The address bus must be stable prior to the start of the operation and must remain stable until the end of the operation. Unless a read operation or interrupt acknowledge cycle is in progress the data bus (D0-D7) will remain in the tri-state condition. To write a register, CS and DS must be asserted and R/W must be low. The address must be stable prior to the start of the operation and must remain stable until the end of the operation. After the MK68901 asserts DTACK, the CPU negates DS,. At this time, the MFP latches the data bus and writes the contents into the appropriate register. Also when DS is negated, the MFP rescinds DTACK. For an interrupt acknowledge, the operation starts when IACK goes low, and ends when IACK goes high. The data bus is tri-stated when either IACK or DS goes high. When CS or IACK are asserted the MFP starts an internal cycle. DS is needed to enable the address and data buffers. It is recommended taht CS and IACK be gated by DS so that DS is always present whenever an MFP bus cycle starts. 19/33 MK68901 MK68901 ELECTRICAL SPECIFICATIONS – PRELIMINARY ABSOLUTE MAXIMUM RATINGS Symbol Parameter Value Unit TA Temperature under Bias – 25 to + 100 °C T s tg Storage Temperature – 65 to + 150 °C – 0.3 to + 7 V 1.5 W VI Voltage on Any Pin with Respect to Ground PD Power Dissipation S tr esses above those l ist ed under ”Absol ute Maximum Ratings” may cause permanent damage to the device. This is a stress rating only and functi onal operation of the devi ce at these or any other condition above those indicated in the operational secti ons of this specificati on is not implied. Exposure t o absolut e maximum rating conditions for extended peri ods may aff ect rel iability. D.C. CHARACTERISTICS TA = 0°C to 70°C ; V C C = + 5V ± 5% Unless Otherwise Specified Symbol Parameter Test Condition Min. Max. Unit V IH Input High Voltage 2.0 V CC + .3 V V IL Input Low Voltage – 0.3 0.8 V V OH Output High Voltage (except DTACK) I OH = – 120µA V OL Output Low Voltage (except DTACK) I OL = 2.0mA 0.5 V IL L Power Supply Current Outputs Open 180 mA IL I ± 10 µA 10 µA 2.4 V Input Leakage Current V IN = 0 to V CC I L OH Tri-state Output Leakage Current in Float V OUT = 2.4 to V CC I L OL Tri-state Output Leakage Current in Float V OUT = 0.5V – 10 µA IOH DTACK Output Source Current V OUT = 2.4 – 400 µA I OL DTACK Output Sink Current V OUT = 0.5 5.3 mA Test Condition Max. Unit Unmeasured pins returned to ground 10 pF 10 pF A ll voltages are referenced to ground. CAPACITANCE TA = 25°C, f = 1MHz unmeasured pins returned to ground. Symbol C IN C O UT 20/33 Parameter Input Capacitance Tri-state Output Capacitance MK68901 AC ELECTRICAL CHARACTERISTICS (V CC = 5.0Vdc ± 5%, GND = 0Vdc, T A = 0°C to 70°C) Value Number Characteristic MK689 01-4 MK689 01-5 Min. Min. Max. Unit Fig. Note 5 Max. 1 CS, DS Width High 50 35 ns 21,22 2 R/W, A1-A5 Valid to Falling CS (setup) 0 0 ns 21,22 3 Data Valid Prior to Falling CLK 280 0 ns 22 4 CS, IACK Valid to Falling Clock (setup) 50 ns 21-24 5 CLK Low to DTACK Low ns 21,22 6 CS, DS or IACK High to DTACK High 60 55 ns 21-24 7 CS, DS or IACK High to DTACK Tri-state 100 95 ns 21-24 8 DTACK Low to Data Invalid (hold time) 9 CS, DS or IACK High to Data Tri-state 10 CS or DS High to R/W, A1-A5 Invalid (hold time) 11 Data Valid from CS Low 12 Read Data Valid to DTACK Low (setup) 13 DTACK Low to DS, CS or IACK High (hold time) 14 IEI Low to Falling CLK (setup) 15 IEO Valid from Clock Low (delay) 180 16 Data Valid from Clock Low (delay) 17 IEO Invalid from IACK High (delay) 18 DTACK Low from Clock High (delay) 180 19 IEO Valid from IEI Low (delay) 100 20 Data Valid from IEI Low (delay) 21 Clock Cycle Time 250 22 Clock Width Low 110 23 Clock Width High 24 CS, IACK Inactive to Rising Clock (setup) 25 I/O Minimum Active Pulse Width 26 IACK Width High 27 I/O Data Valid from Rising CS or DS 450 28 Receiver Ready Delay from Rising RC 600 29 Transmitter Ready Delay from Rising TC 30 Timer Output Low from Rising Edge of CS or DS (A & B) (reset T OUT ) 31 T OUT Valid from Internal Timeout 32 Timer Clock Low Time 45 220 0 180 0 50 0 50 0 310 22 ns 21,23,24 ns 21,22 ns 21 50 ns 21 0 0 ns 21-23 50 50 ns 23,24 180 ns 23 300 300 ns 23 150 150 ns 23, 24 165 ns 23, 24 100 ns 24 220 ns 24 1000 ns 21 90 ns 21 110 90 ns 21 100 80 ns 21-23 100 100 ns 25 2 2 T CL K 23-24 450 ns 26 600 ns 27 600 600 ns 28 450 450 ns 29 7 2 t CL K + 300 2 t CL K + 300 ns 29 2 ns 29 50 260 ns 3 220 110 1000 200 90 3,6 1 1 4,5 2 21/33 MK68901 AC ELECTRICAL CHARACTERISTICS (continued) (V C C = 5.0Vdc ± 5%, GND = 0Vdc, T A = 0°C to 70°C) Value Number Characteristic MK689 01-4 MK689 01-5 Min. Min. 33 Timer Clock High Time 110 34 Timer Clock Cycle Time 250 Max. ns 29 1000 ns 29 µs 30 35 RESET Low Time 36 Delay to Falling INTR from External Interrupt Active Transition 380 380 ns 25 37 Transmitter Internal Interrupt Delay from Falling Edge of TC 550 550 ns 28 38 Receiver Buffer Full Interrupt Transition Delay from Rising Edge of RC 800 800 ns 27 39 Receiver Error Interrupt Transition Delay from Falling Edge of RC 800 800 ns 27 40 Serial in Set Up Time to Rising Edge of RC (divide by one only) 80 70 ns 27 41 Data Hold Time from Rising Edge of RC (divide by one only) 350 325 ns 27 42 Serial Output Data Valid from Falling Edge of TC (÷1) ns 28 43 Transmitter Clock Low Time 500 450 ns 28 44 Transmitter Clock High Time 500 450 ns 28 45 Transmitter Clock Cycle Time 1.05 µs 28 46 Receiver Clock Low Time 500 450 ns 27 47 Receiver Clock High Time 500 450 ns 27 48 Receiver Clock Cycle Time 1.05 ∞ µs 27 49 CS, IACK, DS Width Low 80 80 T CL K 29 50 Serial Output Data Valid from Falling Edge of TC (÷16) 490 370 ns 28 Notes : 22/33 1. IEO only goes low if no acknowledgeable interrupt is pending. If IEO goes low, DTACK and the data bus remain tri-stated. 2. TCLK refers to the clock applied to the MFP CLK input pin. tCLK refers to the timer clock signal, regardless of whether that signal comes from the XTAL 1/XTAL2crystal clock inputs or the TAI or TBI timer inputs. 3. If the setup time is not met, CS or IACK will not be recognized until the next falling CLK. 4. If this setup time is met (for consecutive cycles), the minimum hold-off time of one clock cycle will be obtained. If not met, the hold-off will be two clock cycles. 2 200 Fig. 1.8 440 ∞ ∞ 420 0.95 0.95 Note Max. 90 1000 Unit ∞ 2 5. CS is latched internally, therefore if spec’s 1 and 24 are met then CS may be reasserted before the rising clock and still terminate the current bus cycle.The new bus cycle will be delayed by the MK68901 until all appropriate internal operations have completed. 6. Although CS and DTACK are synchronized with the clock, the data out during a read cycle is asynchronous to the clock, relying only on CS for timing. 7. Spec. 30 applies to timer outputs TAO and TBO only. MK68901 TIMER A.C. CHARACTERISTICS Definitions : Error = Indicated Time Value - Actual Time Value tpsc = tCLKx Prescale Value Internal Timer Mode ± 100ns Single Interval Error (free running) (note 2) Cumulative Internal Error 0 ± (tpsc + 4t CLK ) Error between Two Timer Reads Start Timer to Stop Timer Error + (2t CLK + 100ns) to - (tpsc + 6t CLK + 100ns) Start Timer to Read Timer Error Start Timer to Interrupt Request Error (note 3) + 0 to – (tpsc + 6t CLK + 400ns) - 2t CLK to – (4t CLK + 800ns) PULSE WIDTH MEASUREMENT MODE Measurement Accuracy (note 1) Minimum Pulse Width + 2t CLK to – (tpsc + 4t CLK) 4t CLK EVENT COUNTER MODE Minimum Active Time of TAI, TBI 4t CLK Minimum Inactive Time of TAI, TBI 4t CLK Notes : 1. Error may be cumulative if repetitively performed. 2. Error with respect to TOUT or INT if note 3 is true. 3. Assuming it is possible for the timer to make an interrupt request immediately. 23/33 MK68901 Figure 21 : Read Cycle. V000367 Figure 22 : Write Cycle. V000368 Note : CS and I ACK must be a funct ion of DS. 24/33 MK68901 Figure 23 : Interrupt Acknowledge (IEI low). V000369 Figure 24 : Interrupt Acknowledge Cycle (IEI high). V000370 Note : CS and I ACK must be a funct ion of DS. 25/33 MK68901 Figure 25 : Interrupt Timing. V 000371 Note : Active edge i s assumed t o be the rising edge. Figure 26 : Port Timing. V000372 26/33 MK68901 Figure 27 : Receiver Timing. V 000346 Figure 28 : Transmitter Timing. V000347 27/33 MK68901 Figure 29 : Timer Timing. V 000348 Figure 30 : Reset Timing. V000349 28/33 MK68901 Figure 31 : Typical Output. For all outputs except DTACK C L = 100pf R L = 20k Ω R 1 = 180Ω Figure 32 : INTR Test Load. For DTACK CL = 130pf RL = 6kΩ R1 = 470 Ω V000333 V000373 Figure 33 : MK68901 MFP External Oscillator Components. CRY STAL PARAMET ERS : Paral lel resonance, f undament al mode AT cut R S ≤ 150Ω (F R = 2.8 – 5.0MHz); R S ≤ 300Ω (F R = 2.0 – 2.7MHz) C L = 18pf ; C M = 0.02pf ; C h = 5pf ; LM = 96mH F R (typ) = 2.4576MHz V000374 MK68901 ORDER CODES Part Number 68901P04 68901P05 68901N04 68901N05 68901Q04 68901Q05 PackageType Ceramic DIP Ceramic DIP Plastic DIP Plastic DIP Plastic PLCC Plastic PLCC Max. ClockFrequency 4.0MHz 5.0MHz 4.0MHz 5.0MHz 4.0MHz 5.0MHz TemperatureRange 0° 0° 0° 0° 0° 0° to 70°C to 70°C to 70°C to 70°C to 70°C to 70°C 29/33 MK68901 MK68901 48–PIN PLASTIC DUAL–IN–LINE PACKAGE (N) Dim Millimeters Inches Min. Max. Min. Max. A 61.468 62.738 2.420 2.470 B 14.986 16.256 .590 .640 C 13.462 13.97 .530 .550 D 3.556 4064 .140 .160 E 0.381 1.524 .015 .060 F 3048 3.81 .120 .150 G 1.524 2.286 .060 .090 H 1.186 1.794 .090 .110 J 15.24 17.78 .600 .700 K 0.381 0.533 .015 .021 L 0.203 0.305 .008 .012 M 1.143 1.778 .045 .070 30/33 MK68901 MK68901 48–PIN CERAMIC DUAL–IN–LINE PACKAGE (P) Dim A Inches Min. Max. 2.376 2.424 B 0.576 0.604 C 0.120 0.160 D 0.015 0.021 F 0.030 0.055 G 0.100 BSC J 0.008 0.013 K 0.100 0.165 L 0.590 0.616 M 0° 10° N 0.040 0.060 31/33 MK68901 MK68901 52–PIN PLASTIC LEADED CHIP CARRIER (Q) Dim Inches Min. Max. A .165 .180 A1 .090 .130 D .785 .795 D1 .750 .756 D2 .690 .730 E .785 .795 E1 .750 .756 E2 .690 .730 H .042 .048 J .042 .048 K .013 .024 L .008 .014 M .026 .032 N/N 1 .043 .048 32/33 MK68901 MK68901 PIN CONNECTIONS PLCC DIP FUNC. PLCC D IP FUNC. PLCC DIP FUNC. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 – 1 2 3 4 5 6 7 8 9 10 11 – 12 13 14 15 16 NC R/W A1 A2 A3 A4 A5 TC SO SI RC V CC NC NC TAO TBO TCO TDO 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 17 18 – 19 20 21 22 23 24 25 26 27 28 29 – 30 31 32 XTAL1 XTAL2 NC TAI TBI RESET IO I1 I2 I3 I4 I5 I6 I7 NC TR RR INTR 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 IEO IEI CLK GND D0 D1 D2 D3 D4 D5 D6 D7 IACK DTACK DS CS Note : NC – No Connection Information furnished is believed to be accurate and reliable. However, SGS-THOMSON Microelectronics assumes no responsability for the consequences of use of such information nor for any infringement of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of SGS-THOMSON Microelectronics. Specifications mentioned in this publication are subject to change without notice. This publication supersedes and replaces all information previously supplied. SGS-THOMSON Microelectronics products are not authorized for use as critical components in life support devices or systems without the express written approval of SGS-THOMSON Microelectronics. 1994 SGS-THOMSON Microelectronics - All rights reserved. Purchase of I2C Components by SGS-THOMSON Microelectronics conveys a license under the Philips I2C Patent. Rights to use these components in an I2C system is granted provided that the system conforms to the I2 C Standard Specification as defined by Philips. SGS-THOMSON Microelectronics Group of Companies Australia - Brazil - France - Germany - Hong Kong - Italy - Japan - Korea - Malaysia - Malta - Morocco The Netherlands Singapore - Spain - Sweden - Switzerland - Taiwan - Thailand - United Kingdom - U.S.A. 33/33