NSC NS32FX200VF-25 Datasheet

TL/EE11331
NS32FX100-15/NS32FX100-20/NS32FV100-20/NS32FV100-25/
NS32FX200-20/NS32FX200-25 System Controller
PRELIMINARY
July 1992
NS32FX100-15/NS32FX100-20/NS32FV100-20/ NS32FV100-25/NS32FX200-20/NS32FX200-25 System Controller
The NS32FX200, NS32FV100 and NS32FX100 are highly integrated system chips designed for a FAX system based on National Semiconductor’s embedded processorsÐ NS32FX161, NS32FV16 or NS32FX164. The NS32FX100 is the common core for all three system chips. The NS32FV100 and NS32FX200 offer additional functions. Throughout this document, references to the NS32FX100 also apply to both the NS32FV100 and the NS32FX200. Specific NS32FV100 or NS32FX200 features are explicitly indicated.
The NS32FX200, NS32FV100 and NS32FX100 feature an interface to devices like stepper motors, printers and scan­ners, a Sigma-Delta CODEC, an elapsed-time counter, a DMA controller, an interrupt controller, and a UART.
The NS32FX200 is optimized for high-end FAX applications, such as plain-paper FAX and multifunctional peripherals. The NS32FX100, is optimized for low-cost FAX applica­tions. The NS32FV100 is optimized for thermal paper FAX machines with Digital Answering Machine support.
Features
Y
Direct interface to the NS32FX161, NS32FV16 and NS32FX164 embedded processors
Y
Supports a variety of Contact Image Sensor (CIS) and Charge Coupled Device (CCD) scanners
Y
Direct interface to a variety of Thermal Print Head (TPH) printers. Bitmap shifter and DMA channels facili­tate the connection of other types of printers
Y
Supports two stepper motors
Y
Direct interface to ROM and SRAM. The NS32FX200 and NS32FV100, in addition, interface to DRAM devices
Y
Programmable wait state generator
Y
Demultiplexed address and data buses
Y
Multiplexed DRAM address bus (NS32FX200 and NS32FV100)
Y
Supports 3V freeze mode by maintaining only elapsed time counter
Y
Control of power consumption by disabling inactive modules and reducing the clock frequency
Y
Operating frequency Ð Normal mode: 19.6608 MHzÐ24.576 MHz in steps
of 1.2288 MHz. (NS32FX200)
Ð Normal mode: 19.6608 MHzÐ24.576 MHz in steps
of 1.2288 MHz. (NS32FV100)
Ð Normal mode: 14.7456 MHzÐ19.6608 MHz in steps
of 1.2288 MHz. (NS32FX100)
Ð Power Save mode: Normal mode frequency divided
by sixteen
Y
On-Chip full duplex Sigma-Delta CODEC with: Ð Total harmonic distortion better than
b
70 dB Ð Programmable hybrid balance filter Ð Programmable reception and transmission filters Ð Programmable gain control
Y
On-Chip Interrupt Control Unit with: Ð 16 interrupt sources Ð Programmable triggering mode
Y
On-Chip counters, WATCHDOGTM, UART, MICROWIRE
TM
, System Clock Generator, and I/O
ports
Y
On-Chip DMA controller (NS32FX200Ðfour channels, NS32FX100, NS32FV100Ðthree channels)
Y
Up to 37 on-chip general purpose I/O pins, expandable externally
Y
Flexible allocation of I/O and modules’ pins
Y
132-pin JEDEC PQFP package
TL/EE/11331– 1
FIGURE 1-1. A FAX Controller Block Diagram
TRI-STATEÉis a registered trademark of National Semiconductor Corporation. MICROWIRE
TM
and WATCHDOGTMare trademarks of National Semiconductor Corporation.
C
1995 National Semiconductor Corporation RRD-B30M105/Printed in U. S. A.
Table of Contents
1.0 FAX SYSTEM CONFIGURATION АААААААААААААААААА6
1.1 Block Diagram Description АААААААААААААААААААААА6
1.2 Module Diagram ААААААААААААААААААААААААААААААА7
1.2.1 Bus and Memory Controller (BMC) АААААААААА8
1.2.2 Timing Control Unit (TCU) ААААААААААААААААА8
1.2.3 Sigma-Delta CODEC (SDC) АААААААААААААААА8
1.2.4 Scanner Controller (SCANC) ААААААААААААААА8
1.2.5 Printer Controller (PRNTC) ААААААААААААААААА8
1.2.6 DMA Controller (DMAC) ААААААААААААААААААА8
1.2.7 Universal Asynchronous Receiver-Transmitter (UART)АААААААААААААААААААААААААААААААААА8
1.2.8 MICROWIRE (MWIRE) АААААААААААААААААААА8
1.2.9 Interrupt Control Unit (ICU)ААААААААААААААААА8
1.2.10 Ports АААААААААААААААААААААААААААААААААА8
1.3 Operation Modes АААААААААААААААААААААААААААААА8
1.3.1 Functionality ААААААААААААААААААААААААААААА9
2.0 ARCHITECTURE ААААААААААААААААААААААААААААААА10
2.1 MCFGРModule Configuration Register АААААААААА10
2.2 Timing Control Unit (TCU) АААААААААААААААААААААА10
2.2.1 Features ААААААААААААААААААААААААААААААА10
2.2.2 Operation АААААААААААААААААААААААААААААА10
2.2.2.1 External Clocks АААААААААААААААААА11
2.2.2.2 Internal Clocks ААААААААААААААААААА11
2.2.3 Registers ААААААААААААААААААААААААААААААА12
2.2.3.1 Usage Recommendations ААААААААА13
2.3 Sigma-Delta CODEC (SDC) АААААААААААААААААААА13
2.3.1 Features ААААААААААААААААААААААААААААААА13
2.3.2 Operation АААААААААААААААААААААААААААААА13
2.3.2.1 Block Diagram ААААААААААААААААААА13
2.3.2.2 On-Chip Digital Blocks АААААААААААА15
2.3.3 Programmable Functions ААААААААААААААААА15
2.3.3.1 Sigma-Delta ON/OFFААААААААААААА15
2.3.4 Off-Chip Analog Circuits АААААААААААААААААА15
2.3.4.1 Analog Transmitter ААААААААААААААА17
2.3.4.2 Analog Receiver ААААААААААААААААА17
2.3.5 Registers ААААААААААААААААААААААААААААААА17
2.3.6 Usage Recommendations АААААААААААААААА18
2.4 Scanner Controller (SCANC) ААААААААААААААААААА18
2.4.1 Features ААААААААААААААААААААААААААААААА18
2.4.2 Operation АААААААААААААААААААААААААААААА18
2.4.2.1 Scanner Signals Generator Block ÀÀ19
2.4.2.2 Scanner Period Pulse (SPP)
Generation АААААААААААААААААААААА20
2.4.2.3 Video Handling Block ААААААААААААА21
2.4.2.4 Threshold DAC (Dithering and
Automatic Background Control) ÀÀÀÀ22
2.4.2.5 Stepper Motor Control Block ААААААА23
2.0 ARCHITECTURE (Continued)
2.4.3 Registers ААААААААААААААААААААААААААААААААА23
2.4.4 Usage Recommendations АААААААААААААААААА24
2.5 Printer Controller (PRNTC) ААААААААААААААААААААА25
2.5.1 Features ААААААААААААААААААААААААААААААА25
2.5.2 Operation АААААААААААААААААААААААААААААА25
2.5.2.1 Printer Bitmap Shifter BlockАААААААА25
2.5.2.2 Thermal Print-Head Control Block ÀÀ25
2.5.3 Registers ААААААААААААААААААААААААААААААА28
2.5.4 Usage Recommendations АААААААААААААААА28
2.6 Direct Memory Access Controller (DMAC) АААААААА29
2.6.1 Features ААААААААААААААААААААААААААААААА29
2.6.2 Description ААААААААААААААААААААААААААААА29
2.6.2.1 A General DMA Channel АААААААААА29
2.6.2.2 Transfer TypesААААААААААААААААААА29
2.6.2.3 Operation Modes ААААААААААААААААА29
2.6.3 Detailed Operation Flow АААААААААААААААААА29
2.6.4 NS32FX200 DMA Channels АААААААААААААА30
2.6.5 Registers ААААААААААААААААААААААААААААААА30
2.6.6 Usage Recommendations АААААААААААААААА32
2.6.7 DMAC Bus Cycles ААААААААААААААААААААААА32
2.7 Universal Asynchronous Receiver-Transmitter (UART) АААААААААААААААААААААААААААААААААААААА36
2.7.1 Features ААААААААААААААААААААААААААААААА36
2.7.2 Operation АААААААААААААААААААААААААААААА36
2.7.3 Registers ААААААААААААААААААААААААААААААА37
2.7.4 Usage Recommendations АААААААААААААААА38
2.8 MICROWIRE (MWIRE) АААААААААААААААААААААААА38
2.8.1 Features ААААААААААААААААААААААААААААААА38
2.8.2 Operation АААААААААААААААААААААААААААААА38
2.8.3 Registers ААААААААААААААААААААААААААААААА38
2.8.4 Usage Recommendations АААААААААААААААА40
2.9 Interrupt Control Unit (ICU) ААААААААААААААААААААА40
2.9.1 Features ААААААААААААААААААААААААААААААА40
2.9.2 Operation АААААААААААААААААААААААААААААА40
2.9.3 Registers ААААААААААААААААААААААААААААААА41
2.9.4 Usage Recommendations АААААААААААААААА41
2.10 Ports Module АААААААААААААААААААААААААААААААА41
2.10.1 Features ААААААААААААААААААААААААААААА41
2.10.2 Operation АААААААААААААААААААААААААААА41
2.10.2.1 General Purpose Input/Output Ports АААААААААААААААААААААААА41
2.10.2.2 External Output Port Extension À43
2.10.2.3 Stepper Motors Output Ports ÀÀÀ43
2.10.3 Registers АААААААААААААААААААААААААААА43
2.10.4 Usage Recommendations АААААААААААААА45
2
Table of Contents (Continued)
2.0 ARCHITECTURE (Continued)
2.11 Bus and Memory Controller (BMC) ААААААААААААА45
2.11.1 Features ААААААААААААААААААААААААААААА45
2.11.2 Operation АААААААААААААААААААААААААААА45
2.11.2.1 Zones 0, 1 (ROM and SRAM) Transactions ААААААААААААААААА46
2.11.2.2 Zone 2 (Dynamic Memory) Transactions (NS32FX200 and NS32FV100 only) ААААААААААААА46
2.11.2.3 Zone 3 (I/O) Transactions ААААА47
2.11.2.4 Operation in Freeze ModeАААААА47
2.11.2.5 On-Chip Registers Access ААААА47
2.11.3 Registers АААААААААААААААААААААААААААА47
2.11.4 Usage Recommendations АААААААААААААА48
2.12 Register Summary ААААААААААААААААААААААААААА48
2.12.1 NS32FX100 Registers Access Method ÀÀÀ48
2.12.2 NS32FX200, NS32FV100 and NS32FX100 Registers АААААААААААААААААААААААААААА48
3.0 SYSTEM INTERFACEААААААААААААААААААААААААААА53
3.1 Power and Grounding ААААААААААААААААААААААААА53
3.2 Clocks and Traps Connectivity АААААААААААААААААА53
3.0 SYSTEM INTERFACE (Continued)
3.3 Control of Power Consumption ААААААААААААААААА53
3.4 Bus Cycles ААААААААААААААААААААААААААААААААААА54
4.0 DEVICE SPECIFICATIONS АААААААААААААААААААААА62
4.1 NS32FX100 Pin Descriptions ААААААААААААААААААА62
4.1.1 Supplies ААААААААААААААААААААААААААААААА62
4.1.2 Input Signals АААААААААААААААААААААААААААА62
4.1.3 Output Signals АААААААААААААААААААААААААА63
4.1.4 Input/Output Signals ААААААААААААААААААААА64
4.2 Output Signal Levels АААААААААААААААААААААААААА64
4.2.1 Freeze Mode Output Signals АААААААААААААА65
4.2.2 Reset/Power Restore Output Signals АААААА65
4.3 Absolute Maximum Ratings АААААААААААААААААААА67
4.4 Electrical Characteristics ААААААААААААААААААААААА67
4.5 Analog Electrical Characteristics АААААААААААААААА69
4.6 Switching Characteristics АААААААААААААААААААААА70
4.6.1 Definitions АААААААААААААААААААААААААААААА70
4.6.2 Timing Tables ААААААААААААААААААААААААААА71
4.6.2.1 Output Signals: Internal Propagation Delays АААААААААААААААААААААААААА71
4.6.2.2 Input Signal RequirementsААААААААА76
APPENDIX A: CODEC TRANSMISSION
PERFORMANCE ААААААААААААААААААААА92
3
List of Figures
FIGURE 1-1 A FAX Controller Block DiagramААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА1
FIGURE 1-2 NS32FX100 Module Diagram ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА7
FIGURE 1-3 NS32FV100 Module Diagram ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА7
FIGURE 1-4 NS32FX200 Module Diagram ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА7
FIGURE 1-5 System Chip States and Operation Modes АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА9
FIGURE 2-1 Clocks and Traps Connectivity ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА10
FIGURE 2-2 High Speed Oscillator Clocks АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА11
FIGURE 2-3 Low Speed Oscillator Clocks АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА11
FIGURE 2-4 Sigma-Delta Block Diagram ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА14
FIGURE 2-5 SDC Off-Chip Analog Circuit ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА16
FIGURE 2-6 Block Diagram of Scanner’s Signals Generator Block ААААААААААААААААААААААААААААААААААААААААААААААААА19
FIGURE 2-7 Scanner Pixel Control SignalsАААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА20
FIGURE 2-8 Scanner Period Control Signals АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА21
FIGURE 2-9 Block Diagram of Scanner’s Video Handling BlockАААААААААААААААААААААААААААААААААААААААААААААААААААА21
FIGURE 2-10 Dither Cyclic Buffer ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА22
FIGURE 2-11 Bitmap Shifter Signals АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА25
FIGURE 2-12 Four Strobes Mode (STBM
e
00) АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА26
FIGURE 2-13 Two Strobes Mode (STBMe01) АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА26
FIGURE 2-14 Temperature ADC АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА27
FIGURE 2-15 DMA Fly-By Read Transaction (DIRe0, FBYe0) АААААААААААААААААААААААААААААААААААААААААААААААААААА32
FIGURE 2-16 DMA Fly-By Write Transaction (DIRe1, FBYe0)ААААААААААААААААААААААААААААААААААААААААААААААААААААА33
FIGURE 2-17 DMA Memory to I/O Read Transaction (DIR
e
0, NFBYe1)АААААААААААААААААААААААААААААААААААААААААААА34
FIGURE 2-18 DMA I/O to Memory Write Transaction (DIRe1, NFBYe1) АААААААААААААААААААААААААААААААААААААААААААА35
FIGURE 2-19 Two Adjacent Fly-By DMA TransactionsААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА36
FIGURE 2-20 Character Format АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА37
FIGURE 2-21 MICROWIRE Transaction (CLKM
e
0)ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА39
FIGURE 2-22 MICROWIRE Transaction (CLKMe1)ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА39
FIGURE 2-23 Port A АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА42
FIGURE 2-24 Port B АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА42
FIGURE 2-25 Port C АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА42
FIGURE 2-26 External Output Port ExtensionААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА43
FIGURE 3-1 Power and Ground ConnectionsАААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА53
FIGURE 3-2 Oscillator Circuits АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА53
FIGURE 3-3 Zones 0, 1 (ROM/SRAM) Read Transaction, Zero Wait State АААААААААААААААААААААААААААААААААААААААААА54
FIGURE 3-4 Zones 0, 1 (ROM/SRAM) Read Transaction, One Wait State АААААААААААААААААААААААААААААААААААААААААА54
FIGURE 3-5 Zones 0, 1 (ROM/SRAM) Write Transaction, Zero Wait State АААААААААААААААААААААААААААААААААААААААААА55
FIGURE 3-6 Zones 0, 1 (ROM/SRAM) Write Transaction, One Wait StateААААААААААААААААААААААААААААААААААААААААААА55
FIGURE 3-7 Zone 2 (DRAM) Refresh Transaction, Zero Wait State АААААААААААААААААААААААААААААААААААААААААААААААА56
FIGURE 3-8 Zone 2 (DRAM) Refresh Transaction, Three Wait States АААААААААААААААААААААААААААААААААААААААААААААА56
FIGURE 3-9 Freeze Mode Refresh Transaction Waveform АААААААААААААААААААААААААААААААААААААААААААААААААААААААА56
FIGURE 3-10 Zone 2 (DRAM) Read Transaction, Zero Wait State ААААААААААААААААААААААААААААААААААААААААААААААААААА57
FIGURE 3-11 Zones 0, 1 Access Delayed by a Refresh Transaction (No Wait) АААААААААААААААААААААААААААААААААААААААА57
FIGURE 3-12 Zone 2 (DRAM) Read Transaction, One Wait State ААААААААААААААААААААААААААААААААААААААААААААААААААА58
FIGURE 3-13 Zone 2 (DRAM) Write Transaction, Zero Wait State ААААААААААААААААААААААААААААААААААААААААААААААААААА58
FIGURE 3-14 Zone 2 (DRAM) Write Transaction, One Wait State ААААААААААААААААААААААААААААААААААААААААААААААААААА59
FIGURE 3-15 Zone 3 (I/O) Read Transaction, Two Wait States ААААААААААААААААААААААААААААААААААААААААААААААААААААА59
FIGURE 3-16 Zone 3 (I/O) Read Transaction, Four Wait StatesААААААААААААААААААААААААААААААААААААААААААААААААААААА60
FIGURE 3-17 Zone 3 (I/O) Write Transaction, Four Wait States ААААААААААААААААААААААААААААААААААААААААААААААААААААА60
FIGURE 3-18 Zone 3 (I/O) Write Transaction, Six Wait States АААААААААААААААААААААААААААААААААААААААААААААААААААААА61
FIGURE 3-19 CPU/DMA ArbitrationААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА61
FIGURE 3-20 Spaced Memory Transaction, Two Tidles after T4 АААААААААААААААААААААААААААААААААААААААААААААААААААА61
4
List of Figures (Continued)
FIGURE 4-1 Connection DiagramРTop View ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА66
FIGURE 4-2 Analog Circuitry Block Diagram АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА69
FIGURE 4-3 TTLРOutput Signals Specification StandardААААААААААААААААААААААААААААААААААААААААААААААААААААААААА70
FIGURE 4-4 TTLРInput Signals Specification Standard АААААААААААААААААААААААААААААААААААААААААААААААААААААААААА70
FIGURE 4-5 CMOSРOutput Signals Specification Standard АААААААААААААААААААААААААААААААААААААААААААААААААААААА70
FIGURE 4-6 CMOSРInput Signals Specification Standard АААААААААААААААААААААААААААААААААААААААААААААААААААААААА70
FIGURE 4-7 Input HysteresisАААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА70
FIGURE 4-8 Clock Waveforms АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА79
FIGURE 4-9 DRAM Read Bus Cycle ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА79
FIGURE 4-10 DRAM Write Bus Cycle ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА80
FIGURE 4-11 ROM/SRAM Read Bus Cycle АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА81
FIGURE 4-12 ROM/SRAM Write Bus Cycle (One Wait State)ААААААААААААААААААААААААААААААААААААААААААААААААААААААА82
FIGURE 4-13 I/O Read Bus Cycle АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА83
FIGURE 4-14 I/O Write Bus Cycle АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА83
FIGURE 4-15 DRAM Refresh Bus Cycles АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА84
FIGURE 4-16 DMA Read Transaction (DIR
e
0) АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА85
FIGURE 4-17 DMA Write Transaction (DIR
e
1) АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА86
FIGURE 4-18 Interrupt Signals Timing ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА87
FIGURE 4-19 Sigma-Delta Signals TimingАААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА87
FIGURE 4-20 SBYPS Input Signal Timing АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА87
FIGURE 4-21 Printer Signals TimingААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА88
FIGURE 4-22 Reset Signals Timing ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА88
FIGURE 4-23 Scanner Signals Timing ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА89
FIGURE 4-24 UART Signals Timing ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА90
FIGURE 4-25 MWIRE Signals TimingАААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА90
FIGURE 4-26 Ports Signals Timing АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА91
FIGURE 4-27 Analog Signals Timing АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА91
List of Tables
TABLE 2-1 CTTL, MCLON and MCLOFF ValuesАААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА12
TABLE 2-2 Component Values ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА15
TABLE 2-3 Interrupt Sources and Priority Levels АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА40
TABLE 2-4 DRAM Address Multiplexing ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА46
TABLE 2-5 DRAM Address Sizes ААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА46
TABLE 3-1 R, C and L Values АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА53
TABLE 3-2 System Chip Operation Modes and Power ConsumptionААААААААААААААААААААААААААААААААААААААААААААААААА53
TABLE A-1 Transmitter Performance АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА92
TABLE A-2 Receiver Performance АААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААААА93
5
1.0 Fax-System Configuration
A typical FAX system based on the NS32FX100, NS32FX200 or NS32FV100, is shown in
Figure 1-1
.
1.1 BLOCK DIAGRAM DESCRIPTION
CPU. The typical FAX system shown below is based on a
single embedded processor. The choice between the NS32FX161, NS32FV16 and the NS32FX164 depends on the specific application requirements.
System Chip. The FAX-system chip interfaces between FAX-system peripheral devices, such as motors, printers and scanners, and the embedded processor. The chip con­tains FAX-system elements such as CODEC, DMA Control­ler, Interrupt Control Unit and counters.
Scanner. Either a Charge-Coupled Device (CCD) scanner or a Contact Image Sensor (CIS) scanner may be used. The NS32FX100 incorporates most of the video circuits, such as shading compensation, dithering and digitizing, which are required for the scanner interface.
Printer. A Thermal Print Head (TPH) can be connected di­rectly to the NS32FX100. Other types of printer engine, such as laser or ink-jet, can easily be interfaced to the NS32FX100 via an additional, small ASIC.
Motors. The NS32FX100 controls two stepper motors. The only external components required to operate the motors are buffers/drivers.
DAA I/F. The telephone line is accessed via a Data Access Arrangement (DAA). The NS32FX100 contains the digital part of a Sigma-Delta CODEC, which connects to the DAA.
A few external components are required to implement the analog part of the CODEC.
Memory. The NS32FX100 directly controls ROM and SRAM. Both the NS32FX200 and the NS32FV100 directly control DRAM, in addition to ROM and SRAM.
Memory access time is also controlled by the NS32FX100, thus allowing the designer to tune memory price and system performance.
MICROWIRE. The serial channel, with programmable inter­face parameters, can be used by advanced FAX systems to interface with other devices (such as EEPROMs).
UART. This serial channel, with programmable interface pa­rameters, can be used by advanced fax systems to commu­nicate with other devices (e.g., host machines).
I/O Pins. General purpose I/O pins are used both to moni­tor (e.g., ring detector read) and control (e.g. scanner light control) the FAX-system peripheral devices.
DMA Channels:
NS32FX100 and NS32FV100. The NS32FX100 and
NS32FV100 have three DMA channels which are used to interface the scanner and the printer. All three channels may be allocated for external usage (e.g., Centronics paral­lel interface, Ethernet).
NS32FX200. The NS32FX200 has four DMA channels. Three channels are used by the NS32FX200 to interface to the scanner and the printer, and one channel is for external usage. All four channels may be allocated for external us­age (e.g., Centronics parallel interface, Ethernet).
6
1.0 Fax-System Configuration (Continued)
1.2 MODULE DIAGRAM
The various functions of the NS32FX100, NS32FV100 and NS32FX200 are performed by on-chip modules as shown below.
The NS32FX100 module diagram is shown in
Figure 1-2.
TL/EE/11331– 3
FIGURE 1-2. NS32FX100 Module Diagram
The NS32FV100 module diagram is shown in
Figure 1-3.
TL/EE/11331– 4
FIGURE 1-3. NS32FV100 Module Diagram
The NS32FX200 module diagram is shown in
Figure 1-4.
TL/EE/11331– 2
FIGURE 1-4. NS32FX200 Module Diagram
7
1.0 Fax-System Configuration (Continued)
The NS32FX100 modules, and their functions, are summa­rized below: For a more detailed description of each mod­ule, see the relevant section.
1.2.1 Bus and Memory Controller (BMC)
The Bus and Memory Controller (BMC) interfaces directly to the NS32FX161, the NS32FV16 or the NS32FX164. It en­ables the NS32FX100 to respond to both read and write transactions, and to generate DMA transactions. It divides the address space into four external zones and generates wait states, and idle cycles, according to the addressed zone, type of transaction and the programmed wait value. The memory controller directly interfaces to ROMs and SRAMs. The memory controllers of the NS32FX200 and the NS32FV100, in addition, directly interface to DRAMs.
1.2.2 Timing Control Unit (TCU)
The Timing Control Unit (TCU) contains three blocks. An oscillators block generates the CPU high-speed clock and the time-keeper clock. The TCU module keeps trace of elapsed time during all operation modes. A counters block contains timers/counters for the various FAX-system con­troller operations.
1.2.3 Sigma-Delta CODEC (SDC)
The Sigma-Delta CODEC (SDC) interfaces with the tele­phone line via an external Data Access Arrangement (DAA), performing analog-to-digital and digital-to-analog conver­sions, data sampling and buffering. Off-hook control and ring-detect monitoring are performed by the Ports module.
1.2.4 Scanner Controller (SCANC)
The Scanner Controller (SCANC) contains the video han­dling block, the scanner signals generator and the stepper motor control block. The block includes both analog and digital circuits. It uses DMA channel 0 to fetch a reference line from memory and DMA channel 2 to store the digitized video data to memory.
1.2.5 Printer Controller (PRNTC)
The Printer Controller (PRNTC) contains the printer bitmap shifter, the stepper motor control block, the temperature­sensing block and the thermal print head control block. It uses DMA channel 1 to fetch the bitmap from memory.
1.2.6 DMA Controller (DMAC)
NS32FX200. The DMA Controller (DMAC) provides four in-
dependent channels for transferring blocks of data between memory and I/O devices, with minimal CPU intervention. Two channels are used for scanner control, one for printer control and one is available for external usage.
NS32FX100, NS32FV100. The DMA Controller (DMAC) pro­vides three independent channels for transferring blocks of data between memory and I/O devices, with minimal CPU intervention. Two channels are used for scanner control, one for printer control.
1.2.7 Universal Asynchronous Receiver-Transmitter (UART)
The Universal Asynchronous Receiver-Transmitter (UART) supports 7-bit or 8-bit data formats, with or without parity, with or without hardware flow control, and with one or two stop bits. The baud rate is generated on-chip, under soft­ware control.
1.2.8 MICROWIRE (MWIRE)
The MWIRE is a serial synchronous communication inter­face. It enables the CPU to interface with any of National Semiconductor’s chips which support MWIRE, such as COP400, COP800 and EEPROMs. The MWIRE interface consists of three signalsÐserial data in, serial data out, and shift clock. Several devices can share the MWIRE channel using selection signals provided by the Ports module.
1.2.9 Interrupt Control Unit (ICU)
The Interrupt Control Unit (ICU) receives internal and exter­nal interrupt sources and generates an interrupt to the CPU when required. Priority is allocated according to a predeter­mined scheme. The ICU supports programmable triggering mode and polarity. Each interrupt source can be individually enabled or disabled. Pending interrupts can be polled, re­gardless of whether they are enabled or disabled.
1.2.10 Ports
The Ports module controls the usage of general-purpose input and output pins. The pins are shared with other mod­ules, and can be configured either as general-purpose I/O pins or as pins that belong to other modules. An input port always holds the current value/state of its associated pins. Output pins can be enabled or disabled (TRI-STATE
É
).
The number of general-purpose output pins can easily be increased using an external latch (e.g., DM74LS373).
1.3 OPERATION MODES
The NS32FX100 operates in one of three modes:
#
Normal Mode: The CPU operates at the full clock fre-
quency. Maximum current consump­tion is 200 mA.
#
Power Save Mode: The CPU runs at 1/16 of the Normal
mode frequency. DMA channels must be disabled, output ports must be TRI­STATE, and MCFG, except for bit 0, must be cleared. Maximum current consumption is 17 mA.
#
Freeze Mode: The CPU is frozen by active reset and
frozen clock; it is not connected to the backup battery. The NS32FX100 chip keeps track of elapsed time. The NS32FX200 and NS32FV100 can, if required, refresh the memories. Maxi­mum current consumption is 1 mA with refresh, and 0.1 mA without refresh.
In normal operation, (see
Figure 1-5
) when reset is assert­ed, the NS32FX100 enters S6 of the Power Save mode. Switching from Power Save to Normal mode is carried out by software.
An RC circuit may be used to generate the CPU’s input reset signal. The WATCHDOG trap signal (WDT), generated by the NS32FX100, may also force active CPU’s input reset. The NS32FX100 receives its reset from the CPU output re­set signal. This line should be pulled down by a resistor to force reset in case the CPU is not powered.
Failure of the main power source is detected externally (see
Figure 1-6
). The CPU is notified by a non-maskable inter­rupt. The NS32FX100 is also notified that power has failed, through the PFAIL
input pin. The NS32FX100 power source
should be externally switched to the backup battery. The
8
1.0 Fax-System Configuration (Continued)
power-fail input is asynchronous. It is recognized by the NS32FX100 during cycles in which the input setup-time re­quirement is satisfied.
Switching from Normal mode to Power Save mode, and vice versa, must always be carried out using the NS32FX100 explicitly. The clock scaling option of the CPU should not be used for this purpose.
1.3.1 Functionality
State S1: Normal Mode. The system operates at the full
clock frequency. The NS32FX100 is powered by the main power supply. Software can switch the system to state S7, Power Save Mode.
The NS32FX100 switches to state S2, Power Fail, when PFAIL
is asserted.
State S2: Power Fail. In this state, the CPU enters an NMI handler, in which the software performs all the bookkeeping required for recovery and switches to full clock frequency. The software should write H’80 to MCFG. Once finished, the software activates the WATCHDOG trap output signal, which asserts the RST
input of the CPU by writing three
times to the WATCHDOG.
When both PFAIL
and RST are active, the NS32FX100 and the RAM must be powered from a battery. The CPU can be powered down.
When RST
is detected, the system chip goes from S2 to
one of the following states:
State S3, if DRAM refresh is enabled (only in NS32FV100
and NS32FX200).
State S5, if no DRAM refresh is needed (NS32FX100Ðal-
ways).
State S3: Complete Refresh Transaction. If RST
is de­tected, while refresh is enabled, in state S2, a refresh trans­action is performed. The system chip then switches to state S4.
State S4: Freeze and Refresh. In this state, the system chip de-activates the fast crystal oscillator and freezes the CCLK clock. Only the Elapsed Time Counter and the DRAM refresh generator are functional.
When the ETC count reaches zero, the state machine switches to state S5, and refresh transactions are stopped. Thus, the contents of the DRAM can be kept for a prede­fined period (software programmable). If the power failure lasts longer than this period, the system should disconnect the DRAM and leave only the ETC, and possibly an SRAM device, connected to the battery.
If PFAIL
goes high, the state machine switches to state S6,
Power Restore.
State S5: FreezeÐNo Refresh. In this state only the ETC counter is activeÐcounting the duration of the power fail­ure. In this state the NS32FX100 functions with a supply voltage as low as 3V.
If PFAIL
goes high, the state machine switches to state S6,
Power Restore.
State S6: Power Restore. This state can be entered either from Freeze Mode or during normal operation when reset is asserted. When entering from Freeze Mode (PFAIL
goes
high), RST
is kept low for a few milliseconds by an external circuit. During this time, the fast crystal oscillator is activated and the CPU and NS32FX100 clocks are synchronized.
If refresh is enabled, the system chip will initiate refresh transactions during this timeÐthe refresh rate is forced to a default value.
When RST
goes high, the NS32FX100 switches to state S7, Power Save Mode.
State S7: Power Save Mode. The CPU runs at a slow fre­quencyÐ1/16 of the Normal Mode frequency.
The system can swtich to S1, Normal Mode, under software control.
If PFAIL
input is asserted, the NS32FX100 switches to state
S2, Power Fail.
TL/EE/11331– 5
FIGURE 1-5. System Chip States and Operation Modes
9
2.0 Architecture
2.1 MCFGÐMODULE CONFIGURATION REGISTER
The software can configure some of the NS32FX100 major operation modes by programming the Module Configuration Register (MCFG). Some of the bits in this register are also used to initialize the TPH block in the PRNTC, the bitmap shfiter block in the PRNTC and the scanner module. When a bit in the MCFG is ‘‘0’’, the associated module is idle. Setting a bit to ‘‘1’’ enables the operation of the associated module. Prior to activating a module, its appropriate regis­ters must be initialized by software.
15 6 5 4 3 2 1 0
res ESDC EDMA0 ESCAN EPBMS ETPHB ECOUNT
ECOUNT: Enable internal counters of the TCU module.
Once set, this bit can not be cleared by software. The TCU counters, except TIMER and WDC, must be initialized prior to setting this bit since they start working when the ECOUNT bit is set.
ETPHB: Enable Thermal Print-Head Block of the PRNTC
module. The strobe-on and strobe-off counters of this block must be initialized prior to setting this bit to ‘‘1’’.
EPBMS: Enable Bitmap Shifter Block of the PRNTC mod-
ule. Clearing this bit is treated, by the Bitmap Shifter, as a hardware reset. The block starts op­erating when this bit is set. When disabled, DMA channel 1 uses the printer PCLK/DMRQ1
pin.
ESCAN: Enable Scanner module. Clearing this bit is treat-
ed, by the Scanner Controller, as a hardware re­set. The module starts operating when this bit is set. When cleared to ‘‘0’’, DMA channel 2 uses the scanner pins and interrupt.
EDMA0: Enable scanner usage of DMA channel 0. When
cleared to ‘‘0’’, DMA channel 0 uses the scanner pins and interrupt.
ESDC: Enable Sigma-Delta CODEC module. When this
bit is set the SDC operation takes place as de­scribed in Section 2.3.
Upon reset the non reserved bits of the MCFG are cleared to ‘‘0’’, thus disabling the above modules and options.
2.2 TIMING CONTROL UNIT (TCU)
2.2.1 Features
#
Generation and control of clock running frequency
#
CPU and NS32FX100 synchronization by Phase Lock Loop (PLL)
#
Fixed System-Tick interrupt of 100 Hz
#
WATCHDOG
#
Timer
#
Buzzer
#
Freeze mode
2.2.2 Operation
The Timing Control Unit (TCU) is responsible for generating the clocks, used for the various timing and counting func­tions in the system, and for freeze mode operation.
Figure
2-1
shows how the clocks are connected in an NS32FX100-
based FAX system.
TL/EE/11331– 6
FIGURE 2-1. Clocks and Traps Connectivity
10
2.0 Architecture (Continued)
2.2.2.1 External Clocks
The TCU contains two oscillators, the high-speed oscillator and the low-speed oscillator. The high-speed oscillator is the FAX system clocking source. It generates the CPU clock and, after division, clocks for the Sigma-Delta CODEC, scanner, printer and serial communications channels. A high-speed clock signal is input to the NS32FX100, from an external crystal, through the FOSCI pin. The NS32FX100 uses this signal to generate the CCLK clock, which serves as the input clock to the CPU. The CPU then divides CCLK by two, and generates CTTL which serves as the bus clock. The NS32FX100 includes a PLL to ensure synchronization between the NS32FX100 clocks and the CPU. CTTL is used to close the PLL loop and enable tracking of the CPU inter­nal clocks.
The low-speed oscillator, which gets its input through the SOSCI pin, is used to keep track of elapsed time and to operate the refresh requester. This oscillator operates in Normal mode, as well as in Power Save and Freeze modes.
The NS32FX100 controls the CPU running frequency. It may reduce the frequency by dividing CCLK by 16. To en­sure accurate tracking of the CTTL phase by the NS32FX100, clock division should be carried out via the NS32FX100, and the power save mode of the CPU should not be used.
The slow oscillator, which operates during Normal, Power Save and Freeze modes, can be a 32.768 kHz oscillator for systems with memory refresh rate of up to 8 kHz. Systems with memory refresh rate higher than 8 kHz should use a slow oscillator of 455 kHz.
2.2.2.2 Internal Clocks
The TCU module generates a 1.2288 MHz Master Clock (MCLK). MCLK is generated by a programmable divider, which divides the CTTL input clock. The MCLK clock is used for synchronization throughout the NSFX100-based FAX system. In particular, the following are derived from MCLK:
#
CLK128ÐA 12.8 kHz clock
#
Time-Slots generator (TSL)ÐAn 8-bit down counter fed by CLK128
The Time-Slots generator performs two functions:
#
Division of each 20 ms period into 256 time slots
#
Generation of a 100 Hz System Tick (STIC)
The time slots are used to synchronize the various compo­nents of the FAX system, e.g., the printer and scanner with their respective motors.
The System Tick is used by both the Interrupt Control Unit (ICU), for generating an interrupt, and by the WATCHDOG counter, as described in Section 2.2.3.
Several registers are provided, to control and use the TCU and I/O signals. These registers are described in Section
2.2.3.
Note 1: When CSCLe1, CLK128 is generated by dividing MCLK by 6.
Note 2: When CSCL
e
0, CLK128 is generated by dividing MCLK by 96.
(MCLK is 1.2288 MHz; refer to Table I for MCLON and MCLOFF values)
TL/EE/11331– 7
Note 3: CLK128 is always 12,800 Hz and STIC is always 100 Hz.
FIGURE 2-2. High Speed Oscillator Clocks
TL/EE/11331– 8
FIGURE 2-3. Low Speed Oscillator Clocks
11
2.0 Architecture (Continued)
2.2.3 Registers
CSCL: CCLK (CPU Input Clock) Scale register.
7543 0
res F res
F: Controls the CCLK frequency.
1: The CCLK frequency is the FOSCI input
frequency divided by 16.
0: The CCLK frequency is the FOSCI input
frequency.
Upon reset F is set to ‘‘1’’.
res: Reserved
MCLOFF: MCLK Off Time. 8-bit register.
MCLOFF should be set to a fixed value, as shown in Table I, as a function of CTTL in nor­mal operation mode, to generate a 1.2288 MHz clock, thus controlling the CTTL duty cycle.
MCLON: MCLK On Time. 8-bit register.
MCLON should be set to a fixed value, as shown in Table I, as a function of CTTL in nor­mal operation mode, to generate a 1.2288 MHz clock, thus controlling the CTTL duty cycle.
TABLE 2-1. CTTL, MCLON and MCLOFF Values
CTTL (MHz) MCLON MCLOFF
14.7456 5 5
15.9744 6 5
17.2032 6 6
18.4320 7 6
19.6608 7 7
20.8896 8 7
22.1184 8 8
23.3472 9 8
24.5760 9 9
TIMER: Programmable Timer.
15 0
TIMER
TIMER: The actual counter bits.
TIMER is a programmable, retriggerable, down counter which generates an interrupt pulse after a programmable number of MCLK cycles. When it goes below zero it stops counting and holds the value 0x0ffff. If a new value is written to the TIMER before it reaches zero, it starts counting down from this new value. Reading TIMER gives its current con­tents.
Each bit in the TIMER register stands for 0.8 ms (1/1.2288 MHz), thus the counter may represent the maximum value of 0.8 x 2
16
ms.
Writing ‘‘0’’ to the timer is not allowed.
BUZCFG: Buzzer Configuration register.
765 0
BCTRL res
BCTRL: Used to control the BUZCLK pin.
00 : BUZCLK pin
e
0.
01 : BUZCLK pine1.
10 : BUZCLK pinesymmetric square wave,
according to BUZSWC register.
11 : Reserved.
BUZSWC: Buzzer Square Wave Counter. 16-bit register.
Used for dividing MCLK to generate a symmetric square wave on the BUZCLK pin, as follows:
BUZCLK frequency
e
MCLK/(2 *
BUZSWC
a
2).
WDC: WATCHDOG Counter. 8-bit register.
The WATCHDOG Counter (WDC) is a down counter that counts STIC pulses. The counter generates a trap signal, on the WATCHDOG Trap (WDT) pin, if the counter reaches zero, or if WDC is written into more than once per STIC cycle. After reset WDC is idle (not counting). It starts counting after it is first written, starting from the value that is written into it. Once start­ed, WDC can be stopped only by a hardware reset.
The WATCHDOG counts STIC pulses which are generated by the TCU. Therefore the WATCH­DOG is functional only when the TCU’s counters are enabled by the MCFG.ECOUNT bit.
Writing ‘‘0’’ to the timer is not allowed.
TSL: Time Slot down counter. 8-bit, read only.
Holds the current time slot. Upon reset the TSL bits are set to ‘‘1’’.
ETC: Elapsed Time Counter. A 32-bit down counter
that counts at a rate of the slow clock (SOSCI) divided by 512.
Accessed as double-word only.
Not affected by reset.
At least four slow-clock cycles are required, be­tween a write and any accesses to ETC, to avoid unpredictable results.
Successive reads from the ETC may differ from each other by two.
Example:
Read ETC, value
e
n (correct value should be
n
a
1)
Read ETC, value
ena
2 (correct value).
RFRT: Refresh Rate Control. 8-bit register.
The refresh is set to occur once every (RFRT
a
1) cycles of the slow clock. RFRT must be set to a minimum value of 3.
The actual refresh transaction may be post­poned due to synchronization with the fast clock and with other memory transactions.
12
2.0 Architecture (Continued)
After reset, RFRT is initialized to 6.
Writing to RFRT must be followed by read back to ensure that the RFRT has, in fact, been up­dated. This procedure must be repeated until RFRT is updated (value read
e
value written).
RFRT exists only in the NS32FV100 and the NS32FX200.
RFEN: Refresh enable
765 0
res EN res
EN 0: No refresh transactions.
1: Refresh transactions are issued by
the chip according to the refresh rate, selected by RFRT.
After reset EN is set to ‘‘1’’.
RFEN exists only in the NS32FV100 and the NS32FX200.
2.2.3.1 Usage Recommendations
The ECOUNT bit, in MCFG, must be set to enable TCU counters operation.
2.3 SIGMA-DELTA CODEC (SDC)
2.3.1 Features
#
16-bit format Analog-to-Digital converter and Digital-to­Analog converter
#
Full and Half Duplex operation
#
Optimized for FAX and DATA Modems
#
Various sampling rates for voice and data applications
#
Total harmonic distortion better thanb70 dB
#
Programmable IIR filters
Ð Programmable transmit filters
Ð Programmable receive filters
Ð Programmable echo canceling filter
#
Programmable gain control
#
Programmable fine timing tuning
#
Digital loop-back mode
#
Reduced CPU load by 12-level transmission FIFO and 12­level reception FIFO
2.3.2 Operation
The Sigma Delta CODEC performs high resolution analog­to-digital (A/D) and digital-to-analog (D/A) conversions us­ing an over sampling technique. This module is optimized for use as the analog front end for Digital Signal Processing (DSP) applications such as modems or voice processing.
The SDC’s main advantage, compared to other A/D and D/A convertors, is the use of digital circuitry resulting in high reliability and reduced cost. The SDC solution incorporates a second-order, digital Sigma-Delta modulator and a noise shaping technique to improve performance.
The digital parts of the converters are implemented on-chip and a few external components implement the analog parts.
NSFAX Software package fully supports the SDC. Software drivers handle both the SDC initialization and data transfers.
National Semiconductor’s modem software is usually pro­vided in binary form, and hence the internal structure of the SDC is transparent to the user. A detailed description of the SDC is available only for source-level customers.
2.3.2.1 Block Diagram
The Sigma-Delta CODEC block diagram is shown in
Figure
2-4.
13
2.0 Architecture (Continued)
TL/EE/11331– 9
FIGURE 2-4. Sigma-Delta Block Diagram
14
2.0 Architecture (Continued)
A full Sigma-Delta CODEC includes a digital part and an analog part. The NS32FX100 includes the digital part, and the analog part should be implemented externally.
2.3.2.2 On-Chip Digital Blocks
Sigma-Delta Over Sampling Rate (OSR) is 128 times the Sampling Rate (SR). Some Sigma-Delta blocks use also Double Sampling Rate (DSR).
For communication applications the SR is 9.6 kHz, DSR is
19.2 kHz and the OSR is 1.2288 MHz. For voice applica­tions the SR is 8 kHz, DSR is 16 kHz and the OSR is
1.024 MHz.
DF (Decimation Filter)ÐReceives 1-bit stream at OSR and decimates it to 16-bit at DSR.
IIR FiltersÐThe IIR filters include Transmission, Reception and Echo-canceler programmable filters. The Echo-cancel­ing filter can be bypassed.
The Transmission IIR includes two filters. The first filter operates at SR. The second filter interpolates the data rate by two. Thus the filter operates at DSR.
The Reception IIR includes two filters. The first filter operates at DSR and decimates the data rate by two. Thus the second filter operates at SR.
The Echo-canceler filter works at DSR. This filter is used to cancel the echo path.
Receive Gain Control (RGC)ÐAmplifies or attenuates the received data, to achieve the required signal level, con­trolled by software Automatic Gain Control (AGC).
Transmit Gain Control (TGC)ÐAttenuates the transmitted data, to achieve the required signal level, controlled by soft­ware Automatic Gain Control (AGC).
Digital Sigma-Delta (DSDM)ÐTransforms the 16-bit trans­mitted data at DSR into a 1-bit stream at OSR. A second-or­der digital Sigma-Delta circuit performs this function.
Processor Interface (PI)ÐContains the SDC control and data registers, a 12-level transmission FIFO, a 12-level re­ception FIFO and a clock divider unit.
2.3.3 Programmable Functions
The Sigma-Delta programming model consists of the follow­ing elements:
#
IIR coefficients memory
#
Data registers
#
Control registers
2.3.3.1 Sigma-Delta ON/OFF
The SDC module is enabled by MCFG.ESDC control bit. When MCFG.ESDC is ‘‘0’’ the SDC module is disabled.
The user can access all SDC memory-mapped addresses (IIR coefficients and SDC registers) only while MCFG.ESDC is active. Any attempt to access SDC memory-mapped ad­dresses while MCFG.ESDC is ‘‘0’’ will cause an unpredict­able result.
To turn off SDC, turn off receive mode (SDCNTL.RE
e
0)
and transmit mode (SDCNTL.TE
e
0) and only then clear
MCFG.ESDC to ‘‘0’’.
2.3.4 Off-Chip Analog Circuits
The circuit required to connect the SDC on-chip module to a 2-wire line is shown in
Figure 2-5
. The components are de-
tailed in the following table:
TABLE 2-2. Component Values
Component Value Tolerance
R1 600X 1%
R2 47 kX 5%
R3 47 kX 5%
R4 47 kX 5%
R5 330X 5%
R6 330X 5%
R7 15.4 kX 1%
R8 56 kX 5%
R9 100 kX 5%
R10 22 kX 5%
R11 22 kX 5%
R12 56 kX 5%
R13 5.1 kX 5%
R14 5.6 kX 5%
R15 1.0 kX 5%
R16 330X 5%
R17 330X 5%
R18 56 kX 5%
C1 0.1 mF 10%
C2 3.3 nF 10%
C3 100 pF 10%
C4 1 nF 10%
C5 22 mF 10%
C6 0.1 mF 10%
C7 22 mF 10%
C8 0.1 mF 10%
C9 47 pF 10%
C10 330 pF 10%
C11 200 pF 10%
C12 22 mF 10%
C13 0.1 mF 10%
C14 22 mF 10%
C15 0.1 mF 10%
C16 100 pF 10%
15
2.0 Architecture (Continued)
TL/EE/11331– 10
FIGURE 2-5. SDC Off-Chip Analog Circuit
16
2.0 Architecture (Continued)
2.3.4.1 Analog Transmitter
The input to the transmit analog circuit is the serial bit stream at OSR, which is generated by DSDM. This serial bit stream is fed to a 1-bit D/A converter. This D/A converter is implemented by an analog switch, which selects either
a
5V
or
b
5V inputs. These voltages are filtered by an RC, low­frequency, Low Pass Filter (LPF), to filter supply noise, and to avoid crosstalk between the transmit and receive circuits. The D/A output is filtered, by a three pole LPF with unity gain, to attenuate the out-of-band quantization noise. The output of the LPF passes through a 600X resistor.
2.3.4.2 Analog Receiver
The reception analog circuit obtains its analog input signal from an isolation transformer. The signal passes through a buffer amplifier, and then enters the Sigma Delta second order loop. The amplifier has two gain levels. One gain level provides a total gain of 0 dB and the second level provides a total gain of 9 dB. The two gain level are controlled by the GAIN signal.
The Sigma Delta second order loop contains two integrators and a comparator to zero. The comparator output is the SDIN input to the on-chip Sigma Delta part. SDIN is sam­pled on-chip at OSR, is passed to the digital filters and re­turns as feedback (SDFDBK pin) to the analog part. This feedback enters a 1-bit D/A converter. This D/A converter is implemented by an analog switch, which selects either
a
5V orb5V inputs. These voltages are filtered by an RC low frequency LPF, to reduce supply noise, and to avoid crosstalk between the transmit and receive circuits. The feedback is an input to the first integrator unit.
The receiver analog circuit can be calibrated by receiving a known reference voltage. When the circuit is calibrated, the receiver input signal is a known reference voltage (V
REF
), otherwise the receiver input is the input signal from the iso­lation transformer.
2.3.5 Registers
The following is a partial list of registers. For a full list see the detailed SD documentation, available to source-level customers.
SDTX Sigma-Delta Transmit Data. This register is the
transmit FIFO port. Any attempt to read from this register will cause an unpredictable result.
SDRX Sigma-Delta Transmit Data. This register is the re-
ceive FIFO port. Any attempt to write to this regis­ter will cause an unpredictable result.
SDCNTL Control register
15 13 12 11 7 6 5 4 3 2 1 0
N/A N/A PRES N/A TE N/A RE N/A
Upon reset SDCNTL.PRES is loaded at the minimum pre­scale value in Full-duplex mode, ‘‘01001’’. All other imple­mented bits of SDCNTL are cleared to ‘‘0’’.
NOTE: Bits marked N/A are available only for source-level customers. For
other customers, they must not be modified.
RE Enables or disables receive mode.
0 : Receive mode is disabled.
1 : Receive mode is enabled.
TE Enables or disables transmit mode.
0 : Transmit mode is disabled.
1 : Transmit mode is enabled.
PRES CTTL prescale. The SDC over-sampling rate is gen-
erated by dividing the CTTL clock by a pre-scale di­vider. The PRES value is calculated as follows:
PRES
e
[
(CTTL/OSR) - 1].
Some examples for sample rate 9.6 kHz and 8 kHz are giv­en below:
CTTL Frequency CTTL Frequency
SDCNTL.PRES (Sample Rate (Sample Rate
9.6 kHz) 8.0 kHz)
01011 14.7456 MHz 12.2880 MHz 01110 18.4320 MHz 15.3600 MHz 01111 19.6608 MHz 16.3840 MHz 10000 20.8896 MHz 17.4080 MHz 10001 22.1184 MHz 18.4320 MHz 10010 23.3472 MHz 19.4560 MHz 10011 24.5760 MHz 20.4800 MHz
SDFTM Fine Timing register.
74320
res ADV STEP
STEP Advance or delay steps amount (0–7)
ADV Advance direction
0: Delay mode is enabled
1: Advance mode is enabled
Writing to this register, while SDCNTL.RE is ac­tive, is allowed only if SDFTM.STEP is equal to a ‘‘0’’.
Writing to this register, while both SDCNTL.RE is active and SDFTM.STEP is not ‘‘0’’, will cause an unpredictable result.
While SDCNTL.RE is active, this register holds the number of advance or delay steps yet to be executed.
SDRGC Receive Gain Control register. Used to amplify or
attenuate the receive IIR output samples. The value to be written in SDRGC register is 128
c
10
(Gain/20)
, rounded to the nearest integer num-
ber.
Some examples are given in the following table:
Gain (dB) SDRGC
b
18 0x0010
b
17.5 0x0011 .. ..
0 0x0080
0.1 0x0081 .. ..
48.0 0x7D98
17
2.0 Architecture (Continued)
SDTGC Transmit Gain Control register. Used to attenuate
the transmit IIR input samples. The value to be written in SDTGC register is 16384
c
10
(Gain/20)
,
rounded to the nearest integer number.
Some examples are given in the following table:
Gain (dB) SDTGC
b
42 0x0082
b
41.9 0x0084 .. ..
0 0x4000
SDSTAT Status Register. Provides information about the
status of the Sigma-Delta operation.
76543210
TSAT RSAT TFNE RFNE TERR RERR TIRQ RIRQ
RIRQ When ‘‘1’’ during receive enable (SDCNTL.REe1),
it indicates that N or more samples are ready in the receive FIFO. This bit will remain high as long as the number of samples is greater than, or equal to, N. If this bit is not masked by SDMASK.RIRQ it will cause an interrupt.
TIRQ When ‘‘1’’ during transmit enable (SDCNTL.TE
e
1), it indicates that less than N samples are ready in the transmit FIFO. This bit will remain high as long as the number of samples is less than N. If this bit is not masked by SDMASK.TIRQ it will cause an interrupt.
RERR When ‘‘1’’ during receive enable (SDCNTL.RE
e
1) it indicates an attempt to read an empty receive FIFO, or incoming sample when the receive FIFO is full. If this bit is not masked by SDMASK.RERR it will cause an interrupt.
TERR When ‘‘1’’ during transmit enable (SDCNTL.TE
e
1) it indicates an attempt to read from an empty trans­mit FIFO, or writing to a full transmit FIFO. If this bit is not masked by SDMASK.TERR it will cause an interrupt.
TFNE Transmit FIFO Not Empty, when ‘‘0’’ indicates that
the transmit FIFO is empty.
RFNE Receive FIFO Not Empty, when ‘‘0’’ indicates that
the receive FIFO empty.
RSAT Reception Saturation. This bit is set to ‘‘1’’, whenev-
er a saturation value is created in the receive IIR (including the echo-canceling filter, when enabled) or in the receive gain control logic.
TSAT Transmit Saturation. This bit is set to ‘‘1’’, whenever
a saturation value is created in the transmission IIR or in DSDM.
Upon reset all implemented bits in the SDSTAT reg­ister are cleared to ‘‘0’’.
SDMASK Mask Register. Enables masking of SDC inter-
rupts.
7 43210
res TERR RERR TIRQ RIRQ
RIRQ Mask Receive Interrupt Request.
0 : SDSTAT.RIRQ will not cause an interrupt.
1 : SDSTAT.RIRQ will cause an interrupt.
TIRQ Mask Transmit Interrupt Request.
0 : SDSTAT.TIRQ will not cause an interrupt.
1 : SDSTAT.TIRQ will cause an interrupt.
RERR Mask Receive Error.
0 : SDSTAT.RER will not cause an interrupt.
1 : SDSTAT.RER will cause an interrupt.
TERR Mask Transmit Error.
0 : SDSTAT.TER will not cause an interrupt.
1 : SDSTAT.TER will cause an interrupt.
2.3.6 Usage Recommendations
The SDC should be enabled (by setting the SDC bit in the MCFG register to ‘‘1’’) before programming SDMASK and SDCNTL.
2.4 SCANNER CONTROLLER (SCANC)
2.4.1 Features
#
Programmable generation of control signals which sup­port a wide range of Charge Coupled Device (CCD) and Contact Image Sensor (CIS) scanners
#
Supports line scan times of 2.5 ms, 5 ms, 10 ms and 20 ms
#
On-Chip shading-correction circuitry, using reference line values stored in the system RAM, via DMA channel 0
#
On-Chip dithering and Gamma correction circuit of 16 grey levels. (64 grey levels in NS32FX200)
#
Support for Automatic Background Control (ABC) and edge enhancement with external circuitry
#
On-Chip multiplying Digital-to-Analog Converter (DAC) for compensation of scanner offset
#
Automatic writing of scanned bitmap to memory via DMA channel 2
#
Optional bypass of on-chip video-data generation to sup­port external image enhancement
2.4.2 Operation
The Scanner Controller Module (SCANC) consists of a scanner signals generator block, a video handling block (shading compensation, dithering and bitmap accumulation) and a stepper motor control block. The module includes analog and digital circuits. It uses two DMA channelsÐone for fetching a reference line and one for storing the digitized video data. The module is synchronized with the TCU mod­ule. The operation of SCANC, and the allocation of DMA channels 0 and 2 to the Scanner Controller or for external usage, are controlled by the Module Configuration Register (MCFG). The module’s minimum operation frequency is
14.7456 MHz (i.e., it can not operate in Power Save mode). Some of the Scanner signals can be assigned to an I/O port when the Scanner is not used (e.g., after reset).
18
2.0 Architecture (Continued)
2.4.2.1 Scanner Signals Generator Block
This block generates the timing control signals required by CIS and CCD scanners. Scanners with line scan time of
2.5 ms, 5 ms, 10 ms or 20 ms are supported. This period is derived from the TCU module’s time-slots (generated by the TCU dividing each 20 ms into 256 time-slots).
The block generates the following signals:
Ð Scanner Period Pulse (SPP), an internal synchronization
pulse.
Ð Scanner Pixel Clock (SPCLK), an internal pixel clock (its
frequency is twice the scanner clock).
Ð Pixel clocks (two phasesÐSCLK1 and SCLK2).
Ð Integrator Discharge Pulse (SDIS).
Ð Sample and Hold control clock (SNH). Used to sample
the scanner analog video signal.
Ð Scan Line Synchronization Pulse (SLS). Indicates the
beginning of a scan line.
Ð Scanner Comparator Preset, an internal initialization sig-
nal for the on-chip analog comparator.
Ð Active window, an internal time frame that controls the
operation of the bitmap generator.
Ð Peak Detector Window (SPDW). One of the Automatic
Background Control (ABC) control signals.
Ð Scanner interrupt pulse.
Ð Scanner motor interrupt pulse.
Each signal is generated by an independently programmed waveform generator. The flexible waveform definition facili­tates the support of different scanner models.
TL/EE/11331– 11
FIGURE 2-6. Block Diagram of Scanner’s Signals Generator Block
19
2.0 Architecture (Continued)
2.4.2.2 Scanner Period Pulse (SPP) Generation
The Scanner Period Pulse (SPP) is used to synchronize all the scanner control signals. It is derived from the time slots generated by the TCU module (which divides each 20 ms into 256 time slots).
SPCLK Generation
The internal Scanner Pixel Clock (SPCLK) is generated by dividing CTTL by a programmable prescale value. The result is a video clock which is twice the frequency of the scanner clocks. SPCLK is used for generation of other scanner sig­nals. The value of SPCLK should be determined according to the scanner specification.
The SPCLK pre-scale divider is reset by each SPP leading edge. As a result, the first SPCLK cycle after the SPP may be distorted. Software should program the control registers SAVWD, SLSD and SPDWD so that the first pixel after the SPP is ignored.
SCLK1 and SCLK2 Generation
The two scanner clocks, SCLK1 and SCLK2, are generated by dividing SPCLK by two. SCLK1 is high and SCLK2 is low after SPP leading edge.
SDIS and SNH Generation
The Integrator Discharge Pulse (SDIS) and the Sample-and­Hold Control Clock (SNH) are generated by timers which are clocked by CTTL and triggered by SPCLK. For each of these signals, the polarity, the delay (between SPCLK and its leading edge) and the width are software programmable. The total number of delay and width cycles must not exceed the number of CTTL cycles in one SPCLK period.
Analog Comparator Preset Generation
The Analog Comparator Preset is an internal signal used to initialize the on-chip analog comparator. It is generated by a timer, clocked by CTTL and triggered by SNH leading edge.
TL/EE/11331– 12
Note: In this figure SDIS has inverted polarity (DISPe0).
FIGURE 2-7. Scanner Pixel Control Signals
20
2.0 Architecture (Continued)
SLS Pulse Generation
Scan Line Sync (SLS) is generated by a timer according to a calculated delay (in CTTL cycles) from the beginning of the SPP pulse. The delay between the beginning of SPP and the leading edge of SLS, SLS pulse width, and SLS polarity are software programmable.
The first pixel clock after SPP may be distorted. SLS must be programmed so that this pixel is ignored.
Active Video Window and Peak Detector Window Generation
The active Video Window, signaling the valid data window, and the Peak Detector Window, signaling the programmable window for Automatic Background Control, are generated
by timers which are triggered by SPP and clocked by SPCLK.
Scanner Interrupt Generation
The scanner interrupt is a rising-edge interrupt, generated at the beginning of a time slot which is defined by the Scanner Interrupt Time-Slot register (SITSL).
2.4.2.3 Video Handling Block
The Video Handling Block is an Analog-to-Digital convertor for the analog video signal. It enables shading, half-toning and bi-level support with Automatic Background Control (ABC). It also allows pixel generation control, using external circuitry.
TL/EE/11331– 13
Note 1: The delay is controlled by the respective register (SLSD, SAVWD or SPDWD).
Note 2: Measured in CTTL cycles.
Note 3: Measured in SPCLK cycles.
FIGURE 2-8. Scanner Period Control Signals
TL/EE/11331– 14
FIGURE 2-9. Block Diagram of Scanner’s Video Handling Block
21
2.0 Architecture (Continued)
Video DAC (Shading-Compensation)
The shading-compensation circuit includes an 8-bit multiply­ing Digital-to-Analog Converter (DAC) that multiplies SVI, the analog input from an external video sample and hold circuit, with a digital reference value (white line) fetched by DMA channel 0. The Video DAC compensates for the input offset, according to the compensation value in the SVDB register, and the control bits in the SVHC register. By writing to the SVDB register, it is possible to control the Video DAC directly by software. In this case, the same 8-bit value repli­ca should be written to both bytes of the register. When the compensation value is greater than the input video signal, the compensated video data signal is ‘‘0’’. The compensat­ed video data, at the output of the video DAC, feeds the video comparator. It also goes to an external pin (SCVO) to enable external implementation of an Automatic Back­ground Control (ABC) circuit.
To enable a longer latency for DMA channel 0 operations, a double buffer is used. DMA cycles are synchronized to the leading edge of SNH during active video window.
When DMA channel 0 is disabled, the same value should be written to both bytes of the Scanner Video DAC Buffer (SVDB) register.
2.4.2.4 Threshold DAC (Dithering and Automatic Background Control)
The dithering circuit includes an 8-bit multiplying DAC that multiplies SBG, the input from an external Automatic Back­ground Control (ABC) circuit, with the digital dither value from one of the eight dither bytes. The threshold DAC has no output pin and no I
OFF
, internal offset current, but is
otherwise similar to the video DAC.
The block includes a cyclic buffer for 64 grey levels. The cyclic buffer contains eight bytes, only one of which is ac­cessible at any given time. Any buffer access (software read, software write or hardware read) causes a cyclic shift in the buffer after the access is completed. A hardware ac-
cess, on SNH leading edge, loads the value of the accessed byte to the DAC’s input. Hardware access can take place only during active video window. Software access is carried out via the SDITH register. Software may not access the buffer during active video window. The dither cyclic buffer is shown in
Figure 2-10.
For a gray-level image, ABC should be disabled by externally clamping the SBG input to a con­stant source. For this purpose, an external analog switch, controlled by any of the Ports module, may be used.
Note: Eight dither registers are available on all system chips. The difference
between the number of supported gray levels lies in the different characteristics of the associated analog circuits.
TL/EE/11331– 15
FIGURE 2-10. Dither Cyclic Buffer
Video Comparator
The output of the shading-compensation (video) DAC is compared by the video comparator with the output of the dithering (threshold) DAC. The comparator feeds the pixel generator.
Bitmap Accumulator
The bitmap accumulator includes a pixel generator and a bitmap shift register. It uses DMA channel 2 to store the bitmap into memory.
22
2.0 Architecture (Continued)
Pixel Generator
Pixels may be treated in one of three ways:
No bypass The output of the video comparator is an
image pixel. It may be inverted by the pixel generator before the pixel is shifted into the bitmap shifter.
Input bypass (Available in the NS32FX200 only.) The vid-
eo comparator output is bypassed, (the vid­eo DAC output is taken through the SCVO output pin to an external circuit), and an ex­ternally generated pixel is taken as the input to the pixel generator through the SBYPS pin.
Output bypass (Available in the NS32FX200 only.) As in the
No bypass case, the comparator feeds the bitmap shifter. In addition, the last sampled pixel, sampled on the last SNH leading edge and inverted, is driven onto the SBYPS pin for optional use by an external circuit (e.g., for edge emphasis).
The operation mode of the pixel generator, in the NS32FX200, is controlled by the Scanner Video Handling Control register (SVHC) and Port C control registers (PCMS, PCEN). It must be configured as ‘‘No bypass’’ in the NS32FX100 and NS32FV100.
No bypass Ð SVHC.BYPASS
e
0 and
PCMS.MS4
e
0.
Input bypass Ð SVHC.BYPASSe1 and
PCMS.MS4
e
1 and
PCEN.EN4
e
0.
Output bypass Ð SVHC.BYPASSe0 and
PCMS.MS4
e
1 and
PCEN.EN4
e
1.
Note that the pin output value is unpredictable if the scanner module is disabled (MCFG.ESCAN
e
0) while both
PCMS.MS4 and PCEN.EN4 are set.
The pixel generator can be configured to invert a pixel be­fore it is shifted.
Bitmap Shifter
The pixel generator output is accumulated and stored into memory via DMA channel 2. Pixels are shifted from left to right i.e. The first pixel in each word is the Least Significant Bit (LSB). The bitmap is double buffered by the Scanner Bitmap Shifter (SBMS) and a word buffer between the scan­ner module and the DMA channel. The shifter operation is enabled during active window only, and clocked by SNH leading edge. In order to allow software intervention in col­lecting the scanner’s bitmap, the shifter is readable by soft­ware.
2.4.2.5 Stepper Motor Control Block
The stepper motor is controlled by four phases. The motor direction and speed is controlled by setting, or clearing, each phase as scanning progresses. The motor is con­trolled by setting the time-slots in which the phases should be changed (in the SMTSL register). When the set time-slot is reached, an interrupt is generated and the phase values are updated to the values in the phase register (SMPH) in the Ports module.
2.4.3 Registers
SPRES: Scanner SPCLK Prescale. 8-bit register.
One SPCLK cycle time equals (SPRES
a
1)
CTTL cycles.
SDISD: Scanner Discharge Delay. Write only. 8-bit reg-
ister. Controls the delay between the edge of SCLK1 and the leading edge of the SDIS signal. The delay is (SDISD
a
1) CTTL cycles.
SDISW: Scanner Integrator Discharge Pulse Width.
Write only. 8-bit register. The width is (SDISW
a
1) CTTL cycles.
SNHD: Scanner Sample and Hold Delay. Write only.
8-bit register. Controls the delay between the edge of SCLK1 and the leading edge of SNH signal. The delay is (SNHD
a
1) CTTL cycles.
SNHW: Scanner Sample and Hold Pulse Width. Write
only. 8-bit register. The width is (SNHW
a
1) CTTL cycles.
SCMPRW: Scanner Comparator Preset Pulse Width. Write
only. 8-bit register. The width is (SCMPRW
a
1) CTTL cycles.
SLSD: Scanner Line Sync Delay. Write only. 8-bit regis-
ter. Controls the delay between the Scanner’s Peri­od Pulse (SPP) and the leading edge of the SLS signal.
SLSW: Line Sync Pulse Width. Write only. 8-bit register.
The width is (SLSW
a
1) CTTL cycles.
SAVWD: Active Video Window Delay. Write only. 16-bit
register. Controls the delay between the leading edge of the Scanner’s Period Pulse (SPP) and the be­ginning of the active video window (number of ignored pixels).
SAVWW: Active Video Window Width. Write only. 16-bit
register. The width is (SAVWW
a
1) SPCLK cycles.
SPDWD: Peak Detector Window Delay. Write only. 16-bit
register. The delay between leading edge of Scanner’s Period Pulse (SPP) and the beginning of peak detector window.
SPDWW: Peak Detector Window Width. Write only. 16-bit
register. The width is (SPDWW
a
1) SPCLK cy-
cles.
SGC: Scanner Signals Generator Control register.
23
2.0 Architecture (Continued)
743210
res LSPP PDWP SNHP DISP
DISP: Scanner Discharge Pulse Polarity.
0 : Active low
1 : Active high
SNHP: Sample and Hold Pulse Polarity.
0 : Active low
1 : Active high
PDWP: Peak Detector Window Polarity.
0 : Active low
1 : Active high
LSPP: Line Sync Pulse Polarity.
0 : Active low
1 : Active high
SPP: Scanner period pulse. 8-bit register.
7F : Period pulse each 20 ms (TSL
e
255).
BF : Period pulse each 10 ms (TSLe255 and 127).
DF : Period pulse each 5 ms (TSLe255, 63, 127
and 191).
EF : Period pulse each 2.5 ms (TSL
e
255, 31, 63,
95, 127, 159, 191, 223).
SPP must be programmed with one of these four values, otherwise the period pulse frequency is un­defined.
(TSL indicates the appropriate TCU time slot.)
SVHC: Scanner Video handling Control Register.
7654 0
res BYPASS INVERT VDILS
VDILS: Video DAC Input Level Shift.
Number of current steps to be added-to/sub­tracted-from the input of the Video DAC. This field is encoded as: Sign bit
a
four magnitude bits. When the input of the video DAC is to be incremented, the sign bit, bit 4, should be set to ‘‘1’’. When it is to be decremented, the sign bit should be ‘‘0’’. Legal values for VDILS are in the range
1F . . . 10
0 ...0F
INVERT: 0 : Pixel not inverted by the pixel generator
1 : Pixel inverted by the pixel generator
BYPASS: (NS32FX200 only.)
0 : No bypass. The comparator output is received by the pixel genertor.
1 : Bypass enabled. The SBYPS input is selected by the pixel generator and the comparator output is ignored.
Note: Only the NS32FX200 enables bypassing the video
comparator output through the SBYPS pin. BYPASS must always be cleared to ‘‘0’’ in the NS32FX100 and NS32FV100.
SVDB: Scanner Video DAC Buffer. 16-bit register.
Holds two bytes of compensation values. The lower byte is used first and the upper byte is used for the next pixel.
Normally written by DMA channel 0. Accessible by software when the DMA channel is either disabled or not allocated to the scanner (i.e., MCFG.EDMA0
e
0).
SBMS: Scanner Bitmap Shifter. Read Only. 16-bit regis-
ter. Pixels are shifted from left to right, i.e., the first pixel in each word is the LSB.
SITSL: Scanner Interrupt Time Slot. 8-bit register.
Holds the number of the time-slot in which the scanner interrupt pulse is generated.
SMTSL: Scanner Motor Time Slot. 8-bit register.
Holds the number of the time-slot in which the motor interrupt is generated.
Note: For an event to occur at the beginning of time slot n,
the relevant register (SITSL or SMTSL) must be pro­grammed with n
a
1. If the written value equals the TSL value (the current time slot) then the event will occur either in the next time slot, or after 257 time slots.
Example: If a scanner interrupt is to occur at the begin­ning of time slot
Ý
255 the value: ‘‘0’’ should be written
to SITSL.
SDITH: Scanner Dither Cyclic Buffer.
15 8 7 0
accessible byte res
The accessible byte is decoded into eight suc­cessive address locations. The eight dither val­ues must be initialized before the video active window is reached (the first write for the first pix­el).
2.4.4 Usage Recommendations
1. Before activating the Scanner, program the appropriate Ports module registers PBDO, PBMS, PCDO, PCMS and PCEN to connect the Scanner module to the NS32FX100 I/O pins.
2. To activate the Scanner Module, set the ESCAN and ECOUNT bits in the MCFG register.
3. The number of current steps, to be added to the input of the Video DAC, may be initialized by comparing the Video DAC to the appropriate dither value, and using an iterative process to evaluate the required Input Level Shift.
4. The reference line may be initialized, by software, by reading a white line and using an iterative process to evaluate the best value of each pixel’s compensation byte.
5. When a scanner with an internal shading-compensation circuit is used, DMA channel 0 is free for external use.
6. DMA channel 2 must be cleared before it can be used, this should be done through 32-bit dummy transactions as follows:
a. activate DMA channel 2 for a 4-byte read transaction
b. dummy write two words, to ensure that at least two bus cycles occur, thus clearing the channel, read SBMS to clear the shifter counter.
7. The SAVWD, SLSD and SPDWD control registers should be programmed, by software, to ignore the first pixel after SPP.
24
2.0 Architecture (Continued)
8. The peak detector window may be used to disable the ABC circuit outside the programmed window. The ac­tive video window and the peak detector window are configured separately, thus allowing a peak detector window smaller than the active video window.
9. Programming the Pixel Generator bypass control (using SVHC.BYPASS) must be accompanied by an appropri­ate setup in the Port C control bits, PCMS.MS4 and PCEN.EN4.
10. To prevent loss of pixels by the Bitmap Shifter, the ac­tive window should be programmed to allow the accu­mulation of exactly 16 pixels.
11. Whenever the time-slot set for the stepper motor is reached, the SMPH register in the Ports module should be updated, by software, to hold the phase value of the next change. This should be done in the appropriate interrupt handler code. At the same time, a different time-slot may be set in the SMTSL to control the next stepper motor phase.
12. The NS32FX100 Scanner module should be configured to match the requirements of the scanner device, the external analog circuit and the NS32FX100 analog cir­cuit. The NS32FX100 analog circuit requirements are detailed in Section 4.5.
13. Do not disable the Scanner Controller during Active Window time frame.
14. Access dither registers only outside the active window.
2.5 PRINTER CONTROLLER (PRNTC)
2.5.1 Features
#
Interfaces with a variety of Thermal Print-Head (TPH) devices
#
Programmable strobe mode, strobe cycle, duty cycle and polarity
#
On-Chip TPH temperature sensing circuitry
#
Bitmap shift register, using DMA channel 1
#
Support for Laser Beam and Ink-Jet engines (NS32FX200 only)
2.5.2 Operation
The NS32FX100 provides a complete interface to TPH de­vices. The PRNTC operates at a minimum frequency of
14.7456 MHz.
This module is composed of two blocks:
Printer Bitmap Shifter Block
Transfers data to the printer from memory, via DMA channel 1, to the Printer Bitmap Shifter of the PRNTC, from which it is then serially shifted to the printer.
The block’s output signals are:
PCLK (clock)
PDO (data)
Thermal Print-Head Block
Controls signals, such as strobes and stepper motor phase signals. It also features a temperature sensing circuit, which receives an indication of the TPH temperature through the PTMP temperature sense pin, and is used by software to control the strobes, ensuring that the TPH does not over­heat.
The block’s input signal is:
PTMP (analog temperature)
The block’s output signals are:
STB0–3 (TPH strobes)
2.5.2.1 Printer Bitmap Shifter Block
Data for the printer is first transferred from memory via DMA channel 1, into a 16-bit latch in the Printer Bitmap Shifter. From this latch the data is transferred to a 16-bit shift regis­ter, from which it is serially shifted to the printer.
At the beginning of the operation (when PRNTC is enabled by setting the EPBMS bit in the MCFG register), this block issues two consecutive DMA requestsÐone to fill the shift register and one to fill the latch. Subsequently, whenever the shift register is empty, the latch contents are transferred to it, and a new DMA transfer is requested to refill the latch.
Shift direction is controlled by the SLNR bit of the Printer Bitmap Configuration (PBCFG) register. Actual bitmap shift takes place according to the ECLK bit of the PBCFG regis­ter, using either an internal or an external clock, (in the NS32FX100 and NS32FV100 this bit is always ‘‘0’’ and the shifting always uses an internal clock). Data is always shift­ed out, when the shifter is not empty, on clock falling edge. When an internal clock is used, the clock signal is high when there is no available data to shift out.
An internal clock is used for Thermal Print-Heads.
An external clock is recommended for Laser Beam Printers since video (pixels) left margin, active time and polarity are externally synchronized with the printer engine.
The frequency of the external clock should be in the range
0.5 MHz to 4 MHz.
2.5.2.2 Thermal Print-Head Control Block
This block generates the printer stepper motor phase sig­nals, the printer strobes, and the printer interrupt. Its opera­tion is synchronized with the TCU time slots, and is fully controlled by software.
Stepper Motor Controller
The stepper motor is controlled by four phases. The motor direction and speed is controlled by setting, or clearing, each phase as printing progresses. The motor is controlled by setting the time-slots in which the phases should be changed (in the PMTSL register). When the set time-slot is reached, an interrupt is generated and the phase values are updated to the values in the phase register (PMPH) in the Ports module.
TL/EE/11331– 16
FIGURE 2-11. Bitmap Shifter Signals
25
2.0 Architecture (Continued)
Strobes Generator
A train of strobes consists of two or four strobes depending on the strobes mode. The train of strobe pulses starts on the time slot pre-defined in the Printer Strobes-Start Time Slot (PSTSL) register. The train of strobe pulses starts with a strobe-on interval, followed by a sequence of strobe-off and strobe-on intervals. The duration of the strobe-on inter­val is controlled by the STBON register and the duration of the strobe-off interval is controlled by the STBOFF register. The strobe-on and strobe-off intervals may be programmed while the strobe pulses are being generated. After the last strobe-on interval is completed, a Strobes-Done interrupt pulse is generated. The interrupt is periodic, occurring when the pre-defined time slot is reached and the train of strobe pulses is completed.
Strobing pulses are generated on the STB0–3 output pins, if enabled by the STBEN bit of the Thermal Print-Head Con­trol (TPHC) register. After the last strobe-on interval is com­pleted, the STBEN bit is automatically cleared by hardware. To prevent losing strobe pulses, the software should verify that the bit is cleared before setting it to ‘‘1’’.
The strobing mode defines both the number of strobes in a train and the distribution of strobes among the STB0 –3 pins. Two strobing modes are supported, Two-Strobes mode and Four-Strobes mode. The Strobe Mode (STBM) field of the TPHC register selects the strobing mode to be used.
The two strobing modes are shown in
Figure 2-12
and
Fig-
ure 2-13
for TPHC.SPOLe1. Note that ‘‘Start’’ is the begin-
ning of the time slot and ‘‘Done’’ is the Strobes-Done event.
TL/EE/11331– 17
FIGURE 2-12. Four Strobes Mode (STBMe00)
TL/EE/11331– 18
FIGURE 2-13. Two Strobes Mode (STBMe01)
26
2.0 Architecture (Continued)
Printer Interrupt Generator
The Interrupt Control Unit dedicates one interrupt either to the Strobes-Done pulse or to DMA channel 1. The Printer Interrupt Source (PIS) bit of the TPHC register selects which of the interrupt pulses is routed to the Interrupt Control Unit.
Temperature Sensing Circuit
A 6-bit A/D Converter (ADC) is implemented by a 6-bit Pulse Width Modulation (PWM) based D/A convertor and an analog comparator. The control loop of the ADC is exe­cuted under software control. The total time for both PWM based D/A conversion and for comparator settling is less than 2 ms. The DAC must be initialized to 011111 at least 10 ms prior to the first reading of the comparator output.
TL/EE/11331– 19
FIGURE 2-14. Temperature ADC
27
2.0 Architecture (Continued)
2.5.3 Registers
PBCFG: Printer Bitmap Shifter Configuration register.
7210
res SLNR ECLK
ECLK: External Clock. (NS32FX200 only.)
0 : Shift using an internal clock. Clock frequency
is selected by the printer bitmap internal clock generator.
1 : Shift using an external clock.
The external clock must be frozen at least four instructions after both DMA channel 1 and the Bitmap Shifter are enabled (i.e., MCFG.EPBMS
e
1).
Note: Only the NS32FX200 supports operation using an
external clock. ECLK must always be cleared to ‘‘0’’ in the NS32FX100 and NS32FV100.
SLNR: Shift direction.
0 : Shift right (LSB first)
1 : Shift left (MSB first)
PBCFG may not be written while MCFG.ETPHB
e
1. It
should be configured before printer activation.
PCLON: Printer Bitmap Shifter internal clock (PCLK) high
time. 8-bit register. PCLK is high for (PCLON
a
1) CTTL cycles. PCLON may be modified only when MCFG.EPBMS
e
0.
PCLOFF: Printer Bitmap Shifter internal clock (PCLK) low
time. 8-bit register. PCLK is low for (PCLOFF
a
1) CTTL cycles.
PCLOFF may be modified only when MCFG.EPBMS
e
0.
TPHC: Thermal Print-Head Control register.
7543210
res STBEN PIS SPOL STBM
STBM: Strobing mode (see
Figure 2-12
and
Figure
2-13
).
00 : Four strobes
01 : Two strobes
10 : Reserved
11 : Reserved
SPOL: Strobes polarity.
0 : Active low strobe-on
1 : Active high strobe-on
PIS: Printer Interrupt Source.
0 : Strobes done interrupt pulse
1 : DMA channel 1 interrupt pulse
STBEN: Strobes Enable.
Set by software to enable strobe generation on strobe pins STB0–3. Automatically cleared by hardware after the last strobe-on interval is com­pleted. To avoid losing strobe pulses, verify that this bit is cleared before setting it to ‘‘1’.
Upon reset the non-reserved bits of TPHC are cleared to ‘‘0’’.
STBON: Strobe-On. 16-bit register.
The strobe-on interval is (STBON
a
1) MCLK
cycles.
STBOFF: Strobe-Off. 16-bit register.
The strobe-off interval is (STBOFF
a
1) MCLK
cycles.
PSTSL: Printer Strobes Start Time Slot. 8-bit register.
Holds the time slot in which the strobe pulse train starts.
PMTSL: Printer Motor Time-Slot. 8-bit register.
Holds the time slot in which the Printer Motor In­terrupt Pulse is generated. The interrupt pulse oc­curs at the beginning of the specified time slot.
Note: For an event to occur at the beginning of time slot n, the
relevant register (PSTSL or PMTSL) must be set to the value n
a
1. If the written value equals the TSL value the current time slot) then the event will occur either in the next time slot, or after 257 time slots.
Example: If a printer interrupt is to occur at the begin­ning of time slot
Ý
255 write the value ‘‘0’’ to PSTSL.
PDAC: Printer PWM Pulse Width Modulation DAC.
765 0
res PDAC
The PWM signal duty cycle is (PDACa1)/64.
The signal width is zero when PDACe3F.
PACMP: Printer Analog Comparator Status. 8-bit register.
Read only.
Bit 0:
1 : DAC voltage
l
PTMP pin voltage.
0 : DAC voltagekPTMP pin voltage.
Bits 1–7: Reserved.
2.5.4 Usage Recommendations
1. Before activating the Printer, program the appropriate Ports module registers PBDO, PBMS, PCDO, PCMS and PCEN to connect the Printer module to the NS32FX100 I/O pins.
2. Completion of the Printer Bitmap Shifter operation is indi­cated either through the STROBE-DONE interrupt or through the DMA COUNTER-DONE status bit (STAT.TC is set to ‘‘1’’). If indicated by the DMA STAT.TC bit, 32 additional bits must be explicitly shifted out of the Bitmap Shifter, to complete the DMA transfer.
3. When TPHC.STBEN
e
0, strobes are still generated in­ternally, hence the Strobes-done interrupt can still be used even when strobes are disabled.
4. When using the Bitmap Shifter with an external clock the operation must be carried out in the following order:
a. Initialize the ports module to work with the printer us-
ing an external clock (ports B and C).
5. Disable the strobes (TPHC.STBEN
e
0) before disabling
the TPH module (MCFG.ETPHB
e
0).
28
2.0 Architecture (Continued)
b. Initialize the PRNTC module to work with an external
clock.
c. Initialize DMA channel 1 registers without enabling the
channel (set CNTL1.CHEN
e
0).
d. Set MCFG.ECOUNT, and MCFG.EPBMS to ‘‘1’’ to en-
able the PRNTC module.
e. Set CNTL1.CHEN to ‘‘1’’ to enable DMA channel 1.
f. Issue at least four instructions (may be NOPs).
g. Enable the external clock operation.
2.6 DIRECT MEMORY ACCESS CONTROLLER (DMAC)
2.6.1 Features
#
Four independent channels in NS32FX200, three in NS32FX100 and NS32FV100
#
Single and double buffering, and auto-initialize modes
#
Fly-By or memory-to-I/O transactions
#
8- or 16-bit wide transactions
#
Maximum throughput 12.5 Mbyte/second
#
Channels configurable as internal or external
2.6.2 Description
The DMA Controller (DMAC) provides independent chan­nels for transferring blocks of data between memory and I/O devices with minimal CPU intervention. A block transfer is composed of several byte or word transfers.
A general DMA channel, with eight registers and a superset of features, is described first. Any on-chip DMA channel is either similar to, or a subset of, this general channel. The four NS32FX200 DMA channels, and the three NS32FX100 and NS32FV100 DMA channels, are described after the de­scription of the general DMA channel.
2.6.2.1 A General DMA Channel
Memory address, block size and type of operation are set up prior to DMA activation by programming the appropriate control registers. Actual byte or word transfers are handled by the DMA channel in response to I/O device requests. Upon receiving a transfer request from an I/O device, the DMA Controller performs the following operations:
1. Acquires control of the bus (via HOLD
, HLDA mecha-
nism).
2. Acknowledges the requesting I/O device, or one of sev­eral requesting I/O devices, according to the priority and to the values stored in the control registers of the re­spective channel.
3. Executes the data transfer.
4. Updates the termination status bit (TC bit of the STAT register) when the specified number of bytes has been transferred.
2.6.2.2 Transfer Types
Each byte or word transfer can be carried out as one of the following two types:
Fly-By (Direct) Transfers
In Fly-by mode each data item is transferred using a single bus cycle without reading the data into the DMA Controller. This mode offers the fastest transfer rate. Data transfer can­not occur between two memory elements. One of the ele­ments must be the I/O device that requested the DMA
transfer. This device is referred to as the implied I/O device. The other element can be either memory or another I/O device, and is referred to as the addressed device. The number of bytes transferred in each cycle is always two. Fly­by DMA transactions are word aligned; device address and block length must be even numbers. DMA transfers are con­trolled by the DMA module registers. A detailed description of the DMA operation is provided in Section 2.6.3.
Memory-to-I/O (Indirect) Transfers
In Memory-to-I/O mode each data item is transferred using two bus-cycles. Data transfer cannot occur between two memory elements. One of the elements must be the I/O device which requested the DMA transaction. This device is referred to as the implied I/O device and is 8-bits wide. The other element can be either memory or another I/O device, is referred to as the addressed I/O device and is 16-bits wide. The DMA controller takes care of both byte gathering and scattering. DMA transfers are controlled by the DMA module registers. A detailed description of the DMA opera­tion is provided in Section 2.6.3. Memory-to-I/O transfers are available only through channel 3.
2.6.2.3 Operation Modes
Each block transfer can be carried out in one of three modes:
#
Single Buffer Mode provides the simplest way to accomplish a
single block transfer operation. It performs one DMA block transfer, and, when the transfer is completed, prepares the speci­fications for the next transfer.
#
Double Buffer Mode allows the software to set up the next
block-transfer specification while the cur­rent block-transfer is in progress.
#
Auto-Initialize Mode allows the DMA Controller to continuously
fill the same memory area without soft­ware intervention.
A detailed description of the various modes of operation is provided in Section 2.6.3.
2.6.3 Detailed Operation Flow
The DMA operation is controlled through the DMA registers. The flow of the various DMA operations, using different reg­isters for each transfer type and operation mode, is detailed below:
Fly-By Operation
The address for the Fly-by mode is taken from the ADCA counter register. The DMA channel generates either a read or a write bus cycle according to the setting of the transfer direction (DIR) bit in the MODE register. When the DIR bit is ‘‘0’’, a read bus-cycle from the addressed device is per­formed and the data is written to the implied I/O device. When the DIR bit is ‘‘1’’, a write bus-cycle to the addressed cycle is performed, and the data is read from the implied I/O device. After the two bytes have been transferred, the Block Length Counter (BLTC) is decremented by two. The Device Address Counter (ADCA) is incremented or decremented by two, or remains unchanged, according to the Decrement/In­crement (DEC) and Device Address Control (ADA) bits in the MODE register.
29
Loading...
+ 65 hidden pages