# **SL11R**USB Controller/16-Bit RISC Processor Technical Reference # **ScanLogic Corporation** 8 New England Executive Park Burlington, MA 01803 http://www.scanlogic.com | DEI | FINITIONS | 7 | |----------------------|----------------------------------------------------------------------|----| | REI | FERENCES | 7 | | RE | VISION HISTORY | 8 | | 1. | INTRODUCTION | 9 | | 1.1 | Overview | g | | 1.2 | SL11R FEATURES | 9 | | 1.3 | SL11R 16-BIT RISC PROCESSOR | 11 | | 1.4 | 3KX16 MASK ROM AND BIOS | 11 | | 1.5 | NTERNAL RAM | 12 | | 1.6 | CLOCK GENERATOR | 12 | | 1.7 | USB INTERFACE | 12 | | 1.8 | PROCESSOR CONTROL REGISTERS | 12 | | 1.9 | Interrupts | 12 | | 1.10 | 0 UART INTERFACE | 12 | | 1.11 | 1 2-WIRE SERIAL EEPROM INTERFACE | 12 | | 1.12 | 2 EXTERNAL SRAM/DRAM/EPROM INTERFACE | 13 | | 1.13 | 3 GENERAL TIMERS AND WATCH DOG TIMER | 13 | | 1.14 | 4 SPECIAL GPIO FUNCTIONALITY FOR SUSPEND, RESUME AND LOW POWER MODES | 13 | | 1.15 | 5 PROGRAMMABLE PULSE/PWM INTERFACE | 13 | | 1.16 | 6 FAST DMA MODE | 13 | | 1.17 | 7 SL11R INTERFACE MODES | 13 | | | 1.17.1 General Purpose IO mode (GPIO) | | | | 1.17.2 8/16-bit DMA Mode | | | | 1.17.3 Fast EPP Mode<br>1.17.4 DVC 8-bit DMA Mode | | | 2. | INTERFACE | | | <del>2.</del><br>2.1 | | | | 2.2 | | | | 2.3 | | _ | | 2.4 | | _ | | 2.5 | | | | | 2.5.1 USB Global Control & Status Register (0xC080: R/W) | | | | 2.5.2 USB Frame Number Register (0xC082: Read Only) | | | | 2.5.3 USB Address Register (0xC084: R/W) | | | 2.6 | 2.5.4 USB Command Done Register (0xC086: Write Only) | | | 2.7 | , | | | 2.8 | | | | 2.9 | | | | ۷.5 | 2.9.1 USB Endpoint 0 Address Register (0x0120: R/W) | | | | 2.9.2 USB Endpoint 1 Address Register (0x0124: R/W) | | | | 2.9.3 USB Endpoint 2 Address Register (0x0128: R/W) | 20 | | | 2.9.4 USB Endpoint 3 Address Register (0x012C: R/W) | | | | 2.9.5 USB Endpoint 0 Count Register (0x0122: R/W) | 20 | © 1996 - 2000 ScanLogic Corporation. All rights reserved. SL11R is a trademark of ScanLogic Corporation. The information and specifications contained in this document are subject to change without notice. Date: 07/25/00 **Revision: 1.80** Date: 07/25/00 **Revision: 1.80** | | 2.9.6 | USB Endpoint 1 Count Register (0x0126: R/W) | | |------|------------------|-------------------------------------------------------------------------------------------|----| | | 2.9.7<br>2.9.8 | USB Endpoint 2 Count Register (0x012A: R/W)USB Endpoint 3 Count Register (0x012E: R/W) | 21 | | 2.10 | 2.10.1 | CESSOR CONTROL REGISTERS Configuration Register (0xC006: R/W) | | | | 2.10.1 | Speed Control Register (0xC008: R/W) | | | | 2.10.3 | Power Down Control Register (0xC00A: R/W) | | | | 2.10.4 | Breakpoint Register (0xC014: R/W) | | | 2.11 | | RRUPTS | | | | 2.11.1 | Hardware Interrupts | | | | 2.11.2 | Interrupt Enable Register (0xC00E: R/W) | | | | 2.11.3<br>2.11.4 | GPIO Interrupt Control Register (0xC01C: R/W)Software Interrupts | | | 2.12 | | RT INTERFACE | | | | 2.12.1 | UART Control Register (0xC0E0: R/W) | | | | 2.12.2 | , | | | | 2.12.3 | UART Transmit Data Register (0xC0E4: Write Only) | 28 | | | 2.12.4 | <b>5</b> \ \ | | | 2.13 | | AL EEPROM INTERFACE (2-WIRE SERIAL INTERFACE) | | | 2.14 | EXT | ERNAL SRAM, EPROM, DRAM | 29 | | | 2.14.1 | Memory Control Register (0xC03E: R/W) | 30 | | | 2.14.2 | Extended Memory Control Register (0xC03A: R/W) | | | | 2.14.3 | Extended Page 1 Map Register (0xC018: R/W) | | | | 2.14.4 | Extended Page 2 Map Register (0xC01A: R/W) | | | | 2.14.5<br>2.14.6 | DRAM Control Register (0xC038: R/W) Memory Map | | | 2.15 | _ | ERAL TIMERS AND WATCH DOG TIMER | | | _ | 2.15.1 | Timer 0 Count Register (0xC010: R/W) | | | | 2.15.2 | Timer 1 Count Register (0xC012: R/W) | | | | 2.15.3 | Watchdog Timer Count & Control Register (0xC00C: R/W) | | | 2.16 | SPE | CIAL GPIO FUNCTION FOR SUSPEND, RESUME AND LOW POWER MODES | 35 | | 2.17 | Pro | GRAMMABLE PULSE/PWM INTERFACE | 35 | | | 2.17.1 | PWM Control Register (0xC0E6: R/W) | 36 | | | 2.17.2 | PWM Maximum Count Register (0xC0E8: R/W) | | | | 2.17.3 | PWM Channel 0 Start Register (0xC0EA: R/W) | | | | 2.17.4 | PWM Channel 0 Stop Register (0xC0EC: R/W) | | | | 2.17.5<br>2.17.6 | PWM Channel 1 Start Register (0xC0EE: R/W)PWM Channel 1 Stop Register (0xC0F0: R/W) | | | | 2.17.7 | PWM Channel 2 Start Register (0xC0F2: R/W) | | | | 2.17.8 | PWM Channel 2 Stop Register (0xC0F4: R/W) | | | | 2.17.9 | PWM Channel 3 Start Register (0xC0F6: R/W) | | | | 2.17.10 | PWM Channel 3 Stop Register (0xC0F8: R/W) | | | | 2.17.11 | PWM Cycle Count Register (0xC0FA: R/W) | | | 2.18 | | r DMA Mode | | | | 2.18.1 | DMA Control Register (0xC02A: R/W) | | | | 2.18.2<br>2.18.3 | Low DMA Start Address Register (0xC02C: R/W)High DMA Start Address Register (0xC02E: R/W) | | | | 2.18.4<br>2.18.4 | Low DMA Stop Address Register (0xC030: R/W) | | | | 2.18.5 | High DMA Stop Address Register (0xC032: R/W) | | | 3. | | 1R INTERFACE MODES | | | 3.1 | GEN | ERAL PURPOSE IO MODE (GPIO) | 40 | | - | 3.1.1 | I/O Control Register 0 (0xC022: R/W) | | | | 3.1.2 | I/O Control Register 1 (0xC028: R/W) | | Date: 07/25/00 **Revision: 1.80** | 3.2 | 3.1.3<br>3.1.4<br>3.1.5<br>3.1.6<br>8/16 | Output Data Register 0 (0xC01E: R/W) Output Data Register 1 (0xC024: R/W) Input Data Register 0 (0xC020: Read only) Input Data Register 1 (0xC026: Read only) | 41<br>41<br>41 | |------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 3.3 | 3.2.1<br>3.2.2<br>3.2.3<br>3.2.4<br>3.2.5<br>3.2.6<br>FAST | Mailbox Protocol INBUFF Data Register (0xC0C4: R/W) OUTBUFF Data Register (0xC0C4: R/W) STATUS Register (0xC0C2: Read Only) DMA Protocol DMA Control Register (0xC0C0: R/W) | 43<br>43<br>43<br>43 | | | 3.3.1<br>3.3.2<br>3.3.3<br>3.3.4<br>3.3.5<br>3.3.6 | EPP Data Register (0xC040: R/W) | | | 3.4 | 3.4.1<br>3.4.2<br>3.4.3<br>3.4.4<br>3.4.5<br>3.4.6<br>3.4.7 | 8-BIT DMA MODE Video Status Register (0xC06E: Read Only) Camera Serial Interface Registers Serial Interface Control & Status Register (0xC068: R/W) Serial Interface Address Register (0xC06A: Write Only) Serial Interface Data Write Register (0xC06C: Write Only) Serial Interface Data Read Register (0xC06C: Read Only) I/O Address Map. | 46<br>47<br>47<br>47<br>47 | | 4. | PHY | SICAL CONNECTION | 50 | | 4.1 | PAC | (AGE TYPE | 50 | | 4.2 | GPI | O AND 8/16-BIT DMA MODES - PIN ASSIGNMENT AND DESCRIPTION | 50 | | 4.3 | FAST | EPP PIN ASSIGNMENT AND DESCRIPTION | 52 | | 4.4 | DVC | 8-BIT DMA MODE PIN ASSIGNMENT AND DESCRIPTION | 54 | | 5. | SL1 | IR CPU PROGRAMMING GUIDE | 57 | | 5.1 | INST | RUCTION SET OVERVIEW | 57 | | 5.2 | RESI | ET VECTOR | 57 | | 5.3 | REG | STER SET | 57 | | 5.4 | GEN | ERAL PURPOSE REGISTERS | 57 | | 5.5 | GEN | ERAL PURPOSE/ADDRESS REGISTERS | 57 | | 5.6 | REG | BANK REGISTER (0xC002: R/W) | 58 | | 5.7 | FLAG | SS REGISTER (0XC000: READ ONLY) | 58 | | 5.8 | INST | RUCTION FORMAT | 58 | | 5.9 | | RESSING MODES | | | 5.10 | | STER ADDRESSING | | | 5.11 | | DIATE ADDRESSING | | | 5.12 | | CT ADDRESSING | | | 5.13 | | RECT A DDRESSING | | | 5.14 | | RECT ADDRESSING WITH AUTO INCREMENT | | | 5.15 | | RECT ADDRESSING WITH OFFSET | | | 5.16 | STAC | CK POINTER (R15) SPECIAL HANDLING | 60 | | Example 2 SL11R extended memory setup: | 29 | |--------------------------------------------------------------------------------------------------------------------------|-----| | T | 4.4 | | Table 1 Internal Masked ROM (SL11R BIOS) | | | Table 2 Internal RAM memory usage | 15 | | Table 3 Hardware Interrupt Table | 24 | | Table 4 Software Interrupt Table | 26 | | Ta ble 5 Memory Map | 32 | | Figure 1 SL11R Block DiagramFigure 2: 48MHz Crystal CircuitFigure 3: 12MHz Crystal circuitsFigure 4 UART Port Connection | 11 | | Figure 2: 48MHz Crystal Circuit | 16 | | Figure 3: 12MHz Crystal circuits | 17 | | Figure 4 UART Port Connection | 27 | | ©1996 - 2000 Scanlogic Corporation All rights reserved. \$L11P is a trademark of | | Revision: 1.80 Page: 5 ScanLogic Corporation. The information and specifications contained in this document are subject to change without notice. ## **ScanLogic Corporation** ## SL11R Hardware Specification Date: 07/25/00 **Revision: 1.80** | Figure 5 2-wire serial interface 2K-byte connection | 29 | |-----------------------------------------------------|----| | Figure 6 2-wire serial interface 16K Connection | | | Figure 7 Special GPIO pull up connection example | 35 | | Figure 8 PWM Block Diagram | | | Figure 9 GPIO mode Block Diagram | | | Figure 10 8/16-bit DMA Mode Block Diagram | 42 | Page: 7 Revision: 1.80 ## **DEFINITIONS** USB Universal Serial Bus **SL11R** The SL11R is a ScanLogic **USB** Controller, which provides multiple functions on a single chip. QT Quick stream data Transfer engine, which contains a small set of RISC instructions designed for the SL11R USB controller. QTS 'QT' is a naming convention that represents QT Engine utility tools. For example: 'QTS' indicates all tools, which interface with the RS232 serial interface port. QTU QT Engine Tools that interface with the USB port R/W Read/Write PLL Phase Lock Loop. PWM Pulse Width Modulation DVC Digital Video Camera MFU Multi Function Units WDT Watch Dog Timer RAM Random Access Memory EPP Enhanced Parallel Port: An asynchronous, byte-wide, bi-directional channel controlled by the host device. This mode provides separate address and data cycles over the eight data lines of the interface. 2-wire serial interface 2-wire Serial EEPROM interface. R0-R15 SL11R Registers: R0-R7 Data registers or general-purpose registers. R8-R14 Address/Data registers, or general-purpose registers. R15 Stack pointer register. **SL11R BIOS** A simulation model similar to 80x86 BIOS ## **REFERENCES** [Ref. 1] SL11R\_BIOS [Ref. 2] SL11R\_TOOLS [Ref. 3] Universal Serial Bus Specification 1.1 Date: 07/25/00 **Revision: 1.80** Page: 8 ## **REVISION HISTORY** | Name and Version | Date Issue | Comments | | | | | | |------------------|---------------|----------------------|--|--|--|--|--| | Rev 1.60 | April 7, 2000 | Update from Rev 1.20 | | | | | | | Rev 1.70 | June 14, 2000 | Update from Rev 1.60 | | | | | | Page: 9 Revision: 1.80 ## 1. INTRODUCTION #### 1.1 Overview The SL11R is a low cost, high speed Universal Serial Bus (USB) RISC based Controller. It contains a 16-bit RISC processor with built-in SL11R BIOS ROM to greatly reduce firmware development work. Its 2-wire serial EEPROM interface offers low cost storage for USB device configuration and customer's product-specific functions. New functions can be programmed into the 2-wire serial interface by downloading them from a USB Host PC. This unique architecture provides the ability to upgrade products in the field without changing the peripheral hardware. The SL11R Processor can execute code from either internal ROM/RAM or external ROM and SRAM. The SL11R Programmable bi-directional Data Port supports both DMA and I/O modes. A built in USB port supports up to 12 MBits/sec. data transfers, the maximum USB transfer rate. All USB protocol modes are supported: Isochronous (up to 1024 bytes/packet), Bulk, Interrupt, and Control. The SL11R requires only a 3.3 Volt power supply, which can be powered via a USB host PC or a Hub. Resume, Suspend and Low power modes are available. The SL11R offers an optimal solution for a variety of peripheral products such as: Scanners, Digital Cameras (Video and Still), Color Printers, Multi-function Units (MFU), Faxes, External Storage devices, Monitors, Connectivity boxes, and other peripherals that traditionally interface via EPP or SCSI to a host PC. #### 1.2 SL11R Features - ScanLogic offers a Development Kit with each of its product lines. These Development Kits include multiple peripheral Mini-port class drivers for Windows 98/2000, firmware source code and demo USB source code for a variety of applications. Also available is an SL11R "C" compiler, debugger, and assembler with a reference demo board. - 48 MHz 16 bit RISC Processor - Up to 16 bits of Programmable Bi-directional Data I/O - Up to 32 bits of General Purpose I/O (GPIO) - 6Kx8 internal Mask ROM with built-in BIOS in supporting a comprehensive list of interrupt calls (see [Ref. 1] SL11R\_BIOS for detailed information). These include USB functions, 2-wire serial interface, and UART and Boot-Up options (Boot-up from 2-wire serial interface or External ROM). Executable code can also run from 8-bit or 16-bit external Memory. - 3Kx8 internal RAM that can be configured as the USB Ping-Pong buffer for USB DATA0 and DATA1 packets. It also can be used for data and/or code. - Two-wire serial EEPROM interface port with SL11R BIOS support to allow on-board EEPROM programming - Flexible Programmable external memory wait-states and a 8/16 data path - Up to 16-bit address for Extended Memory Interface Port for External SRAM and ROM - On chip DRAM Controller - On chip fast EPP Interface - On chip 8/16-bit DMA data path interface - Supports 12 MHz/48MHz external crystal or clock **Page:** 10 - Executable code or data can be loaded either from the USB port or via the UART port. The code/data is moved to RAM for either debugging purposes (using a break point register), or to be programmed as a two-wire serial EEPROM. - USB Port (12 Mbits/sec), including a built-in USB transceiver. All USB standard protocol modes are supported: Isochronous mode (up to 1024 packet size), Bulk, Interrupt, and Control modes. - There are four available Endpoints. Each endpoint utilizes a bi-directional DMA port to move data between the Memory and the USB. Independently, data can be sent/received to/from the Data Port. - Two General Purpose Timers, a Watchdog timer (WDT), four programmable PWM channels, and four Programmable Timing Generator outputs - Four PWM or Programmable Timing Generator output channels are available. Each channel provides a programmable timing generator sequence that can be used to interface to various CCD, CIS, and CMOS image sensors, or can be used for other types of applications. - Suspend, Resume and Low Power modes are supported - UART interface supports from 900 Baud to 115.2K Baud - USB Generic Mini-Port Driver for WIN98/2000 is available - Debugger and QT-Assembler are available - "C" Compiler option available - Package: 100 LPQFP - Power requirements 3.3v Page: 11 Revision: 1.80 #### SL11R Block Diagram Figure 1 SL11R Block Diagram #### 1.3 SL11R 16-Bit RISC Processor The SL11R can be used as a general purpose 16 bit embedded processor. It includes a USB interface (Universal Serial Bus) and up to 32 bits of GPIO supporting a variety of functions and modes. The 16-bit main data port can be used in either I/O or DMA bi-directional modes. Also, the SL11R contains 4 PWM channels or four Programmable Time Generator (PTG) signals, a UART, a 2-wire serial EEPROM interface, an additional External DRAM or SRAM interface for extended memory, two Timers, a Watchdog Timer, an internal mask BIOS ROM (3kx16) and an SRAM (3Kx8). The SL11R is optimized to offer maximum flexibility in the implementation of a variety of applications such as: Embedded Digital Video USB controller, USB Scanner controller, USB Cable Modems, Printers, External Storage Devices, MFU, etc. The SL11R contains a specialized instruction set (RISC) that is highly optimized to provide efficient coding for a variety of applications such as video processing algorithms, Network data packet translation and USB transaction processing. The SL11R includes a simple software interface for all USB transaction processing, which supports Bulk mode (up to 64 Bytes/packet), Isochronous mode (up to 1024 Bytes/packet), Interrupt and Control modes. #### 1.4 3Kx16 Mask ROM and BIOS The SL11R has a built in 3Kx16 Mask ROM that contains the SL11R BIOS. This BIOS ROM provides the software interface for the USB and a boot-up option for a 2-wire serial interface or external 8/16 EEPROM. Page: 12 Revision: 1.80 #### 1.5 Internal RAM The SL11R contains 3K x 8 internal RAM. The RAM can be used for code/program, variables, buffer I/O, DMA data (i.e. Video data), and USB packets. This memory can be accessed by the 16-Bit processor for data manipulation or by the SIE (Serial Interface Engine), which receives or sends USB host data. #### 1.6 Clock Generator A 12 or 48 MHz external Crystal or logic-level clock can be used with the SL11R. Two pins, X1 and X2, are provided to connect a low cost crystal circuit to the device. If a logic-level clock is available, it may be connected directly to the X1 pin instead of a crystal. Register C006 must be configured appropriately depending on the frequency used. #### 1.7 USB Interface The SL11R has a built-in SIE and USB transceiver that meet the USB (Universal Serial Bus) specification v1.1. The transceiver is capable of transmitting or receiving serial data at the USB maximum data rate of 12 Mbits/sec. The SL11R Controller supports four endpoints. Endpoint 0 is the default pipe and is used to initialize and manipulate the peripheral device. It also provides access to the peripheral device's configuration information, and supports control transfers. Endpoint 1, 2, and 3 support Interrupt transfers, Bulk transfers (up to 64 Bytes/packet), or Isochronous transfers (up to 1024 Bytes/packet size). ## 1.8 Processor Control Registers The SL11R provides software control registers that can be used to configure the chip mode, the clock generator, and the software breakpoint and to read the BIOS version. ## 1.9 Interrupts The SL11R provides 127 interrupt vectors for the SL11R BIOS software interface (see [Ref. 1] SL11R BIOS). #### 1.10 UART Interface The SL11R has a built-in UART interface, which supports data rates from 900 to 115.2K Baud. It can be used as a development port or for other interface requirements. The ScanLogic development environment for the SL11R chip includes a debugger and assembler. Optional "C" compiler is also available\*. You can download modified code to internal SRAM and debug it using the built-in Breakpoint register and Breakpoint Interrupt to break on any specified address location. \*Contact ScanLogic for details. #### 1.11 2-wire Serial EEPROM Interface The SL11R provides an interface to an external serial EEPROM. The interface is implemented using General Purpose I/O signals. A variety of serial EEPROM formats can be supported; currently the BIOS ROM supports a two-wire serial EEPROM. A serial EEPROM can be used to store specific Peripheral USB configuration and value-added functions. In addition, serial EEPROM can be used for field product upgrades. #### 1.12 External SRAM/DRAM/EPROM Interface The SL11R provides a multiplexed address port and an 8/16-bit data port. This port can be configured to interface to an external SRAM, EPROM or DRAM. The port provides nRAS; nCASL, nCASH, nDRAMWR and nDRAMOE control signals for data access and refresh cycles to the DRAM. ## 1.13 General Timers and Watch Dog Timer The SL11R has two built in programmable timers that can provide an interrupt to the SL11R Engine. The timers decrement on every microsecond Clock tick. An interrupt occurs when the timer reaches zero. A separate Watchdog timer is also provided to provide a fail-safe mechanism. The Watchdog timer can also interrupt the SL11R processor. ## 1.14 Special GPIO functionality for Suspend, Resume and Low Power modes The SL11R CPU supports suspend, resume and CPU low power modes. The SL11R BIOS assigns GPIO29 for the USB DATA+ line pull-up (this pin can simulate USB cable removal or insertion while the USB power is still applied to the board) and the GPIO20 for controlling power off function. ## 1.15 Programmable Pulse/PWM Interface The SL11R has four built-in PWM output channels available under 8/16-bit DMA mode. Each channel provides a programmable timing generator sequence that can be used to interface to various line CCD, CIS, CMOS image sensors or can be used for other applications. This feature is only available in the 8/16-bit DMA Mode. #### 1.16 Fast DMA Mode This mode is currently used by the DVC 8-Bit DMA and 8/16-Bit DMA modes. In DVC 8-Bit DMA mode, the DMA data path will be 8-bits, which correspond to SD7-SD0. In the 8/16-Bit DMA mode, the DMA data path can be configured to either 8 or 16 bits. #### 1.17 SL11R Interface Modes The SL11R has four modes. They are General Purpose I/O mode, Fast EPP mode, 8-bit DMA mode, and 8/16-bit DMA, Mailbox Protocol ports mode. These modes are shared and can be configured under software control. Note: The UART and 2-wire serial interface IO pins are fixed in all cases. ## 1.17.1 General Purpose IO mode (GPIO) In the GPIO mode, the SL11R has up to 32 General-Purpose IO signals available. However, there are 4 pins that are used by the UART and the 2-wire serial interface that cannot be used as GPIO pins. A typical application for this GPIO is the Parallel Port to USB. The SL11R executes at 48MHz, which is fast enough to generate any Parallel Port timing. The SL11R also includes a special mode for EPP timing designed for special devices that have no delay in EPP mode. On any other available General Purpose programmable I/O, pins can be programmed for peripheral control and/or status, etc. **Note**: The Fast DMA and PWM Interfaces are not supported in this mode. #### 1.17.2 8/16-bit DMA Mode This Mode includes the Mailbox Protocol and DMA Protocol. The Mailbox Protocol allows asynchronous exchange of data between the external Processor (i.e. DSP or other Microprocessor) and SL11R via SD15-SD0 (GPIO15-0) bi-directional data port. The DMA ©1996 - 2000 ScanLogic Corporation. All rights reserved. SL11R is a trademark of ScanLogic Corporation. The information and specifications contained in this document are subject to change without notice. Date: 07/25/00 **Revision: 1.80** Page: 14 Revision: 1.80 Protocol allows large blocks of data to be transferred to or from the SL11R via the 8/16-bit DMA port. #### 1.17.3 Fast EPP Mode This mode is designed to interface with a special optimized high-speed EPP interface. In this mode, the SL11R processor has direct access to the EPP control port. Note: The Fast DMA and PWM Interface are not supported in this mode. #### 1.17.4 DVC 8-bit DMA Mode This DVC 8-bit DMA mode is designed to interface with CCD cameras. Camera control and setup is performed through the serial control bus. The SL11R 16-bit processor has direct access to the control port and the camera operation is dependent on commands passed from the USB Host to the SL11R. Raw video data from the CCD Camera is input to the SL11R on the 8-bit video data bus (SD7-SD0) using a combination of clock, control signals and 8-bit DMA. **Note**: The PWM Interface is not supported in this mode. ## 2. INTERFACE #### 2.1 Internal Masked ROM: 0xE800-0xFFFF The SL11R has a built-in 3Kx16 internal masked ROM that contains software bootstrap code to allow programs in an external 8/16-bit ROM to be executed. The ROM code can also load data from the 2-wire serial interface into internal RAM for execution. In addition, the internal BIOS ROM contains the Interrupt Service Routines (see [Ref. 1] SL11R\_BIOS for information) that support the USB, 2-wire serial interface, UART interfaces and Boot-Up options (Boot-up from 2-wire serial interface or External ROM). This SL11R BIOS ROM eases software development of all SL11R interfaces. The SL11R Chip is ready for all the USB enumeration and download/program code. The SL11R Internal Masked ROM (i.e. SL11R BIOS) is mapped from address 0xE800 to 0xFFFF. On power up or hardware reset, the SL11R processor jumps to the address of 0xFFF0, which contains a long jump to the beginning of the internal ROM of address 0xE800. See table below: | Address | Memory Description | |---------------|--------------------------------| | 0xE800-0xFFEF | SL11R BIOS code/data space | | 0xFFF0-0xFFF3 | Jump to 0xE800 | | 0xFFF4-0xFFF9 | Reserved for future use. | | 0xFFFA-0xFFFB | ROM BIOS Checksum | | 0xFFFC- | SL11R BIOS Revision | | 0xFFFD | | | 0xFFFE-0xFFFE | Peripheral Revision | | 0xFFFF-0xFFFF | QT Engine Instruction Revision | | | | Table 1 Internal Masked ROM (SL11R BIOS) #### 2.2 External ROM: 0xC100-0xE800 The SL11R BIOS ROM reserves addresses from 0xC100 to 0xE800 for external ROM. During BIOS initialization, the SL11R will scan for the signature ID (0xCB36) at location 0xC100. After a valid signature is detected, execution will begin at address 0xC102 (see [Ref. 1] SL11R\_BIOS for more information). The signal nXROMSEL is used to enable the external ROM. It is mapped from 0xC100 to 0xE800 by default. However, the Extended Memory Control can be used to configure multiple windows for external ROM setup. <u>Note</u>: The Address space from 0x8000-0xC100 can also be used as the external ROM (see the External Memory Control setup for more detail). #### 2.3 Internal RAM: 0x0000-0x0BFF The SL11R contains a 1.5Kx16 internal RAM. This memory is used to buffer video data and USB packets and is accessed by the 16-bit processor and the SIE (Serial Interface Engine). USB transactions are automatically routed to the memory buffer. The 16-bit processor has the ability to set up pointers and block sizes in buffer memory for USB DMA transactions. For example, video data can be read from the camera interface and is sent to the USB port by the internal DMA engine. The SL11R BIOS uses this internal RAM for USB buffers, BIOS variables and user data/code. Executable code or data can reside in multiple locations: internal masked ROM (3Kx16), internal RAM (3Kx8), external ROM and external SRAM. Program code or data can also be loaded to either the internal or the external RAM from the USB port, the RS232 port, or the 2-wire serial interface. The SL11R Internal RAM is mapped from 0x0000 to 0x0BFF. See internal RAM memory usage in **Table 2** below: | Address | Memory Description | |------------------------------|-----------------------------------------| | 0x0000 - 0x00FF | Hardware/Software Interrupts | | 0x0100 - 0x01FF | Register Banks/USB Control/Software | | | Stack | | 0x0200 - 0x021F | Hardware Interrupts stack | | 0x0220 - 0x0343 <sup>1</sup> | SL11R BIOS internal buffers & variables | | 0x0344 - 0x0BFF | User's Programming Space | #### Table 2 Internal RAM memory usage - The addresses from 0x0000 to 0x00FF are reserved for hardware and software interrupt vectors (see [Ref. 1] SL11R\_BIOS for more information). - Addresses from 0x0100 to 0x01FF are reserved for Internal Register Banks (SL11R register R0-R15 bank 0 and R0-R15 bank 1) and the software stack. Others are reserved for USB Control registers and other read/write control registers. - Addresses from 0x0200 to 0x021F are reserved for the hardware interrupt stack. - Addresses from 0x0220 to 0x0343 are available internal RAM for application software. Software can be downloaded via the USB port or UART interface (see [Ref. 1] SL11R\_BIOS for more information). ©1996 - 2000 ScanLogic Corporation. All rights reserved. SL11R is a trademark of ScanLogic Corporation. The information and specifications contained in this document are subject to change without notice. Date: 07/25/00 **Revision: 1.80** <sup>&</sup>lt;sup>1</sup> This address may be changed due to SL11R BIOS revision updates. The new SL11R BIOS may require more internal memory for its variable usage in any new SL11R BIOS. #### 2.4 Clock Generator The SL11R has an option to use either a 48 MHz or 12 MHz external crystal or oscillator as its clock source. SL11R includes an internal PLL that can be configured by software. At power-up, the SL11R BIOS default configuration sets the processor clock to run at 2/3 of X1 (of the external provided clock). #### Example 1 Changing SL11R CPU Speed The default of the SL11R BIOS assumes a 48MHz input clock, so the SL11R processor clock is (2/3)\*48MHz = 32MHz. See example below: mov [0xC006],0x10 ;clock = 2/3\*X1 mov [0xC008],0 ;CPU clock at 32MHz If the X1 input clock is 48MHz, then the maximum speed of the SL11R processor can be set at follows: mov [0xC006],0 ;clock = set up at X1 clock input mov [0xC008],0 ;CPU clock at 48MHz If the X1 input clock is 12MHz, then the maximum speed of the SL11R processor can be set to: mov [0xC006],0x40 ;clock = 4\*X1 mov [0xC008],0 ;CPU clock at 48MHz Figure 2: 48MHz Crystal Circuit Resistors and capacitor value: - R2 = 1Meg Ohms - R6 = 100 Ohms - C31 = 0.01 uF - C27 = 20pF - L1 = 3.3 uH - X1 = 48Mhz, series, 20pF load capacitance. **Page:** 17 Revision: 1.80 Figure 3: 12MHz Crystal circuits X1 X2 R2 1 MEG X101 R6 C31 C31 R6 Resistors and capacitor value: - R2 = 1Mega Ohms - R6 = 100 Ohms - C31 = 20pF - C27 = 20pF - X1 = 12Mhz, series, 20pF load capacitance. Note: You need to set bit C2 =1 from configuration address (0xC006). See **section 2.72** for CPU control speed. ## 2.5 USB Interface The SL11R has a built-in transceiver that meets the USB (Universal Serial Bus) specification v1.1. The transceiver connects directly to the physical layer of the USB engine. It is capable of transmitting or receiving serial data at the USB maximum data rate, 12 Mbits/sec. The SL11R has four USB DMA engines for four USB endpoints. Each of the USB DMA engines is independently responsible for its respective USB transaction. The 16-bit processor has the ability to set up pointers and block sizes in buffer memory for USB transactions. The SL11R Controller contains a number of Registers that provide overall control and status functions for USB transactions. The first set of registers is for control and status functions, while the second group is dedicated to specific endpoint functions. Communication and data flow on the USB is implemented using endpoints. These uniquely identifiable entities are the terminals of communication flow between a USB host and USB devices. Each USB device is composed of a collection of independently operating endpoints. Each endpoint has a unique identifier: the endpoint number. See USB specification v1.1. Sec 5.3.1 The SL11R also includes the SL11R BIOS that provides a set of subroutines via interrupt calls for all USB interface functions required to communicate with a USB host (refer to [Ref. 1] **SL11R\_BIOS** for more information). The SL11R BIOS greatly simplifies the firmware/software development cycle. ## 2.5.1 USB Global Control & Status Register (0xC080: R/W) The USB Global Control & Status Register allows high-level control and provides status of the USB-DMA engines. The Global Control & Status register bits are defined as follows: | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | UA | US | UR | UE | D15-D4 Reserved #### ScanLogic Corporation | SI 11R | Hardware | Specification | |--------|----------------|---------------| | JLIII | i iai a vvai c | Specification | | D0 | UE | USB Enable = '1', Overall USB enable/disable bit | |----|----|--------------------------------------------------| | D1 | UR | USB Reset = '1', USB received Reset command | | D2 | US | USB SOF = '1', USB received SOF command | | D3 | UA | USB Activity = '1', Activity Seen | #### Notes: - Suspend state should be entered if after 3mS there is no activity (UA). - The US and UA bits are automatically cleared after they are read by the SL11R processor. - D15-D4 are the reserved bits, should be written with zeros. - The SL11R BIOS will set the UE=1 upon reset. ## 2.5.2 USB Frame Number Register (0xC082: Read Only) The Frame Number Register contains the 11-bit ID Number of the last SOF received by the device from the USB Host. | | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |---|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | ĺ | 0 | 0 | 0 | 0 | 0 | S10 | S9 | S8 | S7 | S6 | S5 | S4 | S3 | S2 | S1 | S0 | D15-D11 Reserved set to all zeros. D10-D0 S10-S0 SOF ID Number of last SOF Received #### Note: The SL11R BIOS uses this register to detect USB activity for the internal idle task. ## 2.5.3 USB Address Register (0xC084: R/W) Address Register holds the USB address of the device assigned by the Host - initialized to address 0x0000 upon Power up. | | | D13 | | | | | | | | | | | | | | |---|---|-----|---|---|---|---|---|---|----|----|----|----|----|----|----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | A6 | Α5 | A4 | А3 | A2 | A1 | Α0 | D15-D7 Reserved set to all zeros D6-D0 A6-A0 USB Address of device after assignment by Host #### Note: The SL11R BIOS modifies this register upon receiving the SET\_ADDRESS from the host. (See [Ref. 3] Universal Serial Bus Specification 1., Chapter 9 for more information) ## 2.5.4 USB Command Done Register (0xC086: Write Only) This is the USB command done register. It is only used by the control point (endpoint 0). | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Е | D15-D1 Reserved set to all zeros. D0 E Set E=0 for Successful Command Completion Set E=1 for Error Command Completion #### Note • The SL11R BIOS modifies this register upon command completion on endpoint 0. Date: 07/25/00 **Revision: 1.80** **Page:** 19 Revision: 1.80 ## 2.6 USB Endpoint 0 Control & Status Register (0xC090: R/W) See the USB Endpoint 3 Control & Status Register for more information. ## 2.7 USB Endpoint 1 Control & Status Register (0xC092: R/W) See the USB Endpoint 3 Control & Status Register for more information. ## 2.8 USB Endpoint 2 Control & Status Register (0xC094: R/W) See the USB Endpoint 3 Control & Status Register for more information. ## 2.9 USB Endpoint 3 Control & Status Register (0xC096: R/W) #### General description for all endpoints from Endpoint 0 to Endpoint 3: The SL11R Controller supports four endpoints. Endpoint 0 is the default pipe and is used to initialize and control the peripheral device. It also provides access to the peripheral device's configuration information, and supports control transfers. Endpoint 1, 2, and 3 support interrupt transfers, bulk transfers up to 64 Bytes/packet, or Isochronous transfers up to 1024 Bytes/packet size. #### **USB Endpoints Control (For Writing)** Each of the endpoint Control Registers when written have the following functions assigned: | BIT<br>POSITION | BIT NAME | FUNCTION | |-----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------| | D0 | ARM | Allows enabled transfers when set to '1'. Cleared to '0' when transfer is complete | | D1 | Enable | When set to '1' allows transfers to this endpoint. When set to '0' USB transactions are ignored. If enable = '1' and Arm = '0', endpoint will return NAK | | | | to USB transmissions. | | D2 | DIR | When set to '1', transmit to Host (IN). When '0' receive from Host (OUT) | | D3 | ISO | When set to '1' allows isochronous mode for this endpoint | | D4 | Stall | When set to '1' sends Stall in response to next request on this endpoint | | D5 | Zero Length | When set to '1' sends a zero length packet | | D6-D15 | Not Defined | Set to logic '0's | #### **USB Endpoints Status (For Reading)** Reading the Endpoint Status Register provides Status information relative to the packet that has been received or transmitted. The register is defined as follows: | BIT<br>POSITION | BIT<br>NAME | FUNCTION | |-----------------|-------------|---------------------------------------------------------------------------------------------| | D0 | Arm | If '1', the endpoint is armed | | D1 | Enable | If '1', the endpoint is enabled | | D2 | DIR | Direction bit. If '1', set to transmit to Host (IN). If '0', set to receive from Host (OUT) | | D3 | ISO | If '1', isochronous mode selected for this endpoint | | D4 | Stall | If '1', endpoint will send stall on USB when requested | | D5-D12 | Not used | Read returns logic '0's | | D13 | Setup | If '1', a Setup packet has been received | | D14 | Error | If '1', an error condition occurred on last transaction for this endpoint | | D15 | Done | If '1', transaction completed. Arm Bit is cleared to '0' when Done Set | Page: 20 Revision: 1.80 #### Note: - Endpoint 0 is set up as a control endpoint. The **DIR** bit is read-only, and indicates the direction of the last completed transaction. If the direction is incorrect, it is the firmware's responsibility to handle the error. On other endpoints, **DIR** is written, and if the direction of the transfer does not match DIR, then the transaction is ignored. - At the end of any transfer to an armed and enabled endpoint (with the correct DIR bit), an interrupt occurs, and vectors to a different location depending upon whether an error occurred or not. At the end of this transfer, the corresponding endpoint is disarmed (the Arm bit is cleared), and the DATAO/DATA1 toggle bit is advanced if no error occurred. If a packet is received with an incorrect toggle state, the packet is ignored so that the host will re-send the data. - The DATA0/DATA1 bit is automatically toggled by the hardware. To reset this DATA0/DATA1 toggle bit to DATA0, the **Enable** on the **D1** bit should be cleared to '0' and then set to '1'. - When the Zero Length bit **(D5)** is set, the host will receive the zero length USB packet, regardless of the number of bytes in the USB Count register. - The SL11R BIOS has full control of USB endpoint 0. The SL11R BIOS responds to all numeration from the host. On other endpoints, the SL11R BIOS can be used to control under BIOS interrupt calls (see [Ref. 1] **SL11R\_BIOS**). - The SL11R BIOS will set all USB Control & Status registers for endpoint 1 through 3 to zero upon receiving the SET\_CONFIG command from host. (See [Ref. 3] Universal Serial Bus Specification 1.1, Chapter 9 for more information.) ## 2.9.1 USB Endpoint 0 Address Register (0x0120: R/W) This is the pointer to memory buffer location for USB reads and writes to this Endpoint. At the end of any transfer, this register will contain its original value plus the value in the USB Endpoint Count Register. #### 2.9.2 USB Endpoint 1 Address Register (0x0124: R/W) See USB Endpoint 0 Address Register (0x0120: R/W) #### 2.9.3 USB Endpoint 2 Address Register (0x0128: R/W) See USB Endpoint 0 Address Register (0x0120: R/W) #### 2.9.4 USB Endpoint 3 Address Register (0x012C: R/W) See USB Endpoint 0 Address Register (0x0120: R/W) #### 2.9.5 USB Endpoint 0 Count Register (0x0122: R/W) This register is used to set the maximum packet size for the USB transfer. At the end of a successful transfer, the USB endpoint Count Register is set to zero. #### 2.9.6 USB Endpoint 1 Count Register (0x0126: R/W) See USB Endpoint 0 Count Register (0x0122: R/W) ## 2.9.7 USB Endpoint 2 Count Register (0x012A: R/W) See USB Endpoint 0 Count Register (0x0122: R/W) Page: 21 Revision: 1.80 ## 2.9.8 USB Endpoint 3 Count Register (0x012E: R/W) See USB Endpoint 0 Count Register (0x0122: R/W) ## 2.10 Processor Control Registers The SL11R provides software control registers that can be used to configure the chip mode, clock control, read software version and software breakpoint control. ## 2.10.1 Configuration Register (0xC006: R/W) The Configuration Register is used to configure the SL11R into the appropriate mode, and to select clock multiplier. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | C2 | C1 | C0 | CD | M1 | MO | MD | D6-4 C2-0 Clock Configuration bits. These bits select the clock source. The clock may come from an outside pin (X1 or X\_PCLK) or it may come from the PLL multiplier as indicated in the table. | C2 | C1 | C0 | PCLK | RCLK | OE | |----|----|----|--------|------|----| | 0 | 0 | 0 | X1 | X1 | 0 | | 0 | 0 | 1 | 2/3*X1 | X1 | 0 | | 0 | 1 | 0 | X_PCLK | X1 | 0 | | 0 | 1 | 1 | 2/3*X1 | X1 | 1 | | 1 | 0 | 0 | 4*X1 | 4*X1 | 0 | | 1 | 0 | 1 | 8/3*X1 | 4*X1 | 0 | | 1 | 1 | 0 | 4*X1 | 4*X1 | 1 | | 1 | 1 | 1 | 8/3*X1 | 4*X1 | 1 | D3 CD If Clock Disable bit = '1', this Clock Configuration register can no longer be modified through software writes. It is a "sticky bit" used to lock the configuration through a write to this bit in the boot prom code. #### Note: - On the SL11R chip set, this bit will be set to zero. - There are 4 modes defined in this documentation: DVC 8-bit DMA mode, Fast EPP mode, 8/16-bit DMA mode and General Purpose IO (GPIO) mode. All modes are pin-compatible. D2, D1 M1, 0: SL11R modes are selected as shown here: | M1 | M0 | Mode | |----|----|---------------| | 0 | 0 | GPIO | | | | | | 0 | 1 | DVC 8-Bit DMA | | 1 | 0 | Fast EPP | | | | | | 1 | 1 | 8/16-Bit DMA | | | | | Page: 22 Revision: 1.80 D0 MD If Mode Disable bit = '1', this Configuration register can no longer be modified through software writes. It is a "sticky bit" used to lock the configuration through a Write to this bit in the boot prom code. #### Note: By default, this bit will be set to zero by the SL11R BIOS. D15-D7 Reserved should be set to all zeros. #### Where: **PCLK** is connected to the SL11R processor clock. $\mbox{\bf RCLK}\$ is the resulting clock that connects to other modules (i.e. PWM, USB engine). **OE** when **OE**=1, the **X\_PCLK** (pin 59) will become an output pin of the **PCLK** value. #### Notes: - When the X1 input pin is fed with a 12 MHz signal, the software should set C2 to '1' to enable the PLL. - **X\_PCLK** is a bi-directional pin allowing an additional clock input for PCLK when selected or an observation pin for PCLK when OE = '1'. - The X\_PCLK can be used as the input clock like X1, but only when mode C2=0, C1=1, C0=0. - Upon reset, the SL11R BIOS will set this register equal to 0x0010 (i.e. C2=0, C1=0, C0=1, PCLK=X1, RCLK=X1, OE=0, M1-M0=0=GPIO Mode). ## 2.10.2 Speed Control Register (0xC008: R/W) The Speed Control Register allows the SL11R processor to operate at a number of speed selections. A four-bit divider (SPD3-0 + 1) selects the speed as shown below. Speed will also depend on the clock multiplier. See Configuration Register (0xC006: R/W) for more information. | D15-D4 | D3 | D2 | D1 | D0 | |--------|------|------|------|------| | 0 | SPD3 | SPD2 | SPD1 | SPD0 | D3-D0 SPD3-SPD0 Speed selection bits | SPD3-0 | SL11R | |--------|------------| | | SPEED | | 0000 | 48.00 MHz. | | 0001 | 24.00 MHz. | | 0010 | 16.00 MHz. | | 0011 | 12.00 MHz. | | 0100 | 09.60 MHz. | | 0101 | 08.00 MHz. | | 0110 | 06.86 MHz. | | 0111 | 06.00 MHz. | | 1000 | 05.33 MHz. | | 1001 | 04.80 MHz. | | 1010 | 04.36 MHz. | | | | | 1011 | 04.00 MHz. | |------|------------| | 1100 | 03.69 MHz. | | 1101 | 03.42 MHz. | | 1110 | 03.20 MHz. | | 1111 | 03.00 MHz. | D15-D4 Reserved should be set to all zeros. #### Note: Upon reset, the lowest speed is selected for low power operation. The SL11R BIOS will configure the clock to 24MHz as part of its initialization. ## 2.10.3 Power Down Control Register (0xC00A: R/W) During Power down mode, the peripherals are put in a "pause" state. All counters and timers stop incrementing and the PWM stops. | D15-D6 | D5 | D4 | D3 | D2 | D1 | D0 | |--------|-----|------|------|------|---------|------| | 0 | USB | GPIO | PUD1 | PUD0 | SUSPEND | HALT | There are two ways to enter to power down mode: #### Suspend or Halt. | D5 | USB | Enable restarts on USB transition resulting in device power up. | |-------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D4 | GPIO | Enable restarts on GPIO transition resulting in device power up (See GPIO Interrupt Control Register (0xC01C:R/W)). | | D3-D2 | PUD1-PUD0 | <u>Power Up Delay Selection</u> . Four delays are provided and selected using these select bits. This is time from power up until processor starts executing allowing clock to settle. | | PUD1 | PUD0 | Power up delay | |------|------|-----------------| | 0 | 0 | 0 milliseconds | | 0 | 1 | 1 milliseconds | | 1 | 0 | 8 milliseconds | | 1 | 1 | 64 milliseconds | D1 SUSPEND To save power, Suspend mode stops all clocks in the SL11R. This mode ends with a transition on either USB or any Interrupt. Date: 07/25/00 Page: 23 Revision: 1.80 It is followed by a delay set in the Power-up delay bit fields. D0 **HALT** ends with an interrupt. D15-D6 Reserved should be set to all zeros. ## 2.10.4 Breakpoint Register (0xC014: R/W) The Breakpoint Register holds the breakpoint address. Access to this address causes an INT127. Page: 24 Revision: 1.80 | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | A15 | A14 | A13 | A12 | A11 | A10 | Α9 | A8 | Α7 | A6 | A5 | A4 | А3 | A2 | Α1 | A0 | D15-0 A15-0 Breakpoint address. ## 2.11 Interrupts The SL11R provides 127 interrupt vectors. The first 64 vectors are hardware interrupts and the next 64 are software interrupts (see the [Ref. 1] **SL11R\_BIOS** for more information). ## 2.11.1 Hardware Interrupts The SL11R allocates addresses from 0x0000 to 0x003E for hardware interrupts. The hardware interrupt vectors are shown below: | Interrupt | Vector | Interrupt | |-----------|----------------|--------------------------------------| | Number | Address | Туре | | 0 | 0x0000 | Timer0 ♣ | | 1 | 0x0002 | Timer1 ◆ | | 2 | 0x0004 | GP IRQ0 ♦ | | 3 | 0x0006 | GP IRQ1 ♦ | | 4 | 0x0008 | UART Tx * | | 5 | 0x000A | UART Rx ♣ | | 6 | 0x000C | Fast DMA Done ◆ | | 7 | 0x000E | USB Reset | | 8 | 0x0010 | USB SOF ** | | 9 | 0x0012 | USB Endpoint0 No Error ♣ | | 10 | 0x0014 | USB Endpoint0 Error ♣ | | 11 | 0x0016 | USB Endpoint1 No Error | | 12 | 0x0018 | USB Endpoint1 Error | | 13 | 0x001A | USB Endpoint2 No Error | | 14 | 0x001C | USB Endpoint2 Error | | 15 | 0x001E | USB Endpoint3 No Error | | 16 | 0x0020 | USB Endpoint3 Error | | 17 | 0x0022 | 8/16-bit DMA Mode Mailbox TX Empty ◆ | | 18 | 0x0024 | 8/16-bit DMA Mode Mailbox RX Full ◆ | | 19-63 | 0x0026- 0x003E | Reserved ◆ | #### **Table 3 Hardware Interrupt Table** Note: - ♣ These hardware interrupt vectors are reserved for internal SL11R-BIOS usage. You should not attempt to overwrite these functions. - \*\* The SOF interrupt is generated when there is an incoming SOF on the USB. - These hardware interrupt vectors are initialized to return on the interrupt. All these vector interrupts are read/write accessible. You can overwrite these default software interrupt vectors by replacing your interrupt service subroutine. The addresses from 0x0000 to 0x003E are read/write accessible and can be used for variables. Page: 25 Revision: 1.80 ## 2.11.2 Interrupt Enable Register (0xC00E: R/W) This is a global hardware interrupt enable register that allows control of the hardware interrupt vectors. The SL11R BIOS default setup of this register is 0x28 (i.e. USB and UART bits are set). | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|------|----|----|---------|------------|----------|-------------------------|----------|-----|-------|-----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | MBX | USB | FDMA | UART | GP | T1 | T0 | | | | D6 | | N | ИВХ | | M | lail Bo | ox interr | upt ena | ıble (8/16 | -bit DMA | Mod | e Onl | y) | | | | D5 | | ι | JSB | | U | SB In | iterrupt e | enable | | | | | | | | | D4 | | F | DMA | | F | ast D | MA Don | e Interr | upt enab | le | | | | | | | D3 | | ι | JART | | U | ART | Interrupt | enable | • | | | | | | | | D2 | | G | BP | | | | • | | oins Inter<br>ster (0xC | • | , | ee G | PIO | | | | D1 | | Т | 1 | | Т | imer1 | Interrup | t Enab | le | | | | | | | | D0 | | Т | TO O | | Т | imer0 | Interrup | t Enab | le | | | | | ## 2.11.3 GPIO Interrupt Control Register (0xC01C: R/W) This register defines the polarity of the GPIO interrupt on IRQ1 (GPIO25) and IRQ0 (GPIO24). The **GPIO** bit on the Interrupt Enable Register must be set in order for this register to operate. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | |-----|-----|-----|-----|-----|------|--------|---------|--------|------|--------|----------|-------|---------|----|----|--| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | P1 | E1 | P0 | E0 | | | | D3 | | | P1 | IRQ1 | polar | ity is | rising | edge | if "1" | , fallir | ng ed | ge if " | 0" | | | | | D2 | | | E1 | Enab | le IR0 | Q1 if s | set to | "1" | | | | | | | | | | D1 | | | P0 | IRQ0 | polar | ity is | rising | edge | if "1" | , fallir | ng ed | ge if " | 0" | | | | | D0 | | | E0 | Enab | le IR0 | QO if s | set to | "1" | | | | | | | | #### Note: The interrupts can be enabled for "Suspend mode" by the power down Register or enabled for interrupts by the Interrupt Enable Register. ## 2.11.4 Software Interrupts The SL11R allocates addresses from 0x0040 to 0x00FE for software interrupts. The software interrupt vectors are shown below: | Interrupt | Vector | Interrupt | |---------------------|--------|------------------------------------------------------| | Number<br>64 (0x40) | Ox0080 | Type 2-wire serial interface_INT • | | 65 (0x41) | 0x0082 | Reserved for future extension of other Serial EEPROM | Page: 26 Revision: 1.80 | 66 (0x42) | 0x0084 | UART_INT ♣ | |------------|-----------|----------------------------------------------------------------| | 67 (0x43) | 0x0086 | SCAN_INT ♣ | | 68 (0x44) | 0x0088 | ALLOC_INT * | | 69 (0x45) | 0x008A | Data: start of free memory. Default=0x200 ** | | 70 (0x46) | 0x008C | IDLE_INT | | 71 (0x47) | 0x008E | IDLER_INT | | 72 (0x48) | 0x0090 | INSERT_IDLE_INT | | 73 (0x49) | 0x0092 | PUSHALL_INT ♣ | | 74 (0x4a) | 0x0094 | POPALL_INT * | | 75 (0x4b) | 0x0096 | FREE_INT * | | 76 (0x4c) | 0x0098 | REDO_ARENA * | | 77 (0x4d) | 0x009A | HW_SWAP_REG ♣ | | 78 (0x4e) | 0x009C | HW_REST_REG ♣ | | 79 (0x4f) | 0x009E | SCAN_DECODE_INT | | 80 (0x50) | 0x00A0 | USB_SEND_INT ♣ | | 81 (0x51) | 0x00A2 | USB_RECEIVE_INT ♣ | | 82 (0x52) | 0x00A4 | Reserved | | 83 (0x53) | 0x00A6 | USB_STANDARD_INT | | 84 (0x54) | 0x00A8 | Data: Standard loader vector. Defaut=0 ** | | 85 (0x55) | 0x00AA | USB_VENDOR_INT | | 86 (0x56) | 0x00AC | Data: USB_Vendor loader. Default = 0xff ** | | 87 (0x57) | 0x00AE | USB_CLASS_INT | | 88 (0x58) | 0x00B0 | Data: USB_Class_Loader. Default = 0 ** | | 89 (0x59) | 0x00B2 | USB_FINISH_INT | | 90 (0x5a) | 0x00B4 | Data: Device Descriptor. Default = Scanlogic Device Desc ** | | 91 (0x5b) | 0x00B6 | Data: Configuration Desc. Default = Scanlogic Configuration ** | | 92 (0x5c) | 0x00B8 | Data: String Descriptor. Default = Scanlogic String Desc. ** | | 93 (0x5d) | 0x00BA | USB_PARSE_CONFIG_INT | | 94 (0x5e) | 0x00BC | USB_LOADER_INT | | 95 (0x5f) | 0x00BE | USB_DELTA_CONFIG_INT | | 96 (0x60) | 0x00C0 | USB_PULLUP_INT | | 97 - 104 | 0xC2-0xD0 | Reserved for future addition secondary USB Port | | 105 (0x69) | 0x00D2 | POWER_DOWN_SUBROUTINE | | 106-109 | 0xD4-0xDA | Reserved for future secondary USB Port | | 110-124 | 0xDE-0xF8 | User's ISR or internal peripheral interrupt | | 125-127 | 0xFA-0xFE | Reserved for the Debugger | | | | | **Table 4 Software Interrupt Table** **Note:** • These software vectors are reserved for the internal SL11R-BIOS. The user should not overwrite these functions. \*\* These vectors are used as the data pointers. The user should not execute code (i.e. **JMP** or **INT**) to these vectors. See [Ref. 1] **SL11R\_BIOS** for more information. All these vector interrupts are read/write accessible. User can overwrite these default software interrupt vectors by replacing the user's interrupt service subroutine. #### 2.12 UART Interface. The SL11R Controller UART port supports a range of baud rates from 900 Baud up to 115.2K Baud. Baud Rate selection is made in the UART Control Register. Buffer status can be monitored in the UART Status Register. Transmit and receive data is written or read from the UART data register. The UART timers are independent of the general-purpose timers. The UART will cause "edge trigger" type interrupts when the receive buffer becomes FULL or the transmit buffer becomes EMPTY. The SL11R BIOS uses the UART port for the software debugging process. It is recommended that the user include this interface in their hardware design. A simple 4-pin header may be used to connect to a serial cable equipped with a MAX202 transceiver. **Figure 4 UART Port Connection** The SL11R BIOS uses GPIO28 for data transmit (TX) and GPIO27 for data receive (RX). These two pins cannot be used for any other purpose. **Note**: On reset, the SL11R BIOS will configure the UART to operate at 14,400 baud. Other parameters are: 1 stop bit, 8 data bits, no parity. ## 2.12.1 UART Control Register (0xC0E0: R/W) The SL11R allocates two General Purpose I/O signals for the UART function. They are GPIO28 (UART\_TXD) and GPIO27 (UART\_RXD). On reset, the SL11R BIOS will default this register to the value of 0x000b (i.e. UART Enable and Baud = 14.4K Baud). | | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |---|-----|-----|-----|-----|-----|-----|----|----|----|----|----|------|----|----|----|----| | Ī | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DIV8 | B2 | B1 | B0 | Е | D15-D5 Reserved bits Set to all zeros. D4 DIV8 Acts as a pre-scaler if set to '1', divides the clock by 8 before generating the UART clock. D3-1 B2-0 **SELECTOR BAUD RATE** WITH /8 BITS. PRESCALER 000 115.2K Baud 14.4K Baud 001 57.6K Baud 7.2K Baud 38.4K Baud 010 4.8K Baud 011 28.8K Baud 3.6K Baud 100 19.2K Baud 2.4K Baud 14.4K Baud 1.8K Baud 101 110 9.6K Baud 1.2K Baud 111 7.2K Baud 0.9K Baud D0 E Enable UART when set = '1'. When '0' UART pins are GPIO. ## 2.12.2 UART Status Register (0xC0E2: Read Only) This register is used by the SL11R BIOS to detect the UART status function via RXF and TXE flags. ©1996 - 2000 ScanLogic Corporation. All rights reserved. SL11R is a trademark of ScanLogic Corporation. The information and specifications contained in this document are subject to change without notice. Date: 07/25/00 **Revision: 1.80** Page: 28 Revision: 1.80 | D15-D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |--------|----|----|----|----|----|-----|-----| | 0 | 0 | 0 | 0 | 0 | 0 | RXF | TXE | D15-D2 Reserved bits Set to all zeros. D1 RXF Receive Buffer Full Flag. D0 TXE Transmit Buffer Empty Flag. Set to '1' when data moves from buffer to output shift register. Note: No error detection for received data is supported. ## 2.12.3 UART Transmit Data Register (0xC0E4: Write Only) This register is used by the SL11R BIOS to send data to the host. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | TR7 | TR6 | TR5 | TR4 | TR3 | TR2 | TR1 | TR0 | D7-D0 TR7-0 UART Transmit Data ## 2.12.4 UART Receive Data Register (0xC0E4: Read Only) This register is used by the SL11R BIOS to receive data from the host. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|-----|-----|----|-----|-----|----|----|-----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | RD7 | RD6 | RD | RD4 | RD3 | RD | RD | RD0 | | | | | | | | | | | | 5 | | | 2 | 1 | | D7-D0 RD7-0 UART Receive Data. ## 2.13 Serial EEPROM Interface (2-wire serial interface) The SL11R provides an interface to an external serial EEPROM. The interface is implemented using General Purpose I/O signals. A variety of serial EEPROM formats can be supported: currently the BIOS ROM supports the two-wire serial EEPROM type. The serial EEPROM can be used to store specific Peripheral USB configuration and add on value functions. It can also be used for field product upgrades. The SL11R BIOS uses an interrupt to read and write from/to an external serial EEPROM. The recommended serial EEPROM device is a 2-Wire Serial CMOS EEPROM (AT24CXX Device Family). Currently, the SL11R BIOS Revision 1.1 allows reading/writing to/from EEPROM, up to 2K Bytes (16K bits), 2-wire serial interface device (i.e. AT24C16). The user's program and USB vendor/device configuration can be programmed and stored into the external EEPROM device. On power up the content of the EEPROM will be downloaded into RAM and may be executed as code or used as data, or both. The advantage of the 2-wire serial interface/EEPROM interface is the space and cost saving when compared to using an external 8-bit PROM/EPROM. The SL11R BIOS uses two GPIO pins, GPIO31 and GPIO30 to interface to an external serial EEPROM (see figure below): - GPIO31 is connected to the Serial Clock Input (SCL). - GPIO30 is connected to the Serial Data (SDA). - We recommend you add a 5K to 15K pull-up resistor on the Data line (e.g. GPIO30). - Pin 1 (A0), Pin 2 (A1), Pin 3 (A2), Pin 4 (GND) and Pin 7 Write Protect) are connected to Ground. Figure 5 2-wire serial interface 2K-byte connection The current SL11R BIOS only support up to a 2Kbyte serial EEPROM. To read and write to a device that is larger than 2Kbytes, the SL11R-BIOS requires additional serial EEPROM to be connected as shown below: Figure 6 2-wire serial interface 16K Connection In this example, the SL11R BIOS will first access the (small) program residing on **IC1** serial EEPROM, and then it will access the second **IC2 EEPROM** (see [Ref. 1] **SL11R\_BIOS** for more information). ## 2.14 External SRAM, EPROM, DRAM The SL11R has a multiplexed address port and 16-bit data port. These interface signals are provided to interface to an external SRAM, ROM or DRAM. The DRAM port provides RAS, CAS, RD and WR control signals for data access and refresh cycles to the DRAM. At boot up stage, the SL11R BIOS configures the SL11R for external SRAM and serial EEPROM. In addition, the external memory interface is set up as 16-bit and 7 wait states for both external SRAM and EEPROM. The DRAM controller needs to be set up by the user. **Example 2** SL11R extended memory setup: internal\_rom\_start: Date: 07/25/00 Revision: 1.80 Page: 29 Page: 30 Revision: 1.80 mov [0xC03A],0x0077 ;set 16-bit ROM & 7 wait cmp [0xC100],0xCB36 ;check for special pattern in external ROM je 0xC102 ;if it's there, jump to it mov [0xC006],0x10 ;2/3 clock mov [0xC008],1 ;at 24mhz mov [0xC03E],3 ;extra wait state for ROM and Debug cmp [0xC100],0xC3B6 ;external ROM has 0xC3B6 as first 16 bits je xrom\_ok cmp b[0xC100],0xB6 ;check 0xc3b6 for 8-bit ROM jne xrom\_ok or [0xC03A],0x80 ;set for 8-bit ROM xrom\_ok: mov [0xC00],0xC3B6 ;check 0xC3B6 for 16-bit RAM cmp [0xC00],0xC3B6 je xram\_ok or [0xC03A],8 ;set for 8-bit external RAM xram\_ok: #### Note: The external memory devices can be 8 or 16 bits wide, and can be programmed to have up to 7 wait-states. External SRAM/PROM requires one wait state. ## 2.14.1 Memory Control Register (0xC03E: R/W) This register provides control of Wait States for the internal RAM and ROM. | | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | | |-------|-----|-------|-----|------|------|-----|--------------------------------------------------|--------------------------------------------------|------------------------------------------|--------|---------|-------|-------|--------|--------|-------|--|--| | | | ^ | | | | | | | | | | ^ | ^ | | | | | | | | 0 | U | U | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | U | U | RA | RO | DB | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | D2 | | | RA | | If '1', one-wait state for internal RAM is added | | | | | | | | | | | | | | | | | | | • | | | | | | | | | | | | | | | | D1 RO | | | | | | If '1', one-wait state for internal ROM is added | | | | | | | | | | | | | | D1 NO | | | | | | | , one man otate to microal trom to addou | | | | | | | | | | | D0 DB | | | | | | | If | '1' D | EBI IC | moc | ام اد د | nahla | ad Ir | ntarna | l addr | ess b | | | | | | טט | | - 11 | ı, D | | שטווו כ | 10 10 6 | FIIADIC | Ju. II | пенна | adui | C33 D | | | | | | echoed to external address pins. ## 2.14.2 Extended Memory Control Register (0xC03A: R/W) This register provides control of Wait States for the external SRAM/DRAM/EPROM. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | RM | EM3 | EM2 | EM1 | EM0 | RO3 | RO2 | RO1 | RO0 | RA3 | RA2 | RA1 | RA0 | | D12 | RM | ROM Merge. If '1', nXROMSEL is active if nXMEMSEL is active. | |-------|-------|--------------------------------------------------------------| | D11 | EM3 | Extended Memory Width ('0' = 16, '1' = 8) | | D10-8 | EM2-0 | Extended Memory Wait states (0 - 7) | | D7 | RO3 | External ROM Width ('0' = 16, '1' = 8) | | D6-4 | RO2-0 | External ROM wait states (0 - 7) | | D3 | RA3 | External RAM Width ('0' = 16, '1' = 8) | D2-0 RA2-0 External RAM Wait States (0 - 7) Note: The default Wait State setting on power up or reset is 7 wait states. ## 2.14.3 Extended Page 1 Map Register (0xC018: R/W) This register contains the Page 1 high order address bits. These bits are always appended to accesses to the Page 1 Memory mapped space. The default is 0x0000. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | A21 | A20 | A19 | A18 | A17 | A16 | A15 | A14 | A13 | If Bit A21 is '1', Page 1 reads/writes will access external DRAM If bit A21 is '0' Page 1 reads/writes will access some other external area (SRAM, ROM or peripherals). nXMEMSEL will be the external Chip Select for this space. D8-0 A21-13 Page 1 high order address bits. The address pins on A21-A13 will reflect the content of this register when SL11R accesses the address 0x8000-0x9FFF. ## 2.14.4 Extended Page 2 Map Register (0xC01A: R/W) This register contains the Page 2 high order address bits. These bits are always appended to accesses to the Page 2 Memory mapped space. The default is 0x0000. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | A21 | A20 | A19 | A18 | A17 | A16 | A15 | A14 | A13 | If Bit A21 is '1', Page 2 reads/writes will access external DRAM If bit A21 is '0' Page 2 reads/writes will access some other external area (SRAM, ROM or peripherals) and nXMEMSEL will be the external Chip Select for this space. D8-0 A21-13 Page 2 high order address bits. The address pins on A21-A13 will reflect the content of this register when SL11R access the address 0xA000-0xBFFF. ## 2.14.5 DRAM Control Register (0xC038: R/W) A multiplexed address port and 16-bit data port are provided to interface to an external 256Kx16 or a 1Megx16 EDO DRAM. The port provides nRAS, nCASL, nCASH, nDRAMWR and nDRAMOE control signals for data access and refresh cycles to the DRAM. This register is designed to control the DRAM interface. | D15-D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |--------|----|----|----|----|----|----|----| | 0 | 0 | 0 | 0 | 0 | DT | PE | RE | | ScanLogic Corporation | 1 | SL11R Hardware Specification | |-----------------------|----|-----------------------------------------------------------------------| | D2 | DT | DRAM Turbo, Enable when set = '1'. Uses 1 clock for CAS instead of 2. | | D1 | PE | DRAM Page Mode Enable when set = '1'. | #### Note: D0 RE Most of EDO and Page mode DRAM can be used as long as the CAS signal is issued before the RAS signal. DRAM Refresh Enable when set = '1'. Page mode access allows multiple CAS addresses to be issued within 1 Row address. The Page really corresponds to the Row. Once the Row address has been accessed, any accesses to that Page can be made without issuing the Row address again. Only the Column address is necessary. This allows for faster read and write accesses to the same page. ## 2.14.6 Memory Map The total memory space allocated by the SL11R is 64K-bytes. Program, data, and I/O space are contained within a 64K-byte address space. The program code or data can be stored in either external RAM or external ROM. The SL11R allows extended data (video) to be stored on an external EDO DRAM. The entire (video image) data can be transferred via DMA directly to DRAM without software intervention. The total DMA size can be up-to 2M-bytes. The SL11R processor can access DRAM data via the address space from **0x8000** to **0xBFFF**. The SL11R Controller provides a 16-bit Memory interface that can support a wide variety of external DRAM, RAM and ROM devices. The SL11R Controller memory space is byte addressable and is divided as follows: | FUNCTION | ADDRESS | |-------------------------|--------------------| | Internal RAM | 0x0000 - 0x0BFF | | External RAM | 0x0C00 − 0x7FFF. | | Extended Page 1/DRAM | 0x8000 - 0x9FFF | | Extended Page 2/DRAM | 0xA000 – 0xBFFF | | Memory Mapped Registers | 0xC000 - 0xC0FF | | External ROM | 0xC100 - 0xE7FF ** | | Internal ROM | 0xE800 – 0xFFFF | #### **Table 5 Memory Map** Each External memory space can be 8 or 16 bits wide, and can be programmed to have up to 7 wait-states. #### Note: ♣ The External RAM address from 0x0000 to 0x0C00 will not be accessible from the SL11R processor. This is an overlay memory space between internal RAM and external RAM. The addressable external RAM will occupy from 0x0C00-0x7FFF, which is 29K-byte. The signal name nXRAMSEL on SL11R-pin56 will be active when the CPU access address from 0x0C00 to 0x7FFF. Date: 07/25/00 **Page:** 32 Unused Overlay Memory Space 0x0000 to 0x0C00 Actual External RAM 0x0C00 to 0x7FFF SRAM (16Kx16) or SRAM (32Kx8) \*\*When bit 12 (ROM Merge Bit) of the Extended Memory Controller Register at address 0xC03A is '0', then the External ROM address space will be mapped from 0xC100 to 0xE7FF. The address from 0x8000 to 0xC100 and the address from 0xE800 to 0xFFFF are the overlay memory spaces. The actual total size of the external ROM will be (0xE800-0xC100), which is 9.75K-byte. The signal nXROMSEL on the SL11R (pin57) will be active when the CPU accesses the address from 0xC100 to 0xE7FF. The signal nXMEMSEL on the SL11R (pin58) will be active when the CPU accesses the address from 0x8000 to 0xBFFF. When bit 12 (ROM Merge Bit) of the Extended Memory Controller Register at address 0xC03A is '1', then the External ROM address space will be mapped into these windows: 0x8000 to 0xBFFF and 0xC100 to 0xE7FF. The address from 0xC000 to 0xC100 and the address from 0xE800 to 0xFFFF are the overlay memory spaces. The actual total size of the external ROM will be (0xC000-0x8000) and (0xE800-0xC100), which is 16K-byte + 9.75K-bytes, or 25.75K. # Bit 12 (ROM Merge) of the Extended Memory Bit 12 (ROM Merge) of the Extended Memory Controller Register = 0 Controller Register = 1 Unused Overlay Memory Space 0x8000 to 0x9FFF Unused Overlay Memory Space 0xA000 to 0xBFFF Unused Overlay Memory Space 0xC000 to 0xC0FF Actual External ROM 0xC100 to 0xE7FF ROM (16Kx16) or ROM (32Kx8) Actual External ROM 0x8000 to 0xBFFF Unused Overlay Memory Space 0xC000 to 0xC0FF Actual External ROM 0xC100 to 0xE7FF ROM (16Kx16) or ROM (32Kx8) Date: 07/25/00 Page: 33 ## 2.15 General Timers and Watch Dog Timer The SL11R Controller has two built in programmable timers that can provide an interrupt to the SL11R Engine. The timers decrement on every microsecond clock tick. An interrupt occurs when the timer reaches zero. ## 2.15.1 Timer 0 Count Register (0xC010: R/W) The SL11R BIOS uses the timer 0 for time-out function and power down mode. At the end of the power up, the SL11R BIOS disables the timer 0 interrupt. If you wish to use timer 0 for power down function, see the **[Ref.** 1] **SL11R\_BIOS** for more information. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | T15 | T14 | T13 | T12 | T11 | T10 | T9 | T8 | T7 | T6 | T5 | T4 | T3 | T2 | T1 | T0 | D15-0 T15-0 Timer Count value. ## 2.15.2 Timer 1 Count Register (0xC012: R/W) The SL11R timer 1 is for user applications. The SL11R BIOS does not use this timer. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | T15 | T14 | T13 | T12 | T11 | T10 | T9 | T8 | T7 | T6 | T5 | T4 | T3 | T2 | T1 | T0 | D15-0 T15-0 Timer Count value ## 2.15.3 Watchdog Timer Count & Control Register (0xC00C: R/W) The SL11R provides a Watchdog timer to monitor certain activities. The Watchdog timer can also interrupt the SL11R processor. The default value of this register is 0x0000. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | |-----|-----|--------|-----|-----|------|-------|------------------------------|-------------------------|-------|--------------------------------------------------------------------------|--------------------|--------|-------|------|----|--| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | WT | TO1 | TO0 | ENB | ΕP | RC | | | | D | )5 | | WT | | | Wato | chdog | Time | e-out o | occurre | d. | | | | | | | D | )4-3 | -0 | | Time | out ( | Coun | t: 00<br>01<br>10<br>11 | | 01 milliseconds<br>04 milliseconds<br>16 milliseconds<br>64 milliseconds | | | | | | | | | D | D2 EP | | | | | | timer | | | /D time<br>enabled | | | y on | | | | | D | D1 ENB | | | 3 | | Enab | ole W | D Tin | ner op | eration | when : | ='1'. | | | | | | D | D0 RC | | | | | Reset Count. When set = '1'. | | | | | | | | | | #### Notes: - You must assert Reset Count (RC), before time-out occurs to avoid Watchdog trigger - The Watchdog Timer overflow causes an internal processor reset. The Processor can read the WT bit after exiting reset to determine if the WT bit is set. If it is set, a watchdog time-out occurred. - The WT value will be cleared on the next external reset. Date: 07/25/00 Page: 34 ## 2.16 Special GPIO function for Suspend, Resume and Low Power modes The SL11R CPU supports suspend, resume and CPU low power modes. The SL11R BIOS assigns GPIO29 for the USB DATA+ line pull-up (This pin can simulate USB cable removal or insertion while USB power is still applied to the circuit) and the GPIO20 for controlling power off function. The GPIO20 can be used for device low power mode; it will remove power from the peripherals in suspend mode. Once USB power is restored, the power to the peripherals may be enabled. The SL11R BIOS will execute the pull up interrupt upon power-up. To use this feature, the GPIO29 pin must be connected to the DATA+ line of the USB connector (see Figure below). For more information about this function, see the [Ref. 1] SL11R\_BIOS. Figure 7 Special GPIO pull up connection example ## 2.17 Programmable Pulse/PWM Interface The SL11R Controller supports four Programmable Digital Pulse output channels. These channels can also be used for Pulse Width Modulation (PWM) operation. Operation is directed by the PWM Control Register, Maximum Count Register, and the individual Start and Stop Counter Registers. These are provided for each of the four output channels. To set up PWM operation, the Maximum Count Register is set to the desired maximum count value. Then the start and stop value for each channel is written with the required values. The start and stop values are chosen to achieve the desired pulse widths during each cycle. When the channels are disabled (by the Control Register), the associated I/O pins revert to GPIO use. Figure 8 PWM Block Diagram Note: The RCLK is the resulting clock (see the Speed Control Register (0xC006: R/W)). Date: 07/25/00 **Revision: 1.80** ## 2.17.1 PWM Control Register (0xC0E6: R/W) | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|-----|-----|-----|-----| | ST | 0 | 0 | 0 | SC2 | SC1 | SC0 | os | P3 | P2 | P1 | P0 | EN3 | EN2 | EN1 | EN0 | D15 ST Start Bit. Set to '1' to begin operation. '0' stops operation D14-12 Reserved always '0' 's. D11-9 SC2-0 Prescaler value selection | SC2-0 | FREQ. | |-------|-----------| | 000 | 48.00 MHz | | 001 | 24.00 MHz | | 010 | 06.00 MHz | | 011 | 01.50 MHz | | 100 | 375 kHz | | 101 | 93.80 kHz | | 110 | 23.40 kHz | | 111 | 05.90 kHz | D8 OS Enable One Shot Mode for PWM channels. One Shot mode runs the number of counter cycles set in the PWM cycle count register and then stops. The default is continuous repeat. D7-D4 P3-0 Individual Polarity bits for channels 3 - 0. '1' is active high or rising edge pulse. D3-D0 EN3-0 Individual Enable bits for channels 3 - 0. '1' enables. #### Notes: • If not enabled, i.e., if set is '0', the pins become GPIO. To force the outputs to '0' or '1': - If start register = stop register, then output stays at "0" - If stop register > Max count register, then output stays at "1" ## 2.17.2 PWM Maximum Count Register (0xC0E8: R/W) | 015 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | 0 | 0 | 0 | 0 | 0 | 0 | C9 | C8 | C7 | C6 | C5 | C4 | C3 | C2 | C1 | C0 | D15-10 Reserved always '0' 's. D9-0 C9-C0 Maximum Count Value. ## 2.17.3 PWM Channel 0 Start Register (0xC0EA: R/W) | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | 0 | 0 | 0 | 0 | 0 | 0 | S9 | S8 | S7 | S6 | S5 | S4 | S3 | S2 | S1 | S0 | D15-10 Reserved always '0' 's. D9-0 S9-S0 Start Count for PWM Channel 0. Page: 37 Revision: 1.80 ## 2.17.4 PWM Channel 0 Stop Register (0xC0EC: R/W) | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | 0 | 0 | 0 | 0 | 0 | 0 | S9 | S8 | S7 | S6 | S5 | S4 | S3 | S2 | S1 | S0 | D15-10 Reserved always '0' 's. D9-0 S9-S0 Stop Count for PWM Channel 0. #### 2.17.5 PWM Channel 1 Start Register (0xC0EE: R/W) | D15 | D14 | D13 | D12 | D11 | | | | | | | | | | | | |-----|-----|-----|-----|-----|---|----|----|----|----|----|----|----|----|----|----| | 0 | 0 | 0 | 0 | 0 | 0 | S9 | S8 | S7 | S6 | S5 | S4 | S3 | S2 | S1 | S0 | D15-10 Reserved always '0' 's. D9-0 S9-S0 Start Count for PWM Channel 1. #### 2.17.6 PWM Channel 1 Stop Register (0xC0F0: R/W) | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | 0 | 0 | 0 | 0 | 0 | 0 | S9 | S8 | S7 | S6 | S5 | S4 | S3 | S2 | S1 | S0 | D15-10 Reserved always '0' 's. D9-0 S9-S0 Stop Count for PWM Channel 1. ## 2.17.7 PWM Channel 2 Start Register (0xC0F2: R/W) | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | 0 | 0 | 0 | 0 | 0 | 0 | S9 | S8 | S7 | S6 | S5 | S4 | S3 | S2 | S1 | S0 | D15-10 Reserved always '0' 's. D9-0 S9-S0 Start Count for PWM Channel 2. #### 2.17.8 PWM Channel 2 Stop Register (0xC0F4: R/W) | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | 0 | 0 | 0 | 0 | 0 | 0 | S9 | S8 | S7 | S6 | S5 | S4 | S3 | S2 | S1 | S0 | D15-10 Reserved always '0' 's. D9-0 S9-S0 Stop Count for PWM Channel 2. # 2.17.9 PWM Channel 3 Start Register (0xC0F6: R/W) | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | 0 | 0 | 0 | 0 | 0 | 0 | S9 | S8 | S7 | S6 | S5 | S4 | S3 | S2 | S1 | S0 | D15-10 Reserved always '0' 's. D9-0 S9-S0 Start Count for PWM Channel 3. ## 2.17.10 PWM Channel 3 Stop Register (0xC0F8: R/W) | | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----------------|----------------------------------|------|-----|-----|-------|-----|-----|-------|---------|-------|------|-------|-------|----|----|----| | | 0 0 0 0 0 0 0<br>D15-10 Reserved | | | | | | | S8 | S7 | S6 | S5 | S4 | S3 | S2 | S1 | S0 | | D15-10 Reserved | | | | | | | alv | ways | '0' 's. | | | | | | | | | | | D9-0 | ) | | S9-S0 | | St | op Co | ount f | or PV | VM C | hanne | el 3. | | | | ## 2.17.11 PWM Cycle Count Register (0xC0FA: R/W) | | D14 | | | | | | | | | | | | | | | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | C15 | C14 | C13 | C12 | C11 | C10 | C9 | C8 | C7 | C6 | C5 | C4 | C3 | C2 | C1 | C0 | D15-0 C15-0 Number of cycles to run in one-shot mode (0-64K) The OS bit in the PWM Control Register must be set. Note: Number of OS Cycles to run = C+1. Example for 1 Cycle, set C=2 #### 2.18 Fast DMA Mode This mode is currently used by the DVC 8-Bit DMA and 8/16-Bit DMA modes. In DVC 8-Bit DMA mode, the DMA data path will be 8, which corresponds to SD7-SD0. In the 8/16-Bit DMA mode, the DMA data path can be configured as either 8 or 16. ## 2.18.1 DMA Control Register (0xC02A: R/W) | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|----|----|----|-----|-----|-----| | 0 | 0 | 0 | 0 | 0 | TSZ | DIR | DMA | External device data presented to S15-SD0/SD7-SD0 is automatically written into the RAM of the SL11R, under fast DMA control. The DMA must be enabled in the DMA Control and Address register. D2 TSZ Transfer Size. 8 bit when set to '1', 16-bit when set to '0' D1 DIR DMA Direction. When set to '0', data transfers from Peripheral to Memory. When set to '1' Memory to Peripheral. DO DMA DMA Enabled when set to '1'. Bit clears to '0' when DMA is done. #### Note for DVC 8-Bit DMA mode: Set Transfer Size to 16 bits for the DVC 8-Bit DMA mode. Set DMA Direction for *Peripheral to Memory* for DVC 8-Bit DMA mode. # 2.18.2 Low DMA Start Address Register (0xC02C: R/W) This register contains the low order word of the starting DMA address. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | A15 | A14 | A13 | A12 | A11 | A10 | Α9 | A8 | A7 | A6 | Α5 | A4 | А3 | A2 | A1 | Α0 | D15-0 A15-A0 Low 16 Bits of DMA address # 2.18.3 High DMA Start Address Register (0xC02E: R/W) This register contains the high order word of the starting DMA address. | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|-----|-----|-----|-----|-----|-----| | 0 | 0 | A21 | A20 | A19 | A18 | A17 | A16 | D5-D0 A21-A16 High Address bits for DMA start address Note: A21 = 1 the starting memory address will be in the DRAM. The A21 bit in the High DMA Stop Address register must match this bit. ## 2.18.4 Low DMA Stop Address Register (0xC030: R/W) This register contains the low order word of the stopping SL11R memory address. This is the last DMA address in memory. DMA will stop when this address is reached and if the **FDMA** bit in the Interrupt Enable Register (0xC00E: R/W) is enabled, an interrupt will also be generated. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | A15 | A14 | A13 | A12 | A11 | A10 | Α9 | A8 | Α7 | A6 | Α5 | A4 | А3 | A2 | A1 | A0 | D15-0 A15-A0 Low 16 Bits of the DMA stop address ## 2.18.5 High DMA Stop Address Register (0xC032: R/W) This register contains the high order word of the stopping SL11R memory address. This is the last DMA address in memory. DMA will stop when this address is reached. | | | | | | D2 | | | |---|---|-----|-----|-----|-----|-----|-----| | 0 | 0 | A21 | A20 | A19 | A18 | A17 | A16 | D5-D0 A21-A16 High Address bits for DMA stop address. Date: 07/25/00 **Page:** 39 Revision: 1.80 #### Note: A21 = 1 the stopping memory address will be in the DRAM. The A21 bit must be matched on the High DMA Start Address register. Page: 40 Revision: 1.80 #### 3. SL11R INTERFACE MODES The SL11R has four modes. They are General Purpose IO mode, Fast EPP mode, 8-bit DMA mode, and 8/16 DMA, Mailbox Protocol ports mode. These modes are shared and can be configured under software control. Note: The UART and 2-wire serial interface IO pins are fixed in all SL11R Interface modes. #### 3.1 General Purpose IO mode (GPIO) In GPIO mode, the SL11R has up to 32 general-purpose I/O signals available. However, there are 4 pins used by the UART and the 2-wire serial interface that cannot be used as the GPIO pins. A typical application for this GPIO is Parallel Port to USB. The SL11R executes at 48MHz -- fast enough to generate any Parallel Port timing. The SL11R also includes a special mode for EPP timing designed for special devices that have no delay in the EPP mode. Other available General Purpose I/O pins can be programmed for peripheral control and/or status, etc. When the SL11R interface is in GPIO mode, a number of GPIO pins are used to support the parallel interface. The remaining pins can be used for GPIO or if desired, some can be configured for special functions. The following registers are used for all pins configured as GPIO. The outputs are enabled in the I/O Control registers. Note that the output Data can be read back via the Output Data Register even if the outputs are not enabled. **Note**: The Fast DMA and PWM Interface will not be supported in this mode. #### 3.1.1 I/O Control Register 0 (0xC022: R/W) This register controls the input/output direction of the GPIO data pins from GPIO15 to GPIO0. When any bit of this register set to one, the corresponding GPIO data pin becomes an output pin. When any bit of this register is set to zero, the corresponding GPIO data pin becomes an input pin. | D1: | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | E1: | E14 | E13 | E12 | E11 | E10 | E9 | E8 | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 | D15-0 E15-0 Enable individual outputs, GPIO 15-0. Logic '1' enables. #### 3.1.2 I/O Control Register 1 (0xC028: R/W) This register controls the input/output direction of the GPIO data pins from GPIO31 to GPIO16. When any bit of this register set to one, the corresponding GPIO data pin becomes an output pin. When any bit of this register is set to zero, the corresponding GPIO data pin becomes an input pin. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | E31 | E30 | E29 | E28 | E27 | E26 | E25 | E24 | E23 | E22 | E21 | E20 | E19 | E18 | E17 | E16 | D15-0 E31-16 Enable individual outputs, GPIO 31-16. Logic '1' enables. #### 3.1.3 Output Data Register 0 (0xC01E: R/W) This register controls the output data of the GPIO data pins from GPIO15 to GPIO0. Note: A read of this register reads back the last data written, not the data on pins configured as input (see below). | D15 | | | | | | _ | - | | - | | | _ | | | _ | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | O15 | O14 | O13 | O12 | O11 | O10 | O9 | 08 | 07 | 06 | O5 | 04 | O3 | 02 | 01 | 00 | D15-0 Output Pin Data #### 3.1.4 Output Data Register 1 (0xC024: R/W) This register controls the output data of the GPIO data pins from GPIO31 to GPIO16. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | O31 | O30 | O29 | O28 | O27 | O26 | O2 | O2 | 02 | O2 | O2 | O2 | 01 | 01 | 01 | 01 | | 15 | 14 | 13 | 12 | 11 | 10 | 59 | 48 | 37 | 26 | 15 | 04 | 93 | 82 | 7 | 60 | D15-0 O31-16 Output Pin Data ## 3.1.5 Input Data Register 0 (0xC020: Read only) This register reads the input data of the GPIO data pins from GPIO15 to GPIO0. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-------|-----|-----|-----|-----|-------|-------|------|----|----|----|----|----|----|------------|----| | l15 | l14 | I13 | l12 | l11 | I10 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | <b>I</b> 1 | 10 | | D15-0 | | 115 | 5-0 | | Input | Pin c | lata | | | | | | | | | ## 3.1.6 Input Data Register 1 (0xC026: Read only) This register reads the input data of the GPIO data pins from GPIO31 to GPIO16. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-------|-----|------|--------|------|-----|-----|-----|-----|-----|-----|-----|-----| | I31 | 130 | 129 | 128 | 127 | 126 | 125 | 124 | 123 | 122 | 121 | 120 | l19 | I18 | 117 | l16 | | D15 | -0 | l; | 31-16 | | Inpu | ıt Pin | data | | | | | | | | | Figure 9 GPIO mode Block Diagram Date: 07/25/00 **Revision: 1.80** #### 3.2 8/16-bit DMA Mode This mode includes the **Mailbox Protocol** and **DMA Protocol**. The **Mailbox Protocol** allows asynchronous exchange of data between an external Processor (i.e. DSP or Microprocessors) and the SL11R, via the bi-directional data port SD15-SD0 (GPIO15-0). The DMA Protocol allows the large data blocks to be transferred to or from SL11R memory devices via the 8/16-bit DMA port. The SL11R has four built-in PWM output channels available in the 8/16-bit DMA mode. Each channel provides a programmable timing generator sequence which can be used to interface to various line CCD, CIS, CMOS image sensors or can be used for other types of applications (see Programmable Pulse/PWM Interface for more detail of controlling these PWM functions). **Note**: Any other unused IO pins can be used as the GPIO pins under control of the General Purpose IO mode (GPIO). Figure 10 8/16-bit DMA Mode Block Diagram #### 3.2.1 Mailbox Protocol The physical interface for the Mailbox is shared with the DMA data path on the SD15-SD0 bus. When accessing the Mailbox INBUFF & OUTBUFF registers, the ADDR pin should be driven high. The ADDR pin should be driven low to access the Mailbox STATUS register. The external processor and SL11R can both access the INBUFF, OUTBUFF & STATUS Mailbox registers. The SL11R includes two interrupt vectors for this Mailbox Protocol. Whenever the external Processor accesses the Mailbox, the associated interrupt will be generated. #### Note: - To enable the Mailbox interrupt, the bit MBX in the Register 0xC00E must be enabled. - The external processor cannot access the Mailbox while DMA is in progress. ©1996 - 2000 ScanLogic Corporation. All rights reserved. SL11R is a trademark of ScanLogic Corporation. The information and specifications contained in this document are subject to change without notice. Date: 07/25/00 **Revision: 1.80** ## 3.2.2 INBUFF Data Register (0xC0C4: R/W) The external processor will write to this register with the ADDR signal set to one and the SL11R will read this register after receiving the interrupt (if the MBX interrupt is enabled in the Register 0xC00E). | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | D15-0 D15-0 Data from input Mailbox ## 3.2.3 OUTBUFF Data Register (0xC0C4: R/W) The SL11R will write to this register and the external processor will read from this register with the ADDR signal set to one. The SL11R will receive an interrupt after the external processor finished reading (if the MBX interrupt is enabled in the Register 0xC00E). | | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |---|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | ſ | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | D15-0 D15-0 Data for Output Mailbox ## 3.2.4 STATUS Register (0xC0C2: Read Only) The external processor can read the STATUS of the OUTBUFF and INBUFF Status bits from this output buffer. The external ADDR pin should be driven to low when reading this STATUS register. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ΙF | OF | D1 IF **INBUFF Full** D0 OF OUTBUFF Full Note: The SL11R also can access this register. #### 3.2.5 DMA Protocol The physical interface for the DMA is shared with the Mailbox protocol on the SD15-SD0 bus. If the DREQ (DMA Request Enable) bit is set, this enables SL11R DMA cycles to or from the external device (scanner, printer, camera, modem or etc.). The DREQ is asserted by the SL11R when data is ready to be sent or received. When the external device is ready to send Data, it asserts the **nWRITE** signal. Data must be available at this point. If the external device is ready to accept data, it asserts the **nREAD** signal. The DMA mode can be used to move large amounts of data to or from a variety of peripherals such as Scanners, Printers, Cable Modems, External Storage devices, and others. For example for a DVC, video data from the camera can be moved via DMA to an internal memory buffer for subsequent transfer to the USB host. This data can be transferred to the host via the USB DMA engine (i.e. no SL11R Processing is involved, since the USB has its own DMA engine). Users can program 8 bit or 16 bit DMA transfers in either direction; Peripheral to SL11R or SL11R to Peripheral. A control register (0xC02A) sets the DMA bus width, direction and DMA enable and four further registers control the DMA start and end addresses (see Fast DMA Mode, section 2.14). Furthermore, if the **FDMA** bit in Register 0xC00E is enabled, an interrupt will be issued to indicate the DMA operation is complete. ## 3.2.6 DMA Control Register (0xC0C0: R/W) Before setting this register, the Low DMA Start Address (0xC02C), High DMA Start Address (0xC02E), the Low DMA Stop Address (0xC030) and the High DMA Stop Address (0xC032) must be configured. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|------|----|----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DREQ | D1 | D0 | D2 DREQ External DREQ DMA Enable, if set to '1', the SL11R can DMA to or from the external device (scanner or printer) by asserting the DREQ signal when data is requested or ready to send. D1 D1 Set to '1' D0 D0 Set to '1' #### 3.3 Fast EPP Mode This interface is designed to interface with a specially optimized high-speed EPP interface. The SL11R processor has direct access to the EPP control port. The EPP function has four transfer modes: Data Write, Data Read, Address Write and Address Read. Strobe signals **nDTSRB** and **nASTRB** are generated by the SL11R for data or address operations respectively. The signal **nWRITE** indicates read or write as described below. #### Note: - The Fast DMA and PWM Interface will not be supported in this mode. - Any other unused IO pins can be used as the GPIO pins under control of theGeneral Purpose IO mode (GPIO). ## 3.3.1 EPP Data Register (0xC040: R/W) Writing to this register results in the generation of a pulse on the **nDTSRB** output pin, with the **nWRITE** output pin low, and the register data being driven onto the SD7-SD0 Data bus. Reading from this register results in the generation of a pulse on the **nDTSRB** output pin, with the **nWRITE** output pin high, and data being read from the SD7-SD0 Data bus. | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|-----|-----| | SD7 | SD6 | SD5 | SD4 | SD3 | SD2 | SD1 | SD0 | D7-D0 SD7-SD0 EPP data # 3.3.2 EPP Address Register (0xC044: R/W) Writing to this register results in the generation of a pulse on the **nASTRB** output pin, with the **nWRITE** output pin low, and the register data being driven onto the SD7-SD0 Data bus. Reading from this register results in the generation of a pulse on the **nASTRB** output pin, with the **nWRITE** output pin high, and data being read from the SD7-SD0 Data bus. | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|----|----|----|----|----|----| | A7 | A6 | A5 | A4 | А3 | A2 | A1 | A0 | Date: 07/25/00 **Revision: 1.80** D7-D0 A7-A0 Device and register address value from the SD7-SD0 Data Bus. ## 3.3.3 EPP Address Buffer Read Register (0xC046: Read Only) Reading this register returns existing data from Read Buffer to the I/O processor. The **nASTRB** will not be asserted. | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|----|----|----|----|----|----| | A7 | A6 | A5 | A4 | A3 | A2 | A1 | A0 | D7-D0 A7-A0 Read Data ### 3.3.4 EPP Data Buffer Read Register (0xC042: Read Only) Reading this register returns existing data from Read Buffer to the I/O processor. The **nDTSRB** will not be asserted | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|-----|-----| | SD7 | SD6 | SD5 | SD4 | SD3 | SD2 | SD1 | SD0 | D7-D0 SD7-SD0 EPP data from the SD7-SD0 data bus. #### 3.3.5 EPP Status Data Register (0xC04E: R/W) This register is used to read the actual status signal from GPIO9-8. The P9 pin will be set to the value in D7 when written. GPIO8 and GPIO9 are not affected by writing to this register. | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-------------|----|----|----|----|----|------|------| | P9 (GPIO21) | 0 | 0 | 0 | 0 | 0 | INTR | WAIT | | | | | | | | | | D7 P9 Value output on GPIO21. D1 INTR from the GPIO8 D0 WAIT line from GPIO9. # 3.3.6 EPP P\_REG Register (0xC050: R/W) The SL11R has a set of eight pins labeled P1-P8, which are general-purpose output pins. The functionality of each bit is selected in the respective Control Register. The SL11R 16-bit processor has access to these pins through a read write, which is defined in the P\_REG register. The bit assignments are noted in the following table. | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-------------|-------------|--------------|-------------|-------------|-------------|-------------|-------------| | P8 (GPIO15) | P7 (GPIO14) | P6 (!GPIO13) | P5 (GPIO20) | P4 (GPIO19) | P3 (GPIO18) | P2 (GPIO17) | P1 (GPIO16) | D7-D0 P8-P1 Set to logic '1' or '0' for corresponding P output pin #### Note: A write to this register causes the SL11R to write this out the corresponding GPIO pins (Except P6). The output value of the P6 will be the complement of the value written. Date: 07/25/00 **Revision: 1.80** **Page:** 46 Revision: 1.80 #### 3.4 DVC 8-bit DMA Mode This mode is designed to interface with CCD cameras. Camera control and setup is performed through the serial control bus. The SL11R 16-bit processor has direct access to the control port and the camera operation is dependent on commands passed from the USB Host to the SL11R. Raw video data from the Camera is input to the SL11R on the 8-bit video data bus (SD7-SD0) using a combination of clock and control signals and 8 bit DMA. The signals include a clock (MCK0), Field Index (FI), Sync and blanking signals (SYNC, PBLK), and Drive signals (VD and HD). The DMA Engine is used to transfer the image from the 8-bit bus (SD7-SD0) to external DRAM port. The software uses the Fast DMA configuration registers. #### Note: - The PWM Interface is not supported in this mode. - Any other unused IO pins can be used as GPIO pins under control of the GPIO mode. #### 3.4.1 Video Status Register (0xC06E: Read Only) The camera sends an 8 bit data bus with a number of control signals. The SL11R uses the following control signals to acquire the video data: | MCK0 | From Camera | Pixel Clock = 9.534965MHz | |---------|-------------|------------------------------------------------| | FI | From Camera | Field Index. Contains 1 Vertical sweep + Blank | | VD | From Camera | Active During Vertical Sweep. | | PBLK | From Camera | Active during Horizontal sweep. | | SD7-SD0 | From Camera | CCD Video data. | | N_RST | To Camera | Active Low Reset | The first 8 bytes of Data is discarded from the video stream starting at the assertion of each PBLK. After PBLK is de-asserted, 7 more bytes of data are taken. The Video Control and Status Register allows the acquisition of video images and provides power and reset controls for the camera. | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|----|------|--------|----|----|----| | 0 | 0 | 0 | VRST | P-CONT | 0 | F | SC | | D7-5 | Reserved | Always = '0' | |------|----------|-----------------------------------------------------------------------------------| | D4 | VRST | Video Reset. '0' Resets Camera (See Note). | | D3 | P-CONT | When set = '1' powers up camera. | | D2 | Reserved | Always = '0'. | | D1 | F | When set = '1' capture even then odd field else when '0' capture even field only. | | D0 | SC | Start Capture When set = '1', clears to '0' when done. | #### Note: After P-CONT is set high to provide camera power, the Video Reset must be held low a minimum of 100 milliseconds. ### 3.4.2 Camera Serial Interface Registers The Serial Interface port of the SL11R is used to pass control information to the camera and to communicate with serial EPROM1, and EPROM2 (EPROM 1 is used to store camera default data). The Serial Port Control Register determines if the next operation will be a write cycle to the camera or the EEPROM, or if the operation will be a read cycle of the EPROM. When an EPROM or camera cycle is required the device must be selected in the Control Register, and an EEPROM address location must be written to the Serial Interface Address Register. When a Read Cycle is selected, writing the Busy Bit begins the cycle, and when completed, the valid returned data can be read in the Serial Interface Data Read Register. The SL11R has a dedicated serial bus to support the camera and EPROM. On power up, an SL11R signal, AEEP, is driven high, (AEEP connects to the Camera DSP device), the SL11R Camera serial bus is tri-stated, which allows the Camera DSP to read the camera default data directly from the EEPROM. (During this time the DSP drives the Serial Clock to the EEPROM and the CCS select line to the SL11R, EEP1 is driven high from the SL11R). After a timed interval, the AEEP line is driven low and the SL11R can now communicate to the camera via the Camera Serial Port. #### 3.4.3 Serial Interface Control & Status Register (0xC068: R/W) | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|----|----|----|----|----|------| | 0 | 0 | 0 | 0 | 0 | M1 | M0 | Busy | D7-3 Reserved 0 D2-D1 M1-M0 Mode Setting: 11 = AEEP MODE 10 = EPROM 2 01 = EPROM1 00 = DSP PROCESSOR D0 Busy When Set = '1', initiates a cycle to selected target. Cleared to '0' when the cycle has completed. No new cycles are allowed until Busy bit = '0'. ## 3.4.4 Serial Interface Address Register (0xC06A: Write Only) | | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | |---|------|----|----|-------|-------|---------|--------|----------|----------|--------| | _ | P2 | P1 | P0 | A5 | A4 | А3 | A2 | Α1 | A0 | | | | | | | | | | | | | | | | D8-6 | | P: | 2- P0 | Comm | and: 10 | 01 = W | rite, 11 | 0 = rea | d | | | D5-0 | | A: | 5-A0 | EEPR( | OM or 0 | Camera | a Regis | ster add | lress. | ## 3.4.5 Serial Interface Data Write Register (0xC06C: Write Only) When data is transmitted, setting the Busy bit in the Control Status Register initiates transmission. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | T15 | T14 | T13 | T12 | T11 | T10 | T9 | T8 | T7 | T6 | T5 | T4 | T3 | T2 | T1 | T0 | D15-0 T15-0 Data to be transmitted. Date: 07/25/00 **Revision: 1.80** # 3.4.6 Serial Interface Data Read Register (0xC06C: Read Only) Read cycle data from the selected device in Control Status Register, and address specified in the Address Register. Data is valid after a Read Cycle has been initiated by setting the Busy bit in the Status Register. Data is valid after Busy bit clears to '0'. | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | R15 | R14 | R13 | R12 | R11 | R10 | R9 | R8 | R7 | R6 | R5 | R4 | R3 | R2 | R1 | R0 | D15-0 R15-0 Read Data from the SD7-SD0 Data Bus. ## 3.4.7 I/O Address Map | Function | Address | Mode | |-----------------------------------------|---------|-----------| | USB Endpoint 0 Address Register | 0x0120 | R/W | | USB Endpoint 0 Count Register | 0x0122 | R/W | | USB Endpoint 1 Address Register | 0x0124 | R/W | | USB Endpoint 1 Count Register | 0x0126 | R/W | | USB Endpoint 2 Address Register | 0x0128 | R/W | | USB Endpoint 2 Count Register | 0x012A | R/W | | USB Endpoint 3 Address Register | 0x012C | R/W | | USB Endpoint 3 Count Register | 0x012E | R/W | | Configuration Register | 0xC006 | R/W | | Speed Control Register | 0xC008 | R/W | | Power Down Control Register | 0xC00A | R/W | | Watchdog Timer Count & Control Register | 0xC00C | R/W | | Interrupt Enable Register | 0xC00E | R/W | | Timer 0 Count Register | 0xC010 | R/W | | Timer 1 Count Register | 0xC012 | R/W | | Breakpoint Register | 0xC014 | R/W | | Extended Page 1 Map Register | 0xC018 | R/W | | Extended Page 2 Map Register | 0xC01A | R/W | | GPIO Interrupt Control Register | 0xC01C | R/W | | Output Data Register 0 | 0xC01E | R/W | | Input Data Register 0 | 0xC020 | Read Only | | I/O Control Register 0 | 0xC022 | R/W | | Output Data Register 1 | 0xC024 | R/W | | Input Data Register 1 | 0xC026 | Read Only | | I/O Control Register 1 | 0xC028 | R/W | | DMA Control Register | 0xC02A | R/W | | Low DMA Start Address Register | 0xC02C | R/W | | High DMA Start Address Register | 0xC02E | R/W | | Low DMA Stop Address Register | 0xC030 | R/W | | High DMA Stop Address Register | 0xC032 | R/W | | DRAM Control Register | 0xC038 | R/W | | Extended Memory Control Register | 0xC03A | R/W | | Memory Control Register | 0xC03E | R/W | This table continues on the next page. Date: 07/25/00 **Revision: 1.80** Date: 07/25/00 **Revision: 1.80** Page: 49 # I/O Address Map (Cont'd) | Function | Address | Mode | |--------------------------------------------|---------|------------| | EPP Data Register | 0xC040 | R/W | | EPP Data Buffer Read Register | 0xC040 | Read Only | | EPP Address Register | 0xC042 | R/W | | EPP Address Buffer Read Register | 0xC044 | Read Only | | EPP Status Data Register | 0xC04E | R/W | | EPP P_REG Register | 0xC050 | R/W | | Serial Interface Control & Status Register | 0xC068 | R/W | | Serial Interface Address Register | 0xC06A | Write Only | | Serial Interface Data Write Register | 0xC06C | Write Only | | Serial Interface Data Read Register | 0xC06C | Read Only | | Video Status Register | 0xC06E | Read Only | | USB Global Control & Status Register | 0xC080 | R/W | | USB Frame Number Register | 0xC082 | Read Only | | USB Address Register | 0xC084 | R/W | | USB Command Done Register | 0xC086 | Write Only | | USB Endpoint 0 Control & Status Register | 0xC090 | R/W | | USB Endpoint 1 Control & Status Register | 0xC092 | R/W | | USB Endpoint 2 Control & Status Register | 0xC094 | R/W | | USB Endpoint 3 Control & Status Register | 0xC096 | R/W | | DMA Control Register | 0xC0C0 | R/W | | STATUS Register | 0xC0C2 | Read Only | | INBUFF Data Register | 0xC0C4 | R/W | | OUTBUFF Data Register | 0xC0C4 | R/W | | UART Control Register | 0xC0E0 | R/W | | UART Status Register | 0xC0E2 | Read Only | | UART Transmit Data Register | 0xC0E4 | Write Only | | UART Receive Data Register | 0xC0E4 | Read Only | | PWM Control Register | 0xC0E6 | R/W | | PWM Maximum Count Register | 0xC0E8 | R/W | | PWM Channel 0 Start Register | 0xC0EA | R/W | | PWM Channel 0 Stop Register | 0xC0EC | R/W | | PWM Channel 1 Start Register | 0xC0EE | R/W | | PWM Channel 1 Stop Register | 0xC0F0 | R/W | | PWM Channel 2 Start Register | 0xC0F2 | R/W | | PWM Channel 2 Stop Register | 0xC0F4 | R/W | | PWM Channel 3 Start Register | 0xC0F6 | R/W | | PWM Channel 3 Stop Register | 0xC0F8 | R/W | | PWM Cycle Count Register | 0xC0FA | R/W | | | | | # 4. PHYSICAL CONNECTION # 4.1 Package Type 100 PQFP. # 4.2 GPIO and 8/16-Bit DMA modes - Pin Assignment and Description | Pin Name | Pi | GPIO | Pin | GPIO & 8/16-bit DMA modes Pin Chip | |----------|----|------|--------|------------------------------------------------| | | n | pins | Type | Revision 1.1 | | | No | - | | | | VDD | 1 | | Power | +3.3 VDC Supply | | D0 | 2 | | Bidir | External Memory Data Bus, Data0 | | D1 | 3 | | Bidir | External Memory Data Bus, Data1 | | D2 | 4 | | Bidir | External Memory Data Bus, Data2 | | D3 | 5 | | Bidir | External Memory Data Bus, Data3 | | D4 | 6 | | Bidir | External Memory Data Bus, Data4 | | D5 | 7 | | Bidir | External Memory Data Bus, Data5 | | D6 | 8 | | Bidir | External Memory Data Bus, Data6 | | D7 | 9 | | Bidir | External Memory Data Bus, Data7 | | D8 | 10 | | Bidir | External Memory Data Bus, Data8 | | D9 | 11 | | Bidir | External Memory Data Bus, Data9 | | D10 | 12 | | Bidir | External Memory Data Bus, Data10 | | D11 | 13 | | Bidir | External Memory Data Bus, Data11 | | GND | 14 | | GND | Digital ground. | | X1 | 15 | | Input | External 48 MHz Crystal or Clock Input. | | X2 | 16 | | Output | External crystal output. No connection when X1 | | | | | | is used for clock input | | VDD | 17 | | Power | +3.3 VDC Supply | | D12 | 18 | | Bidir | External Memory Data Bus, Data12 | | D13 | 19 | | Bidir | External Memory Data Bus, Data13 | | D14 | 20 | | Bidir | External Memory Data Bus, Data14 | | D15 | 21 | | Bidir | External Memory Data Bus, Data15 | | A20 | 22 | | Output | External Memory Address Bus, A20 | | A19 | 23 | | Output | External Memory Address Bus, A19 | | A18 | 24 | | Output | External Memory Address Bus, A18 | | A17 | 25 | | Output | External Memory Address Bus, A17 | | A16 | 26 | | Output | External Memory Address Bus, A16 | | A15 | 27 | | Output | External Memory Address Bus, A15 | | A14 | 28 | | Output | External Memory Address Bus, A14 | | A13 | 29 | | Output | External Memory Address Bus, A13 | | A12 | 30 | | Output | External Memory Address Bus, A12 | | A11 | 31 | | Output | External Memory Address Bus, A11 | | A10 | 32 | | Output | External Memory Address Bus, A10 | | A9 | 33 | | Output | External Memory Address Bus, A9 | | A8 | 34 | | Output | External Memory Address Bus, A8 | | A7 | 35 | | Output | External Memory Address Bus, A7 | | A6 | 36 | | Output | External Memory Address Bus, A6 | | A5 | 37 | | Output | External Memory Address Bus, A5 | | A4 | 38 | | Output | External Memory Address Bus, A4 | | A3 | 39 | | Output | External Memory Address Bus, A3 | | GND | 40 | | GND | Digital ground. | ©1996 - 2000 ScanLogic Corporation. All rights reserved. SL11R is a trademark of ScanLogic Corporation. The information and specifications contained in this document are subject to change without notice. Date: 07/25/00 **Revision: 1.80** | A2 | 41 | | Output | External Memory Address Bus, A2 | |-----------------------|----|--------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | A1 | 42 | | Output | External Memory Address Bus, A1 | | A0 | 43 | | Output | External Memory Address Bus, A0 | | TEST | 44 | | Input | No Connection, MFG test only | | nWRL | 45 | | Output | Active low, write to lower bank of External SRAM | | nWRH | 46 | | Output | Active low, Write to upper bank of External SRAM | | nRD | 47 | | Output | Active low, Read from External SRAM or ROM | | nRESET | 48 | | Input | Master Reset. SL11R Device active low reset input. | | nRAS | 49 | | Output | Active low, DRAM Row Address Select | | VDD | 50 | | Power | +3.3 VDC Supply | | VDD | 51 | | Power | +3.3 VDC Supply | | nCASL | 52 | | Output | Active low, DRAM Column Low Address Select | | nCASH | 53 | | Output | Active low, DRAM Column High Address Select | | nDRAMOE | 54 | | Output | Active low, DRAM Output Enable | | nDRAMWR | 55 | | Output | Active low, DRAM Write | | nXRAMSEL | 56 | | Output | Active low, Select external SRAM ( 16 bit ) | | nXROMSEL | 57 | | Output | Active low, select external SNAW (16 bit ) Active low, select external ROM | | nXMEMSEL | | | | | | HAMEMSEL | 58 | | Output | Active low, select external Memory bus, external SRAM, DRAM, ROM or any memory mapped device | | X PCLK | 59 | | Bidir | See register 0xC006 for more information | | SECLK | 60 | GPIO31 | Bidir | SECLK, Serial EEPROM clock, or GPIO31 | | SEDO | 61 | GPIO30 | Bidir | SEDO, Serial flash EPROM Data, or GPIO30 | | | | | | This pin requires a 5K Ohm pull-up. | | USB_PU | 62 | GPIO29 | Bidir | Turn on/off D+ Pull Up Resistor, or GPIO29 | | UART_TXD | 63 | GPIO28 | Output | UART Transmit Data (out), or GPIO28 | | GND | 64 | | GND | Digital ground. | | GND | 65 | 001007 | GND | Digital ground. | | UART_RXD | 66 | GPIO27 | Input | UART Receive Data (in), or GPIO27 | | PWR_OFF | 67 | GPIO26 | Bidir | This signal can be used for device low power mode, it will turn off or disable external powers to the peripheral in suspend mode. Once USB power is resumed, external power can be | | | | | | enabled again | | IRQ1 (in) | 68 | GPIO25 | Bidir | GPIO25, or IRQ1 (in) interrupts the SL11R processor | | PWM3, or<br>IRQ0 (in) | 69 | GPIO24 | Bidir | IRQ0 (in) interrupts the SL11R processor or PWM. | | | | | | See the PWM Control register setup for more information | | PWM2 | 70 | GPIO23 | Bidir | Same as above or GPIO23 | | PWM1 | 71 | GPIO22 | Bidir | Same as above or GPIO22 | | PWM0 | 72 | GPIO21 | Bidir | Same as above or GPIO21 | | DREQ | 73 | GPIO20 | Bidir | DMA Request Enable. DREQ indicates that SL11R is ready to accept or send data from/to an external device. DREQ along with nCS, nWRITE and nREAD bits are the DMA handshake signals for the main SDATA port, or | | ADDR | 74 | GPIO19 | Bidir | GPIO20. ADDR =1, Read/Write data from the INBUF/OUTBUFF, ADDR=0 read data from the | | TATUS register, or GPIO19 +3.3 VDC Supply | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 13.3 VDC Supply | | +3.3 VDC Supply | | CS (in) Active low, Selects the bi-directional SDATA Port, or GPIO18 | | Active input low signal used to indicate write data transfers to the general bi-directional SD15-0 Data Port. Signal is driven high for read transfers to the SL11R, or GPIO17 | | Active low input signal used to indicate read data transfers from the general bi-directional SD15-0 Data Port. Or GPIO16 | | Digital ground. | | Main bi-directional SDATA port bit 15, or GPIO15 | | Main bi-directional SDATA port bit 14, or GPIO14 | | Main bi-directional SDATA port bit 13, or GPIO13 | | Main bi-directional SDATA port bit 12, or GPIO12 | | Main bi-directional SDATA port bit 11, or GPIO11 | | Main bi-directional SDATA port bit 10, or GPIO10 | | Main bi-directional SDATA port bit 9, or GPIO9 | | USB +3.3 VDC Supply. | | USB Differential DATA Signal High Side. | | USB Differential DATA Signal Low Side. | | USB Digital Ground. | | Main bi-directional SDATA port bit 8, or GPIO8 | | Main bi-directional SDATA port bit 7, or GPIO7 | | Main bi-directional SDATA port bit 6, or GPIO6 | | Main bi-directional SDATA port bit 5, or GPIO5 | | Main bi-directional SDATA port bit 4, or GPIO4 | | Main bi-directional SDATA port bit 3, or GPIO3 | | Main bi-directional SDATA port bit 2, or GPIO2 | | Main bi-directional SDATA port bit 1, or GPIO1 | | Main bi-directional SDATA port bit 0, or GPIO0 | | +3.3 VDC Supply | | | # 4.3 Fast EPP Pin Assignment and Description | Pin Name | Pin | GPIO pins | Pin | GPIO & Fast EPP Pin Chip Revision 1.1 | |----------|-----|-----------|-------|---------------------------------------| | | No | | Type | | | VDD | 1 | | Power | +3.3 VDC Supply | | D0 | 2 | | Bidir | External Memory Data Bus, Data0 | | D1 | 3 | | Bidir | External Memory Data Bus, Data1 | | D2 | 4 | | Bidir | External Memory Data Bus, Data2 | | D3 | 5 | | Bidir | External Memory Data Bus, Data3 | | D4 | 6 | | Bidir | External Memory Data Bus, Data4 | | D5 | 7 | | Bidir | External Memory Data Bus, Data5 | © 1996 - 2000 ScanLogic Corporation. All rights reserved. SL11R is a trademark of ScanLogic Corporation. The information and specifications contained in this document are subject to change without notice. | ScanLogic | Corporation | | SL11R Hardware Specification | |-----------|-------------|--------|----------------------------------------------------------------------------------------------| | D6 | 8 | Bidir | External Memory Data Bus, Data6 | | D7 | 9 | Bidir | External Memory Data Bus, Data7 | | D8 | 10 | Bidir | External Memory Data Bus, Data8 | | D9 | 11 | Bidir | External Memory Data Bus, Data9 | | D10 | 12 | Bidir | External Memory Data Bus, Data10 | | D11 | 13 | Bidir | External Memory Data Bus, Data11 | | GND | 14 | GND | Digital ground. | | X1 | 15 | Input | External 48 MHz Crystal or Clock Input. | | X2 | 16 | Output | External crystal output. No connection when X1 is used for clock input | | VDD | 17 | Power | +3.3 VDC Supply | | D12 | 18 | Bidir | External Memory Data Bus, Data12 | | D13 | 19 | Bidir | External Memory Data Bus, Data13 | | D14 | 20 | Bidir | External Memory Data Bus, Data14 | | D15 | 21 | Bidir | External Memory Data Bus, Data15 | | A20 | 22 | Output | External Memory Address Bus, A20 | | A19 | 23 | Output | External Memory Address Bus, A19 | | A18 | 24 | Output | External Memory Address Bus, A18 | | A17 | 25 | Output | External Memory Address Bus, A17 | | A16 | 26 | Output | External Memory Address Bus, A16 | | A15 | 27 | Output | External Memory Address Bus, A15 | | A14 | 28 | Output | External Memory Address Bus, A14 | | A13 | 29 | Output | External Memory Address Bus, A13 | | A12 | 30 | Output | External Memory Address Bus, A12 | | A11 | 31 | Output | External Memory Address Bus, A11 | | A10 | 32 | Output | External Memory Address Bus, A10 | | A9 | 33 | Output | External Memory Address Bus, A9 | | A8 | 34 | Output | External Memory Address Bus, A8 | | A7 | 35 | Output | External Memory Address Bus, A7 | | A6 | 36 | Output | External Memory Address Bus, A6 | | A5 | 37 | Output | External Memory Address Bus, A5 | | A4 | 38 | Output | External Memory Address Bus, A4 | | A3 | 39 | Output | External Memory Address Bus, A3 | | GND | 40 | GND | Digital ground. | | A2 | 41 | Output | External Memory Address Bus, A2 | | A1 | 42 | Output | External Memory Address Bus, A1 | | A0 | 43 | Output | External Memory Address Bus, A0 | | TEST | 44 | Input | No Connection, MFG test only | | nWRL | 45 | Output | Active low, write to lower bank of External SRAM | | nWRH | 46 | Output | Active low, Write to upper bank of External SRAM | | nRD | 47 | Output | Active low, Read from External SRAM or ROM | | nRESET | 48 | Input | Master Reset. SL11R Device active low reset input. | | nRAS | 49 | Output | Active low, DRAM Row Address Select | | VDD | 50 | Power | +3.3 VDC Supply | | VDD | 51 | Power | +3.3 VDC Supply | | nCASL | 52 | Output | Active low, DRAM Column Low Address Select | | nCASH | 53 | Output | Active low, DRAM Column High Address Select | | nDRAMOE | 54 | Output | Active low, DRAM Output Enable | | nDRAMWR | 55 | Output | Active low, DRAM Write | | nXRAMSEL | 56 | Output | Active low, select external SRAM ( 16 bit ) | | nXROMSEL | 57 | Output | Active low, select external ROM | | nXMEMSEL | 58 | Output | Active low, select external Memory bus, external SRAM, DRAM, ROM or any memory mapped device | <sup>©1996 - 2000</sup> ScanLogic Corporation. All rights reserved. SL11R is a trademark of ScanLogic Corporation. The information and specifications contained in this document are subject to change without notice. | X_PCLK | 59 | | Bidir | See register 0xC006 for more information | |----------|-----|--------|-------------------|------------------------------------------| | SECLK | 60 | GPIO31 | Bidir | SECLK, Serial EEPROM clock, or GPIO31 | | SEDO | 61 | GPIO30 | Bidir | SEDO, Serial flash EPROM Data, or GPIO30 | | | | | | This pin requires a 5K Ohm pull-up. | | GPIO29 | 62 | GPIO29 | Bidir | GPIO29 | | UART_TXD | 63 | GPIO28 | Output | UART Transmit Data (out), or GPIO28 | | GND | 64 | | GND | Digital ground. | | GND | 65 | | GND | Digital ground. | | UART_RXD | 66 | GPIO27 | Input | UART Receive Data (in), or GPIO27 | | nENS | 67 | GPIO26 | Output | Serial EPROM control signal | | CLKS | 68 | GPIO25 | Output | Serial EPROM Clock | | nDTSRB | 69 | GPIO24 | Output | EPP Data Strobe | | nASTRB | 70 | GPIO23 | Output | EPP Address Strobe | | nWRITE | 71 | GPIO22 | Output | EPP Write Strobe | | P9 | 72 | GPIO21 | Output | P Register | | P5 | 73 | GPIO20 | Output | P Register or PWR_OFF | | P4 | 74 | GPIO19 | Output | P Register | | VDD | 75 | | Power | +3.3 VDC Supply | | P3 | 76 | GPIO18 | Output | P Register or USB_PU (USB DATA+ pull up) | | P2 | 77 | GPIO17 | Output | P Register | | P1 | 78 | GPIO16 | Output | P Register | | GND | 79 | | GND | Digital ground. | | P6 | 80 | GPIO15 | Output | P Register | | P7 | 81 | GPIO14 | Output | P Register | | P8 | 82 | GPIO13 | Output | P Register | | GPIO12 | 83 | GPIO12 | Bidir | GPIO12 | | DATAS | 84 | GPIO11 | Bidir | DATA Strobe for Serial EPROM | | VREQ | 85 | GPIO10 | Input | TBD | | WAIT | 86 | GPIO9 | <u>.</u><br>Bidir | EPP WAIT signal | | VDD1 | 87 | | Power | USB +3.3 VDC Supply. | | DATA+ | 88 | | Bidir | USB Differential DATA Signal High Side. | | DATA- | 89 | | Bidir | USB Differential DATA Signal Low Side. | | GND1 | 90 | | GND | USB Digital Ground. | | INTR | 91 | GPIO8 | Input | EPP INTR pin | | SD7 | 92 | GPIO7 | Bidir | EPP Data bit 7 | | SD6 | 93 | GPIO6 | Bidir | EPP Data bit 6 | | SD5 | 94 | GPIO5 | Bidir | EPP Data bit 5 | | SD4 | 95 | GPIO4 | Bidir | EPP Data bit 4 | | SD3 | 96 | GPIO3 | Bidir | EPP Data bit 3 | | SD2 | 97 | GPIO2 | Bidir | EPP Data bit 2 | | SD1 | 98 | GPIO1 | Bidir | EPP Data bit 1 | | SD0 | 99 | GPIO0 | Bidir | EPP Data bit 0 | | VDD | 100 | 0, 100 | Power | +3.3 VDC Supply | | VDD | 100 | | I OWEI | 10.0 VDO Oupply | # 4.4 DVC 8-Bit DMA mode Pin Assignment and Description | Pin Name | Pin | GPIO pins | Pin | GPIO & DVC 8-bit DMA modes Pin Chip Revision 1.1 | |----------|-----|-----------|-------|--------------------------------------------------| | | No | | Type | | | VDD | 1 | | Power | +3.3 VDC Supply | | D0 | 2 | | Bidir | External Memory Data Bus, Data0 | | D1 | 3 | | Bidir | External Memory Data Bus, Data1 | | D2 | 4 | | Bidir | External Memory Data Bus, Data2 | | D3 | 5 | | Bidir | External Memory Data Bus, Data3 | ©1996 - 2000 ScanLogic Corporation. All rights reserved. SL11R is a trademark of ScanLogic Corporation. The information and specifications contained in this document are subject to change without notice. | ScanLogic | Corporation | | SL11R Hardware Specification | |-----------|-------------|--------|------------------------------------------------------------------------| | D4 | 6 | Bidir | External Memory Data Bus, Data4 | | D5 | 7 | Bidir | External Memory Data Bus, Data5 | | | 8 | Bidir | External Memory Data Bus, Data6 | | D6 | | | · · · · · · · · · · · · · · · · · · · | | D7 | 9 | Bidir | External Memory Data Bus, Data7 | | D8 | 10 | Bidir | External Memory Data Bus, Data8 | | D9 | 11 | Bidir | External Memory Data Bus, Data9 | | D10 | 12 | Bidir | External Memory Data Bus, Data10 | | D11 | 13 | Bidir | External Memory Data Bus, Data11 | | GND | 14 | GND | Digital ground. | | X1 | 15 | Input | External 48 MHz Crystal or Clock Input. | | X2 | 16 | Output | External crystal output. No connection when X1 is used for clock input | | VDD | 17 | Power | +3.3 VDC Supply | | D12 | 18 | Bidir | External Memory Data Bus, Data12 | | D13 | 19 | Bidir | External Memory Data Bus, Data13 | | D14 | 20 | Bidir | External Memory Data Bus, Data14 | | D15 | 21 | Bidir | External Memory Data Bus, Data15 | | A20 | 22 | Output | External Memory Address Bus, A20 | | A19 | 23 | Output | External Memory Address Bus, A19 | | A18 | 24 | Output | External Memory Address Bus, A18 | | A17 | 25 | Output | External Memory Address Bus, A17 | | A16 | 26 | Output | External Memory Address Bus, A16 | | A15 | 27 | Output | External Memory Address Bus, A15 | | A14 | 28 | Output | External Memory Address Bus, A14 | | A13 | 29 | Output | External Memory Address Bus, A13 | | A12 | 30 | Output | External Memory Address Bus, A12 | | A11 | 31 | Output | External Memory Address Bus, A11 | | A10 | 32 | Output | External Memory Address Bus, A10 | | A9 | 33 | Output | External Memory Address Bus, A9 | | A8 | 34 | Output | External Memory Address Bus, A8 | | A7 | 35 | Output | External Memory Address Bus, A7 | | A6 | 36 | Output | External Memory Address Bus, A6 | | | 37 | | External Memory Address Bus, A5 | | A5<br>A4 | 38 | Output | · | | | 39 | Output | External Memory Address Bus, A4 | | A3 | | Output | External Memory Address Bus, A3 | | GND | 40 | GND | Digital ground. | | A2 | 41 | Output | External Memory Address Bus, A2 | | A1 | 42 | Output | External Memory Address Bus, A1 | | A0 | 43 | Output | External Memory Address Bus, A0 | | TEST | 44 | Input | No Connection, MFG test only | | nWRL | 45 | Output | Active low, write to lower bank of External SRAM | | nWRH | 46 | Output | Active low, Write to upper bank of External SRAM | | nRD | 47 | Output | Active low, Read from External SRAM or ROM | | nRESET | 48 | Input | Master Reset. SL11R Device active low reset input. | | nRAS | 49 | Output | Active low, DRAM Row Address Select | | VDD | 50 | Power | +3.3 VDC Supply | | VDD | 51 | Power | +3.3 VDC Supply | | nCASL | 52 | Output | Active low, DRAM Column Low Address Select | | nCASH | 53 | Output | Active low, DRAM Column High Address Select | | nDRAMOE | 54 | Output | Active low, DRAM Output Enable | | nDRAMWR | 55 | Output | Active low, DRAM Write | | nXRAMSEL | 56 | Output | Active low, select external SRAM ( 16 bit ) | | nXROMSEL | 57 | Output | Active low, select external ROM | © 1996 - 2000 ScanLogic Corporation. All rights reserved. SL11R is a trademark of ScanLogic Corporation. The information and specifications contained in this document are subject to change without notice. Date: 07/25/00 **Revision: 1.80** | nXMEMSEL | 58 | | Output | Active low, select external Memory bus, external SRAM, DRAM, ROM or any memory mapped device | |-----------|-----|----------|--------|----------------------------------------------------------------------------------------------| | X_PCLK | 59 | | Bidir | See register 0xC006 for more information | | SECLK | 60 | GPIO31 | Bidir | SECLK, Serial EEPROM clock, or GPIO31 | | SEDO | 61 | GPIO30 | Bidir | SEDO, Serial flash EPROM Data, or GPIO30 | | OLDO | 0. | G1 1000 | Dian | This pin requires a 5K Ohm pull-up. | | GPIO29 | 62 | GPIO29 | Bidir | GPIO29 | | UART TXD | 63 | GPIO28 | Output | UART Transmit Data (out), or GPIO28 | | GND | 64 | | GND | Digital ground. | | GND | 65 | | GND | Digital ground. | | UART RXD | 66 | GPIO27 | Input | UART Receive Data (in), or GPIO27 | | GPIO26 | 67 | GPIO26 | Bidir | GPIO26 | | IRQ1 (in) | 68 | GPIO25 | Bidir | GPIO25, or IRQ1 (in) interrupts the SL11R processor | | IRQ0 (in) | 69 | GPIO24 | Bidir | IRQ0 (in) interrupts the SL11R processor or GPIO24 | | GPIO23 | 70 | GPIO23 | Bidir | GPIO23 | | GPIO22 | 71 | GPI022 | Bidir | GPIO22 | | nVID RST | 72 | GPIO21 | Output | VIDEO Reset Pin | | P CONT | 73 | GPIO20 | Output | P_CONT pin | | AGC_C | 74 | GPIO19 | Output | AGC_C control pin | | VDD | 75 | | Power | +3.3 VDC Supply | | AEEP | 76 | GPIO18 | Output | AEPP pin | | DSP_CS | 77 | GPIO17 | Output | DSP Chip select pin | | EEP2_CS | 78 | GPIO16 | Bidir | Serial EPROM2 chip select | | GND | 79 | Si 10 10 | GND | Digital ground. | | EEP1_CS | 80 | GPIO15 | Output | Serial EPROM1 chip select | | DO | 81 | GPIO14 | Output | Serial EPROM Data out pin | | SK | 82 | GPIO13 | Input | Serial EPROM Clock pin | | PBLK | 83 | GPIO12 | Input | PBLK from CCD | | VD | 84 | GPIO11 | Input | VD from CCD | | FI | 85 | GPIO10 | Input | FI from CCD | | MCK0 | 86 | GPIO9 | Bidir | MCK0 from CCD | | VDD1 | 87 | | Power | USB +3.3 VDC Supply. | | DATA+ | 88 | | Bidir | USB Differential DATA Signal High Side. | | DATA- | 89 | | Bidir | USB Differential DATA Signal Low Side. | | GND1 | 90 | | GND | USB Digital Ground. | | DI | 91 | GPIO8 | Bidir | Serial EPROM Data Input | | SD7 | 92 | GPI07 | Input | SDATA port bit 7, or GPIO7 | | SD6 | 93 | GPIO6 | Input | SDATA port bit 6, or GPIO6 | | SD5 | 94 | GPIO5 | Input | SDATA port bit 5, or GPIO5 | | SD4 | 95 | GPIO4 | Input | SDATA port bit 4, or GPIO4 | | SD3 | 96 | GPIO3 | Input | SDATA port bit 3, or GPIO3 | | SD2 | 97 | GPIO2 | Input | SDATA port bit 2, or GPIO2 | | SD1 | 98 | GPIO1 | Input | SDATA port bit 1, or GPIO1 | | SD0 | 99 | GPIO0 | Input | SDATA port bit 0, or GPI00 | | VDD | 100 | 0. 100 | Power | +3.3 VDC Supply | **Page:** 57 Revision: 1.80 #### 5. SL11R CPU PROGRAMMING GUIDE This is the preliminary specification for the SL11R Processor Instruction set. #### 5.1 Instruction Set Overview This document describes the SL11R CPU Instruction Set, Registers and Addressing modes, Instruction format, etc. The SL11R PROCESSOR uses a unified program and data memory space; although this RAM is also integrated into the SL11R core, provision has been made for external memory as well. The SL11R PROCESSOR engine incorporates 38 registers: fifteen general-purpose registers, a stack pointer, sixteen registers mapped into RAM, a program counter, and a REGBANK register whose function will be described in a subsequent section. The SL11R PROCESSOR engine supports byte and word addressing. Subsequent sections of this document will describe: - The SL11R PROCESSOR Engine (QT Engine) Register Set - SL11R PROCESSOR Engine Instruction Format - SL11R PROCESSOR Engine Addressing Modes - SL11R PROCESSOR Engine Instruction Set #### 5.2 Reset Vector On receiving hardware reset, the SL11R Processor jumps to address 0xFFF0, which is an internal ROM address. ## 5.3 Register Set The SL11R Processor incorporates 16-bit general-purpose registers called R0..R15, a REGBANK register, and a program counter, along with various other registers. The function of each register is defined as follows: | Name | Function | |------------------|------------------------------------------------| | R0-R14 | General Purpose Registers | | R15 | Stack Pointer | | PC | Program Counter | | REGBANK | Forms base address for registers R0-R15 | | FLAGS | Contains flags: defined below | | INTERRUPT ENABLE | Bit masks to enable/disable various interrupts | ## 5.4 General Purpose Registers The general-purpose registers can be used to store intermediate results, and to pass parameters to and return them from subroutine calls. # 5.5 General Purpose/Address Registers In addition to acting as general-purpose registers, registers R8-R14 can also serve as pointer registers. Instructions can access RAM locations by referring to any of these registers. In normal operation, register R15 is reserved for use as a stack pointer. ### 5.6 REGBANK Register (0xC002: R/W) Registers R0..R15 are mapped into RAM via the REGBANK register. The REGBANK register is loaded with a base address, of which the 11 most significant bits are used. A read from or write to one of the registers will generate a RAM address by: - Shifting the 4 least significant bits of the register number left by 1. - OR-ing the shifted bits of the register number with the upper 11 bits of the REGBANK register. - Forcing the Least Significant Bit to 0. For example, if the REGBANK register is left at its default value of 100 hex, a read of register R14 would read address 11C hex. | Register | Hex Value | Bi | ina | ry | Va | lue | | | | | | | | | | | | |--------------|------------------|----|-----|----|----|-----|---|---|---|---|---|---|---|---|---|---|---| | REGBANK | 0100 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | Х | Х | Х | Х | Х | | R14 | 000E << 1 = 001C | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | 0 | 1 | 1 | 1 | 0 | 0 | | RAM Location | 011C | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | #### Note: Regardless of the value loaded into the REGBANK register, bits 0..4 will be ignored. ## 5.7 Flags Register (0xC000: Read Only) The SL11R Processor uses these flags: | FLAG | | | | | | | | | | | | | | | | | |------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | S | 0 | С | Ζ | - **Zero**: instruction execution resulted in a result of 0 - C Carry/Borrow: Arithmetic instruction resulted in a carry (for addition) or a borrow (for subtraction) - O Overflow: Arithmetic result was either larger than the destination operand size (for addition) or smaller than the destination operand should allow for subtraction - S Sign: Set if MS result bit is "1" - I Global Interrupts Enabled if "1" #### Note: Flag behavior for each instruction will be described in the following section #### 5.8 Instruction Format To understand addressing modes supported by the SL11R Processor, you must know how the instruction format is defined. In general, the instructions include four bits for the instruction **opcode**, six bits for the source operand, and six bits for the destination operand. | ADD<br>bit: | 15 | 14 | 12 | 12 | 11 | 10 | a | Ω | 7 | 6 | 5 | 1 | 2 | 2 | 1 | 0 | |-------------|----|----|-----|----|----|----|---|------|----------|----------|---|---|--------|--------|---------------|---| | DIL. | 13 | | ode | 12 | 11 | 10 | J | ırce | <i>'</i> | <u> </u> | 5 | - | destir | natior | <u>'</u><br>ነ | | Some instructions, especially single operand-operator and program control instructions, will not adhere strictly to this format. They will be discussed in detail in turn. **Page:** 59 Revision: 1.80 ## 5.9 Addressing Modes This section describes in detail the six-operand field bits referred to in the previous section as **source** and **destination**. Bear in mind that although the discussion refers to bits 0 through 5, the same bit definitions apply to the "source" operand field, bits 6 through 11. These are the basic addressing modes in the SL11R Processor. | Mode | 5 | 4 | 3 | 2 | 1 | 0 | |------------------------------|---|---|-----|---|---|---| | Register | 0 | 0 | r | r | r | r | | Immediate | 0 | 1 | 1 | 1 | 1 | 1 | | Direct | 1 | 0 | b/w | 1 | 1 | 1 | | Indirect | 0 | 1 | b/w | r | r | r | | Indirect with Auto Increment | 1 | 0 | b/w | r | r | r | | Indirect with Index | 1 | 1 | b/w | r | r | r | #### Notes: - b/w: '1' for byte-wide access, '0' for word access. - Indirect with auto increment and byte-wide Indirect addressing is illegal with the stack pointer (R15). ## 5.10 Register Addressing In register addressing, any one of registers R0-R15 can be selected using bits 0-3. If register addressing is used, operands are always 16-bit operands, since all registers are 16-bit registers. For example, an instruction using register R7 as an operand would fill the operand field like this: | Bits | 5 | 4 | 3 | 2 | 1 | 0 | |------------------|---|---|---|---|---|---| | Register Operand | 0 | 0 | 0 | 1 | 1 | 1 | # 5.11 Immediate Addressing In Immediate Addressing, the instruction word is immediately followed by the source operand. For example, The operand field would be filled with: | Bits | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|---|---|---|---| | Operand field | 0 | 1 | 1 | 1 | 1 | 1 | #### Note: In immediate addressing, the source operand *must* be 16 bits wide, eliminating the need for a b/w bit. # 5.12 Direct Addressing In Direct Addressing, the word following the instruction word is used as an address into RAM. Again, the operand can be either byte or word sized, depending on the state of bit 3 of the operand field. For example, to do a word-wide read from a direct address, the **source** operand field would be formed like this: | Bits | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---|---|---|---|---|---| | I/O operand | 1 | 0 | 0 | 1 | 1 | 1 | #### Note: For a memory-to-memory move, the instruction word would be followed by two words, the first being the **source** address and the second being the **destination**. Page: 60 Revision: 1.80 ## 5.13 Indirect Addressing Indirect addressing is accomplished using address registers R8-15. In Indirect addressing, the operand is found at the memory address pointed to by the register. Since only eight address registers exist, only three bits are required to select an address register. For example, register R10 (binary 1010) can be selected by ignoring bit 3, leaving the bits 010. Bit 3 of the operand field is then used as the byte/word bit, set to "0" to select word or "1" to select byte addressing. In this example, a byte-wide operand is selected at the memory location pointed to by register R10: | Bits | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|---|---|---|---|---| | Memory operand | 0 | 1 | 1 | 0 | 1 | 0 | #### Note: For register R15, byte-wide operands are prohibited. If bit 3 is set high, the instruction is decoded differently, as explained at the top of this section. ## **5.14 Indirect Addressing with Auto Increment** Indirect Addressing with Auto Increment works identically to Indirect Addressing, except that at the end of the read or write cycle, the register is incremented by 1 or 2 (depending whether it is a byte-wide or word-wide access.) This mode is prohibited for register R15. If bits 0..2 are all high, the instruction is decoded differently, as explained at the top of this section. #### 5.15 Indirect Addressing with Offset In Indirect Addressing with Offset, the instruction word is followed by a 16-bit word that is added to the contents of the address register to form the address for the operand. The offset is an unsigned 16-bit word, and will "wrap" to low memory addresses if the register and offset add up to a value greater than the size of the processor's address space. ## 5.16 Stack Pointer (R15) Special Handling Register R15 is designated as the Stack Pointer, and has these special behaviors: - If addressed in indirect mode, the register pre-decrements on a write instruction, and post-increments on a read instruction, emulating Push and Pop instructions. - Byte-wide reads or writes are prohibited in indirect mode. - If R15 is addressed in Indirect with Index mode, it does not auto-increment or auto-decrement. #### SL11R - CPU Instruction Set The instruction set can be roughly divided into three classes of instructions: - **Dual Operand Instructions** (Instructions with two operands, a source and a destination) - Program Control Instructions (Jump, Call and Return) - Single Operand Instructions (Instructions with only one operand: a destination) #### 5.17 Dual Operand Instructions Instructions with source and destination, for ALL dual operand instructions, byte values are zero extended by default. | MOV | | | | | | | | | | | | | | | | | |------|----|----|-----|----|----|----|-----|------|---|---|---|---|-------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 00 | 000 | | | | sou | ırce | | | | | Desti | natior | 1 | | destination := source Flags Affected: none | ADD | | | | | | | | | | | | | | | | | |------|----|----|----|----|----|----|-----|------|---|---|---|---|--------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 00 | 01 | | | | SOL | ırce | | | | | Destir | natior | 1 | | destination := destination + source Flags Affected: Z, C, O, S | ADDC | | | | | | | | | | | | | | | | | |------|----|----|----|----|----|----|-----|------|---|---|---|---|-------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 00 | 10 | | | | sou | ırce | | | | | Desti | natior | 1 | | destination := destination + source + carry bit Flags Affected: Z, C, O, S | | | 00 | 11 | | | | SOL | irce | | | | | Destir | natior | 1 | | |------|----|----|----|----|----|----|-----|------|---|---|---|---|--------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | SUB | | | | | | | | | | | | | | | | | destination := destination - source Flags Affected: Z, C, O, S | SUBB | | | | | | | | | | | | | | | | | |------|----|----|----|----|----|----|-----|------|---|---|---|---|--------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 01 | 00 | | | | SOL | ırce | | | | | Destir | natior | 1 | | destination := destination - source - carry bit Flags Affected: Z, C, O, S | CMP | | | | | | | | | | | | | | | | | |------|----|----|----|----|----|----|-----|------|---|---|---|---|--------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 01 | 01 | | | | sou | irce | | | | | Destir | natior | 1 | | [not saved] = destination - source Flags Affected: Z, C, O, S | AND | | | | | | | | | | | | | | | | | |------|----|----|----|----|--------|----|---|---|---|---|---|--------|--------|---|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 10 | | source | | | | | | | Destir | natior | 1 | | | destination := destination & source Flags Affected: Z, S | TEST | | | | | | | | | | | | | | | | | |------|----|----|----|----|--------|----|---|---|---|---|---|--------|--------|----------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 11 | | source | | | | | | | Destir | natior | <u> </u> | | | [not saved] := destination & source Flags Affected: Z, S | OR | | | | | | | | | | | | | | | | | |------|----|------|----|----|----|----|-----|------|---|---|---|---|--------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 1000 | | | | | SOL | ırce | | | | | Destir | natior | 1 | | destination := destination | source Flags Affected: Z, S | XOR | | | | | | | | | | | | | | | | | |------|----|----|----|----|----|----|-----|------|---|---|---|---|--------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 10 | 01 | | | | SOL | ırce | | | | | Destii | natior | 1 | | destination := destination ^ source Flags Affected: Z, S ## **5.18 Program Control Instructions** | Jcc | JL | JMP I | RELA | TIVE | ccc | ; | | | | | | | | | | | | |------|----|-------|------|------|-----|----|----|----|---|---|---|---|---|-------|---|---|---| | bit: | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 11 | 00 | | | СС | СС | | 0 | | | | Offse | t | | | PC := PC + (offset\*2) (offset is a 7-bit signed number from -64..+63) | JccL | JUMP | ABS | SOLU | TE co | ccc | | | | | | | | | | | | |------|------|-----|------|-------|-----|----|----|---|---|---|---|---|--------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 11 | 00 | | | СС | СС | | 1 | 0 | | | Destir | natior | 1 | | PC := [destination] (destination is computed in the normal fashion for operand fields) | Rcc | RET | cccc | | | | | | | | | | | | | | | |------|-----|------|----|----|----|----|----|---|---|---|---|---|-----|-----|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 11 | 00 | | | СС | СС | | 1 | 0 | | | 010 | 111 | | | PC := [R15] R15++ | Ccc CAI | L cc | СС | | | | | | | | | | | | | | | |---------|------|----|-----|----|----|----|----|---|---|---|---|---|--------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 10 | )10 | | | СС | СС | | 1 | 0 | | | Destir | natior | 1 | | R15--[R15] := PC PC = [destination] | INT | | | | | | | | | | | | | | | | | |------|----|----|-----|----|----|----|----|---|---|---|---|----|--------|----|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 10 | )10 | | | 00 | 00 | | 0 | | | in | t vect | or | | | [R15] := PC R15-- PC = [int vector \* 2] This instruction allows the programmer to implement software interrupts. *Int vector* is multiplied by two, and zero extended to 16 bits. **Note:** Interrupt vectors 0 through 31 *may* be reserved for hardware interrupts, depending on the application. The condition (cccc) bits for all of the above instructions are defined as: | Condition | cccc<br>Bits | Description | JUMP mnemonic | CALL<br>mnemonic | RET<br>mnemonic | |-----------|--------------|----------------|---------------|------------------|-----------------| | Z | 0000 | Z=1 | JZ | CZ | RZ | | NZ | 0001 | Z=0 | JNZ | CNZ | RNZ | | C/B | 0010 | C=1 | JC | CC | RC | | NC / AE | 0011 | C=0 | JNC | RNC | RNC | | S | 0100 | S=1 | JS | CS | RS | | NS | 0101 | S=0 | JNS | CNS | RNS | | 0 | 0110 | O=1 | JO | CO | RO | | NO | 0111 | O=0 | JNO | CNO | RNO | | A / NBE | 1000 | (Z=0 AND C=0) | JA | CA | RA | | BE / NA | 1001 | (Z=1 OR C=1) | JBE | CBE | RBE | | G/NLE | 1010 | (O= S AND Z=0) | JG | CG | RG | | GE/NL | 1011 | (O=S) | JGE | CGE | RGE | ©1996 - 2000 ScanLogic Corporation. All rights reserved. SL11R is a trademark of ScanLogic Corporation. The information and specifications contained in this document are subject to change without notice. #### ScanLogic Corporation **SL11R Hardware Specification** | L/NGE | 1100 | (O≠S) | JL | CL | RL | | |---------------|------|---------------|-----|------|-----|---| | LE / NG | 1101 | (O≠S OR Z=1) | JLE | CLE | RLE | | | (not used) | 1110 | | | | | | | Unconditional | 1111 | Unconditional | JMP | CALL | RET | , | Note: 1) For the JUMP mnemonics, adding an "L" to the end indicates a long or absolute jump. Adding an "S" to the end indicates a short or relative jump. If nothing is added, the assembler will choose "S" or "L." #### 5.19 Single Operand Operation Instructions Since Single operand instructions do not require a source field, the format of the Single operand Operation instructions is slightly different. | Instruction | | | | | | | | | | | | | | | | | |-------------|----|----|----|------|----|----|---|-----|-----|----|---|----|------|------|----|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 11 | 01** | * | | | [pa | ara | m] | | de | stir | nati | on | | Notice that the *opcode* field is expanded to seven bits wide. The four most significant bits for all instructions of this class are "1101." In addition, there is space for an optional three bit immediate value, which is used in a manner appropriate to the instruction. The destination field functions exactly as it does in the dual operand operation instructions. #### Note: - For the SHR, SHL, ROR, ROL, ADDI and SUBI instructions, the three-bit *count* or *n* operand is incremented by 1 before it is used. - The SL11R QT assembler takes this into account. | SHR | | | | | | | | | | | | | | | | | |------|----|----|----|-------|----|----|---|---|-------|----|---|---|--------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 1 | 10100 | 00 | | | С | ount- | ·1 | | | destir | natior | 1 | | destination := destination >> count Flags Affected: Z, C, S #### Note: - The SHR instruction shifts in sign bits. - The C flag is set with last bit shifted out of LSB. | SHL | | | | | | | | | | | | | | | | | |------|----|----|----|-------|----|----|---|---|-------|----|---|---|--------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 1 | 10100 | )1 | | | С | ount- | ·1 | | | destir | natior | 1 | | destination := destination << count Flags Affected: Z, C, S Note: The C flag is set with last bit shifted out of MSB. | ROR | | | | | | | | | | | | | | | | | |------|----|----|----|-------------------|----|----|---|---|-------|----|---|---|--------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 1 | 1010 <sup>°</sup> | 10 | | | С | ount- | ·1 | | | destir | natior | 1 | | Works identically to the SHR instruction, except that the LSB of *destination* is rotated into the MSB, as opposed to SHR, which discards that bit Flags Affected: Z, C, S | ROL | | | | | | | | | | | | | | | | | |------|----|----|----|-------|----|----|---|---|-------|----|---|---|--------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 1 | 10101 | 11 | | | С | ount- | ·1 | | - | destir | natior | ) | | Date: 07/25/00 **Revision: 1.80** Works identically to the SHL instruction, except that the MSB of *destination* is rotated into the LSB, as opposed to SHL, which discards that bit Flags Affected: Z, C, S | ADDI | | | | | | | | | | | | | | | | | |------|----|----|----|------|----|----|---|---|-----|---|---|---|--------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 11 | 0110 | 0 | | | | n-1 | | | ( | destir | nation | 1 | | destination := destination + n Flags Affected: Z, S | SUBI | | | | | | | | | | | | | | | | | |------|----|----|----|-------|----|----|---|---|-----|---|---|---|--------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 1 | 10110 | )1 | | | | n-1 | | | ( | destir | natior | 1 | | destination := destination - n Flags Affected: Z, S | NOT | | | | | | | | | | | | | | | | | |------|---------|----|----|----|----|----|---|---|-----|---|---|---|--------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 1101111 | | | | | | | | 000 | | | | destir | natior | 1 | | destination := ~destination (bitwise 1's complement negation) Flags Affected: Z, S | NEG | | | | | | | | | | | | | | | | | |------|----|----|----|------|----|----|---|---|-----|---|---|---|--------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 1 | 1011 | 11 | | | | 001 | | | | destir | natior | 1 | | destination := -destination (2's complement negation) Flags Affected: Z, O, C, S | CBW | | | | | | | | | | | | | | | | | |------|----|----|----|-------|----|----|---|---|-----|---|---|---|--------|--------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 1 | 10111 | 11 | | | | 010 | | | - | destir | natior | ) | | Sign-extends a byte in the lower eight bits of [destination] to a 16-bit signed word (integer). Flags Affected: Z, S #### 5.20 Miscellaneous Instructions | STI | | | | | | | | | | | | | | | | | |------|----|----|----|------|----|----|---|---|-----|---|---|---|-----|-----|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 1 | 1011 | 11 | | | | 111 | | | | 000 | 000 | | | Sets interrupt enable flag Flags Affected: I Note: The STI instruction takes effect 1 cycle after it is executed. | CLI | | | | | | | | | | | | | | | | | |------|----|----|----|------|----|----|---|---|-----|---|---|---|-----|-----|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | 1011 | 11 | | | | 111 | | | | 000 | 001 | | | Clears interrupt enable flag Flags Affected: I | STC | | | | | | | | | | | | | | | | | |------|----|----|----|------|----|----|---|---|-----|---|---|---|----|------|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 1 | 1011 | 11 | | | | 111 | | | | 00 | 0010 | | | Set Carry bit. Flags Affected: C | CLC | | | | | | | | | | | | | | | | | |------|---------|----|----|----|----|-----|---|---|---|-----|-----|---|---|---|---|---| | bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 1101111 | | | | | 111 | | | | 000 | 011 | | | | | | Clear Carry bit. Flags Affected: C ## 5.21 Built-in Macros For the programmer's convenience, the SL11R QT assembler implements several built-in macros. The table below shows the macros, and the mnemonics for the code that the assembler will generate for these macros. | Macro | Assembler will Generate | |--------|-------------------------| | INC X | ADDI X, 1 | | DEC X | SUBI X, 1 | | PUSH X | MOV [R15], X | | POP X | MOV X, [R15] | # 5.22 SL11R Processor Instruction Set Summary | | | | Opcode | | Flags | Clock | | |----------|---------|----------------------------------|---------------------|-----|---------|-------|-------| | Mnemonic | Operand | Description | MSb | LSb | Affecte | Cycle | Note | | | S | | | | d | S | S | | MOV | s,d | Move s to d | 0000 ssss ssdd dddd | | None | 5 | 1,3 | | ADD | s,d | Add s to d | 0001 ssss ssdd dddd | | Z,C,O,S | 5 | 1,3 | | ADDC | s,d | Add s to d with carry | 0010 ssss ssdd dddd | | Z,C,O,S | 5 | 1,3 | | SUB | s,d | Subtract s from d | 0011 ssss ssdd dddd | | Z,C,O,S | 5 | 1,3 | | SUBB | s,d | Subtract s from d with carry | 0100 ssss ssdd dddd | | Z,C,O,S | 5 | 1,3 | | CMP | s,d | Compare d with s | 0101 ssss ssdd dddd | | Z,C,O,S | 5 | 1,3 | | AND | s,d | AND d with s | 0110 ssss ssdd dddd | | Z,S | 5 | 1,3 | | TEST | s,d | Bit test d with s | 0111 ssss ssdd dddd | | Z,S | 5 | 1,3 | | OR | s,d | OR d with s | 1000 ssss ssdd dddd | | Z,S | 5 | 1,3 | | XOR | s,d | XOR d with s | 1001 ssss ssdd dddd | | Z,S | 5 | 1,3 | | Jcc | C,V | Jump relative on condition 'c' | 1100 cccc 0000 0000 | | None | 3 | 3 | | JccL | c,d | Jump absolute on condition 'c' | 1100 cccc 10dd dddd | | None | 4 | 3 | | Rcc | С | Return on condition 'c' | 1100 cccc 1001 0111 | | None | 7 | 3 | | Ccc | c,d | Call subroutine on condition 'c' | 1010 cccc 10dd dddd | | None | 7 | 3 | | Int | V | Software interrupt | 1010 0000 0vvv vvvv | | None | 7 | 3 | | SHR | n,d | Shift right out of carry | 1101 000n nndd dddd | | Z,C,S | 4 | 1,2,3 | | SHL | n,d | Shift left into carry | 1101 001n nndd dddd | | Z,C,S | 4 | 1,2,3 | | ROR | n,d | Rotate right | 1101 010n nndd dddd | | Z,C,S | 4 | 1,2,3 | | ROL | n,d | Rotate left | 1101 011n nndd dddd | | Z,C,S | 4 | 1,2,3 | | ADDI | n,d | Add immediate | 1101 100n nndd dddd | | Z,S | 4 | 3 | | SUBI | n,d | Subtract immediate | 1101 101n nndd dddd | | Z,S | 4 | 3 | | NOT | d | 1's complement | 1101 1110 00dd dddd | | Z,S | 4 | 3 | | NEG | d | 2's complement | 1101 1110 01dd dddd | | Z,O,C,S | 4 | 3 | | CBW | d | Sign-extend d(7:0) to d(15:0) | 1101 1110 10dd dddd | | Z,S | 4 | 3 | | STI | | Enable interrupts | 1101 1111 1100 0000 | | None | 3 | 3 | © 1996 - 2000 ScanLogic Corporation. All rights reserved. SL11R is a trademark of ScanLogic Corporation. The information and specifications contained in this document are subject to change without notice. Date: 07/25/00 **Revision: 1.80** #### **ScanLogic Corporation** **SL11R Hardware Specification** Date: 07/25/00 **Page:** 66 Revision: 1.80 | CLI | Disable interrupts | 1101 1111 1100 0001 | None | 3 | 3 | |-----|--------------------|---------------------|------|---|---| | STC | Set carry | 1101 1111 1100 0010 | С | 3 | 3 | | CLC | Clear carry | 1101 1111 1100 0011 | С | 3 | 3 | #### Notes: - 1) The number in the "clock cycles" column reflects the number of clock cycles for register or immediate accesses. For each occurrence of other types of accesses, include the appropriate "clock adder" as listed in the Addressing Modes table below. - 2) A shift of one is done in four clock cycles, each additional shift adds two more clock cycles. - 3) All clock cycle values assume zero wait-states. | Opcode | field descriptions | | | | | | | | Clock | |--------|--------------------|------------------------------|---|---|-----|---|---|---|-------| | Field | Description | Addressing mode | 5 | 4 | 3 | 2 | 1 | 0 | Adder | | S | Source | Register | 0 | 0 | r | r | r | r | 0 | | D | Destination | Immediate | 0 | 1 | 1 | 1 | 1 | 1 | 0 | | С | Condition code | Direct | 1 | 0 | b/w | 1 | 1 | 1 | 1 | | 0 | Signed offset | Indirect | 0 | 1 | b/w | r | r | r | 1 | | V | Interrupt vector | Indirect with Auto Increment | 1 | 0 | b/w | r | r | r | 2 | | N | Count value -1 | Indirect with Index | 1 | 1 | b/w | r | r | r | 3 | b/w: '1' = byte access, '0' = word access. Indirect with auto-increment and byte-wide indirect addressing is illegal with R15. # 6. SL11R - ELECTRICAL SPECIFICATION # 6.1 Absolute Maximum Ratings This section lists the absolute maximum ratings of the SL11R. Stresses above those listed can cause permanent damage to the device. Exposure to maximum rated conditions for extended periods can affect device operation and reliability. | Storage Temperature | -40°C to 125°C | |-------------------------------------------|----------------| | Voltage on any pin with respect to ground | -0.3v to 7.3V | | Power Supply Voltage (VDD) | 3.3V±10% | | Power Supply Voltage (VDD1) | 3.3V±10% | | Lead Temperature (10 seconds) | 180°C | ## **6.2 Recommended Operating Conditions** | Parameter | Min. | Typical | Max | |----------------------------|-------|---------|-------| | Power Supply Voltage, VDD | 3.0 V | 3.3v | 3.6 V | | Power Supply Voltage, VDD1 | 3.0 V | | 3.6 V | | Operating Temperature | 0°C | | 65°C | ## 6.3 Crystal Requirements (XTAL1, XTAL2) | Crystal Requirements,<br>(XTAL1, XTAL2) | Min. | Typical | Max | |--------------------------------------------|-------------|---------|------------| | Operating Temperature Range | 0°C | | 65°C | | Series Resonant Frequency | | 48 MHz | | | Frequency Drift over Temperature | | | +/- 20 PPM | | Accuracy of Adjustment | | | +/- 30 PPM | | Series Resistance | | | 100 ohms | | Shunt Capacitance | 3pf | | 6pf | | Load Capacitance | | 20pF | | | Driver Level | 20microWatt | | 5miliWatt | | Mode of Vibration 3 <sup>rd</sup> overtone | | | | # 6.4 External Clock Input Characteristics (XTAL1) | Parameter | Min. | Typical | Max | |-----------------------------------------------|-------|---------|-----| | Clock Input Voltage @ XTAL1 (XTAL2 is Opened) | 1.5 V | | | | Clock Frequency | | 48MHz | | Date: 07/25/00 **Revision: 1.80** Date: 07/25/00 **Revision: 1.80** Page: 68 #### 6.5 SL11R DC Characteristics | Symbol | Parameter | Min. | Typical | Max | |----------------------------|----------------------------------|--------|---------|-----------| | IL | Input Voltage LOW | -0.5 V | | 0.8 V | | VIH | Input Voltage HIGH | 2.0V | | VDD+ 0.3V | | V <sub>OL</sub> | Output Voltage<br>LOW(loL=4ma) | | | 0.4 V | | VOH | Output Voltage<br>HIGH(IoH=-4ma) | 2.4 V | | | | lOH | Output Current HIGH | 4 ma | | | | l <sub>OL</sub> | Output Current LOW | 4 ma | | | | C <sub>IN</sub> | Input Capacitance | | | 20 pf | | ICC | Supply Current (VDD) | | | < 30mA | | l <sub>USB</sub> | Supply Current (VDD1) | | | < 10mA | | I <sub>CC</sub> +USB Susp. | Suspend Supply Current | | | < 220 uA | #### 6.6 SL11R USB Transceiver Characteristics | Symbol | Parameter | Min. | Typical | Max | |--------------------|---------------------------------------|---------|---------|---------| | VIHYS | Hysteresis On Input<br>(Data+, Data-) | 0.1 V | | 200 mV | | VUSBIH | USB Input Voltage<br>HIGH | | 1.5 V | 2.0 V | | VUSBIL | USB Input Voltage<br>LOW | 0.8 V | 1.3 V | _ | | VUSBOH | USB Output Voltage<br>HIGH | 2.2 V | | _ | | V <sub>USBOL</sub> | USB Output Voltage<br>LOW | | | 0.7 V | | Z <sub>USBH</sub> | Output Impedance<br>HIGH STATE | 28 Ohms | | 42 Ohms | | Z <sub>USBL</sub> | Output Impedance<br>LOW STATE | 28 Ohms | | 42 Ohms | #### Notes: - All typical values are VDDx = 3.3 V and TAMB= 25°C. - Zusbx Impedance Values includes an external resistor of 28-42 Ohms ± 1% Date: 07/25/00 **Revision: 1.80** Page: 69 #### 6.7 SL11R RESET TIMING **SL11R RESET TIMING** | Symbol | Parameter | Min. | Typical | Max | |--------|-----------------------------------|-----------|---------|-----| | treset | nRESET Pulse width | 16 clocks | | | | tioact | nRESET high to nRD or nWRx active | 16 clocks | | | Note: Clock is 48 MHz nominal. # 6.8 SL11R Clock Timing Specifications **SL11R CLOCK TIMING** | Parameter | Min. | Typical | Max | |----------------------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------| | Clock period (48MHz) | 20.0 nsec | 20.8 nsec | | | Clock high time | 9 nsec | | 11 nsec | | Clock low time | 9 nsec | | 11 nsec | | Clock rise time | | | 5.0 nsec | | Clock fall time | | | 5.0 nsec | | Duty Cycle | -5% | | +5% | | | Clock period (48MHz) Clock high time Clock low time Clock rise time Clock fall time | Clock period (48MHz) 20.0 nsec Clock high time 9 nsec Clock low time 9 nsec Clock rise time Clock fall time | Clock period (48MHz) 20.0 nsec 20.8 nsec Clock high time 9 nsec Clock low time 9 nsec Clock rise time Clock fall time | Page: 70 Revision: 1.80 # 6.9 8/16-bit DMA & DVC 8-bit DMA Mode: SDATA Port I/O Read Cycle (Non-DMA) | Symbol | Parameter | Min | Typical | Max | |------------------|------------------------|-------|---------|-------| | t <sub>APW</sub> | ADDR pulse width | 30 ns | | | | t <sub>CPW</sub> | nCS pulse width | 30 ns | | | | t <sub>RPW</sub> | Read pulse width | 30 ns | | | | t <sub>ACC</sub> | Read access time | | | 25 ns | | t <sub>RDH</sub> | Read high to data hold | | | 10 ns | Note: RCLK is the resulting Clock (see Register 0xC006) Page: 71 Revision: 1.80 # 6.10 8/16-bit DMA & DVC 8-bit DMA Mode: SDATA Port I/O Write Cycle (Non-DMA) Note: RCLK is the resulting Clock (see Register 0xC006) | Symbol | Parameter | Min | Typical | Max | |-------------------|--------------------------------|-------|---------|-----| | t <sub>APW</sub> | ADDR pulse width | 20 ns | | | | t <sub>CWS</sub> | nCS low to write high setup | 10 ns | | | | t <sub>WCH</sub> | Write high to CS high hold | 5 ns | | | | t <sub>WRPW</sub> | Write pulse width | 10 ns | | | | t <sub>DWS</sub> | Data setup to write high setup | 10 ns | | | | t <sub>WDH</sub> | Write high to data hold | 5 ns | | | # 6.11 8/16-bit DMA & DVC 8-bit DMA Mode: SDATA, DMA Read Cycle | Symbol | Parameter | Min | Typical | Max | |--------|----------------------------|------|---------|-------| | τDCS | DREQ high to CS low | 5 ns | | | | τDR | DREQ high to read low | 5 ns | | | | τRDH | Read high to DREQ low hold | | | 30 ns | # 6.12 8/16-bit DMA & DVC 8-bit DMA Mode: SDATA, DMA Write Cycle | Symbol | Parameter | Min | Typical | Max | |--------|-----------------------------|-----|---------|------| | τDCS | DREQ high to CS low | 5ns | | | | τDWDH | Write high to DREQ low hold | | | 30ns | | τDW | DREQ high to write low | 5ns | | | Date: 07/25/00 **Revision: 1.80** Page: 73 Revision: 1.80 #### 6.13 SL11R Signals Name convention | Doc. Signal Name | SL11R Pin Name | Doc. Signal Name | SL11R Pin Name | |------------------|----------------|------------------|----------------| | /RAS | nRAS | /WE (DRAM) | nDRAMWR | | /UCAS | nCASH | /LCAS | nCASL | | Dout | Data15-0 | /OE | nDRAMOE | | Din | Data15-0 | Address | A20-0 | | /CS | nXRAMSEL | /RD | nRD | | /WE (SRAM) | nWRL & nWRH | | | ## 6.14 SL11R DRAM Timing This timing is based on the SL11R Processor Clock (PCLK) = (2/3) of RCLK = 32MHz (see the register 0xC006 for information about PCLK). | Symbol | Parameter | Min | Typical | Max | |------------------|-------------------------------------|-------|---------|------| | t <sub>RAS</sub> | /RAS pulse width | 80ns | | | | t <sub>CAS</sub> | /CAS pulse width | 20ns | | | | t <sub>RP</sub> | /RAS precharge time | 60ns | | | | $t_{RCD}$ | /RAS to /CAS delay time | 64ns | | | | t <sub>ASR</sub> | Row address setup time | 20ns | | | | t <sub>RAH</sub> | Row address hold time | 36ns | | | | t <sub>ASC</sub> | Column address setup time | 20ns | | | | t <sub>CAH</sub> | Column address hold time | 36ns | | | | t <sub>WCS</sub> | Write command setup time | 25ns | | | | t <sub>DS</sub> | Data setup time | 05ns | | | | t <sub>DH</sub> | Data hold time | 40ns | | | | t <sub>CRP</sub> | Delay time, /CAS pre-charge to /RAS | 05ns | | | | t <sub>T</sub> | Transition time (rise and fall) | 03ns | | | | t <sub>RPC</sub> | /RAS precharge to /CAS hold time | 00ns | | | | t <sub>CSR</sub> | /CAS setup time | 05ns | | | | t <sub>CPN</sub> | /CAS precharge time | 10ns | | | | t <sub>CHR</sub> | /CAS hold time | 60ns | | | | t <sub>CAC</sub> | Access time from /CAS | | | 20ns | | t <sub>RAC</sub> | Access time from /RAS | 80ns | | | | t <sub>OAC</sub> | Access time from /OE | 20ns | | | | t <sub>RC</sub> | Cycle time read | 150ns | | | | t <sub>OFF</sub> | Data out to High Z | 05ns | | | **Note**: This timing is base on EDO DRAM timing 16Mx16 devices. When the SL11R processor is set up for a higher speed (i.e. 48MHz clock), then the faster parts (i.e. 50ns or 60ns) should be used. Date: 07/25/00 **Revision: 1.80** Page: 74 # 6.15 SL11R DRAM Read Cycle Date: 07/25/00 **Revision: 1.80** Page: 75 # 6.16 SL11R DRAM Write Cycle # 6.17 SL11R CAS-Before-RAS Refresh Cycle Date: 07/25/00 **Revision: 1.80** Page: 77 Revision: 1.80 # 6.18 SL11R DRAM Page Mode Read Cycle Date: 07/25/00 **Revision: 1.80** Page: 78 # 6.19 DRAM Page Mode Write Cycle Page: 79 Revision: 1.80 # 6.20 SL11R SRAM Read Cycle | Symbol | Parameter | Min | Typical | Max | |--------------------|--------------------------|-------|---------|-------| | t <sub>CR</sub> | CS low to RD low | 1 ns | | | | t <sub>RDH</sub> | RD high to data hold | 5 ns | | | | t <sub>CDH</sub> | CS high to data hold | 3 ns | | | | t <sub>RPW</sub> * | RD low time | 28 ns | | 31 ns | | t <sub>AR</sub> | RD low to address valid | 1 ns | | 3 ns | | t <sub>AC</sub> ** | Ram access to data valid | | | 12 ns | <sup>\* 0</sup> wait state cycle. <sup>\*\*</sup> $t_{AC}$ means at 0 wait states, with PCLK = 2/3 RCLK, the SRAM access time should be 12ns max. For a 1 wait state cycle, with PCLK = 2/3 RCLK, the SRAM access time should be at 12 + 31ns = 43ns max. See register 0xC006 description for PCLK information. # 6.21 SL11R SRAM Write Cycle | Symbol | Parameter | Min | Typical | Max | |--------------------|-------------------------------|------|---------|-----| | t <sub>AW</sub> | Write address valid to WE low | 13ns | | | | t <sub>CSW</sub> | CS low to WE low | 13ns | | | | $t_{DW}$ | Data valid to WE high | 25ns | | | | t <sub>WPW</sub> * | WE pulse width | 28ns | | | | t <sub>DH</sub> | Data hold from WE high | 5ns | | | | t <sub>WC</sub> | WE high to CS high | 15ns | | | <sup>\*</sup> This is at 1 wait state with PCLK = 2/3 RCLK. For 2-wait states, add 31ns. Date: 07/25/00 **Revision: 1.80** # 6.22 2-wire serial interface EEPROM timing #### 1-EEPROM Bus Timing- Serial I/O #### 2-Start and Stop Definition 3- Data Validity Date: 07/25/00 Page: 81 Revision: 1.80 Note: Timing will conform to standard as illustrated in ATMEL AT24COX data sheet | Parameter | Min/Max Timing | Notes | |--------------------|----------------|--------------------------| | T <sub>low</sub> | 4.7 μs min | See ATMEL Data Sheet for | | T <sub>high</sub> | 4.0 μs min | Complete Timing Detail | | T <sub>r</sub> | 1.0 μs max | | | T <sub>su1</sub> | 200ns max | | | T <sub>hold1</sub> | 0ns | | | T <sub>su2</sub> | 4.5 μs min | | | T <sub>hold2</sub> | 100ns max | | # 6.23 Fast EPP Data/Address Read Cycle | Symbol | Parameter | Min | Typical | Max | |--------|------------------------------------|-----|---------|------| | τRPW | nDTSRB or nASTRB pulse width | | 50ns | | | τRDS | Data setup before nDTSRB or nASTRB | 5ns | | | | | high | | | | | τRDH | nDTSRB or nASTRB high to data hold | | | 30ns | # 6.24 Fast EPP Data/Address Write Cycle | Symbol | Parameter | Min | Typical | Max | |--------|--------------------------------------|-----|---------|------| | τWPW | nWRITE pulse width | | 85ns | | | τRPW | nDTSRB or nASTRB pulse width | | 50ns | | | τWDA | nWRITE low to nDTSRB or nASTRB low | | 10ns | | | τDAW | nDTSRB or nASTRB high to nWRITE high | | 25ns | | | τWDH | nDTSRB or nASTRB high to data hold | | | 30ns | Date: 07/25/00 **Revision: 1.80**