áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO FEBRUARY 2004 REV. 5.0.1 APPLICATIONS GENERAL DESCRIPTION The ST78C36/36A is a monolithic Parallel Port Interface for use with IBM PC compatible platforms. Operation as a standard Centronics printer port is the default, but software may re-configure the device to support bi-directional IBM PS/2 parallel port, Enhanced Parallel Port (EPP), or the Extended Capabilities Port (ECP, as defined by Hewlett Packard and Microsoft) modes. The ECP modes are supported by a 16 byte FIFO that may be accessed by programmed I/O or DMA cycles. • Printers, Scanners and other peripherals • ZIP Drives and back up drives • Printer Server • Embedded Applications FEATURES • IBM AT bus compatible • Bi-directional port capability • 16 byte FIFO for ECP modes • On-chip oscillator (ST78C36A, ST78C36CQ64) • Software selectable Interrupt (5, 7, or 9) and 8-bit DMA channel (ST78C36CQ64) -IRQx IOCHRDY DRQx PDIR TC -DACKx Printer FIFO Registers Inter Connect Bus Lines & Control signals Register Select Logic A0-A2 A10 -CS AEN -IOR, -IOW Interrupt Control Logic D0-D7 -IOR -IOW RESET Data bus & Control Logic FIGURE 1. ST78C36/36A BLOCK DIAGRAM Printer Data Ports Printer Control Logic Clock & Timing Generator PD0-PD7 -STROBE INIT -AUTOFDX -SELCTIN PE, SELECT BUSY, -ACK -ERROR XTAL2 XTAL1 Exar Corporation 48720 Kato Road, Fremont CA, 94538 • (510) 668-7000 • FAX (510) 668-7017 • www.exar.com áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 GND DRQ2 TC PE -ACK BUSY SLCT -ERROR VCC -IOR -IOW A1 A0 DRQ1 N.C. N.C. 63 62 61 60 59 58 57 56 55 54 53 52 51 50 49 N.C. 1 48 GND -DACK2 2 47 -DACK1 DRQ3 3 46 A2 -DACK3 4 45 PD7 D7 5 44 PD6 D6 6 43 PD5 D5 7 42 PD4 D4 8 41 PD3 D3 9 40 PD2 D2 10 39 PD1 D1 11 38 PD0 D0 12 37 GND AEN 13 36 A10 -IRQ9 14 35 N.C. GND 15 34 N.C. VCC 16 33 N.C. -ERROR VCC -IOR -IOW A1 A0 44 43 42 41 40 27 28 -STROBE -AUTOFDX 32 26 RESET N.C. 25 GND 31 24 -CS 30 23 PDIR -SLCTIN 22 XTAL2 29 21 XTAL1 INIT 20 -IRQ7 19 IOCHRDY N.C. SLCT A0 40 1 A1 41 2 -IOW 42 BUSY -IOR 43 -ACK VCC 44 3 -ERROR 1 4 SLCT 2 PE BUSY 3 5 -ACK 4 TC PE 5 6 TC 6 -IRQ5 N.C. 18 ST78C36CQ64 64-TQFP 17 NOTE: PINOUTS NOT TO SCALE. THE 64-TQFP PACKAGE IS PHYSICALLY SMALLER THAN THE 44-PLCC PACKAGE. 64 FIGURE 2. ST78C36/36A PIN OUT ASSIGNMENTS DRQ3 7 39 A2 DRQ3 7 39 A2 -DACK3 8 38 PD7 -DACK3 8 38 PD7 D7 9 37 PD6 D7 9 37 PD6 D6 10 36 PD5 D6 10 36 PD5 D5 11 35 PD4 D5 11 35 PD4 D4 12 34 PD3 D4 12 34 PD3 D3 13 33 PD2 D3 13 33 PD2 D2 14 32 PD1 D2 14 32 PD1 D1 15 31 PD0 D1 15 31 PD0 D0 16 30 GND D0 16 30 GND AEN 17 29 A10 AEN 17 29 A10 28 -SLCTIN 27 25 -STROBE INIT 24 RESET 26 23 -AUTOFDX 22 28 -SLCTIN -CS 27 INIT GND 26 -AUTOFDX 21 25 -STROBE 20 24 RESET PDIR 23 GND CLOCK 22 -CS 19 21 XTAL2 -IRQ7 20 XTAL1 18 19 -IRQ7 ST78C36CJ44 44-PLCC IOCHRDY 18 IOCHRDY ST78C36ACJ44 44-PLCC ORDERING INFORMATION PART NUMBER PACKAGE OPERATING TEMPERATURE RANGE DEVICE STATUS ST78C36CJ44 44-PLCC 0oC to 70oC Active ST78C36ACJ44 44-PLCC 0oC to 70oC Active ST78C36CQ64 64-TQFP 0oC to 70oC Active 2 áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 PIN DESCRIPTION NAME 44-PLCC PIN # 64-TQFP PIN# TYPE DESCRIPTION DATA BUS INTERFACE A10 A2 A1 A0 29 39 41 40 36 46 53 52 I Address Select Lines. A10 places the ECP control/status/data ports at 0x400 offset from the -CS decoded address. D7 D6 D5 D4 D3 D2 D1 D0 9 10 11 12 13 14 15 16 5 6 7 8 9 10 11 12 I/O Data bus. Bi-directional data port. -IOR 43 55 I Active low AT bus I/O Read strobe. -IOW 42 54 I -CS 22 24 I Chip select (active LOW). A LOW at this pin enables the parallel port / CPU data transfer operation. IOCHRDY 18 19 O I/O Channel ready (internal pull-up / three stated active HIGH). This pin goes low when the device requires addition clock cycles for read and write. -IRQ9 -IRQ7 -IRQ5 19 - 14 20 18 O Interrupt Request Lines (three stated active low). AEN 17 13 I DMA address enable (active HIGH). When this line is HIGH, the DMA controller has control of the address bus. DRQ3 DRQ2 DRQ1 7 - 3 63 51 O Active high AT bus DMA ReQuest for channels 3, 2 and 1 (internal pulldown three stated active HIGH). A request is generated by bringing a DRQx line to a HIGH level. A DRQx line is held HIGH until the corresponding DMA acknowledge “DACKx*” line goes LOW. -DACK3 -DACK2 -DACK1 8 - 4 2 47 I DMA Acknowledge signals for channels 3, 2 and 1 (internal pull-up /three stated active low). TC 6 62 I Terminal Count (active HIGH). The ST78C36 terminates the DMA channel when a HIGH pulse is detected. 3 áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 PIN DESCRIPTION NAME 44-PLCC PIN # 64-TQFP PIN# TYPE DESCRIPTION PRINTER PORT INTERFACE PD7 PD6 PD5 PD4 PD3 PD2 PD1 PD0 38 37 36 35 34 33 32 31 45 44 43 42 41 40 39 38 I/O Bi-directional parallel port (three-state) to transfer data in or out of the ST78C36 parallel port. PD[7:0] are latched during output mode. Output only for SPP and PPF modes, bi-directional for all other modes. -STROBE 25 27 O Data strobe output (internal pull-up / three stated active low). This output indicates to the printer that valid data is available at the printer port (PD0PD7). -AUTOFDX 26 28 O Automatic line feed (internal pull-up / three stated active low). When this signal is low the printer should automatically line feed after each line is printed. INIT 27 29 O Initialize line printer (internal pull-up / three stated active low). When this signal is low, it causes the printer to be initialized. -SLCTIN 28 30 O Line printer select (internal pull-up / three stated active low). When this signal is low, it selects the printer. -ERROR 1 57 I Line printer error (internal pull-up / active low). This is an output from the printer to indicate an error by holding it low during error condition. SLCT 2 58 I Line printer selected (internal pull-up / active high). This is an output from the printer to indicate that the line printer has been selected. BUSY 3 59 I Line printer busy (internal pull-up / active high). An output from the printer to indicate printer is not ready to accept data. -ACK 4 60 I Line printer acknowledge (internal pull-up / active low). This input is pulsed low by the printer to indicate that data has been accepted successfully. PE 5 61 I Line printer paper empty (internal pull-up / active high). An output from the printer to indicate out of paper. PDIR 21 23 O Printer port direction indicator. HIGH indicates device is in input mode, LOW indicates output mode. (ST78C36CJ44 and ST78C36CQ64 only). SYSTEM SIGNALS CLOCK/ XTAL1 20 21 I Crystal oscillator input (ST78C36ACJ44, ST78C36CQ64) or External clock input (ST78C36CJ44), nominal 24 MHz. XTAL2 21 22 O Crystal oscillator output, nominal 24 MHz. ST78C36ACJ44 and ST78C36CQ64 only. RESET 24 26 I System RESET ( active HIGH). 4 áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 PIN DESCRIPTION NAME 44-PLCC PIN # 64-TQFP PIN# TYPE VCC 44 16, 56 Pwr Power Supply (+5V). GND 23,30 15, 25, 37, 48, 64 Pwr Supply Ground. DESCRIPTION 1.0 OVERVIEW This device is designed around the Hewlett Packard/Microsoft specification for Extended Capabilities Port Protocol with “ECR mode 100” defined as Enhanced Parallel Port (EPP) mode. The internal timing engines were designed around a 24 MHz reference, which can be supplied from an external source or by the built-in oscillator circuit (ST78C36ACJ and ST78C36CQ64 only) with an appropriate crystal. At system RESET, the device defaults to standard IBM PC compatible Centronics printer mode (output only). The bi-directional PS/2, EPP, and ECP modes can only be activated by programming the ECR mode field (this requires address bit A10 = 1, which is outside the normal ISA I/O space). Optional capabilities of the ECP specification are set as follows: ■ ■ ■ ■ ■ ■ ■ ECP defined interrupts are pulsed, LOW true (Centronics -ACK is non-pulsed, LOW true). PWord size is forced to 1 byte. There is 1 byte in the transmitter that does not affect the FIFO full bit (ECP modes). RLE compression is not supported in hardware. IRQ channel is selectable as 5, 7, or 9 (ST78C36CQ64 only). DMA channel is selectable as 1, 2, or 3 (ST78C36CQ64 only). FIFO THRESHOLD is set at 8 (used only for non-DMA access to the FIFO). PORT ADDRESS R/W MODE FUNCTION DATA 000 R/W 000, 001 Data Register ECP-AFIFO 000 W 011 ECP FIFO (Address) DSR 001 R All Status Register DCR 002 R/W All Control Register EPP-APort 003 R/W 100 EPP Port (Address) EPP-DPort 004 - 007 R/W 100 EPP Port (Data) C-FIFO 400 W 010 Parallel Port Data FIFO ECP-DFIFO 400 R/W 011 ECP FIFO (Data) T-FIFO 400 R/W 110 Test FIFO Cnfg-A 400 R 111 Configuration Register A Cnfg-B 401 R/W 111 Configuration Register B ECR 402 R/W All Extended Control Register 5 ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO áç REV. 5.0.1 2.0 STANDARD DEFINITIONS • Forward direction only. ■ Compatible Mode: “Centronics” or standard mode. • Reverse direction only. ■ Nibble mode: 4 bits at a time using status lines for data “Hewlett Packard Bi-tronics”. • Bi-directional. ■ ■ EPP: Enhanced Parallel port-used primarily by non-printer peripherals. ECP: Extended Capability Port-used primarily by new generation of printers and scanners. 3.0 INTERNAL REGISTERS 3.1 DATA REGISTER (DATA ) DATA Bits 7-0: For host output cycles in SPP mode (ECR mode 000) or PS/2 mode (ECR mode 001), data from the host is registered at the trailing edge of -IOW. On host input cycles, data at the peripheral port is passed through to the host data bus. 3.2 ECP FIFO ADDRESS ( ECP-AFIFO ) ECP-AFIFO Bits 7-0: This port is only available for programmed I/O (non-DMA), and only has significance for host write. Data written to this port is stored in the FIFO if FIFO-F = 0 and will be lost if FIFO-F = 1. A 9th FIFO bit (tag) is set low on write. A read from this port is the same as a read at 400. 3.3 STATUS REGISTER ( DSR ) This status register is read-only except for bit-0, and all bits are latched for the duration of -IOR. DSR Bit-0: If EPP mode is not selected, this bit returns logic one. During EPP mode, bit-0 will return a high if the EPP 10 msecond TimeOut elapsed during the last EPP read or write cycle (this TimeOut also aborts the EPP cycle). This status bit is cleared by exiting EPP mode or by the host writing a high to bit-0 of this register. DSR Bits 2-1: Reserved, logic one. DSR Bit-3: The true state of the -ERROR pad. DSR Bit-4: The true state of the SLCT pad. DSR Bit-5: The true state of the PE(mpty) pad. DSR Bit-6: The true state of the -ACK pad. DSR Bit-7: The complement of the BUSY pad. 3.4 CONTROL REGISTER ( DCR ) DCR Bit-0: The complement of this bit drives -STROBE, and the complement of the pad state is returned for read. 6 áç REV. 5.0.1 ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO DCR Bit-1: The complement of this bit drives -AUTOFD, and the complement of the pad state is returned for read. DCR Bit-2: This bit drives INIT, and the pad state is returned for read. DCR Bit-3: The complement of this bit drives -SLCTIN, and the complement of the pad state is returned for read. DCR Bit-4: Ack Interrupt Enable set to a high will generate an interrupt when -ACK is low. When either returns to a high state, this interrupt source will go in-active. This interrupt is not pulsed. DCR Bit-5: Peripheral port direction, OUT = 0 and IN = 1. This bit is forced to logic zero by ECR modes 000 or 010. It can be written only in ECR mode 001, and will maintain that state if the ECR mode is changed to 011, 100, or 110. This bit must be set low for EPP mode, which allows the host to control direction with -IOR and -IOW. The final port direction also drives PDIR. DCR Bits 6-7: Reserved, logic zero. 3.5 EPP ADDRESS PORT ( EPP-APort ) When EPP mode is enabled, a host read or write with this port will result in a data transfer directly to/from the peripheral with -SLCTIN active. Direction is set by host read/write and will drive -STROBE low during a write if DCR bit 5 (DIR) is not set high. 3.6 EPP DATA PORT (EPP-DPort ) When EPP mode is enabled, a host read or write with this port will result in a data transfer directly to/from the peripheral with -AUTOFD active. Direction is set by host read/write and will drive -STROBE low during a write if DCR bit 5 (DIR) is not set high. 3.7 PARALLEL PORT DATA ( C-FIFO ) This port is available for programmed I/O and DMA access. Data written to this port is stored in the FIFO if FIFO-F = 0 and will be lost if FIFO-F = 1. Data written to this port will be automatically transferred to the peripheral with -STROBE handshaking with BUSY. This port is only defined for write, host reads will interfere with FIFO read sequencing. 3.8 ECP DATA FIFO ( ECP-DFIFO ) This port is available for programmed I/O and DMA access. Data written to this port is stored in the FIFO if FIFO-F = 0 and will be lost if FIFO-F = 1. A 9th FIFO bit (tag) is set high on write. Data read from this port will undergo de-compression if the FIFO tag bit and data bit-7 are both low. The byte containing the RLE count is loaded into the RLE counter and the succeeding byte in the FIFO will be returned to the host RLE count + 1 times before the FIFO read address is incremented. If a FIFO under-run is incurred during host read, the last data byte is returned and FIFO-E remains coherent. 3.9 TEST FIFO ( T-FIFO ) This port is available for programmed I/O and DMA access. Data written to this port is stored in the FIFO if FIFO-F = 0 and will be lost if FIFO-F = 1. During a read cycle from this port a FIFO under-run will return last data read and FIFO-E remains coherent. 3.10 CONFIGURATION REGISTER A ( Cnfg-A ) This read-only register is available in ECR mode 111 only. Cnfg-A Bits 1-0: Forced to logic zero, this field is don’t care for PWord = 1 byte. 7 áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 Cnfg-A Bit-2: When transmitting, there is 1 byte waiting to be transmitted that does not affect FIFO-F. Cnfg-A Bit-3: Reserved, logic zero. Cnfg-A Bits 6-4: Indicates PWord = 1 byte (8-bit implementation). Cnfg-A Bit-7: Indicates ECP interrupts are pulsed. 3.11 CONFIGURATION REGISTER B ( Cnfg-B ) This register is available in ECR mode 111 only, and returns bits 0-5 as logic zero for the ST78C36CJ44. The ST78C36CQ64 will allow programmed selection of the Interrupt and DMA channels after a system RESET state of 001011 (bits 0-5). Cnfg-B Bits 2-0: With bit 2 forced low, select an 8-bit DMA channel per the following table: TABLE 1: DMA CHANNEL SELECTION: CNFG-B BITS[2:0] WRITE TO FIFO READ FROM FIFO DMA CHANNEL X00 000 3 X01 001 1 X10 010 2 X11 011 3 (Default) Cnfg-B Bits 5-3: Select an IRQ channel per the following table: TABLE 2: IRQ SELECTION: CNFG-B BITS[5:3] WRITE TO FIFO READ FROM FIFO IRQ 000 001 7 001 001 7 (Default) 010 010 9 011 001 7 100 001 7 101 001 7 110 001 7 111 111 5 Cnfg-B Bit-6: Returns the true value of the selected IRQ pad. Cnfg-B Bit-7: Indicates RLE compression is not supported. 8 áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 3.12 EXTENDED CONTROL REGISTER ( ECR ) The Extended Control Register has a system RESET state of 10010101. The significance of the bits is defined by the ECP specification as: ECR Bit-0: This read-only bit returns FIFO empty status (FIFO-E) and is forced high unless PPF, ECP, or TST mode is selected. 0 = At least one byte of data contains in the FIFO. 1 = FIFO is empty. ECR Bit-1: This read-only bit returns FIFO full status (FIFO-F) and is forced low unless PPF, ECP, or TST mode is selected. 0 = At least one empty location is available in the FIFO. 1 = FIFO is full. ECR Bit-2: When low, this bit (ServiceIntr) enables a pulsed interrupt and enables DMA requests (if bit-3 is set). If the enabled interrupt occurs, this bit is automatically returned to a high. The interrupt conditions are: ECR Bit-3 = DMA DCR Bit-5 = DIRection TABLE 3: DMA CONDITION DMA DIR CONDITION 0 0 8 empty bytes in the FIFO 0 1 8 filled bytes in the FIFO 1 X DMA Terminal Count (TC). ECR BIT-3: This bit disables DMA when set low. When set high, a low on ServiceIntr will enable DMA requests. 0 = DMA disabled, DRQx pin is three-stated. 1 = DMA enabled ECR Bit-4: When low, this bit (-ErrIntrEn) enables a pulsed interrupt if -ERROR (-Fault) is low. The interrupt is only enabled in ECP mode. 9 áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 ECR Bits 7-5: This field can be set to any value if the current value is 000 or 001. If the current value is not 000 or 001, then the field can only be written to 000 or 001. The modes are defined as: TABLE 4: DESCRIPTION OF PARALLEL PORT MODES MODE NAME DESCRIPTION 000 SPP Standard Centronics, output only. DCR bit-5 is forced to "0". 001 PS2 Bi-directional PS/2 parallel port. FIFO is disabled 010 PPF FIFOed, output only. DCR Bit-5 is forced to “0”. 011 ECP ECP FIFOed port with RLE de-compression. FIFO direction is controlled by DCR Bit-5. 100 EPP EPP mode. 101 - Reserved. 110 TST FIFO test mode. FIFO is accessible via TFIFO register. 111 CFG Configuration A/B register enable. 4.0 DEVICE OPERATION 4.1 SPP MODE This is ECR mode 000 (system RESET mode). In this output-only mode the host data is registered to PD[7:0] at the trailing edge of -IOW; PDIR is driven low; -STROBE, -AUTOFD, INIT, and -SLCTIN are open-drain; and all timing is managed by the host through DSR and DCR registers. 4.2 PS2 MODE This is ECR mode 001. In this bi-directional mode the host output data is registered to PD[7:0] at the trailing edge of -IOW, PDIR is driven by DIR to allow peripheral data input, -AUTOFD, INIT, and -SLCTIN are totem-pole, and all timing is managed by the host through DSR and DCR registers. 4.3 PPF MODE This is ECR mode 010. In this output-only mode the host data is written to the FIFO with I/O writes to address 400 or by DMA writes; PDIR is driven low; -AUTOFD, INIT, and -SLCTIN are totem-pole. FIFO data is automatically registered to PD[7:0] whenever the FIFO-E bit is low (data available), and timing is generated by controller logic that handshakes -STROBE (controller) with BUSY (peripheral). 4.4 ECP MODE This is ECR mode 011. In this bi-directional mode the host data is written to the FIFO with I/O writes to address 000, 400 or DMA; PDIR is driven by DIR (can only be set in ECR mode 001); -AUTOFD, INIT, and -SLCTIN are totem-pole. I/O writes to address 000 will write a low into the FIFO tag bit, while I/O writes to address 400 or DMA will insert a high. 4.4.1 ECP FORWARD MODE (PDIR = 0) FIFO data is automatically registered to PD[7:0] whenever the FIFO-E bit is low (data available), and timing is generated by controller logic that handshakes -STROBE (controller) with BUSY (peripheral). Data from the FIFO tag bit is output on -AUTOFD after being registered simultaneous with FIFO data. 10 áç REV. 5.0.1 4.4.2 ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO ECP REVERSE MODE (PDIR = 1) PD[7:0] data and BUSY are latched into the FIFO and tag bit respectively at the trailing edge of -AUTOFD if FIFO-F = 0. Timing is generated by controller logic that handshakes -ACK (peripheral) with -AUTOFD (controller). 4.5 EPP MODE This is ECR mode 100. In this bi-directional mode, I/O writes will latch host output data at the trailing edge of -IOW, and peripheral input data will be latched at the trailing edge of -SLCTIN or -AUTOFD. PDIR, and -STROBE are driven by the state of -IOW (DCR bits 5 and 0 must be set low); -AUTOFD, INIT, and -SLCTIN are totem-pole. EPP mode allows buffered access between the PC bus and the peripheral with timing provided by the peripheral via BUSY handshake into IOCHRDY. I/O cycles with address 003 - 007 will immediately drive IOCHRDY low. -STROBE will go low and PD[7:0] is allowed to change (write cycles) after BUSY has been low for at least 60n second. (this delay may have elapsed prior to cycle initiation), immediately followed by a low driven on -SLCTIN for address 003 or -AUTOFD (DATASTB*) for address 004 - 007 (read and write cycles). When BUSY returns high for a minimum of 60n second, IOCHRDY and the active strobe will be driven high allowing the host to complete the I/O transaction. To prevent a system stall, a 10 msecond TimeOut aborts the cycle if it expires before BUSY returns high. This TimeOut also sets bit 0 of DCR, which is cleared by disabling EPP mode or writing a high to DCR bit 0. 4.6 TST MODE This is ECR mode 110. This mode allows data to be transferred (read or write in any direction) between the FIFO and host at address 400 or DMA without activating the control interface (no data is transferred to/from the peripheral). PDIR is driven by DIR (can only be set in ECR mode 001); -AUTOFD, INIT, and -SLCTIN are totem-pole. Performing I/O cycles in this mode allows software to test for the value of FIFOThreshold (FT) for both output and input directions. 4.7 CFG MODE This is ECR mode 111. This mode enables I/O access to the configuration registers CONF-A and CONF-B and disables I/O access to the FIFO. 4.7.1 IRQ The module has four sources of interrupt which may be directed to -IRQ5, -IRQ7, -IRQ9 (see CONF-B) or externally jumpered. 1. When DCR bit 4 (AIE) is high and -ACK is low the interrupt is active. 2. When ECP mode is active, if ECR bit 4 is low when ERROR transitions low or ECR bit 4 transitions low when -Fault is low an interrupt pulse of at least 200n seconds will be generated. 3. In FIFO modes (PPF, ECP, or TST) with ECR bit 3 (DMA) low, an interrupt pulse of at least 200n seconds will be generated when ECR bit 2 (SI) is set low if there are at least 8 empty bytes in the FIFO and PDIR = 0 or there are at least 8 filled bytes in the FIFO and PDIR = 1. This interrupt will automatically disable itself by setting ECR bit 2 high. 4. In FIFO modes (PPF, ECP, or TST) with (DMA request enabled), an interrupt pulse of at least 200n seconds will be generated when TC is received if PD-ACK is low. This interrupt will automatically disable itself and the DMA request by setting ECR bit 2 high. 4.7.2 DMA DMA cycles occur only between the host and the FIFO data port (address 400) for PPF, ECP, or TST modes. The selected DRQ(1, 2, or 3) will be driven high if ECR bit 3 (DMA) is high and ECR bit 2 (SI) is low when {PDIR = 0 and FIFO-F = 0} or {PDIR = 1 and FIFO-E = 0} or TST mode is active. When the selected D-ACK(1, 2, or 3) is low, -IOW will transfer host data to the FIFO and -IOR will transfer FIFO data to the host. 11 áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 The selected DRQ will be driven low to terminate the DMA channel when {PDIR = 0 and FIFO-F = 1} or {PDIR = 1 and FIFO-E = 1} or ECR bit 2 (SI) goes high (interrupt condition 4 above) or more than 32 consecutive DMA data cycles (read or write) have occurred. FIFO-F and FIFO-E terminated cycles will automatically restart when their state returns low. Consecutive cycle termination will automatically restart because the counter is reset when the selected D-ACK goes high. TC terminated cycles can only be restarted by the host setting ECR bit 2 (SI) low again. 4.7.3 RLE The module does not support RLE compression (indicated by the “0” in CONF-B bit 7) but is required to support RLE de-compression. The host may send compressed data to the peripheral by writing the RLE length byte (bit 7 = 0) to address 000 (NOTE: DMA cannot be used for this byte) which will place a zero into the FIFO tag bit. This must be followed immediately by the data byte being written to the FIFO at address 400. These bytes will be transferred to the peripheral in the normal manner. De-compression takes place if PDIR = 1 when data is read from the FIFO at address 000, 400 or DMA. When a byte is read from the FIFO, bits 0-6 (length) are placed in a counter if data bit-7 and the FIFO tag bit are both low. The subsequent byte in the FIFO (data) is presented to the host count + 1 times before the FIFO read pointer is advanced. TABLE 5: INTERNAL REGISTERS DESCRIPTION A10 A2 A1 A0 REGISTER D7 D6 D5 D4 D3 D2 D1 D0 PD7 PD6 PD5 PD4 PD3 PD2 PD1 PD0 1 1 0 0 0 0 Data Port , ECP-AFIFO 0 0 0 1 DSR BUSY -ACK PE SLCT ERROR 1 0 0 1 0 DCR 0 0 DIR INT enable -SLCTIN INIT 0 0 1 1 EPP-APort AP-7 AP-6 AP-5 AP-4 AP-3 AP-2 AP-1 AP-0 1 0 0 0 EPP-DPort PDA-7 PDA-6 PDA-5 PDA-4 PDA-3 PDA-2 PDA-1 PDA-0 0 1 0 1 EPP-DPort PDB-7 PDB-6 PDB-5 PDB-4 PDB-3 PDB-2 PDB-1 PDB-0 0 1 1 0 EPP-DPort PDC-7 PDC-6 PDC-5 PDC-4 PDC-3 PDC-2 PDC-1 PDC-0 0 1 1 1 EPP-DPort PDD-7 PDD-6 PDD-5 PDD-4 PDD-3 PDD-2 PDD-1 PDD-0 1 X 0 0 CONF-A ECP INT type 0 0 1 0 FIFO-F 0 0 1 X 0 1 CONF-B RLE IRQ Input IRQ Sel-2 IRQ Sel-1 IRQ Sel-0 DMA Sel-2 DMA Sel-1 DMA Sel-0 1 X 1 0 ECR MODE Sel-2 MODE Sel-1 MODE Sel-0 FAULT enable DMA En/Dis Service INT FIFO full FIFO empty 12 -AUTO- -STROBE FD áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 5.0 SIGNAL DESCRIPTIONS IN VARIOUS MODES TABLE 6: “CENTRONICS, SPP” SIGNAL DESCRIPTIONS SIGNAL NAME SIGNAL TYPE DESCRIPTION -STROBE O Active low. Indicates valid data is on the data lines. -AUTOFD O Active low. Instructs the printer to automatically insert a line feed for each carriage return. -SLCTIN O Active low. Used to indicate to the printer that it is selected. INIT O Active low. Used to reset the printer -ACK I A low asserted pulse used to indicate that the last character was received. BUSY I A high signal asserted by the printer to indicate that it is busy and cannot take data. PE I A high signal indicated that printer Paper is empty. SLCT I A high signal indicates that printer is online. -ERROR I Asserted low to indicate that some error condition exists. PD0-PD7 O Data. 13 áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 TABLE 7: "NIBBLE MODE" SIGNAL DESCRIPTIONS SIGNAL NAME SIGNAL TYPE NIBBLE MODE NAME -STROBE O -STROBE Not used for reverse data transfer. -AUTOFD O HostBusy Host nibble mode handshake signal. Set low to indicate host is ready for nibble. Set high to indicate nibble has been received. -SLCTIN O 1284Active INIT O INIT -ACK I PtrClk BUSY I PtrBusy Used for Data Bit-3, then Bit-7. PE I AckDataReq Used for Data Bit-2, then Bit-6. SLCT I Xflag Used for Data Bit-1, then Bit-5. -ERROR I -DataAvail Used for Data Bit-0, then Bit-4. PD0-PD7 O N/A 5.1 DESCRIPTION Set high when host is in a 1284 transfer mode. Not used for reverse data transfer. Set low to indicate valid nibble data, set high in response to "HostBusy" going high. Not used. NIBBLE Mode Data Transfer Cycle ■ ■ ■ ■ ■ Host signals ability to take data by asserting HostBusy low. Peripheral responds by placing first nibble on status lines. Peripheral signals valid nibble by asserting PtrClk low. Host sets HostBusy high to indicate that it has received the nibble and is not ready for another nibble. Peripheral sets PtrClk high to acknowledge host. 14 áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 TABLE 8: “EPP MODE” SIGNAL DESCRIPTIONS SIGNAL TYPE EPP MODE NAME -STROBE O -Write -AUTOFD O -DataStb Active low. Indicates a Data-Read or Data-Write operation is in process. -SLCTIN O -AddrStb Active low. Indicates an Address-Read or Address-Write operation is in process. INIT O -Reset -ACK I -Intr Peripheral interrupt. Used to generate an interrupt to the host. BUSY I -Wait Handshake signal. When low it indicates that is okay to start a cycle, when high it indicates that it is okay to end the cycle. PE I User defined SLCT I User defined -ERROR I User defined PD0-PD7 O AD0-AD7 SIGNAL NAME 5.2 DESCRIPTION Active low. Indicates a write operation, high for a read cycle Active low. Peripheral reset. Bi-directional address / data lines. EPP Mode Data Transfer Cycle ■ ■ ■ ■ ■ ■ Program executes an I/O write cycle to EPP Data Port-4. The -Write line is asserted and the data is output to the parallel port. The -DataStb is asserted, since -Write is asserted low. The port waits for the acknowledge from the peripheral, -Write deasserted. The -DataStr is deasserted and EPP cycle ends. -Write is asserted low to indicate that the next cycle may begin. 15 áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 TABLE 9: “ECP MODE” SIGNAL DESCRIPTION SIGNAL NAME SIGNAL TYPE ECP MODE NAME DESCRIPTION -STROBE O HostClk Used with PeriphAck to transfer data or address information in the forward direction. -AUTOFD O HostAck Provides Command / Data status in the forward direction. Used with PeriphClk to transfer data in the reverse direction. -SLCTIN O 1284Active INIT O -ReverseReq -ACK I PeriphClk Used with HostAck to transfer data in the reverse direction. BUSY I PeriphAck Used with HostClk to transfer data or address information in the forward direction. Provides Command / Data status in the reverse direction. PE I -AckReverse SLCT I Xflag -ERROR I -PeriphReq PD0-PD7 I/O D0-D7 5.3 Set high when host is in a 1284 transfer mode. Driven low to put the channel in reverse direction. Driven low to acknowledge ReverseRequest. Extensibility flag. Set low by peripheral to indicate that reverse dat is available. Bi-directional data lines. ECP Mode Forward Data and Command Transfer Cycle ■ ■ ■ ■ ■ ■ 5.4 Host places data on the data lines and indicates a data cycle by setting HostAck high. Host asserts HostClk low to indicate valid data. Peripheral acknowledge host by setting PeriphAck high. Host sets HostClk high. This is the edge that should be used to clock the data in to the peripheral. Peripheral sets PeriphAck low to indicate that it is ready for the next byte. The cycle repeats, but this time it is command cycle because HostAck is low. ECP Mode Reverse Data and Command Transfer Cycle ■ ■ ■ ■ ■ ■ ■ ■ The Host requests a reverse channel transfer by setting -ReverseReq low. The peripheral signals that it is okay to proceed by setting -AckReverse low. The peripheral places data on the data lines and indicates a data cycle by setting PeriphAck high. Peripheral asserts PeriphClk low to indicate valid data. Host acknowledges by setting HostAck high. Peripheral sets PeriphClk high. This is the edge that should be used to clock the data in to the host. Host sets HostAck low to indicate that it is ready for the next byte. The cycle repeats, but this time it is a Command cycle because PeriphAck is low. 16 áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 AC ELECTRICAL CHARACTERISTICS TA = 0oC - 70oC, VCC = 5.0V +/- 10%, unless otherwise specified. SYMBOL PARAMETER MIN LIMITS TYP MAX UNITS T1 AEN setup to command active 40 NS T2 Command width 150 ns T3 AEN hold from command inactive 10 ns T4 Data access from -IOR active T5 Data setup to -IOW inactive 40 ns T6 Data hold from command inactive 10 ns T7 PD7-0, -STROBE, -AUTOFD, INIT, -SLCTIN delay from -IOW inactive 100 ns T8 Interrupt delay from -ACK 60 ns T9 Interrupt pre-charge pulse at release 10 ns T10 TC pulse width T11 TC active to DRQx inactive T12 DRQx active to -DACKx active T13 DRQx inactive delay from -DACKx active T14 PD7-0 setup to -STROBE active 600 ns T15 -STROBE width 600 ns T16 PD7-0 hold from -STROBE inactive 450 ns T17 PD7-0 hold from BUSY inactive 80 ns T18 -STROBE active to BUSY active (handshake) T19 BUSY inactive to -STROBE active (cycle delay) T20 PD7-0, -AUTOFD setup to -STROBE active 0 60 ns T21 PD7-0, -AUTOFD hold from BUSY active 80 180 ns T22 -STROBE inactive to BUSY inactive 0 T23 BUSY inactive to -STROBE active 80 T24 -STROBE active to BUSY active 0 T25 BUSY active to -STROBE inactive 80 T26 PD7-0, BUSY setup to -ACK active 0 ns T27 PD7-0 data hold from -AUTOFD active 0 ns T28 -ACK inactive to -AUTOFD active 80 T29 -AUTOFD active to -ACK active 0 100 60 ns 100 0 ns ns 100 500 680 17 ns ns ns ns ns 200 ns ns 180 200 ns ns ns áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 AC ELECTRICAL CHARACTERISTICS TA = 0oC - 70oC, VCC = 5.0V +/- 10%, unless otherwise specified. SYMBOL PARAMETER MIN LIMITS TYP MAX 200 UNITS T30 -ACK active to -AUTOFD inactive 80 T31 -AUTOFD inactive to -ACK inactive 0 ns T32 Host address setup to -IOW active 40 ns T33 Host address hold from -IOW active 10 ns T34 Host data setup to -IOW active 0 T35 Host data hold from -IOW active 0 T36 -IOW active to IOCHRDY low 0 T37 IOCHRDY high to Host terminate (-IOW inactive) 10 ns T38 -IOW inactive to Host command active (-IOW or -IOR) 40 ns T39 IOCHRDY pre-charge width at release T40 Host address setup to -IOR active 40 ns T41 Host address hold from -IOR active 10 ns T42 Host data setup to -IOR inactive 0 T43 Host data hold from -IOR inactive 0 T44 -IOR active to IOCHRDY low 0 T45 IOCHRDY high to Host terminate (-IOR inactive) 10 ns T46 -IOR inactive to Host command active (-IOW or -IOR) 40 ns 20 ns ns 20 10 18 ns 20 ns ns ns ns 20 ns áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 DC ELECTRICAL CHARACTERISTICS TA = 0oC - 70oC, VCC = 5.0V +/- 10%, unless otherwise specified. SYMBOL PARAMETER MIN LIMITS TYP UNIT MAX S VILCK Clock Input Low level -0.5 0.6 V VIHCK Clock Input High level 3.0 VCC V VIL Input Low level -0.5 0.8 V VIH Input High level 2.0 VCC V VOL Output Low level 0.4 V CONDITIONS DRQ1-3, IOCHRDY: IOL = 14 mA D0-D7: IOL = 12 mA PDIR: IOL = 4 mA All other outputs: IOL = 20mA D0-D7: IOH = -12mA VOH Output High level 2.4 V PDIR: IOH = -1mA All other outputs: IOH = -20mA ICC Avg. power supply current 7 9 mA IIL Input leakage 10 µA ICL Clock leakage 10 µA IR Internal pull up resistor current -30 µA -85 For inputs -DACK1-3, -ERROR, SLCT, BUSY, -ACK and PE NOTE: Hewlett Packard / Microsoft compliance testing requires all ECP mode drivers to be push-pull and that they have an impedance controlled series resistor of at least 20 Ohms and that the typical on resistance of the combination of the driver-resistor pair is in the 45-65 Ohm range. 19 áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 FIGURE 3. GENERAL READ/WRITE TIMING A0-2, A10 AEN T1 -IOR T3 T2 T1 T3 T2 -IOW T4 T5 T6 D0-7 7836-IO FIGURE 4. PARALLEL PORT TIMING IN SPP, PS/2 MODES -IOW T7 PD0-7 -ACK IRQx T8 T8 T9 7836-SPP 20 áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 FIGURE 5. HOST DMA TIMING IN ECP MODE T10 TC T11 DRQx T12 T13 AEN DACKx T1 -IOW,-IOR 7836-DMA FIGURE 6. PARALLEL PORT FIFO TIMING PD0-7 T14 T15 -STROBE T16 T17 T18 T19 BUSY 7836-PPF 21 áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 FIGURE 7. PARALLEL PORT FORWARD TIMING IN ECP MODE PD0-7 -AUTOFDX T21 T20 -STROBE T22 T22 T23 BUSY T24 T25 7836-ECF FIGURE 8. PARALLEL PORT REVERSE TIMING IN ECP MODE PD0-7 BUSY T27 T26 -ACK -AUTOFDX T31 T28 T28 T29 T30 7836-ECR 22 áç REV. 5.0.1 ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO FIGURE 9. ADDRESS OR DATA WRITE TIMING IN EPP MODE A0-2, A10 T32 T33 T34 T35 D0-7 -IOW T36 IOCHRDY T38 T37 T39 7836-EPW FIGURE 10. ADDRESS OR DATA READ TIMING IN EPP MODE A0-2, A10 T41 T40 D0-7 T42 T43 -IOR IOCHRDY T44 T45 T46 T39 7836-EPR 23 áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 PACKAGE DIMENSIONS (44 PIN PLCC) 4 4 L E A D P L A S T IC L E A D E D C H IP C A R R IE R (P L C C ) R e v. 1 .00 C D S e a tin g P la n e D1 2 1 4 5° x H2 4 5° x H1 A2 44 B1 D D1 B D3 e R D3 A1 A Note: The control dimension is the millimeter column INCHES MILLIMETERS SYMBOL MIN MAX MIN MAX A 0.165 0.180 4.19 4.57 A1 0.090 0.120 2.29 3.05 A2 0.020 --- 0.51 --- B 0.013 0.021 0.33 0.53 B1 0.026 0.032 0.66 0.81 C 0.008 0.013 0.19 0.32 D 0.685 0.695 17.40 17.65 D1 0.650 0.656 16.51 16.66 D2 0.590 0.630 14.99 16.00 D3 0.500 typ. 12.70 typ. e 0.050 BSC 1.27 BSC H1 0.042 0.056 1.07 1.42 H2 0.042 0.048 1.07 1.22 R 0.025 0.045 0.64 1.14 24 D2 áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 PACKAGE DIMENSIONS (64-TQFP) D D1 48 33 49 32 D1 64 17 1 16 B e A2 C A α Seating Plane A1 L Note: The control dimension is the millimeter column INCHES MILLIMETERS SYMBOL MIN MAX MIN MAX A 0.055 0.063 1.40 1.60 A1 0.002 0.006 0.05 0.15 A2 0.053 0.057 1.35 1.45 B 0.005 0.009 0.13 0.23 C 0.004 0.008 0.09 0.20 D 0.465 0.480 11.80 12.20 D1 0.390 0.398 9.90 10.10 e 0.020 BSC 0.50 BSC L 0.018 0.030 0.45 0.75 α 0° 7° 0° 7° 25 D áç ST78C36/36A ECP/EPP PARALLEL PRINTER PORT WITH 16-BYTE FIFO REV. 5.0.1 REVISION HISTORY Date Revision Description December 2003 Rev 5.0.0 Changed to standard style format. Added Revision History. Added Device Status to Ordering Information. Updated DC Electrical Characteristics. February 2004 Rev 5.0.1 Corrected the signal type of the -AUTOFDX pin from I (input) to O (output). NOTICE EXAR Corporation reserves the right to make changes to the products contained in this publication in order to improve design, performance or reliability. EXAR Corporation assumes no responsibility for the use of any circuits described herein, conveys no license under any patent or other right, and makes no representation that the circuits are free of patent infringement. Charts and schedules contained here in are only for illustration purposes and may vary depending upon a user’s specific application. While the information in this publication has been carefully checked; no responsibility, however, is assumed for inaccuracies. EXAR Corporation does not recommend the use of any of its products in life support applications where the failure or malfunction of the product can reasonably be expected to cause failure of the life support system or to significantly affect its safety or effectiveness. Products are not authorized for use in such applications unless EXAR Corporation receives, in writing, assurances to its satisfaction that: (a) the risk of injury or damage has been minimized; (b) the user assumes all such risks; (c) potential liability of EXAR Corporation is adequately protected under the circumstances. Copyright 2004 EXAR Corporation Datasheet February 2004. Send your technical inquiry with technical details to hotline: [email protected]. Reproduction, in part or whole, without the prior written consent of EXAR Corporation is prohibited. 26