# NJ1030A



Rev. 1.3 - April 2005

## **GPS Baseband Processor**

#### Datasheet

## **1** General Description

The NemeriX NJ1030A is a GPS baseband processor targeting C/A code L1 GPS low power applications and offering WAAS/EGNOS support. It is based on the NemeriX NP1016 GPS correlation core combined with a 32-bit IEEE1754 (Sparc V8) compatible CPU core, auxiliary on-chip memory, peripherals and analog blocks. Flexible configuration of system performance and memory architecture allow the NJ1030A to be used as an ultra low power GPS receiver delivering formatted navigation information (NMEA protocol with NemeriX extensions) or as a flexible GPS enabled microcontroller.

(Pb)

The GPS correlation is carried out by the NemeriX NP1016 correlator core optimized for high efficiency, low power correlation. While supporting any GPS RF front-end device with 1 bit or 2 bit output, the NJ1030A is optimized to work with the NemeriX NJ1006/A RF front ends. In particular the specific power management modes of the NJ1006/A are directly controlled. Flexible clocking schemes are implemented, making use of internal or external clock sources.

The CPU is a 32-bit RISC IEEE1754 (SPARC V8) compatible core with 32KB scratchpad RAM, 8KB instruction cache and 1KB data cache. An on chip SRAM block of 32KB is availble. A dedicated, battery backed-up, 8KB SRAM block for the storage of navigation information and a real time clock can be used to accelerate Time To First Fix (TTFF).

External memory and I/O space is accessed via a 32-bit external bus interface (EBI), which supports up to 4 banks of SRAM or Flash memory of 16MB each. One UART plus

optionally a master or slave SPI interface, a second UART or a general-purpose interface (GPIO) are available.

An 8 bit ,8 channels analog to digital converter is available. One of the inputs is connected to an on-chip temperature sensor that can be used to compensate the frequency drift of the local oscillator. The other seven external analog inputs can be used to integrate other sensors (such as a compass) for enhanced navigation applications.

#### 1.1 Features

- Single-chip, standalone GPS baseband processor
- Ultra low power: < 25 mW in fully active operation
- 16 low power correlation modules
- WAAS/EGNOS support
- 32-bit, royalty free, processor (Sparc V8 compatible)
- 32 KB of SRAM
- 32KB of scratch pad RAM
- 8 KB battery backed up SRAM and real time clock
- UART and a selectable UART/SPI/GPIO interface
- 32/16 or 8 bit external bus interface (EBI)
- 2-bit sign and magnitude GPS IF signal input
- 8 bit ADC: temperature sensor and 7 analog inputs
- BGA128 7x7mm and BGA128 10x10mm package
- Lead free, RoHS compliant packaging

## 1.2 Applications

- Standalone, battery-powered GPS receivers
- Tracking devices
- PDAs, Portable Media Players (PMP), digital cameras
- Cordless (Bluetooth<sup>™</sup>), remote GPS receivers
- Automotive navigation systems



© 2005 NemeriX SA. All right reserved. All trademarks and registered trademarks are property of their respective owners. The information in this datasheet is of subject to change in any manner at any time without notice. NemeriX SA assumes no responsibility for this product's use, nor for any infringement of patents or other rights from third parties which may result from its use. No license is implied under any patent or patent right by NemeriX SA. NemeriX SA, CH-6928 Manno, Switzerland. http://www.nemerix.com

NJ1030A-ds - Rev. 1.3

## Figure 1 – NJ1030A-based GPS receiver

## 2 Table of content

| 1  | General Description        | 1    |
|----|----------------------------|------|
| 2  | Table of content           | 2    |
| 3  | Absolute Maximum Ratings   | 3    |
| 4  | GPS Performance            | 4    |
| 5  | Architectural Overview     | 5    |
| 6  | Pinout Table               | 7    |
| 7  | CPU                        | . 10 |
| 8  | Clocking                   | . 12 |
| 9  | System Control Block       | . 14 |
| 10 | Interrupt Controller       | . 16 |
| 11 | Timers and Watchdog        | . 18 |
| 12 | Real Time Clock (RTC)      | . 20 |
| 13 | GPS Correlation Processor  | . 22 |
| 14 | External Memory Support    | . 25 |
| 15 | UARTs                      | . 29 |
| 16 | GPIO                       | . 31 |
| 17 | SPI Master Interface       | . 33 |
| 18 | SPI Slave                  | . 35 |
| 19 | DSU Port                   | . 37 |
| 20 | ADC                        | . 40 |
| 21 | Power Supplies             | . 41 |
| 22 | Reset Sequence             | . 41 |
| 23 | Operating Modes            | . 42 |
| 24 | Analog Signal Connection   | . 43 |
| 25 | Timings                    | . 46 |
| 26 | PCB Layout Recommendations | . 47 |
| 27 | Mounting Recommendations   | . 48 |
| 28 | Physical Dimensions        | . 49 |
|    |                            |      |

#### Absolute Maximum Ratings 3

| Max. Supply Voltage (LVDD,VBAT)             | 2.2V    |
|---------------------------------------------|---------|
| Max. Supply Voltage (all other)             | 4.0V    |
| Max. voltage on any pin0.3V to corresp. xVI | DD+0.3V |
| Max. current into any pin (except xVDD)     | ±20mA   |
| Max. current into any pin xVDD              | ±50mA   |
| EDS RatingHBM 1.5kV, CB                     | SM 250V |

| Continuous Power Dissipation       | 400mW        |
|------------------------------------|--------------|
| Operating temperature              | 40 to +85°C  |
| Junction temperature               | 125°C        |
| Storage temperature                | 65 to +150°C |
| Lead temperature (Soldering, <40s) | 260°C        |

5

ns

Absolute maximum ratings are short term stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated in the recommended operating conditions is not implied. Stresses beyond those listed under absolute maximum ratings may cause permanent damage to the device. Exposure to absolute maximum ratings conditions for extended periods may affect device reliability

ESD sensitive device: use proper precautions when handling this device.

#### **DC Electrical Characteristics**

1.6V ≤ DVDD ≤ 3.6V, 1.6V ≤ DAVDD ≤ 3.6V, 1.6V ≤ DVSU ≤ 3.6V, 1.6V ≤ TVDD ≤ 3.6V, 1.2V ≤ LVDD ≤ 1.8V, VBAT ≤ 2V, T<sub>amb</sub> = -40° to +85°C, load = 10 pF, crystal oscillator active, f<sub>sys\_clk</sub>=16.367 MHz. All voltages referred to xGND. Typical values are at xVDD = 2.5V and  $T_{amb}$ =+25°C

| Parameter                      | Conditions/description    | Min      | Тур  | Max      | Unit | Notes |
|--------------------------------|---------------------------|----------|------|----------|------|-------|
| Power Supply                   |                           |          |      |          |      |       |
| DAVDD, TVDD, DVDD              | Padring Supply Voltage    | 1.6      |      | 3.6      | V    |       |
| LVDD                           | Core Power Supply         | 1.2      |      | 2        | V    | 1     |
| DVSU                           | Power Up Unit Supply      | 1.6      |      | 3.6      | V    |       |
| VBAT                           | Battery Power Supply      | 1.1      | 1.5  | 2.0      | V    | 2     |
| I_LVDD                         | Average current with:     | 6        | 12   | 14       | mA   | 3     |
| I_DVDD                         | On-chip LVDD = 1.25V      |          |      | 3        | mA   | 3     |
| I_TVDD                         | Other xVDD = 1.8V         |          |      | 0.5      | mA   | 3     |
| I_DAVDD                        | Chip Fully Active         |          |      | 0.5      | mA   | 3     |
| I_VBAT                         | In Sleep Mode             |          | 4    |          | μA   |       |
| Power Supervisor               |                           | <u>.</u> |      |          |      |       |
| VREF                           | Voltage reference         | 1.22     | 1.24 | 1.26     | V    |       |
| VSI                            | Voltage Superv. Threshold |          | VREF |          | V    |       |
| I_HYST                         | Hysteresis Current        | 1.1      | 1.6  | 2.1      | μA   | 4     |
| Battery OK Flag Threshold      | VBAT Rising               |          | 1.15 |          | V    |       |
|                                | VBAT Falling              |          | 1.10 |          | V    |       |
| AC Electrical Characteristics  |                           |          |      |          |      |       |
| Sys Clock Frequency            | LVDD = 1.8V               | 0        |      | 98.2     | MHz  |       |
|                                | LVDD = 1.2V external      | 0        |      | 32.4     | MHz  |       |
|                                | LVDD = 1.2V on chip       | 0        |      | 16.3     | MHz  |       |
| Sys Clock Crystal Drive Level  |                           |          | 10   |          | μW   |       |
| RTC Clock Crystal Drive Level  |                           |          | 100  |          | nW   |       |
| Clock Input Level Clipped Sine |                           | 100      |      |          | mV   | 5     |
| Digital Interfaces             |                           |          |      |          |      |       |
| VIH                            |                           | 0.7 DVDD |      |          | V    |       |
| VIL                            |                           |          |      | 0.3      | V    |       |
| VOH                            | loh = -50 μA              | 0.9 DVDD |      |          | V    |       |
| VOL                            | lol = 50 μÅ               |          |      | 0.1 DVDD | V    |       |
| Output Rise Time               | Cload = 15 pF             |          |      | 5        | ns   |       |

Output Rise Time Cload = 15 pF Cload = 15 pF Output Fall Time

Note 1: Core (LVDD) may be supplied by the internal voltage regulator.

Note 2: Guarantees NVRAM data retention and RTC operation.

**Note 3:** CPU executing GPS positioning, driving a NJ1006 RF front end with a 16.367 MHz clock **Note 4:** Hysteresis current is turned on when VSI>VREF (See section 22.2).

Note 5: X<sub>osc</sub> used also as TCXO buffer.

## 4 GPS Performance

All performance data refer to a NJ1030A used with a NJ1006/A RF front end and the antenna used in the

DK1030 GPS development kit and running version 3.x of the NS1030 GPS software.

| Item                             |                                            | Values               |              | Conditions/Notes                                                          |  |
|----------------------------------|--------------------------------------------|----------------------|--------------|---------------------------------------------------------------------------|--|
|                                  |                                            | Average              |              |                                                                           |  |
| Initial<br>Acquisition           | Cold Start                                 | 46 s                 |              | Open-sky, 24 hrs statistic, active antenna (signal range is               |  |
| Time [s]                         | Warm Start                                 | 34 s                 |              | between 30 to 49 dB/Hz).                                                  |  |
|                                  | Hot Start                                  | 5 s                  |              |                                                                           |  |
| Fix Time After<br>Obscuration[s] | Obscuration Time 1s to 100 s               | < 3 s                |              | Maximum Sensitivity -147 dBm                                              |  |
| Acquisition<br>Sensitivity (fix  | TTFF [Hot] with all signals at –138 dBm    | 30 s                 |              | Simulator Test, all signals at specified power level.                     |  |
| not available)<br>[dBm]          | TTFF [Hot] with all<br>signals at –141 dBm | 41 s                 |              |                                                                           |  |
| Acquisition Sensi                | tivity (fix available) [dBm]               | –147 dBm             |              | Estimated.                                                                |  |
| Tracking Sensitiv                | ity [dBm]                                  | Better than –150 dBm |              | Simulator Test, continuous fix with all signals at specified power level. |  |
|                                  | Static CEP 50                              | 1.2 m                | 0.8 m (WAAS) |                                                                           |  |
| Static Accuracy                  | Static CEP 95                              | 3.0 m                | 2.0 m (WAAS) | Open-sky, 24 hrs statistic,<br>active antenna (signal range is            |  |
|                                  | Static Altitude 50                         | 1.3 m                | 0.8 m (WAAS) | between 30 to 49 dB/Hz).                                                  |  |
|                                  | Static Altitude 95                         | 3.8 m                | 3.0 m (WAAS) |                                                                           |  |
| Maximum Speed                    | [m/s]                                      | 515 m/s              |              |                                                                           |  |
| Maximum Accele                   | ration [g]                                 | 2 g                  |              |                                                                           |  |
| Maximum Altitude                 | e [m]                                      | 18000                |              |                                                                           |  |

## 5 Architectural Overview

## Figure 2. NJ1030A Block diagram



This chapter briefly describes the main building blocks of the NJ1030A. A more detailed description of all blocks and their sub-blocks can be found in the following chapters.

## 5.1 CPU

The NJ1030A CPU is a royalty free, 32bit RISC processor conforming to the IEEE\_1754 (SPARC V8) architecture. It is designed for embedded applications and provides the following features:

- 5 stages pipelined architecture
- single cycle 32 bit hardware multiplier
- barrel shifter
- radix 2 hardware divider
- 8 windows register file
- 8 kBytes instruction cache, 1 kBytes data cache
- 32 KBytes scratch pad memory
- AMBA AHB and APB compatible interface
- Debug port (DSU)

The scratch pad RAM is a block of 32kB memory dedicated to data, that is directly connected to the CPU core at the same level as the D-Cache. As a consequence it has the quickest poosible access time. At firwmare build time, critical data structures can be assigned to the scratch pad RAM area.

#### 5.2 On Chip SRAM

A block of 32kBytes 0-wait states SRAM is available on chip, on the fast AHB bus. This allows critical code portions

as well as data structures to be stored. The on-chip SRAM content is cachable (both instructions and data). This memory supports 8,16 and 32 bit access mode.

#### 5.3 Battery Backed up Memory

In order for the software to store recent GPS almanac data at boot time, the NJ1030A has a block of 8 kBytes of battery backed-up and write protected SRAM (NVRAM). The power supply of this memory block is monitored by the integrated power supervisor. This memory area can also be used to store relevant system status information before entering power management modes that involve the removal of the power supply. Only 32 bit access is supported.

## 5.4 External Bus Interface (EBI)

The EBI directly supports up to 4 banks of 16 MBytes of asynchronous memory, with a fifth bank optionally accessible through signals of the GPIO interface. Each bank can individually be set to implement an 8, 16 or 32 bit access mode with a selectable number of wait states.

When 16 or 32 bit memory components are used in the sytem, the NJ1030A memory interface allows access to individual bytes by means of byte enable signals, typically provided by state of the art 16 or 32 bit SRAMs.

## 5.5 Clocking

The main system clock can be generated by an on chip oscillator, by a TCXO or be an external digital clock. This is the clock used for all the NJ1030A functions, excluding the GPS correlation that has a dedicated clock derived internally from the system clock (with a division factor from 1 to 8). This allows for flexible frequency plans to be implemented, with the possibility to trade off between the computational requirements of the application, the GPS frequency plan and the power consumption requirements.

## 5.6 GPS Correlation Unit

The GPS correlation function is carried out by the correlation unit which is a 16 tracking modules (64 correlators) implementation of the NemeriX NP1016 GPS correlator IP core. The NP1016 is connected to the CPU as an AMBA APB peripheral. Two GPS interrupt signal (ACC\_INT and MEAS\_INT) are connected to the CPU interrupt controller. The correlation block is clocked by a dedicated clock (NP1016\_GPS\_CLK) signal derived from the main SYS\_CLK, which can be deactivated when the GPS functionality is not needed by the system.

The correlation unit provides:

- 16 C/A-code acquisition and tracking modules (TMx)
- WAAS/EGNOS support
- 2-bit sign and magnitude signal input
- Programmable interrupt interval and measurement rate
- Individual tracking-module activation
- Power management modes
- Direct control of the NJ1006/A RF front end power management features
- Fast acquisition mode (FAM)

## 5.7 Other Peripherals

- UARTs : two serial interfaces are available. UART1 is always available on dedicated pins, while a second UART2 shares the pins of the GPIO interface. UART1 has a 16 bytes receive and send FIFO, while UART 2 has a 4 bytes send and receive FIFO. The UART1 lines can also be configured to act as DSU UART lines, allowing for flash re-programming reusing the buffer and connectors of UART1, without the need to access the dedicated DSU pins.
- **SPI**: both master and slave SPI interface alternatively are supported, by sharing the same pins of the GPIO interface. The SPI master supports up to 2 slaves. The slave has a send and receive buffer of 16 bytes.
- **Timers**: two 24-bit timers are provided on-chip. The timers can work in periodic or one-shot mode. Both timers are clocked by a common 10-bit prescaler.
- Watchdog: a 24-bit watchdog is provided on-chip. The watchdog is clocked by the timer prescaler. When the watchdog reaches zero, an output signal (WDOG) is asserted. If enabled, this signal can be used to generate system reset.
- Interrupt controller : it manages a total of 15 interrupts, originating from internal and external sources. Each interrupt can be programmed with a two levels priority. Internal and external interrupt sources are used.
- Analog to Digital Converter (ADC): an 8 bit resolution 8 channels ADC is available with 7 analog inputs directly

connected to the pads and one input connected to an on chip temperature sensor.

• **RTC**: a pseudo real time clock block with 1 second precision, 30 bits wide register is implemented. It also offers a wake up functionality that can be used to recover the system from power down modes. The RTC has an on chip oscillator that uses a 32 kHz quartz.

## 5.8 GPIO Interface

An 8 bit general purpose I/O interface allows for parallel I/O. This interface can be reconfigured in order to share some lines with other peripherals.

## 5.9 GPS IF Interface

This dedicated interface consist of 2 bits input (sign and magnitude), two power mode control signals for the NJ1006/A RF front ends, the GPS clock and an antenna ok input signal. The GPS IF interface also has a dedicated power supply (TVDD).

## 5.10 Power Supplies

Different power supplies for pad ring and core can be used, with the possibility to generate the core power supply by an on chip voltage regulator. The core voltage can be adjusted between 1.2V and 1.8V, depending on the clock frequency being used. The on chip voltage regulator can also be disabled if an external power supply is available in the system.

The digital pad ring power supply can be between 1.8V and 3.3V (DVDD), with the possibility also to use an independent level for the IF interface (TVDD). In power down mode a third digital power supply is used to maintain a tiny portion of the logic ready to wake up the NJ1030A and the attached components (DVSU).

For the battery backed up memory and the RTC a dedicated power supply is used. The power supervisor can be programmed to monitor the used core or padring power supply. In case of faillure of the monitored power supply, the power supervisor will switch the power supply source to battery for the RTC and battery backed up memory as soon as the programmed threshold is reached.

## 5.11 Power Down Modes

Beside fully active operation, where individual peripherals are clocked only depending on their activity, the NJ1030A supports clock-on-demand and SLEEP modes.

The SLEEP mode is entered by the CPU when a period of complete system inactivity can be expected. At this point the CPU can turn off the core power supply as well as other external components. Only a tiny portion of logic is kept powered and will reboot the system at the occurrence of a RTC wake up or an external wake up or reset.

The clock on demand option can be enabled individually for some of the clock sub-domains of the NJ1030A. When clock on demand is enabled, each block controls the gating of its own clock. One of the typical use of the clock on demand mode is for the CPU to stop it own clock, when no further processing is needed. When an interrupts from a peripheral occurs, then the CPU clock is switch on again, the interrupt is serviced and processing is resumed.

## 6 NJ1030 A Pinout

## **Pinout Table**

| Pin Nb | Ball Nb | Signal                      | Туре           | Description                                          | LVDD=0 status    |
|--------|---------|-----------------------------|----------------|------------------------------------------------------|------------------|
| 1      | C4      | DATA[4]                     | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 2      | C3      | DATA[5]                     | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 3      | C2      | DATA[6]                     | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 4      | C1      | DATA[7]                     | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 5      | D4      | DATA[8]                     | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 6      | D3      | DATA[9]                     | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 7      | D2      | DATA[10]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 8      | D1      | DATA[11]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 9      | E4      | DATA[12]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 10     | E3      | DATA[13]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 11     | E2      | DATA[14]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 12     | E1      | DATA[15]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 13     | F2      | DATA[16]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 14     | F3      | DATA[17]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 15     | F1      | LVDD                        | Digital power  | Core power supply                                    |                  |
| 16     | F4      | LVSS                        | Digital ground | Ground                                               |                  |
| 17     | G1      | DATA[18]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 18     | G2      | DATA[19]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 19     | G3      | DATA[20]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 20     | H1      | DATA[21]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 21     | G4      | DVDD                        | Digital power  | Power supply for padring and voltage reg.            |                  |
| 22     | H4      | DAVSS                       | Digital gnd    | Ground                                               |                  |
| 23     | H3      | DATA[22]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 24     | H2      | DATA[23]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 25     | J1      | DATA[24]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 26     | J2      | DATA[25]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 27     | J3      | DATA[26]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 28     | J4      | DATA[27]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 29     | K1      | DATA[28]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 30     | K2      | DATA[29]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 31     | K3      | DATA[30]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 32     | K4      | DATA[31]                    | Digital IO     | EBI Data Bus                                         | Z + keeper       |
| 33     | L1      | DIR                         | Digital Out    | EBI Data Bus direction                               | 0                |
| 34     | M1      | OEN                         | Digital Out    | EBI Output Enable                                    | 1                |
| 35     | M2      | IOSN                        | Digital Out    | EBI I/O Space chip select                            | 1                |
| 36     | L2      | WRITEN                      | Digital Out    | EBI I/O Space Write Enable                           | 1                |
| 37     | L3      | RWEN[0]/BEN[0] <sup>4</sup> | Digital Out    | EBI RAM Write Strobe / Byte enable                   | 1                |
| 38     | M3      | RWEN[1]/BEN[1] <sup>4</sup> | Digital Out    | EBI RAM Write Strobe / Byte enable                   | 1                |
| 39     | L4      | RWEN[2]/BEN[2] <sup>4</sup> | Digital Out    | EBI RAM Write Strobe / Byte enable                   | 1                |
| 40     | M4      | RWEN[3]/BEN[3] <sup>4</sup> | Digital Out    | EBI RAM Write Strobe / Byte enable                   | 1                |
| 41     | J5      | CSN4                        | Digital Out    | EBI RAM4 Chip Select                                 | 1                |
| 42     | K5      | CSN0                        | Digital Out    | EBI RAM0 Chip Select (Boot)                          | 1                |
| 43     | L5      | CSN1                        | Digital Out    | EBI RAM1 Chip Select                                 | 1                |
| 44     | M5      | CSN2                        | Digital Out    | EBI RAM2 Chip Select                                 | 1                |
| 45     | J6      | CLK_SOURCE <sup>1</sup>     | Digital In     | Clock source type selector                           |                  |
| 46     | K6      | EXT_WAKE_UP1                | Digital In     | External Wake Up Signal                              |                  |
| 47     | L6      | EXT_RESETN <sup>1</sup>     | Digital In     | Active Low Asynchronous Reset                        |                  |
| 48     | M6      | EXT_EN <sup>1</sup>         | Digital Out    | Enable for ext components                            | LVDD independent |
| 49     | L7      | EXT_VREGN <sup>1</sup>      | Digital In     | Internal (1)/External (0) voltage regulator selector |                  |
| 50     | K7      | DVSU                        | Digital power  | Independent power supply for Power-up unit           |                  |
| 51     | M7      | TVDD                        | Digital power  | RF interface power supply                            |                  |
| 52     | J7      | TVSS                        | Digital ground | RF interface ground                                  |                  |
| 53     | M8      | GPS_REF_CLK <sup>2</sup>    | Digital Out    | GPS reference clock output 1                         |                  |
| 54     | J8      | ANTENNA_OK <sup>2</sup>     | Digital In     | Antenna status indicator                             |                  |
| 55     | L8      | MAG <sup>2</sup>            | Digital In     | GPS IF input signal (magnitude)                      | 1                |

| 56       | K8       | SGN <sup>2</sup>              | Digital In     | GPS IF input signal (sign)                |            |
|----------|----------|-------------------------------|----------------|-------------------------------------------|------------|
| 57       | K9       | FE_P0 <sup>2</sup>            | Digital Out    | Power control signal to RF                | 0          |
| 58       | J9       | FE_P1 <sup>2</sup>            | Digital Out    | Power control signal to RF                | 0          |
| 59       | L9       | VSI <sup>3</sup>              | Analog In      | Power supervisor analog input             | 0          |
| 60       | M9       | DAVDD                         | Analog power   | Analog power supply                       |            |
| 61       | L10      | AVSS                          | Analog gnd     | Analog ground                             |            |
| 62       | M10      | VREF <sup>3</sup>             | Analog Out     | Voltage reference                         |            |
| 63       | M10      | MXI <sup>3</sup>              | Analog/Dig. In | Digital Clock input or Crystal            |            |
| 64       | M12      | MXO <sup>3</sup>              | Analog Out     | TCXO input or Crystal                     |            |
| 65       | J10      | AIN[3] <sup>3</sup>           |                | Analog signal input to ADC                |            |
| 66       | K10      | AIN[3]                        | Analog In      |                                           |            |
| 67       |          | AIN[1]<br>AIN[5] <sup>3</sup> | Analog In      | Analog signal input to ADC                |            |
|          | L11      | AIN[5]<br>AIN[0] <sup>3</sup> | Analog In      | Analog signal input to ADC                |            |
| 68<br>69 | K11      |                               | Analog In      | Analog signal input to ADC                |            |
|          | J11      | AIN[4] <sup>3</sup>           | Analog In      | Analog signal input to ADC                |            |
| 70       | L12      | AIN[2] <sup>3</sup>           | Analog In      | Analog signal input to ADC                |            |
| 71       | K12      | AIN[6] <sup>3</sup>           | Analog In      | Analog signal input to ADC                |            |
| 72       | H10      | AVSS                          | Analog ground  | Analog ground                             |            |
| 73       | J12      | RXI                           | Analog In      | RTC Crystal Input                         |            |
| 74       | H12      | RXO                           | Analog Out     | RTC Crystal Out                           |            |
| 75       | H11      | VBAT                          | Analog power   | Back-up battery                           |            |
| 76       | H9       | TEST_MODE[1]                  | Digital In     | Reserved                                  |            |
| 77       | G11      | TEST_MODE[0]                  | Digital In     | Reserved                                  |            |
| 78       | G10      | DSU_MUX                       | Digital In     | UART1/DSU select                          |            |
| 79       | G9       | LVSS                          | Digital ground | Ground                                    |            |
| 80       | G12      | LVDD                          | Digital power  | Core power supply                         |            |
| 81       | F12      | VFB                           | Analog In      | Voltage regulator feedback                |            |
| 82       | F11      | DSUACT                        | Digital Out    | Debug Support Unit (Active)               | 1          |
| 83       | F10      | DSUEN                         | Digital In     | Debug Support Unit (Enable)               |            |
| 84       | F9       | DSURX                         | Digital In     | Debug Support Unit (Receive)              |            |
| 85       | E10      | DSUBRE                        | Digital In     | Debug Support Unit (Break)                |            |
| 86       | E11      | DSUTX                         | Digital Out    | Debug Support Unit (Transmit)             | 1          |
| 87       | E9       | DAVSS                         | Digital ground | Ground                                    |            |
| 88       | D9       | DVDD                          | Digital power  | Padring power supply                      |            |
| 89       | E12      | GPIO[0]                       | Digital IO     | Programmable GPIO interface               | Z + keeper |
| 90       | D12      | GPIO[1]                       | Digital IO     | Programmable GPIO interface               | Z + keeper |
| 91       | D11      | GPIO[2]                       | Digital IO     | Programmable GPIO interface               | Z + keeper |
| 92       | D10      | GPIO[3]                       | Digital IO     | Programmable GPIO interface               | Z + keeper |
| 93       | C11      | GPIO[4]                       | Digital IO     | Programmable GPIO interface               | Z + keeper |
| 94       | C10      | GPIO[5]                       | Digital IO     | Programmable GPIO interface               | Z + keeper |
| 95       | C12      | GPIO[6]                       | Digital IO     | Programmable GPIO interface               | Z + keeper |
| 96       | B11      | GPIO[7]                       | Digital IO     | Programmable GPIO interface               | Z + keeper |
| 97       | B12      | UART1_RX                      | Digital In     | UART1 Receive                             | ·          |
| 98       | A12      | UART1_TX                      | Digital Out    | UART1 Transmit                            | 1          |
| 99       | C9       | ADDR[23]                      | Digital Out    | EBI Address                               | 1          |
| 100      | A11      | ADDR[22]                      | Digital Out    | EBI Address                               | 1          |
| 101      | B10      | ADDR[21]                      | Digital Out    | EBI Address                               | 1          |
| 102      | A10      | ADDR[20]                      | Digital Out    | EBI Address                               | 1          |
| 103      | B9       | ADDR[19]                      | Digital Out    | EBI Address 1                             |            |
| 104      | A9       | ADDR[18]                      | Digital Out    | EBI Address 1                             |            |
| 105      | D8       | ADDR[17]                      | Digital Out    | EBI Address 1                             |            |
| 106      | C8       | ADDR[16]                      | Digital Out    | EBI Address 1                             |            |
| 107      | B8       | ADDR[15]                      | Digital Out    | EBI Address 1                             |            |
| 107      | A8       | ADDR[14]                      | Digital Out    | EBI Address 1                             |            |
| 100      | B7       | ADDR[13]                      | Digital Out    | EBI Address 1                             |            |
| 109      | C7       | ADDR[13]                      | Digital Out    | EBI Address 1<br>EBI Address 1            |            |
| 111      | D7       | DAVSS                         | Digital ground | Ground                                    | I          |
| 112      | D7<br>D6 | DVDD                          | Digital power  | Power supply for padring and voltage reg. |            |
|          |          |                               | ů l            |                                           | 1          |
| 113      | A7       | ADDR[11]                      | Digital Out    | EBI Address                               | 1          |

| 114 | B6 | ADDR[10] | Digital Out | EBI Address  | 1          |
|-----|----|----------|-------------|--------------|------------|
| 115 | C6 | ADDR[9]  | Digital Out | EBI Address  | 1          |
| 116 | A6 | ADDR[8]  | Digital Out | EBI Address  | 1          |
| 117 | A5 | ADDR[7]  | Digital Out | EBI Address  | 1          |
| 118 | B5 | ADDR[6]  | Digital Out | EBI Address  | 1          |
| 119 | C5 | ADDR[5]  | Digital Out | EBI Address  | 1          |
| 120 | D5 | ADDR[4]  | Digital Out | EBI Address  | 1          |
| 121 | A4 | ADDR[3]  | Digital Out | EBI Address  | 1          |
| 122 | A3 | ADDR[2]  | Digital Out | EBI Address  | 1          |
| 123 | A2 | ADDR[1]  | Digital Out | EBI Address  | 1          |
| 124 | A1 | ADDR[0]  | Digital Out | EBI Address  | 1          |
| 125 | B4 | DATA[0]  | Digital IO  | EBI Data Bus | Z + keeper |
| 126 | B3 | DATA[1]  | Digital IO  | EBI Data Bus | Z + keeper |
| 127 | B2 | DATA[2]  | Digital IO  | EBI Data Bus | Z + keeper |
| 128 | B1 | DATA[3]  | Digital IO  | EBI Data Bus | Z + keeper |

Note 1: Pads under DVSU power supply.

Note 2: Pads under TVDD power supply.

Note 3: Pads under DAVDD power supply.

Note 4: The function changes by activating the Byte Enable function on the EBI (see 12.6)

## 7 CPU

Figure 3 Leon block diagram



The following section gives a general overview of the Leon's building blocks. More details can be found in the next chapters or in the online Leon and Sparc V8 documentation available at <a href="http://www.gaisler.com">http://www.gaisler.com</a>. The Leon version implemented in the NJ1030A design is 1.0.16.

## 7.1 Integer Unit

The LEON integer unit implements the full SPARC V8 instruction set, including all multiply and divide instructions. The number of register windows used in the NJ1030A is 8 (see Sparc V8 reference).

## 7.2 Cache Sub-System

The Leon is configured with 8 kBytes of direct mapped instruction cache and 1 kByte of direct mapped data cache. The instruction cache uses streaming during line-refill to minimise refill latency. The data cache uses write-through policy and implements a double-word write-buffer.Debug Support Unit

The debug support unit (DSU) allows debugging on target hardware and has negligible impact on performance. The DSU allows inserting breakpoints and access to all on-chip registers from a remote debugger. Communication to an outside debugger (e.g. gdb) is done using a dedicated UART (RS232).

## 7.3 Watchpoint Registers

To aid software debugging, four watchpoints registers are available. Each register can cause a trap on an arbitrary instruction or data address range. If the debug support unit is enabled, the watchpoints can be used to enter debug mode.

## Memory Map

| Address Space           | Size  | Mapping            | Chip Select       | Cacheable |
|-------------------------|-------|--------------------|-------------------|-----------|
| 0x00000000 - 0x00FFFFFF | 16 M  | RAM0 (boot)        | CSN0              | I and D   |
| 0x01000000 - 0x01FFFFFF | 16 M  | RAM1               | CSN1              | I and D   |
| 0x02000000 - 0x02FFFFFF | 16 M  | RAM2               | CSN2              | I and D   |
| 0x03000000 - 0x03FFFFFF | 16 M  | RAM3               | CSN3 <sup>1</sup> | I and D   |
| 0x04000000 - 0x0FFFFFFF | 192 M | Unused             | Unused            | I and D   |
| 0x10000000 - 0x10FFFFFF | 16 M  | RAM4               | CSN4              | I and D   |
| 0x11000000 - 0x1FFFFFFF | 240 M | Unused             | Unused            | I and D   |
| 0x20000000 - 0x20FFFFFF | 16 M  | IO0                | IOSN              | no        |
| 0x21000000 - 0x2FFFFFFF | 16 M  | IO0 (echo)         | IOSN              | no        |
| 0x30000000 - 0x6FFFFFF  | 16 M  | IO0 (echo)         | IOSN              | I only    |
| 0x70000000 - 0x7FFFFFFF | 32 K  | AHBSRAM            | -                 | I and D   |
| 0x80000000 - 0x8FFFFFF  | 256 M | APB area           | -                 | -         |
| 0x90000000 - 0x9FFFFFF  | 256 M | Debug Support Unit | -                 | -         |
| 0xA0000000 - 0xAFFFFFFF | 32 K  | Scratchpad RAM     | -                 | no        |

Note 1: Available through GPIO interface (GPIO[2]).

## **APB Register Mapping**

| Slave Id | Function               | Internal Amba bus address |
|----------|------------------------|---------------------------|
| 0        | Memory controller      | 0x8000000 - 0x8000008     |
| 1        | AHB status reg         | 0x8000000C - 0x80000010   |
| 2        | Cache controller       | 0x80000014 - 0x80000014   |
| 3        | Write protection       | 0x8000001C - 0x80000020   |
| 4        | Configuration register | 0x80000024 - 0x80000024   |
| 5        | Timers                 | 0x80000040 - 0x8000005C   |
| 6        | UART 1                 | 0x80000070 - 0x8000007C   |
| 7        | UART 2                 | 0x8000080 - 0x800008C     |
| 8        | Interrupt CTRL         | 0x80000090 - 0x8000009C   |
| 9        | I/O Port               | 0x80000A0 - 0x80000AC     |
| 10       | Temperature sensor     | 0x800000B0 - 0x800000BC   |
| 11       | DSU UART               | 0x800000C0 - 0x800000CC   |
| 12       | SPI Master             | 0x800000D0 - 0x800000DC   |
| 13       | SPI Slave              | 0x800000E0 - 0x800000E8   |
| 14       | System CTRL Block      | 0x800000F0 - 0x800000FC   |
| 15       | NP1016                 | 0x80001000 - 0x80001FFC   |
| 16       | NVRAM                  | 0x80002000 - 0x80003FFC   |
|          | RTC <sup>1</sup>       | 0x80008000 - 0x8000800C   |

Note 1 : The NVRAM memory and the RTC module share the same APB slave peripheral.

## 8 Clocking

## Figure 4 Clocking scheme



The main clock (SYS\_CLK) can be generated either by:

- the on-chip crystal oscillator (Xosc).
- a temperature compensated oscillator (TCXO).
- an external digital clock.
- the RF front-end oscillator (full swing).

All along the datasheet, the following rule has been adopted: an 'internally generated clock' refers to a Xosc or a TCXO. An 'externally generated clock' refers to any clock source that can be directly used by the NJ1030A without being buffered (external digital clock or clock generated by the RF front-end)

The clocking of the system is flexible enough to scale the system performance depending on the application, to support a wide range of GPS frequency plans and to allow the use of different clock sources. The NJ1030A has two synchronous clock domains:

- SYS\_CLK: used for the CPU and all the peripherals except the NP1016.
- GPS\_REF\_CLK/NP1016\_GPS\_CLK: the reference clock for the RF front-end and the correlation unit. It is generated from SYS\_CLK by means of a programmable clock divider under control of the NJ1030A CPU. The clock division factor range is from 1 to 8.

The CLK\_SOURCE pin selects between an external ('0') or internal ('1') clock source.

For detailed instruction on how to connect a TCXO, a crystal oscillator or a digital clock to the NJ1030A, refer to section .

#### 8.1 Shut Down of Main Clock in SLEEP Mode

For the implementation of the SLEEP power management mode, the SYS\_CLK generation can be switched off by the CPU. The system clocking is then resumed either by an external wake up, by a system reset or by the internal RTC wake up.

If the on chip oscillator is used, then it is automatically deactivated when the system enters SLEEP mode. Moreover when the system enters SLEEP mode, the internal oscillator is always selected as the source of the clock (independently from the value of CLK\_SOURCE). This feature effectively shuts down the NJ1030A main clock even if the external clock is still running.

The EXT\_EN pin can be used to control the powering down and up of external devices when the NJ1030A is entering/exiting sleep mode.

#### 8.2 Sub-Clocks

A set of subclocks is generated from the main source. All of the following subclocks are either divided version or gated version of the main clock.

- **GPS\_REF\_CLK**: GPS reference clock available on the external pin for the GPS RF front end. It is a divided version of SYS\_CLK. Clock division factor is 1 to 8 according to the value of CLK\_DIV\_FACTOR.
- NP1016\_GPS\_CLK: pulse deleted version of SYS\_CLK. Pulse deletion factor is between 1 and 8 according to the value of CLK\_DIV\_FACTOR.
- NP1016\_APB\_CLK: gated version of SYS\_CLK that goes to the APB part of the NP1016 and that can be shut down when GPS is not needed.
- UART1\_CLK, UART2\_CLK, TIMER\_CLK, SPIM\_CLK, SPIS\_CLK, GPIO\_CLK, DSU\_CLK, CPU\_CLK and MC\_CLK (memory controller) are gated clock version of SYS\_CLK that individually clocks the corresponding subblocks.

For the temperature sensor block an enable signal that is the pulse deleted version of factor 1024 of GPS\_REF\_CLK is generated. It is used by the temperature sensor interface to drive the slow analog blocks of the sensor (DAC + comparator). This signal is also used to implement the ageing mechanism in the UARTs and SPI slave FIFOsThe gating of these clocks is controlled by a glitch free mechanism. The user has the ability to enable or disable each sub-clock individually by setting the corresponding CLK\_EN bit in the CCTRL\_REG of the system control block.

#### 8.3 Clock on demand mechanism

Each APB peripheral can dynamically require the activation of its own sub-clock. This mechanism achieves major power savings since the sub-clocks are activated only when needed by the respective blocks. For each subclock, the "clock demand" feature is enabled by a dedicated bit (DMD\_EN) in the CCTRL\_REG of the system control block.

When the two bits (CLK\_EN and DMD\_EN) of a given block are at '1', then the sub-block can generate a demand signal that activates its own sub-clock.

This mechanism is used by the UART controllers to finish the transmission even if the CPU is asked to deactivate the clock. The same mechanism applies to a UART that is starting to receive data, when no clock is present. The demand signal permits to get the UART clock running, to generate an interrupt and resume the CPU activity.

The NP1016 clocking requires peripherals to be used with a '11' (for CLK\_EN and DMD\_EN) configuration for both the NP1016\_APB\_CLK and the NP1016\_GPS\_CLK, in order for the low power features to be active. If the CLK\_EN bit is cleared for these clocks, then the NP1016 has always all clocks inactive, independently from the number of active tracking modules.

Setting DMD\_EN for the CPU\_CLK enables the CPU clock to be halted, however the CPU clock will be maintained until the current memory access has been completed, therefore after setting this flag the CPU should execute NOPs to allow any pending accesses to complete. After this the CPU clock will be stopped until an interrupt occurs, this will clear the DMD\_EN bit enabling the CPU to continue execution, which will begin with the execution of the trap handler for the pending interrupt.

#### Sub-Clock Domains

| Clock Domain                                  | Demand signal generation                                                                    |
|-----------------------------------------------|---------------------------------------------------------------------------------------------|
| GPS_REF_CLK                                   | Demand signal always at '1'                                                                 |
| NP1016_APB_CLK                                | Demand signal based on the read/write activity on APB                                       |
| NP1016_GPS_CLK                                | Demand signal based on the transfer activity on the APB                                     |
| UART1_CLK                                     | Receive/transmit + edge detection                                                           |
| UART2_CLK                                     | Receive/transmit + edge detection                                                           |
| TIMER_CLK                                     | Demand signal for debug only. DMD_EN should not be set for the TIMER_CLK                    |
| SPIM_CLK                                      | Demand signal based on the read/write activity on APB                                       |
| SPIS_CLK                                      | Demand signal always at '1'                                                                 |
| DSU_CLK                                       | Demand signal signal always at '1' <sup>1</sup>                                             |
| MC_CLK                                        | Not in idle state, DMD_EN bit cleared by an irq pending                                     |
| CPU_CLK                                       | MC not in idle state, DMD_EN cleared by an irq pending                                      |
| GPIO_CLK                                      | Demand signal always at '1' <sup>1</sup>                                                    |
| Note 1: Demand signal always at '1' means the | t the DND EN hit has no effect on the clock. As long as CLK. EN is set the clock will be an |

Note 1: Demand signal always at '1' means that the DMD\_EN bit has no effect on the clock. As long as CLK\_EN is set, the clock will be on.

## 9 System Control Block

## 9.1 System Control Registers

| Address    | Name              | Туре       | Function                           |
|------------|-------------------|------------|------------------------------------|
| 0x800000F0 | SYS_CTRL_REG      | Read/write | Multi purpose system control       |
| 0x800000F4 | Reserved          |            |                                    |
| 0x800000F8 | CCTRL_BYTESEL_REG | Read/write | Sub-clocks and byte enable control |
| 0x800000FC | TEST_REG          | Read/write | Test and debug control             |

The system control block gathers registers with various purposes.

The SYS\_CTRL\_REG controls the clock division factor, sets the system into SLEEP mode, selects the input to the ADC converter, the mode of the GPIO port and enables the watchdog counter overflow to reset the system. It entails also some flags indicating a low backup battery voltage, the validity of the PPS signal and the presence of an antenna at the RF front-end side.

The CCTRL register controls each internally generated sub clock domain with two bits: the DMD\_EN (MSB) and CLK\_EN bit (LSB). The CLK\_EN has the highest priority and if set to '0' completely disable the sub clock domain. Once the sub clock domain has been activated (CLK\_EN='1') the activity is controlled by the peripheral clocked by the sub clock domain. With DMD\_EN = '0', the clock is always switched on, while if DMD\_EN = '1', the clock is controlled by a synchronous signal generated by the peripheral. By default all clocks are switched on and demand mechanism is disabled ('01').

#### Clock control

| DMD_EN | CLK_EN | Situation                                                         |
|--------|--------|-------------------------------------------------------------------|
| Х      | 0      | Clock is always switched off                                      |
| 0      | 1      | Clock is always switched on (default)                             |
| 1      | 1      | Clock is switched on by the peripheral served by the clock domain |

For test purposes, two bits in the TEST\_REG are available in order to speed up the RTC behavior. TEST\_RTC\_CLK permits to feed a SYS\_CLK divided by 4 into the 15 bits prescaler. The TEST\_RTC\_PRESCALER put the prescaler into a divide by 8 mode, in order to accelerate the execution of a functional RTC test. (See RTC chapter)

## 9.2 Register Details

#### SYS\_CTRL\_REG (Addr 0x800000F0)

| Field         | Bits  | Rst   | Description                                                                                                                                                               |  |  |
|---------------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| RESERVED      | 31:15 | undef | Reserved bits                                                                                                                                                             |  |  |
| SYS_SPI_SLAVE | 14    | 0     | SPI master slave select. Selects the mode of the SPI external signals. Default is 0, Master.                                                                              |  |  |
| SYS_ANT_OK    | 13    | undef | Antenna OK. The value delivered by the RF front end is sampled into this register after three SYS_CLK cycles. '1' means that the antenna is present and working properly. |  |  |
| SYS_WD_RST_EN | 12    | 0     | Watchdog reset enable. If set, enables the execution of a system reset, when the watchdog counter overflows.                                                              |  |  |
| SYS_GPIO_MODE | 11:9  | 000   | Selects the mode of the GPIO port.                                                                                                                                        |  |  |
| SYS_ADC_SEL   | 8:6   | 000   | Select the input to the ADC converter. Default (000) is the on chip temperature sensor, while '001' to '111' select AIN[0] to AIN[6].                                     |  |  |
|               | 5     |       | Reserved                                                                                                                                                                  |  |  |
| SYS_LOW_BAT   | 4     | 0     | Low Backup Battery Flag. It is set when the VBAT signal is lower than 1.10V.                                                                                              |  |  |
| SYS_GO_SLEEP  | 3     | 0     | Go to Sleep. When set, this bit forces the system into sleep mode.                                                                                                        |  |  |
| SYS_CLK_DIV   | 2:0   | 111   | Clock division factor for the generation of the GPS_REF_CLK / NP1016_GPS_CLK.<br>Default is 111 = div by 8, 110 = div by 7 until 000 = div by 1.                          |  |  |

## CCTRL\_REG (Addr 0x800000F8)

NB: For each pair of bit of this register, the MSB is the DMD\_EN bit and the LSB is the CLK\_EN bit, as explained in the 'Clock control' table.

| Field                | Bits  | Rst   | Description                                                   |
|----------------------|-------|-------|---------------------------------------------------------------|
| RESERVED             | 31:24 | undef | Reserved bits                                                 |
| CCTRL_GPS_REF        | 23:22 | 01    | External GPS reference clock control                          |
| CCTRL_NP1016_APB_CLK | 21:20 | 01    | Control of the clock of the APB interface of the NP1016       |
| CCTRL_NP1016_GPS_CLK | 19:18 | 01    | Control of the GPS clock of the NP1016                        |
| CCTRL_UART2          | 17:16 | 01    | UART2 clock control                                           |
| CCTRL_UART1          | 15:14 | 01    | UART1 clock control                                           |
| CCTRL_TIMER          | 13:12 | 01    | TIMERs clock control. DMD_EN should never be set. Debug only. |
| CCTRL_SPIM           | 11:10 | 01    | SPI mater clock control                                       |
| CCTRL_SPIS           | 9:8   | 01    | SPI slave clock control                                       |
| BE_MODE              | 7     | 0     | Sets the external memory interface in byte enable mode        |
| CCTRL_DSU            | 6     | 1     | DSU clock control                                             |
| CCTRL_MC             | 5:4   | 01    | Memory controller clock control                               |
| CCTRL_CPU            | 3:2   | 01    | CPU clock control                                             |
| CCTRL_GPIO           | 1:0   | 01    | GPIO clock control                                            |

## TEST\_REG (Addr 0x800000FC)

| Field              | Bits | Rst   | Description                                                                                                                                             |
|--------------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| RESERVED           | 31:9 | undef | Reserved bits                                                                                                                                           |
| TEST_SPI           | 8    | 0     | SPI test mode. When set, data from the slave is routed back to the master so that a back to back test of the master and slave devices can be performed. |
| TEST_DMD_SEL       | 7:2  | 0000  | Selects the internal clock demand signal to be muxed out to the DMD_OUT signal on the GPIO.                                                             |
| TEST_RTC_CLK       | 1    | 0     | If set, SYS_CLK divided by 8 is fed to the input of the RTC prescaler                                                                                   |
| TEST_RTC_PRESCALER | 0    | 0     | If set, the RTC prescaler is set into a divide by 8 mode.                                                                                               |

## **10 Interrupt Controller**

## 10.1 Interrupt Control Registers

| Address    | Name         | Туре       | Function                             |
|------------|--------------|------------|--------------------------------------|
| 0x80000090 | IRQMASK_REG  | Write      | Interrupt mask and priority register |
| 0x80000094 | IRQPEND_REG  | Read       | Interrupt pending register           |
| 0x80000098 | IRQFORCE_REG | Read/Write | Interrupt force register             |
| 0x8000009C | IRQCLEAR_REG | Write      | Interrupt clear register             |

## Figure 5. Interrupt controller block diagram



## Interrupt assignments

| Source                          |
|---------------------------------|
| Reserved                        |
| ACC_INT from NP1016             |
| MEAS_INT from NP1016            |
| CPU_WAKE (RTC_WAKE or EXT_WAKE) |
| DSU                             |
| SPI Master                      |
| Timer 2                         |
| Timer 1                         |
| Watchdog                        |
| SPI Slave                       |
| GPIO interrupt – programmable   |
| GPIO interrupt – programmable   |
| UART1                           |
| UART2                           |
| AHB error                       |
|                                 |

The LEON interrupt controller is used to prioritise and propagate interrupt requests from internal or external devices to the integer unit. In total 15 interrupts are handled, divided on two priority levels.

## 10.2 Operation

When an interrupt is generated, the corresponding bit is set in the interrupt pending register. The pending bits are ANDed with the interrupt mask register and then forwarded to the priority selector. Each interrupt can be assigned to one of two priority levels as programmed in the interrupt level register. Level 1 has higher priority than level 0. The interrupts are prioritised within each level, with interrupt 15 having the highest priority and interrupt 1 the lowest. The highest interrupt from level 1 will be forwarded to the Integer Unit - if no unmasked pending interrupt exists on level 1, then the highest unmasked interrupt from level 0 will be forwarded. When the integer unit acknowledges the interrupt, the corresponding pending bit will automatically be cleared.

Interrupt can also be forced by setting a bit in the interrupt force register. In this case, the IU acknowledgement will clear the force bit rather than the pending bit.

## 10.3 Register Details

## IRQMASK\_REG (Addr 0x80000090)

| Field    | Bits  | Rst   | Description                                                                                                                                                                   |
|----------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ILEVEL   | 31:17 |       | Interrupt level - indicates whether an interrupt belongs to priority level 1 (ILEVEL[n]=1) or level 0 (ILEVEL[n]=0). Bit 31 corresponds to IRQ15, Bit 30 to IRQ14, and so on. |
| RESERVED | 16    | undef | Reserved bit                                                                                                                                                                  |
| IMASK    | 15:1  |       | Interrupt mask - indicates whether an interrupt is masked (IMASK[n]=0) or enabled (IMASK[n]=1).                                                                               |
| RESERVED | 0     | undef | Reserved bit                                                                                                                                                                  |

## IRQPEND\_REG (Addr 0x80000094)

| Field    | Bits  | Rst   | Description                                                                               |
|----------|-------|-------|-------------------------------------------------------------------------------------------|
| RESERVED | 31:16 | undef | Reserved bits                                                                             |
| IPEND    | 15:1  |       | Interrupt pending (IPEND[15:1]) - indicates whether an interrupt is pending (IPEND[n]=1). |
| RESERVED | 0     | undef | Reserved bits                                                                             |

## IRQFORCE\_REG (Addr 0x80000098)

| Field    | Bits  | Rst   | Description                                                                                    |
|----------|-------|-------|------------------------------------------------------------------------------------------------|
| RESERVED | 31:16 | undef | Reserved bits                                                                                  |
| IFORCE   | 15:1  |       | Interrupt force (IFORCE[15:1]) - indicates whether an interrupt is being forced (IFORCE[n]=1). |
| RESERVED | 0     | undef | Reserved bits                                                                                  |

## IRQCLEAR\_REG (Addr 0x8000009C)

| Field    | Bits  | Rst   | Description                                                                                                                                                                                                             |
|----------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RESERVED | 31:16 | undef | Reserved bits                                                                                                                                                                                                           |
| ICLEAR   | 15:1  |       | Interrupt clear (ICLEAR[15:1]) - if written with a '1', ICLEAR[n] will clear IPEND[n] in the interrupt pending register. A consecutive read on ICLEAR[n] will return '0' and confirm that the pending has been cleared. |
| RESERVED | 0     | undef | Reserved bits                                                                                                                                                                                                           |

## 11 Timers and Watchdog

## 11.1 Timer Control Registers

| Address                 | Name               | Туре       | Function                       |
|-------------------------|--------------------|------------|--------------------------------|
| 0x80000040 / 0x80000050 | TIMER_CNTx_REG     | Read       | Timer value                    |
| 0x80000044 / 0x80000054 | TIMER_LOADx_REG    | ReadWrite  | Timer reload value             |
| 0x80000048 / 0x80000058 | TIMER_CTRLx_REG    | Read/Write | Timer general control register |
| 0x8000004C              | WDOG_CNT           | Read       | Watchdog value                 |
| 0x80000060              | PRESCALER_CNT_REG  | Read       | Prescaler counter              |
| 0x80000064              | PRESCALER_LOAD_REG | Read/write | Prescaler reload               |

## Figure 6. Timer unit block diagram



The timer unit implements two 24-bit timers, one 24-bit watchdog and one 10-bit shared prescaler.

## 11.2 Operation

The prescaler is clocked by the system clock and decremented on each clock cycle. When the prescaler underflows, it is reloaded from the prescaler reload register and a timer tick is generated for the two timers and watchdog. The effective division rate is therefore equal to prescaler reload register value + 1.

The operation of the timers is controlled through the timer control register. A timer is enabled by setting the enable bit in the control register. The timer value is then decremented each time the prescaler generates a timer tick. When a timer underflows, it will automatically be reloaded with the value of the timer reload register if the reload bit is set, otherwise it will stop (at 0x000000) and reset the enable bit. An interrupt will be generated after each underflow. The timer can be reloaded with the value in the reload register at any time by writing a '1' to the load bit in the control register.

The watchdog operates similar to the timers, with the difference that it is always enabled. The watchdog output is connected to the reset control block.

For SW debugging the generation of the reset by the watchdog can be disabled by clearing the SYS\_WD\_RST\_EN bit in the SYS\_CTRL\_REG which allows to enable/disable the watchdog and trap the event leading to the watchdog overflow, avoiding a processor reset.

To minimise complexity, the two timers and watchdog share the same decrementer. This means that the minimum allowed prescaler division factor is 4 (reload register = 3).

## 11.3 Register Details

## TIMER\_CNTx\_REG (Addr 0x80000040 / 0x80000050)

| Field        | Bits  | Rst   | Description   |
|--------------|-------|-------|---------------|
| RESERVED     | 31:24 | undef | Reserved bits |
| TIMERx_VALUE | 23:0  | undef | Timer value   |

## TIMER\_LOADx\_REG (Addr 0x80000044 / 0x80000054)

| Field       | Bits  | Rst   | Description        |  |
|-------------|-------|-------|--------------------|--|
| RESERVED    | 31:24 | undef | Reserved bits      |  |
| TIMERx_LOAD | 23:0  | undef | Timer reload value |  |

## TIMER\_CTRLx\_REG (Addr 0x80000048 / 0x80000058)

| Field     | Bits | Rst   | Description                                                                                                         |  |
|-----------|------|-------|---------------------------------------------------------------------------------------------------------------------|--|
| RESERVED  | 31:3 | undef | Reserved bits                                                                                                       |  |
| TIMERx_LD | 2    |       | Load counter. When set, will load the timer reload register into the timer counter register. Always read as a '0'.  |  |
| TIMERx_RL | 1    |       | Reload counter. If set, then the counter will automatically be reloaded with the reload value after each underflow. |  |
| TIMERx_EN | 0    | undef | Enable. Enables the timer when set.                                                                                 |  |

## WDOG\_CNT\_REG (Addr 0x8000004C)

| Field      | Bits  | Rst   | Description            |  |
|------------|-------|-------|------------------------|--|
| RESERVED   | 31:24 | undef | Reserved bits          |  |
| WDOG_VALUE | 23:0  | undef | Watchdog counter value |  |

## PRESCALER\_CNT\_REG (Addr 0x80000060)

| Field     | Bits  | Rst   | Description             |  |
|-----------|-------|-------|-------------------------|--|
| RESERVED  | 31:10 | undef | Reserved bits           |  |
| PRESC_CNT | 9:0   | undef | Prescaler counter value |  |

## PRESCALER\_LOAD\_REG (Addr 0x80000064)

| Field      | Bits  | Rst   | Description            |  |
|------------|-------|-------|------------------------|--|
| RESERVED   | 31:10 | undef | Reserved bits          |  |
| PRESC_LOAD | 9:0   | undef | Prescaler reload value |  |

## 12 Real Time Clock (RTC)

## 12.1 RTC Control Registers

| Address    | Name           | Туре       | Function        |
|------------|----------------|------------|-----------------|
| 0x80008000 | RTC_TIME_REG   | Read/Write | Real Time Clock |
| 0x80008004 | RTC_WAKEUP_REG | Read/Write | Wake up value   |

Clocked by a dedicated 32.768 kHz oscillator the RTC is battery backed up, together with the NVRAM. The RTC has 1s resolution and doesn't overflow when the maximal value of  $2^{30}$  seconds is reached. The RTC is built with a 15 bits ripple carry prescaler that divides the 32.768 kHz clock followed by a synchronous 30 bit programmable counter.

For test purposes the rtc\_clock can be sped-up using the TEST\_RTC\_CLK and the TEST\_RTC\_PRESCALER bits of the TEST\_REG (see 'System Control block' section)

## Figure 7 RTC clock generation



The RTC has a precision of 1 second. The alarm function can be programmed by writing the wake-up time into a 30 bit register (RTC\_WAKEUP\_REG). If the RTC value is the same or bigger than the alarm value, then the RTC\_WKUP event is generated, which is usually used to recover from a sleep mode. The RTC\_WKUP is also connected to the CPU interrupt controller.

The CPU can set the RTC time by writing to the RTC\_TIME\_REG register and gets the RTC value by reading from the same address. The RTC\_TIME\_REG is automatically updated with the latest RTC counter value (RTC\_VALUE) at each tick of the 32.786kHz RTC clock. The max uncertainty on the time switching from one second to the following one, has been calculated in 45msec.

The RTC\_TIME\_REG register is double buffered so that it can be written at system clock speed. However the value is transferred from the system accessible RTC\_TIME\_REG register to the RTC internal register synchronously to the 32 KHz RTC Clock.

As physically writing to the RTC counter may take up to 1.5 RTC clock cycles, the APB\_RTC logic is designed to handle this latency automatically. The RTC\_TIME\_REG register can be updated without taking care of the timing of the RTC counter. The RTC\_WRFLAG acts as a write completed flag. If RTC\_WRFLAG is set by the software, it will be automatically cleared when the update of the RTC counter with the new RTC\_VALUE has been completed. Then, the RTC\_WRFLAG can be polled in the interval to check the progress of the write.

A wake up value can be set with the RTC\_WAKEUP\_REG register. A value of the RTC counter equal or higher than the RTC\_WAKEUP\_TIME value will set the RTC\_WKUP bit in the RTC\_TIME\_REG register and send a wake-up signal to the powerup unit. RTC\_WKUP is also connected to IRQ 12 of the interrupt controller.

Accesses to the RTC\_WAKEUP register occur at system clock speed, this register is not shadowed and comparisons to the RTC\_TIME\_REG are performed in the RTC clock domain, hence it is possible for updates of the RTC\_WAKEUP\_REG register to cause a spurious RTC\_WKUP event. Therefore the RTC wakeup interrupt must be masked when updating the RTC\_WAKEUP\_REG register.

## 12.2 NVRAM

The 2k x 32 bit battery backed-up SRAM is mapped at addresses 0x80002000 - 0x80003FFF in the APB space and is only accessible through 32 bits data words.

Data integrity as well as safe power supply switching to VBAT on failing DVDD or LVDD power supply is guaranteed by the Power Supervisor block.

The internal POWER\_OK signal generated by the Power Supervisor block is used to disable any access from the CPU during the transition phase from valid power supply to invalid power supply.

However if the switching to VBAT occurs during a write operation to the NVRAM, invalid or partially written data blocks could be stored in the NVRAM. Hence, the SW routines for the NVRAM access must implement a data integrity check mechanism that detects corrupted data blocks.

## 12.3 Power Fence

A power fence logic is introduced between the APB interface and the part consisting of the NVRAM macro and the RTC circuits. The power fence guarantees that with any voltage between 0V and LVDD on one side and any voltage between 0V and LVDD max or 0 and VBAT max on the other, no gates are damaged. When power is lost or an asynchronous reset occurs, the power fence forces to a pre-determined level the internal NVRAM control signals while all outputs from the memory and RTC are gated to 0.

## 12.4 Register Details

## RTC\_TIME\_REG (Addr 0x80008000)

| Field      | Bits | Rst | Description                                                                                                                                                                         |
|------------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RTC_WRFLAG | 31   | 0   | "Write has occured" flag. This flag is automatically cleared when the RTC_VALUE has been written to the RTC counter. It can be polled to check if the write operation is completed. |
| RTC_WKUP   | 30   | 0   | Wake-up match flag. Indicates that the RTC wake-up value has been reached (i.e RTC_VALUE $\ge$ RTC_WAKEUP_TIME). Must be cleared manually.                                          |
| RTC_VALUE  | 29:0 | NA  | RTC counter value. The value written here will be transferred to the RTC counter at the next edge of the RTC clock. These bits also reflect the current value of the RTC counter.   |

## RTC\_WAKEUP\_REG (Addr 0x80008004)

| Field           | Bits  | Rst   | Description                                                                                                                                                   |  |  |
|-----------------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| RESERVED        | 31:30 | undef | Reserved bits                                                                                                                                                 |  |  |
| RTC_WAKEUP_TIME | 29:0  |       | Wakeup match value. It is continually compared with the value of the RTC counter.<br>If RTC_WAKEUP_TIME ≥ RTC counter, then a RTC wake-up event is generated. |  |  |

## 13 GPS Correlation Processor

## 13.1 GPS Correlator Global Control Registers

| Address    | Name                  | Size | Туре       | Function                                                                           |
|------------|-----------------------|------|------------|------------------------------------------------------------------------------------|
| 0x80001800 | TIMING_DUTY_CYCLE_REG | 14   | Read/Write | Sets the ACC_INT period and the duration of the LPM1 ON phase                      |
| 0x80001804 | DOZE_PERIOD_REG       | 16   | Read/Write | Defines the duration of the OFF phase of the LPM2 mode                             |
| 0x80001808 | FE_WAKE_UP_REG        | 16   | Read/Write | Defines the RF front end wake up time in the LPM1 and LPM2 modes                   |
| 0x8000180C | Reserved              | 6    | Read/Write |                                                                                    |
| 0x80001810 | MEAS_PERIOD_LOW_REG   | 16   | Read/Write | Low portion of the MEAS_INT duration definition                                    |
| 0x80001814 | MEAS_PERIOD_HIGH_REG  | 9    | Read/Write | High portion of the MEAS_INT duration definition                                   |
| 0x80001818 | BB_CTRL_REG           | 9    | Read/Write | Control Register with different functions                                          |
| 0x8000181C | ACTIVE_TMS_REG        | 16   | Read/Write | Individually activated the tracking modules                                        |
| 0x80001820 | INT_FLAG_CLR_REG      | 2    | Write      | Clears the ACC_INT and MEAS_INT flags                                              |
| 0x80001824 | TM_CLEAR_REG          | 16   | Write      | Individually clears the status of the tracking modules                             |
| 0x8000183C | BB_TEST_REG           | 1    | Read/Write | Sets the global registers in test mode                                             |
| 0x80001840 | STATUS_REG_A          | 16   | Read       | Indicates new dumped values in the individual tracking modules                     |
| 0x80001844 | STATUS_REG_B          | 2    | Read       | Indicate that ACC_INT and MEAS_INT occurred                                        |
| 0x80001848 | STATUS_REG_C          | 16   | Read       | Indicate that a dump occurred in the individual tracking modules, after a MEAS_INT |
| 0x8000187C | VERSION               | 16   | Read       | NP1016 Version Number                                                              |

The GPS correlation processor is an instantiation of the NP1016 correlation processor with 16 tracking modules (TMs). It processes the digital IF signal delivered by the RF front end, correlating it with replicas of the expected GPS signal and producing the measurements data that are used to compute the GPS receivers time and position. Moreover the unit generates two control signals (FE\_P0\_INT and FE\_P1\_INT) used to control the power management modes of the RF front end. The correlation unit generates two interrupt signals (ACC\_INT and MEAS\_INT) that are available on the interrupt controller.

## 13.2 Processor Interface

It has a set of registers for each of the 16 tracking modules and a set of global registers. Each tracking module has its own set of registers that are mapped according to the following table.

## TM register mapping

| TM Number | Address Space |
|-----------|---------------|
| 0         | 0x80001000    |
| 1         | 0x80001080    |
| 2         | 0x80001100    |
| 3         | 0x80001180    |
| 4         | 0x80001200    |
| 5         | 0x80001280    |
| 6         | 0x80001300    |
| 7         | 0x80001380    |
| 8         | 0x80001400    |
| 9         | 0x80001480    |
| 10        | 0x80001500    |
| 11        | 0x80001580    |
| 12        | 0x80001600    |
| 13        | 0x80001680    |
| 14        | 0x80001700    |
| 15        | 0x80001780    |

#### Individual Tracking Module registers

| Name                   | Address | Size | Туре  | Description                                      |
|------------------------|---------|------|-------|--------------------------------------------------|
| CARRIER_NCO_INCR_LOW   | 0x00    | 16   | Write | Low portion of the 30 bit carrier NCO increment  |
| CARRIER_NCO_INCR_HIGH  | 0x04    | 14   | Write | High portion of the 30 bit carrier NCO increment |
| CODE_NCO_INCR_LOW      | 0x08    | 16   | Write | Low portion of the 30 bit code NCO increment     |
| CODE_NCO_INCR_HIGH     | 0x0C    | 14   | Write | High portion of the 30 bit code NCO increment    |
| SLEW_CTRL              | 0x10    | 12   | Write | Controls the slewing of the C/A code generation  |
| TM_MODE                | 0x14    | 16   | Write | TM mode configuration                            |
| EPOCHS_SET             | 0x18    | 12   | Write | Sets the GPS epochs counters                     |
| INTEGR_Q_PROMPT        | 0x40    | 16   | Read  | Integrated value on the Q-prompt path            |
| INTEGR_Q_EL            | 0x44    | 16   | Read  | Integrated value on the Q-early/late path        |
| INTEGR_I_PROMPT        | 0x48    | 16   | Read  | Integrated value on the I-prompt path            |
| INTEGR_I_EL            | 0x4C    | 16   | Read  | Integrated value on the I-early/late path        |
| CARRIER_CYCLE_CNT_LOW  | 0x50    | 16   | Read  | Low portion of the carrier cycles counter        |
| CARRIER_CYCLE_CNT_HIGH | 0x54    | 14   | Read  | High portion of the carrier cycles counter       |
| CARRIER_NCO_PHASE      | 0x58    | 16   | Read  | Carrier NCO phase                                |
| CODE_NCO_PHASE         | 0x5C    | 16   | Read  | Code NCO phase                                   |
| CODE_PHASE             | 0x60    | 10   | Read  | C/A code phase                                   |
| EPOCHS                 | 0x64    | 12   | Read  | GPS epochs status                                |

The table avobe describes which registers are available for each tracking module, within the individual address range

## 13.3 IF Interface

The signal path input is the two bit IF signal generated by the GPS RF front-end (SGN and MAG) with the coding described in the following table. If the RF front-end produces a one bit signal, then only the SGN bit is used, while the MAG input is tied-up.

#### IF signal conversion

| IF value | SGN | MAG |
|----------|-----|-----|
| 3        | 0   | 1   |
| 1        | 0   | 0   |
| -1       | 1   | 0   |
| -3       | 1   | 1   |

## 13.4 Clocking

The GPS correlation engine is clocked with two clocks: the NP1016\_APB\_CLK applied to the interface to the processor and NP1016\_GPS\_CLK that is a pulse deleted version of the SYS\_CLK and is used for the GPS processing. The pulse deletion factor is the same as the clock division factor used to generate the external GPS reference clock for the RF front end. In most of the portion clocked by SYS\_CLK, the clock on demand option is available. If activated, this clocking option generates a clock pulse only when an access to the interface registers is executed by the CPU.

## 13.5 Functional Behaviour

Starting from the IF signal, each Traking Module can be assigned to acquire or track the signal from a selected space vehicle.

Each tracking module entails:

- a carrier NCO (numerically controlled oscillator) generating I and Q components.
- a code NCO feeding a C/A code generator that produces the C/A code corresponding to a given space vehicle and a version of the same code spaced by ½ code symbol (chip). The C/A code generator also offers the option to slew the C/A code generation by a programmable number of symbols.

The incoming IF signal is multiplied by the I and Q carrier components and by the two version of the C/A code. The resulting 4 signal paths are continuously accumulated and the accumulated value is periodically dumped into 4 registers (INTEGR\_Q\_P, INTEGR\_Q\_EL, INTEGR\_I\_EL and INTEGR\_I\_P). These 4 values indicate the level of correlation between the locally generated signal and the one of the space vehicle that the TM has been assigned to.

Beside the correlation values, each TM generates a set of 5 measurements consisting of the code NCO phase, the carrier NCO phase, the carrier cycle count, the C/A code phase and the number of GPS epochs (1ms and 20ms epochs).

The GPS SW stack activates the necessary number of TMs, assigns them to space vehicles and does a C/A code and frequency scan in order to acquire the space vehicles signals. Once the space vehicle is acquired, the correlation values are monitored and the carrier and code NCO generators are continuously adjusted in order to track the acquired signal. By extracting GPS data from the tracked signals and computing pseudo ranges starting from the 5 measurements, the GPS SW can then compute position, velocity and time (PVT) of the receiver.

In order to operate the GPS SW has to continuously serve the ACC\_INT interrupt, while it can set the MEAS\_INT timing to a lower rate and poll the occurrence of this signal.

## 13.6 RF Power Management Signals

The GPS correlator unit generates two internal signals (FE\_P1\_INT and FE\_P0\_INT) that are used to control the power management features of the NJ1006(A) RF front ends. The power modes are coded as follow:

## NJ1006(A) power modes

| NJ1006(A) Mode | FE_P1_INT | FE_P0_INT |
|----------------|-----------|-----------|
| Fully Active   | 1         | 0         |
| Stand-by       | 1         | 1         |
| Doze           | 0         | 1         |
| Off            | 0         | 0         |

Before being made available on the external FE\_P1 and FE\_P0 pins, these signals are combined with the NJ1030A operating mode as described in the following paragraph.

## 13.7 Control of the FE\_P0 and FE\_P1 Signals

The logic in the reset block controls the FE\_P0 and FE\_P1 signals. The FE\_P0 and FE\_P1 output pins are asynchronously overridden for certain system and reset events.

These are listed below in order of decreasing priority, i.e the first in the table is the highest priority. fe\_p0\_in and fe\_p1\_in are the signal generated by the internal NP1016 block which in some cases are overridden, depending on the system status and origin of the clock.

Note that setting bit 6 of BB\_CTRL\_REG to 1 (RF in test mode) will also cause FE\_P0 and FE\_P1 to go to 0 (NJ1006(A) power off).

## FE\_P0 and FE\_P1 control

| EXT_RESETN | CLK_SOURCE | fe_p1_in | fe_p0_in | FE_P1 | FE_P0 | Status                                       |
|------------|------------|----------|----------|-------|-------|----------------------------------------------|
| Х          | Х          | Х        | Х        | 0     | 0     | Sleep mode                                   |
| Х          | Х          | Х        | Х        | 0     | 0     | Power fail (LVDD=0)                          |
| 0          | Х          | Х        | Х        | 1     | 0     | During reset                                 |
| 1          | 0          | 0        | 0        | 1     | 0     | Prevent accidental turn off of external osc. |
| 1          | 0          | 0        | 1        | 0     | 1     | Pass through NP1016                          |
| 1          | 0          | 1        | 0        | 1     | 0     | Pass through NP1016                          |
| 1          | 0          | 1        | 1        | 1     | 1     | Pass through NP1016                          |
| 1          | 1          | 0        | 0        | 0     | 0     | Pass through NP1016                          |
| 1          | 1          | 0        | 1        | 0     | 1     | Pass through NP1016                          |
| 1          | 1          | 1        | 0        | 1     | 0     | Pass through NP1016                          |
| 1          | 1          | 1        | 1        | 1     | 1     | Pass through NP1016                          |

## 14 External Memory Support

#### 14.1 EBI Control Registers

| Address    | Name          | Туре       | Function                      |
|------------|---------------|------------|-------------------------------|
| 0x80000000 | MEM_MCFG1_REG | Read/Write | RAM4 and I/O control          |
| 0x80000004 | MEM_MCFG2_REG | Read/write | Wait states and memory access |
| 0x80000008 | MEM_MCFG3_REG | Read/write | Data width                    |

The external bus interface (EBI) supports 4 banks of asynchronous memory with individually programmable number of wait states: each bank is 16 MBytes wide (24, 23 or 22 bits address depending on data width) and can be cached.

Programmable data width of 8, 16 and 32 bits as well as read-modify-write operation is supported. A fifth bank (RAM3) can be accessed through the GPIO interface. A sixth bank for asynchronous I/O (optionally cachable) is also available. The EBI interface supports state-of-the-art SRAM and Flash memory devices.

- Individual wait state programming (0 to 7 for memories and 0 to 15 for I/O space)
- Access to 8/16/32 bit word as well as with readmodify-write operation.

In addition, RAM4 has an extra write protection bit (MEM\_RAM4\_WEN), with respect to the other 3 memory spaces.

An I/O channel provides access to a general purpose I/O space. Two different addressing spaces are possible for I/O, depending on the need to cache the access or not.

| Adress space            | Size | Mapping  | Chip select       | Cacheable            |
|-------------------------|------|----------|-------------------|----------------------|
| 0x30000000 - 0x6FFFFFFF | 16M  | IO(echo) | IOSN              | Instruction only     |
| 0x21000000 - 0x2FFFFFFF | 16M  | IO(echo) | IOSN              | NO                   |
| 0x20000000 - 0x20FFFFFF | 16M  | 10       | IOSN              | NO                   |
| 0x10000000 - 0x10FFFFFF | 16M  | RAM4     | CSN4              | Instruction and Data |
| 0x03000000 - 0x03FFFFFF | 16M  | RAM3     | CSN3 <sup>1</sup> | Instruction and Data |
| 0x02000000 - 0x02FFFFFF | 16M  | RAM2     | CSN2              | Instruction and Data |
| 0x01000000 - 0x01FFFFFF | 16M  | RAM1     | CSN1              | Instruction and Data |
| 0x00000000 - 0x00FFFFF  | 16M  | RAM0     | CSN0              | Instruction and Data |

#### 14.2 External Memory Access

Note 1: Optionally available through GPIO[2]

#### 14.3 Address Multiplexing of External Memories

Address multiplexing is provided internally to facilitate jumperless selection of 8/16/32 bit external memory devices using a single PCB. This allows a single PCB to be populated according to the desired cost / performance model. The address multiplexing will route the address from

the core CPU to the address pins of the device such that A0 of the NJ1030A can always be connected to A0 of the external component. These address lines are multiplexed dynamically according to the width specified in the control register for the memory area being accessed.

| Memory width | EBI Addr[23]  | EBI Addr[22]  | EBI Addr[210] |
|--------------|---------------|---------------|---------------|
| 8            | CPU Addr[23]  | CPU Addr[22]  | CPU Addr[210] |
| 16           | Not connected | CPU Addr[23]  | CPU Addr[221] |
| 32           | Not connected | Not connected | CPU Addr[232] |

#### 14.4 Data Multiplexing of External Memories

Data is supplied to the CPU on dedicated data lines, as described in the following table. Byte 0 is the least significant byte in a 32 bits word, byte 3 is the most significant. Write lines are associated with the external memories as described in the following table. After Reset the system defaults to treating the external memory as 8 bits and discarding any data on EBI Data[23..0]. A different

NJ1030A startup code for 8,16, and 32 bit memory systems correctly configures the memory controller according to the width of the device fitted, thus the contents of the external flash memory can be used to configure the memory width without using any jumpers on the PCB. A bus keeper function is provided so that unused data lines may be left floating without damage.

| Memory width                                                                                                     | EBI Data[3124] | EBI Data[2316] | EBI Data[158] | EBI Data[70] |  |
|------------------------------------------------------------------------------------------------------------------|----------------|----------------|---------------|--------------|--|
| 8                                                                                                                | RWEN[0]        | -              | -             | -            |  |
| 16                                                                                                               | RWEN[0]        | RWEN[1]        | -             | -            |  |
| 32                                                                                                               | RWEN[0]        | RWEN[1]        | RWEN[2]       | RWEN[3]      |  |
| OTE: if 2 moment devices of 16 bit are used to emplate a 32 bit memory, then DWENI01 (or DWENI1) and DWENI21 (or |                |                |               |              |  |

NOTE: if 2 memory devices of 16 bit are used to emaulate a 32 bit memory, then RWEN[0] (or RWEN[1) and RWEN[2] (or RWEN[3]) shall be used to drive the individual write enable signals of the memory devices.

## 14.5 SRAM Access (standard mode)

#### 14.5.1 Typical Read Access

A read access to SRAM consists of two data cycles and between zero and seven waitstates. On non-consecutive accesses, a lead-out cycle is added after a read cycle to prevent bus contention due to slow turn-off time of memories or I/O devices. Figure 9 shows the basic read cycle waveform (zero waitstate).



#### 14.5.2 Typical Write Access

A write access is similar to the read access but takes a minimum of three cycles. Through a feedback loop from the write strobes, the data bus is guaranteed to be driven until the write strobes are de-asserted. Each byte lane has an individual write strobe to allow efficient byte and halfword writes. If the memory uses a common write strobe for the full 16- or 32-bit data, the read-modify-write bit MCR2 should be set to enable read-modify-write cycles for subword writes.

#### Figure 9 Typical write access



## 14.5.3 Burst Cycles

To improve the bandwidth of the memory bus, accesses to consecutive addresses can be performed in burst mode. Burst transfers will be generated when the memory controller is accessed using an AHB burst request. These include instruction cache-line fills, double loads and double stores. The timing of a burst cycle is identical to the programmed basic cycle with the exception that during read cycles the lead-out cycle will only occur after the last transfer.

Figure 11 Typical read access (BE mode)

## 14.6 SRAM Access (BE mode)

In order to use external memories with byte enable, bit 7 of CCTRL\_BYTEN\_REG needs to be set at 1 (see chapter 7.2). In this case the RWEN[3:0] outputs change into a byte enable function (BEN[3:0]). The write enable function, common to all memory bytes, is provided by the WRITEN signal. Chip select and output enable functions remain unchanged with respect to standard mode.





Note that during a read cycle all BENx signals are low, while durting a write cycle 1,2 or 4 BENx go low, depending on the size of the data being written and the meory size being used.

## 14.7 Register Details

## MEM\_MCFG1\_REG (Addr 0x8000000)



More in detail:

| Pin    | Data driven |
|--------|-------------|
| BEN[0] | DATA[31:24] |
| BEN[1] | DATA[23:16] |
| BEN[2] | DATA[15:8]  |
| BEN[3] | DATA[7:0]   |

| Field                     | Bits  | Rst   | Description                                                                                                                                                                                   |
|---------------------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RESERVED                  | 31:29 | undef | Reserved bits.                                                                                                                                                                                |
| MEM_IO_WIDTH              | 28:27 | 10    | I/O space data width. Defines the data width of the I/O area<br>('00'=8 bits, '01'=16 bits, '10'=32 bits)                                                                                     |
| MEM_IO_RDY                | 26    | 0     | I/O bus ready enable. If set, will enable the BRDYN pin (available through GPIO). BRDYN can be used for interfacing slow peripherals for which the max number of wait states isn't sufficient |
| MEM_IO_ERR                | 25    | 0     | I/O bus error (BEXCN available through GPIO) enable.                                                                                                                                          |
| RESERVED                  | 24    | undef | Reserved bit.                                                                                                                                                                                 |
| MEM_IO_WS                 | 23:20 | 1111  | I/O wait states. Default is '1111', 15 wait states.                                                                                                                                           |
| MEM_IO_EN                 | 19    | 0     | I/O enable. If set, the access to the I/O bus area is enabled.                                                                                                                                |
| RESERVED                  | 18:12 | undef | Reserved bits.                                                                                                                                                                                |
| MEM_RAM4_WEN              | 11    | 0     | Write protection bit to the RAM4 space. If sets, enables write.                                                                                                                               |
| RESERVED                  | 10    | undef | Reserved bit.                                                                                                                                                                                 |
| MEM_RAM4_WIDTH            | 9:8   | 00    | RAM4 data width. ('00'=8 bits, '01'=16 bits, '10'=32 bits)                                                                                                                                    |
| MEM_RAM4_WWS              | 7:4   | 1111  | RAM4 Write wait states. Default is '1111', 15 wait states.                                                                                                                                    |
| MEM_RAM4_RWS <sup>1</sup> | 3:0   | 1111  | RAM4 Read wait states. Default is '1111', 15 wait states.                                                                                                                                     |

**NOTE 1**: if the corresponding memory bank is configured in 16 bit mode, then the programmed number of wait states shall be increased by 1, with respect to the number of desired wait states (e.g. if 3 WS are needed, the value of 4 shall be used).

## MEM\_MCFG2\_REG (Addr 0x80000004)

| Field                     | Bits  | Rst   | Description                                                                                                                                                                                   |
|---------------------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MEM_RAM3_WWS              | 31:29 | 111   | RAM3 Write wait states. Default is '111', 7 wait states.                                                                                                                                      |
| MEM_RAM3_RWS <sup>1</sup> | 28:26 | 111   | RAM3 Read wait states. Default is '111', 7 wait states.                                                                                                                                       |
| MEM_RAM2_WWS              | 25:23 | 111   | RAM2 Write wait states. Default is '111', 7 wait states.                                                                                                                                      |
| MEM_RAM2_RWS <sup>1</sup> | 22:20 | 111   | RAM2 Read wait states. Default is '111', 7 wait states.                                                                                                                                       |
| MEM_RAM1_WWS              | 19:17 | 111   | RAM1 Write wait states. Default is '111', 7 wait states.                                                                                                                                      |
| MEM_RAM1_RWS <sup>1</sup> | 16:14 | 111   | RAM1 Read wait states. Default is '111', 7 wait states.                                                                                                                                       |
| MEM_RAM0_WWS              | 13:11 | 111   | RAM0 Write wait states. Default is '111', 7 wait states.                                                                                                                                      |
| MEM_RAM0_RWS <sup>1</sup> | 10:8  | 111   | RAM0 Read wait states. Default is '111', 7 wait states.                                                                                                                                       |
| RESERVED                  | 7:4   | undef | Reserved bits.                                                                                                                                                                                |
| MEM_RAM_RDY               | 3     | 0     | Memory ready enable. If set, will enable the BRDYN pin (available through GPIO). BRDYN can be used for interfacing slow peripherals for which the max number of wait states isn't sufficient. |
| MEM_RMW                   | 2     | 0     | RAM read modify write. Enable read-modify-write cycles on sub-<br>word writes to 16- and 32-bit areas with common write strobe (no<br>byte write strobe).                                     |
| RESERVED                  | 1:0   | undef | Reserved bits.                                                                                                                                                                                |

**NOTE 1**: if the corresponding memory bank is configured in 16 bit mode, then the programmed number of wait states shall be increased by 1, with respect to the number of desired wait states (e.g. if 3 WS are needed, the value of 4 shall be used).

## MEM\_MCFG3\_REG (Addr 0x8000008)

| Field            | Bits | Rst   | Description                                                                                                                              |
|------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------|
| RESERVED         | 31:9 | undef | Reserved bits.                                                                                                                           |
| MEM_MUX_OVERRIDE | 8    | 0     | Override bit for the address shifting mechanism. If set, no shifting of the data and address is carried out for different memory widths. |
| MEM_RAM3_WIDTH   | 7:6  | 10    | RAM3 data width ('00' = 8bits, '01' = 16bits, '10' = 32bits)                                                                             |
| MEM_RAM2_WIDTH   | 5:4  | 10    | RAM2 data width ('00' = 8bits, '01' = 16bits, '10' = 32bits)                                                                             |
| MEM_RAM1_WIDTH   | 3:2  | 10    | RAM1 data width ('00' = 8bits, '01' = 16bits, '10' = 32bits)                                                                             |
| MEM_RAM0_WIDTH   | 1:0  | 00    | RAM0 data width ('00' = 8bits, '01' = 16bits, '10' = 32bits)                                                                             |

## 15 UARTs

#### 15.1 UARTs Control Registers

| Address                 | Name           | Туре       | Function             |
|-------------------------|----------------|------------|----------------------|
| 0x80000070 / 0x80000080 | UARTx_DATA_REG | Read/Write | Data register        |
| 0x80000074 / 0x80000084 | UARTx_STAT_REG | Read       | Status register      |
| 0x80000078 / 0x80000088 | UARTx_CTRL_REG | Read/Write | Control register     |
| 0x8000007C / 0x8000008C | UARTx_USC_REG  | Read/Write | Scaler reload values |

## Transmit

The transmitter is enabled through the TX\_EN bit in the UART control register. When ready to transmit, data is transferred from the transmitter holding register to the transmitter shift register and converted to a serial stream on the transmitter serial output pin (TX). The UART automatically sends a start bit followed by eight data bits, an optional parity bit, and one stop bit. The least significant bit of the data is sent first.

#### Receive

The receiver is enabled for data reception through the receiver enable (RX EN) bit in the UART control register. The receiver looks for a high to low transition of a start bit on the receiver serial data input pin. If a transition is detected, the state of the serial input is sampled a half bit clock later. If the serial input is sampled high the start bit is invalid and the search for a valid start bit continues. If the serial input is still low, a valid start bit is assumed and the receiver continues to sample the serial input at one bit time intervals (at the theoretical centre of the bit) until the proper number of data bits and the parity bit have been assembled and one stop bit has been detected. The serial input is shifted through an 8-bit shift register where all sampled signals have to have the same value before the new value is taken into account, effectively forming a low-pass filter with a cut-off frequency of 1/8 system clock.

During reception, the least significant bit is received first. The data is then transferred to the receiver holding register and the data ready (READY) bit is set in the USART status register. The parity and framing error bits are set at the received byte boundary at the same time as the receiver ready bit is set.

#### Clocking and baud rate

Both UART clock are individually controlled by means of the CCTRL\_UART1 and CCTRL\_UART2 bits of the SYS\_CTRL\_REG. Each UART contains a 12-bit down-

counting scaler to generate the desired baud-rate. The scaler is clocked by the system clock and generates a UART tick each time it underflows. The scaler is reloaded with the value of the UART scaler reload register after each underflow. The resulting UART tick frequency should be 8 times the desired baud-rate.

#### Loopback

If the LOOPBACK bit in the UART control register is set, the UART will be in loop back mode. In this mode, the transmitter output is internally connected to the receiver input. It is then possible to perform loop back tests to verify operation of receiver, transmitter and associated software routines. In this mode, the outputs remain in the inactive state, in order to avoid sending out data.

#### FIFO

Both UARTs offer an input FIFO and an output FIFO. UART1 has a 16 bytes input and 16 bytes output FIFO. UART2 has a 4 bytes input and 4 bytes output FIFO.

For each FIFO a transmit and receive threshold can be programmed. An interrupt is raised when the receive FIFO content is higher than the receive threshold or the transmit FIFO content is lower than the transmit threshold. Both mechanisms can be disabled by setting the values of the thresholds to '0'. In this case an interrupt on transmit FIFO full or receive FIFO empty is raised.

An ageing mechanism raises an interrupt in the case where the receive FIFO threshold has not been reached, but data has been present in the FIFO for a given period of time. This mechanism avoids the need of polling the FIFO status when communicating on the UART. The ageing period is set by a counter value (0,16,32,64) that is counted to 0 with a signal generated from the GPS clock divided by 1024. If this period elapses, an interrupt is raised.

## 15.2 UARTs Register Details

## UARTx\_DATA\_REG (Addr 0x80000070 / 0x80000080)

| Field     | Bits | Rst   | Descriptions                                                          |
|-----------|------|-------|-----------------------------------------------------------------------|
| RESERVED  | 31:8 | undef | Reserved bits.                                                        |
| UART DATA | 7:0  | 0     | Data: the register is shared for reading and writing data to the UART |

## UARTx\_STAT\_REG (Addr 0x80000074 / 0x80000084

| Field           | Bits  | Rst   | Description                                                                                                                                      |  |
|-----------------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|
| RESERVED        | 31:30 | undef | Reserved bits.                                                                                                                                   |  |
| U_RX_FIFO_EMP   | 29    | 1     | Receive FIFO empty                                                                                                                               |  |
| U_RX_FIFO_FULL  | 28    | 0     | Receive FIFO full                                                                                                                                |  |
| U_RX_FIFO_CNT   | 27:24 | 0     | Receive FIFO content                                                                                                                             |  |
| RESERVED        | 23:22 | undef | Reserved bits.                                                                                                                                   |  |
| U_TX_FIFO_EMP   | 21    | 1     | Transmit FIFO empty                                                                                                                              |  |
| U_TX_FIFO_FULL  | 20    | 0     | Transmit FIFO full                                                                                                                               |  |
| U_TX_FIFO_CNT   | 19:16 | 0     | Transmit FIFO content                                                                                                                            |  |
| RESERVED        | 15:7  | undef | Reserved bits.                                                                                                                                   |  |
| T_TX_CH_EMPTY   | 8     | 0     | Transmit channel empty. Is set when there are no characters in the FIFO, holding buffer and transmit shift register.                             |  |
| T_TX_BUFF_EMPTY | 7     | 0     | Transmit buffer empty. Is set when there are no characters in the FIFO or in holding buffer, but there may be characters still being transmitted |  |
| U_FRAME_ERR     | 6     | 0     | Framing error: framing error detected                                                                                                            |  |
| U_PARITY_ERR    | 5     | 0     | Parity error: parity error detected                                                                                                              |  |
| U_RX_OVFL       | 4     | 0     | Receive overflow                                                                                                                                 |  |
| U_BRK           | 3     | 0     | Break detected: indicates that a BREAK was received.                                                                                             |  |
| U_TX_QEMP       | 2     | 1     | Transmit Queue Empty                                                                                                                             |  |
| U_TX_SR_EMP     | 1     | 1     | Transmit Shift Register Empty                                                                                                                    |  |
| U_READY         | 0     | 0     | Data Ready                                                                                                                                       |  |

## UARTx\_CTRL\_REG (Addr 0x80000078 / 0x80000088)

| Field        | Bits  | Rst   | Description                                                                   |
|--------------|-------|-------|-------------------------------------------------------------------------------|
| RESERVED     | 31:30 | undef | Reserved bits.                                                                |
| U_AGE        | 29:28 | 00    | Ageing threshold (00= disabled, 01=16, 10=32, 11=64)                          |
| U_RX_TH      | 27:25 | 000   | Receive threshold (00=disabled, 001=2, 010=4, 011=8, 100=10, 101=12, 110=14)  |
| U_RX_PURGE   | 24    | 0     | Receive purge                                                                 |
| RESERVED     | 23:20 | undef | Reserved bits.                                                                |
| U_TX_TH      | 19:17 | 000   | Transmit threshold (00=disabled, 001=2, 010=4, 011=8, 100=10, 101=12, 110=14) |
| U_TX_PURGE   | 16    | 0     | Transmit purge                                                                |
| RESERVED     | 15:8  | undef | Reserved bits.                                                                |
| U_LOOPBACK   | 7     | 0     | Loopback: if set, loop back mode will be enabled                              |
| RESERVED     | 6     | undef | Reserved bits.                                                                |
| U_PARITY_EN  | 5     | 0     | Parity Enable if set, enables parity generation and checking                  |
| U_PARITY_SEL | 4     | 0     | Parity Select selects parity polarity (0 = even parity, 1 = odd parity)       |
| U_TX_IRQ_EN  | 3     | 0     | Transmit IRQ enable                                                           |
| U_RX_IRQ_EN  | 2     | 0     | Receive IRQ enable                                                            |
| U_TX_EN      | 1     | 0     | Transmit enable                                                               |
| U_RX_EN      | 0     | 0     | Receive enable                                                                |

| Field    | Bits  | Rst   | Description                                                                                                                                                                                              |
|----------|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RESERVED | 31:12 | undef | Reserved bits.                                                                                                                                                                                           |
| UART_USC | 11:0  | 0     | Clock divider factor. Divide SYS_CLK and generate the clock used by UARTx. It periodically counts from the programmed value down to 0.<br>Divider_value = (SYS_CLK + 4 * baud_rate) / (8 * baud rate) -1 |

#### UARTx\_USC\_REG (Addr 0x8000007C / 0x8000008C)

## 16 GPIO

The GPIO shares 8 external signals to implement different functions. The 8 bits GPIO mode functionality is controlled by the SYS\_GPIO\_MODE bits of the SYS\_CTRL\_REG.

Modes 000 to 101 are functional modes, 110 and 111 are for debug and code profiling purpose.

## 16.1 GPIO Control Mode

| MODE | GPIO[0] | GPIO[1]       | GPIO[2]       | GPIO[]3]    | GPIO[4]     | GPIO[5]     | GPIO[6]   | GPIO[7]   |
|------|---------|---------------|---------------|-------------|-------------|-------------|-----------|-----------|
| 000  | pio(0)  | pio(1)        | pio(2)        | pio(3)      | pio(4)      | pio(5)      | pio(6)    | pio(7)    |
| 001  | pio(0)  | pio(1)        | pio(2)        | pio(3)      | pio(4)      | pio(5)      | uart2_txd | uart2_rxd |
| 010  | pio(0)  | spi_sl_sel(0) | spi_sl_sel(1) | spi_miso_i  | spi_mosi_o  | spi_clk     | uart2_txd | uart2_rxd |
|      | pio(0)  | spi_ssn_i     | reserved      | spis_mosi_i | spis_miso_o | spis_clk_in | uart2_txd | uart2_rxd |
| 011  | pio(0)  | spi_sl_sel(0) | spi_sl_sel(1) | spi_miso_i  | spi_mosi_o  | spi_clk     | pps_valid | pps       |
|      | pio(0)  | spi_ssn_i     | reserved      | spis_mosi_i | spis_miso_o | spis_clk_in | uart2_txd | uart2_rxd |
| 100  | pio(0)  | pio(1)        | acc_int       | meas_int    | pps_valid   | pps         | uart2_txd | uart2_rxd |
| 101  | pio(0)  | pio(1)        | CSN3          | BRDYN       | BEXCN       | pps         | uart2_txd | uart2_rxd |
| 110  | pio(0)  | pio(1)        | DMD_OUT       | AHB_RDY     | AHBRAM_CS   | SCR_RAM_CS  | ERROR     | I_HIT     |
| 111  | int0    | int1          | int2          | int3        | meas_int    | Int_ack     | psr_s     | acc_int   |

## 16.2 GPIO Control Registers

| Address    | Name         | Туре       | Function              |
|------------|--------------|------------|-----------------------|
| 0x800000A0 | PIO_DATA_REG | Read/Write | I/O data              |
| 0x800000A4 | PIO_DIR_REG  | Read/write | I/O direction         |
| 0x800000A8 | PIO_IRQ_REG  | Read/write | I/0 interrupt control |

If the GPIO lines are used as parallel IO (PIO), their functionality is defined by three registers. Two registers are associated with the operation of the I/O port; the combined I/O input/output register (PIO\_DATA\_REG), and I/O direction register (PIO\_DIR\_REG). When read, the PIO\_DATA\_REG register will return the current value of the I/O port; when written, the value will be driven on the port signals (if enabled as output). The direction register

defines the direction for each individual port bit (0=input, 1=output).

The IO ports can also be used as interrupt inputs from external devices. A total of 2 interrupts can be generated and rerouted to interrupt lines 4 and 5 on the interrupt controller. The I/O port interrupt configuration register (PIO\_IRQ\_REG) defines which port should generate each interrupt and how it should be filtered.

## 16.3 GPIO Register Details

## PIO\_DATA\_REG (Addr 0x800000A0)

| Field    | Bits | Rst   | Description                                        |
|----------|------|-------|----------------------------------------------------|
| RESERVED | 31:8 | undef | Reserved bits.                                     |
| PIO_DATA | 7:0  | undef | Individual value set on or read form the PIO lines |

## PIO\_DIR\_REG (Addr 0x800000A4)

| Field    | Bits | Rst   | Description                                                   |
|----------|------|-------|---------------------------------------------------------------|
| RESERVED | 31:8 | undef | Reserved bits.                                                |
| PIO_DIR  | 7:0  | 0x0   | Individually defines the direction of the PIO lines (0=input) |

## PIO\_IRQ\_REG (Addr 0x800000A8)

| Field        | Bits  | Rst   | Description                                                 |
|--------------|-------|-------|-------------------------------------------------------------|
| RESERVED     | 31:16 | undef | Reserved bits.                                              |
| PIO_IRQ5_EN  | 15    | 0     | Enables IRQ5 source from PIO port                           |
| PIO_IRQ5_LEV | 14    | 0     | Selects between level (0) or edge (1) IRQ5 source           |
| PIO_IRQ5_POL | 13    | 0     | Selects between active high (1) or active low (0) IRQ5 type |
| RESERVED     | 12:11 | 00    | Reserved bits                                               |
| PIO_IRQ5_SEL | 10:8  | 000   | Selects which of the PIO lines to use as source for IRQ5    |
| PIO_IRQ4_EN  | 7     | 0     | Enables IRQ4 source from PIO port                           |
| PIO_IRQ4_LEV | 6     | 0     | Selects between level (0) or edge (1) IRQ4 source           |
| PIO_IRQ4_POL | 5     | 0     | Selects between active high (1) or active low (0) IRQ4 type |
| RESERVED     | 4:3   | 00    | Reserved bits                                               |
| PIO_IRQ4_SEL | 2:0   | 000   | Selects which of the PIO lines to use as source for IRQ4    |

#### 17 SPI Master Interface

#### 17.1 SPI Master Control Registers

| Address    | Name         | Туре       | Function                          |
|------------|--------------|------------|-----------------------------------|
| 0x800000D0 | SPI_RXTX_REG | Read/Write | Transmitted/received data.        |
| 0x800000D4 | SPI_CTRL_REG | Read/Write | Interface configuration.          |
| 0x800000D8 | SPI_DIV_REG  | Read/write | SPI interface clock frequency.    |
| 0x800000DC | SPI_SS_REG   | Write      | Select between 2 possible slaves. |

A master SPI interface with 2 slave chip select is available as APB peripheral.

A SPI master is essentially a shift register that simultaneously shifts its contents out onto the SPI\_MOSI\_O (master-out slave-in) output line whilst shifting in received data from the SPI\_MISO\_I (master-in slave-out) input line. The transfer of data is directly controlled by the SPI clock. Data is transferred when the clock is active and held when it is not. This provides a simple synchronous communication interface to and from SPI slaves.

The SPI master must initiate and control all the SPI transfers between itself and the other SPI devices. It must generate the SPI interface clock and cannot respond to an external clock from another SPI device. Individual SPI slaves are selected via slave select lines. The APB\_SPI provides 2 slave select lines so up to 2 slave devices may be directly connected. The slave select pins are directly driven so it is possible to use an external decoder and select up to 4 devices.

The APB\_SPI generates the SPI data rate clock via a 16bit clock divider, which pre-scales the APB PCLK down to the required clock frequency. The divider counts down to zero to produce half an SPI clock cycle. Thus a divider setting of 0 will produce a SPI\_CLK clock of PCLK/2. This allows for a maximum division ratio of  $2^{17}$ .

If required the APB\_SPI can generate an interrupt at the end of a transmission sequence. The interrupt is active high and is cleared down by reading or writing to any APB\_SPI register.

As there is no SPI specification to adhere to, the SPI module has been designed to allow easy interfacing to a

variety of different SPI slaves. Thus the APB\_SPI has several programmable features to cater for different SPI slave devices. The APB\_SPI can be set to transmit and receive data on either edge of the SPI clock. This can be set separately for transmit and receive. The order in which data is transmitted and received can be set (MSB first or LSB first) and the physical polarity of the external SPI\_CLK can be inverted. It can also initiate a transfer of between 1 and 32 bits of data.

During transmission, data is generated on the positive or negative edge of the SPI clock SCLK, according to the value of the C\_SPI\_CTRL\_TX\_NEG control bit. Whilst a transmission is occurring, data is simultaneously received on either the negative or the positive edge according to the value of the C\_SPI\_CTRL\_RX\_NEG control bit. Note that it is expected that data shall be transmitted on one polarity of the clock edge and received on the other. This provides timing and noise immunity between the devices. However it is not particularly sensible to receive data on the positive edge and transmit on the negative edge, as this will effectively loose the first bit of data.

The APB\_SPI uses 3 standard APB registers to implement the divider, the control, and the slave select registers. The data register, which contains the transmit/receive data, is part of the SPI shift register. All registers are read write capable, however they cannot be read whilst a transfer is taking place.

The entire design is fully synchronous and run from the single APB PCLK domain. The SPI clock is only a logical output as it is derived from the PCLK and nothing is actually clocked from it.

## 17.2 Register Details

## SPI\_RXTX\_REG (Addr 0x800000D0)

| Field    | Bits | Rst | Description                                                                                                                                                                                                                        |
|----------|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SPI_RXTX | 31:0 |     | Data. This register is written with the data to be transmitted. After a transmission it contains the received data. Transmit data is justified to the LSB of this register: for a 16 bit transfer, the lower 16 bits will be sent. |

## SPI\_CTRL\_REG (Addr 0x800000D4)

| Field             | Bits  | Rst   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RESERVED          | 31:12 | undef | Reserved bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| SPI_CTRL_LOOPBK   | 11    | 0     | Self test loop back mode. When set, the transmitted data is inverted and fed back into the receive data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| SPI_CTRL_POL      | 10    | 0     | Clock Polarity. When set, it inverts polarity of the SPI clock output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| SPI_CTRL_IE       | 9     | 0     | Interrupt Enable. When set, this causes an interrupt to be generated upon completion of a transmit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| SPI_CTRL_LSB      | 8     | 0     | Least Significant Bit First. This affects the transmission order of the bits of C_SPI_RXTX. It also affects the ordering of received data. When set, it enables the transmission of data LSB first. i.e. C_SPI_RXTX (0) is transmitted first and the first bit of received data will be placed in C_SPI_RXTX (0). Receive data is also assembled in the reverse direction. 0 Enables the transmission of data MSB first. i.e. C_SPI_RXTX (0) is the LAST bit of data to be transmitted and received. The first bit will depend upon the length of the transmission as set by the C_SPI_CTRL_CHAR_LEN bits. |
| SPI_CTRL_CHAR_LEN | 7:3   | 00000 | Data length. This sets the size of the data word to be transmitted. '00000' will transmit 1 bit, '00001' will transmit 2 bits and so on.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| SPI_CTRL_TX_NEG   | 2     | 0     | Transmit on NEG edge. When set, this will cause the transmitter to generate data on each negative edge of the SPI clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| SPI_CTRL_RX_NEG   | 1     | 0     | Receive on NEG edge. When set, this will cause the receiver to capture data on each negative edge of the SPI clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| SPI_CTRL_GO       | 0     | 0     | Start transmission. Setting this bit will initiate a transmission sequence. The bit is automatically cleared at the end of the transmission sequence. Note that it is a condition of the original design that this should not be set when any of the other bits are being changed. Thus the control reg should be written with the appropriate control value and the go bit ='0'. Then it should be rewritten with the same control value and the go bit ='1' to start the transmission. If this condition is not met the behavior of the SPI may be unpredictable.                                        |

## SPI\_DIV\_REG (Addr 0x800000D8)

| Field   | Bits | Rst | Description                                                                                                                                                          |
|---------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SPI_DIV | 15:0 | -   | Prescaler divide. This sets the division ratio of the prescaler used to generate the SPI interface clock. A value of 0x000 divides pclk by 2, 0x0001 by 4 and so on. |

## SPI\_SS\_REG (Addr 0x800000DC)

| Field  | Bits | Rst | Description                                                                                                                                                       |
|--------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SPI_SS | 1:0  |     | Slave select. This drives the slave select output that selects appropriate slave device. The outputs are active low and so are the inverse of the register value. |

#### 18 SPI Slave

#### 18.1 SPI Slave Control Registers

| Address    | Name             | Туре       | Function                     |
|------------|------------------|------------|------------------------------|
| 0x800000E0 | SPISL_DATA_REG   | Read/Write | Transmitted/received data    |
| 0x800000E4 | SPISL_CTRL_REG   | Write      | General control of SPI slave |
| 0x800000E8 | SPISL_STATUS_REG | Read       | Status of SPI slave          |

The SPI slave shares the IO pins of the SPI master by using the SYS\_SPI\_SLAVE register to control the direction of these pins.

The SPI slave device should receive the select, clock and data signals of the SPI master. When SPI test mode is activated by the TEST\_SPI bit of the TEST\_REG, data from the slave is routed back to the master so that a back-to-back test of the master and slave devices can be performed in the silicon.

The SPI slave has a 16 bytes receive and transmit FIFO and a fixed receive/transmit size of 8 bits (1 byte). It can generate an interrupt for each received byte, the interrupt being cleared by a register access. Both the receive and transmit FIFO have a programmable threshold level used to generate an interrupt.

For the receive FIFO an ageing mechanism is available that optionally generates an interrupt after a programmable ageing period, if data is present in the receive FIFO but the receive threshold level has not been reached. The ageing period can be selected between 16, 32 or 64 cycles of a tic signal that has the frequency of GPS\_CLK divided by 1024.

#### 18.2 SPI Slave Operation

Data can be written to the SPI slave up to the limit of the TX FIFO size. This data is transmitted to the master when a transfer occurs. Overfilling the TX FIFO will set the TX FIFO error flag.

The master initiates a transfer by driving the slave select line low and toggles the clock to transfer data. New data is shifted into the slave as the TX data is returned to the master.

The transfer is terminated by the master driving the slave select line high where upon the current contents of the receive register are transferred to the RX FIFO.

If the interrupt generation is enabled, an interrupt is generated. It is cleared by accessing any slave register.

Data can be received up to the limit of the RX FIFO size. If the FIFO is not emptied before the next byte is received then the RX\_FIFO error flag will be set to indicate a buffer overflow.

If the transmit buffer becomes empty and a transfer occurs the TX\_FIFO error flag will be set to indicate a buffer underflow.

The SPI slave reuses the same output pins as the SPI master. The SYS\_SPI\_SLAVE (bit 14 of SYS\_CTRL\_REG) selects the mode of the external signals, with 0 (default) being the master mode.

#### 18.3 Register Details

#### SPISL\_DATA\_REG (Addr 0x800000E0)

| Field      | Bits | Rst | Description |
|------------|------|-----|-------------|
| SPISL_DATA | 7:0  | 0   | Data        |

| SPISL_CIRL_REG (Addr 0x800000E4) |       |     |                                                                                                                                                              |  |
|----------------------------------|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Field                            | Bits  | Rst | Description                                                                                                                                                  |  |
| SPISL_RXAGE                      | 13:14 | 00  | RX ageing value. 00 = disable, 01 = generate an interrupt when age count = 16, 10 when age count = 32 and 11 when age count = 64                             |  |
| SPISL_RX_TRSH                    | 10:12 | 000 | Receive threshold. 000 = disable, else generate an interrupt on receive fifo level = 4 (001), 6 (010), 8 (011), 10 (100), 12 (101), 14 (110), FULL (111)     |  |
| SPISL_TX_TRSH                    | 7:9   | 000 | Transmit threshold. 000 = disable, else generate an interrupt on transmitt fifo level = 4 (001), 6 (010), 8 (011), 10 (100), 12 (101), 14 (110), EMPTY (111) |  |
| SPISL_IRQ_IEN                    | 6     | 0   | If unset, generate an interrupt on every RX byte.                                                                                                            |  |
| RESERVED                         | 5     | 0   | Reserved bit.                                                                                                                                                |  |
| SPISL_CTRL_RX_PURGE              | 4     | 0   | Clear the RX fifo.                                                                                                                                           |  |
| SPISL_CTRL_TX_PURGE              | 3     | 0   | Clear the TX fifo.                                                                                                                                           |  |
| SPISL_CTRL_CTRL_POL              | 2     | 0   | Sclk polarity                                                                                                                                                |  |
| SPISL_CTRL_PHASE                 | 1     | 0   | Sclk Phase (early or late)                                                                                                                                   |  |
| SPISL_CTRL_EN                    | 0     | 0   | Enable the core.                                                                                                                                             |  |

SPISL\_CTRL\_REG (Addr 0x800000E4)

## SPISL\_STATUS\_REG (Addr 0x800000E8)

| -                     | -     |      |                                                                                                                         |
|-----------------------|-------|------|-------------------------------------------------------------------------------------------------------------------------|
| Field                 | Bits  | Rst  | Description                                                                                                             |
| SPISL_STATUS_TXLEVEL  | 12:15 | 0000 | TX FIFO level. Indicates the number of bytes in the FIFO.                                                               |
| SPISL_STATUS_RXLEVEL  | 8:11  | 0000 | RX FIFO level. Indicates the number of bytes in the FIFO.                                                               |
| SPISL_STATUS_RX_ERROR | 7     | 0    | RX FIFO error. Set when attempting to read an empty FIFO or write a full one. Cleared by accessing the status register. |
| SPISL_STATUS_RX_FULL  | 6     | 0    | RX FIFO is full.                                                                                                        |
|                       |       |      |                                                                                                                         |
| SPISL_STATUS_RX_EMPTY | 5     | 1    | RX FIFO is empty.                                                                                                       |
| SPISL_STATUS_TX_ERROR | 4     | 0    | TX FIFO error. Set when attempting to read an empty FIFO or write a full one. Cleared by accessing the status register. |
| SPISL_STATUS_TX_FULL  | 3     | 0    | TX FIFO is full.                                                                                                        |
| SPISL_STATUS_TX_EMPTY | 2     | 1    | TX FIFO is empty.                                                                                                       |
| SPISL_STATUS_BUSY     | 1     | 0    | Busy flag. Indicates that the slave is in the middle of a transfer.                                                     |
| SPISL_STATUS_INT      | 0     | 0    | Interrupt flag - set by end of an SPI sequence, reset by accessing any register.                                        |

## 19 DSU Port

#### 19.1 DSU Control Registers

| Address    | Name                | Туре       | Function                               |
|------------|---------------------|------------|----------------------------------------|
| 0x9000000  | DSU_CTRL_REG        | Read/Write | DSU main control register              |
| 0x90000010 | AHB Break Address 1 | Read/Write | AHB Address/Instruction to be detected |
| 0x90000014 | AHB Mask 1          | Read/Write | Mask to apply on break value 1         |
| 0x90000018 | AHB Break Address 2 | Read/Write | AHB Address/Instruction to be detected |
| 0x9000001C | AHB Mask 2          | Read/Write | Mask to apply on break value 2         |

The LEON processor includes hardware debug support to aid software debugging on target hardware. The support is provided through two modules: a debug support unit (DSU) and a debug communication link (DCL) (see Figure 3). The DSU can put the processor in debug mode, allowing read/write access to all processor registers and cache memories. The debug communication link implements a simple read/write protocol and uses standard asynchronous UART communications.

The optional trace buffer offered by the original Leon DSU is not implemented on the NJ1030A.

The debug support unit is used to control the processor debug mode. The DSU is attached to the AHB bus as slave, occupying a 2 MByte address space. Through this address space, any AHB master can access the processor registers. The DSU control registers can be accessed at any time, while the processor registers and caches can only be accessed when the processor has entered debug mode. In debug mode, the processor pipeline is held and the processor state can be accessed by the DSU. Entering the debug mode can occur on the following events:

- executing a breakpoint instruction
- integer unit hardware breakpoint/watchpoint hit (trap 0xb)
- rising edge of the external break signal (DSUBRE)
- setting the break-now (BN) bit in the DSU control register
- · a trap forcing the processor to enter error mode
- occurrence of any or a selection of traps as defined in the DSU control register
- after a single-step operation
- DSU breakpoint hit

The debug mode can only be entered when the debug support unit is enabled through an external pin (DSUEN). When the debug mode is entered, the following actions are taken:

- PC and nPC are saved in temporary registers (accessible by the debug unit)
- an output signal (DSUACT) is asserted to indicate the debug state
- the timer unit is (optionally) stopped to freeze the LEON timers and watchdog

The instruction that caused the processor to enter debug mode is not executed, and the processor state is kept unmodified. Execution is resumed by clearing the BN bit in the DSU control register or by de-asserting DSUEN. The timer unit will be re-enabled and execution will continue from the saved PC and nPC. Debug mode can also be entered after the processor has entered error mode (for instance when an application has terminated and halted the processor). The error mode can be reset and the processor restarted at any address.

## 19.2 External DSU signals

The DSU uses five external signals: DSUACT, DSUBRE, DSUEN, DSURX and DSUTX. They are used as follows:

- DSUACT DSU active (output). This active high output is asserted when the processor is in debug mode and controlled by the DSU.
- DSUBRE DSU break enable. A low-to-high transition on this active high input will generate break condition and put the processor in debug mode. After a low-to-high transition is detected, up to four instructions will be executed before debug mode is entered.
- DSUEN DSU enable (input). The active high input enables the DSU unit. If de-asserted, the DSU trace buffer will continue to operate but the processor will not enter debug mode.
- DSURX DSU receiver (input). This active high input provides the data to the DSU communication link receiver.
- DSUTX DSU transmitter (output). This active high output provides the output from the DSU communication link transmitter.

## 19.3 DSU Breakpoint Registers

The DSU offers two breakpoints registers for matching either a AHB address or an executed processor instructions. A breakpoint hit is typically used to put the processor in debug mode. A mask register is associated to each breakpoint register allowing breaking on a block of the break value, as specified by the bits that are set to '1' in the mask. To break on executed instructions, the EX bit should be set in the BADDRx register. To break on AHB load or store accesses, the LD and/or ST bits must be set in the MASK register.

## 19.4 DSU UART

The DSU communication link consists of a UART connected to the AHB bus as a master. A simple communication protocol is supported to transmit access parameters and data. A link command consist of a control byte, followed by a 32-bit address, followed by optional write data. If the LR bit in the DSU control register is set, a response byte will be sent after each AHB transfer. If the LR bit is not set, a write access does not return any response, while a read access only returns the read data. Data is sent on 8-bit basis.

Through the communication link, a read or write transfer can be generated to any address on the AHB bus. A response byte can optionally be sent when the processor goes from execution mode to debug mode. Block transfers can be performed by setting the length field to n-1, where n denotes the number of transferred words. For write accesses, the control byte and address is sent once, followed by the number of data words to be written. The address is automatically incremented after each data word. For read accesses, the control byte and address is sent once and the corresponding number of data words is returned.

The UART interface automatically detects the baudrate once the DSU monitor program is launched on the host.

The NJ1030A has a dedicated port for the DSU UART. However, when the DSU\_MUX pin is high, the DSU TX and RX signal are connected to the TX and RX signals of UART1. This allows the access to the DSU port for debug or SW update purposes when no dedicated RS-232 buffers is present on the PCB for the DSU port.

## 19.5 Common operations

#### 19.5.1 Instruction breakpoints

Instruction breakpoints can be inserted by writing the breakpoint instruction (ta 1) to the desired memory address

## 19.6 DSU Register Details

#### DSU\_CTRL\_REG (Addr 0x9000000)

(software breakpoint) or using any of the four integer unit hardware breakpoints. Since cache snooping is only done on the data cache, the instruction cache must be flushed after the insertion or removal of software breakpoints. To minimize the influence on execution, it is enough to clear the corresponding instruction cache tag valid bit (which is accessible through the DSU).

The two DSU hardware breakpoints should not be used for software debugging since there is a 4-instruction delay from the breakpoint hit before the processor enters the debug mode.

## 19.5.2 Single stepping

By setting the SS bit and clearing the BN bit in the DSU control register, the processor will resume execution for one instruction and then automatically return to debug mode.

## 19.5.3 Booting from DSU

By asserting DSUEN and DSUBRE at reset time, the processor will directly enter debug mode without executing any instruction. The system can then be initialised from the communication link, and applications can be downloaded and debugged. Additionally, external (flash) proms for standalone booting can be re-programmed.

| Field    | Bits  | Rst   | Description                                                                                                                                                                                                                         |
|----------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RESERVED | 31:20 | undef | Unused bits.                                                                                                                                                                                                                        |
| RE       | 19    | undef | Reset error mode (RE) - if set, will clear the error mode in the processor.                                                                                                                                                         |
| DR       | 18    | undef | Debug mode response (DR) - if set, the DSU communication link will send a response word when the processor enters debug mode.                                                                                                       |
| LR       | 17    | undef | Link response (LR) - If set, the DSU communication link will send a response word after AHB transfer.                                                                                                                               |
| SS       | 16    | undef | Single step (SS) - if set, the processor will execute one instruction and the return to debug mode.                                                                                                                                 |
| PE       | 15    | undef | Processor error mode (PE) - returns '1' on read when processor is in error mode, else '0'.                                                                                                                                          |
| EE       | 14    | undef | EE - value of the external DSUEN signal (read-only).                                                                                                                                                                                |
| EB       | 13    | undef | EB - value of the external DSUBRE signal (read-only).                                                                                                                                                                               |
| DM       | 12    | undef | Debug mode (DM). Indicates when the processor has entered debug mode (read-only).                                                                                                                                                   |
| RESERVED | 11    | undef | Unused bits                                                                                                                                                                                                                         |
| BZ       | 10    | undef | Break on error traps (BZ) - if set, will force the processor into debug mode on all <i>except</i> the following traps: priviledged_instruction, fpu_disabled, window_overflow, window_underflow, asynchronous_interrupt, ticc_trap. |
| BX       | 9     | undef | Break on trap (BX) - if set, will force the processor into debug mode when any trap occurs.                                                                                                                                         |
| ВВ       | 8     | undef | Break on DSU breakpoint (BD) - if set, will force the processor to debug mode when a DSU breakpoint is hit.                                                                                                                         |
| BN       | 7     | undef | Break now (BN) -Force processor into debug mode. If cleared, the processor will resume execution.                                                                                                                                   |

| BS       | 6 | undef | Break on S/W breakpoint (BS) - if set, debug mode will be forced when a breakpoint instruction (ta 1) is executed.                                                                          |
|----------|---|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BW       | 5 | undef | Break on IU watchpoint - if set, debug mode will be forced on an IU watchpoint (trap 0xb).                                                                                                  |
| BE       | 4 | undef | Break on error (BE) - if set, will force the processor to debug mode when the processor would have entered error condition (trap in trap).                                                  |
| FT       | 3 | undef | Freeze timers (FT) - if set, the scaler in the LEON timer unit will be stopped during debug mode to preserve the time for the software application.                                         |
| BT       | 2 | undef | Break on trace (BT) - if set, will generate a DSU break condition on trace freeze.                                                                                                          |
| DM       | 1 | undef | Delay counter mode (DM). In mixed tracing mode, setting this bit will cause the delay counter to decrement on AHB traces. If reset, the delay counter will decrement on instruction traces. |
| RESERVED | 0 | undef | Unused bit                                                                                                                                                                                  |

# DSU\_BADDR1/2\_REG (Addr 0x90000010/18)

| Field    | Bits | Rst   | Description                                               |
|----------|------|-------|-----------------------------------------------------------|
| BADDR    | 31:2 | undef | AHB Address or instruction to be matched                  |
| RESERVED | 1    | undef |                                                           |
| EX       | 0    | undef | If '1' then a break on executed instruction is generated. |

# DSU\_BMASK1/2\_REG (Addr 0x90000014/1C)

| Field | Bits | Rst   | Description                                      |
|-------|------|-------|--------------------------------------------------|
| BMASK | 31:2 | undef | AHB Address or instruction to be matched         |
| LD    | 1    | undef | If '1' then a break on load access is generated. |
| ST    | 0    | undef | If '1' then a break on store access is generated |

# 20 ADC

## 20.1 ADC Control Register

| Address    | Name         | Туре       | Function             |
|------------|--------------|------------|----------------------|
| 0x800000B0 | ADC_CTRL_REG | Read/Write | ADC value and enable |

An 8 bit ADC with a sampling rate of 1kHz is available. Combined with an on-chip temperature sensor with a resolution of 0.75°C, the ADC achieves temperature compensation in the range between -60 to 132°C. This eliminates the need of an expensive TCXO in many GPS applications.

Seven analog inputs are multiplexed to the ADC: the usable range is between 0V and 1.2V (higher voltages are treated as 1.2V). This allows the seamless integration of other sensors like a compass or a gyroscope.

The temperature sensor provides an 8 bit value proportional to the chip temperature that can be then used by the SW to be translated into a temperature value between -60°C to 132°C with a 0.75°C resolution. The temperature read mechanism is based on a 10 bit ADC CTRL REG register which entails the 8 bit ADC\_VALUE, the ADC\_EN bit and the ADC\_VALID bit.

The ADC is built with a successive approximation register approach. The ADC\_VALUE is converted into an analog signal by a DAC; this analog signal is compared with the signal to be converted into digital. The comparator delivers a COMP ='1' value if the incoming analog signal is higher than the one produced by the DAC. The procedure is repeated for each bit of the ADC\_VALUE, starting from the most significant bit. The procedure is implemented by a finite state machine that is started by the ADC EN signal and stops after asserting an ADC\_VALID signal.

# 20.2 Temperature Sensor Utilization Procedure

From the CPU perspective:

The CPU writes a '1' in the ADC EN bit

The CPU polls the ADC\_CTRL\_REG until a high ADC VALID bit is found

When the enable bit is activated the ADC controlling logic behaves in the following way:

The ADC\_VALUE is initialised to '0'

Then from the MSB down to the LSB of ADC VALUE the bit is set to '1' 0

if COMP ='1' then the bit is maintained at '1' 0

else it is cleared  $\cap$ 

The ADC VALID bit is set

A CPU read operation with a high ADC\_VALID, clears the ADC EN bit so that the temperature sensor is deactivated.

The ADC has 7 external analog inputs that are selected by the value of the SYS\_ADC\_SEL bits of the SYS\_CTRL\_REG. Default value is '000' and selects the Tsens input, while '001' to '111' select ANALOG IN[0] to ANALOG\_IN[6].

Note that AIN[0..6] are high impedance inputs, the voltage should be DC or vary less than 1 LSB/ms (1 LSB = 4.85 mV).

# 20.3 Register Details

# ADC CTRL REG (Addr 0x800000B0)

| Field     | Bits | Rst  | Description                                                                                                                       |
|-----------|------|------|-----------------------------------------------------------------------------------------------------------------------------------|
| ADC_EN    | 9    |      | ADC Enable. Set by the CPU to initiate a conversion. Autonomously cleared at the end of a conversion when ADC_VALID is set.       |
| ADC_VALID | 8    |      | End of conversion. Set by the ADC when the conversion is terminated. Once set, it can be cleared by a read from the ADC_CTRL_REG. |
| ADC_VALUE | 7:0  | 0x00 | ADC conversion value.                                                                                                             |

# 21 Power Supplies

In order to offer different interfacing options, while providing options to minimize the power consumption, the NJ1030A requires a total of 6 different power supplies for pad ring, core and back-up battery:

- DVSU: 1.6V to 3.6V. Power supply for the power up unit and the portion of pad ring with EXT\_WAKE, CLK\_SOURCE, EXT\_RESETN, EXT\_VREGN and EXT\_EN. This is the only power supply that must be present in order to wake up the system from a sleep mode with an EXT\_WAKE (or from an internall RTC\_WAKE or IRQ).
- DVDD 1.6V to 3.6V. Supply (noisy) for pad ring and voltage regulator (to generate LVDD). The level of this voltage is determined by the external digital components used in the system. This power supply shall be monitored by the power supervisor and shall never be pulled below LVDD.
- DAVDD 1.8V to 3.6V. Power supply (quiet) for the onchip analog blocks (excl. Voltage Regulator). DAVDD shall never be turned off when DVDD is present. The easiest way to guarantee this is to derive DAVDD from DVDD. In small systems that generate little noise DAVDD may be connected directly to DVDD, in larger systems that generate much noise an RC filter (e.g. 100 $\Omega$ , 10nF) should be used
- TVDD: 1.6V to 3.6V. Separate power supply for the IF interface to the RF front-end. If the front-end is sourcing the clock signal then TVDD shall be set equal to DVDD +/- 200mV.
- LVDD: 1.2V to 1.98V. Power supply for the core. The core voltage may be adjusted between 1.2V and 1.8V (1.98V max), depending on the clock frequency being used. The voltage regulator may be used to supply LVDD to the core.
- VBAT: 1.2V to 1.98V. Back-up voltage used by RTC and backed-up memory when the main power is removed. Usually connected to a battery (rechargeable or not) or to a capacitor.

DVSS, DAVSS, TVSS and LVSS are the negative supply pins. They all shall be connected to the ground plane with low ohmic, low inductance connections (fan-out and via).

The core power supply - LVDD - may be generated by the on-chip voltage regulator and its level is set by the feedback voltage divider connected to pin VFB. The on-chip voltage regulator can be used in low frequency low power configurations that consume up to 15mA; otherwise an external voltage regulator is required. The on-chip voltage regulator can be disabled by setting pin EXT\_VREGN to 0.

VBAT shall be connected to a back-up voltage, typically a battery or a supercapacitor. A battery is recommended if long back-up times of several months are desired. Many battery types and chemistries may be used as long as their voltage is within the specified range. 1.5V primary batteries such as alkaline or silver oxide and 1.5V rechargeable batteries such as nickel metal hydride or manganese-titanium-lithium are all compatible with the NJ1030A. In case a rechargeable battery can be removed by the user, some protection means is required to prevent the open-circuit voltage of the charging circuit to go above 1.98V. The LOW\_BATTERY bit in the SYS\_CTRL\_REG is set to 1 when a VBAT voltage is lower than 1.1V (falling).

## 21.1 Valid power supplies combinations

Following table lists the valid power supplies combinations

| DVSU | DVDD | DAVDD | LVDD | Status                |
|------|------|-------|------|-----------------------|
| 0    | 0    | 0     | 0    | Power off             |
| 1    | 0    | 0     | 0    | Sleep mode            |
| 1    | 1    | 1     | 0    | Sleep mode            |
| 1    | 1    | 1     | 1    | Operating or stand by |

All other combinations of power supplies must be avoided because they are either invalid or may cause a permanent chip damage in some situations.

#### 21.2 Power Supply Sequence

**DVSU:** is the first power supply to be applied.

**DVDD/DAVDD**: must be applied at the same time. Typically DAVDD is derived from DVDD through a RC filter. The resulting delay on DAVDD is acceptable

**LVDD**: can be applied and removed freely (on or off chip), assuming the other power supplies are all present and stable.

Note that TVDD is completely independent in the power supply sequence.

#### 21.3 Power Supervisor

VRTC1 and VRTC2 are internal power supplies. VRTC1 is the power supply of the RTC logic and of the battery backed up memory. VRTC2 is the power supply of the RTC oscillator.

- VRTC1: When the power that is supervised (typically DVDD) goes under the specified limit (defined in 23.2), VRTC1 switches from LVDD to VBAT.
- VRTC2: Similarly, when the power that is supervised goes under the specified limit, VRTC2 switches from DAVDD to VBAT.

#### 22 Reset Sequence

The system reset sequence is asynchronously initiated by an EXT\_RESETN low, a WATCHDOG low (if not disabled by the WDG\_RESET\_DISABLE bit in the SYS\_CTRL\_REG) or a POWER\_OK low signal given by the internal power supervisor.

The recovery from a reset goes through two sequential phases. In the first one the validity of the SYS\_CLK signal is verified by a 16 bit counter that must overflow.

Once the clock has been verified, a second counter (6 bits) is used to keep the internal reset low. When this counter overflows the internal reset is released (synchronously) and the boot procedure is initiated by the CPU.

A reset procedure initiated by a POWER\_OK low signal goes through the two phases, while in the case where a EXT\_RESETN or a WATCHDOG started the reset procedure in a valid power supply situation, only the second reset phase is entered

# 23 Operating Modes

The system has 3 main operating modes that can be set under control of the CPU: FULLY ACTIVE, STAND\_BY and SLEEP.

## 23.1 Fully Active Mode

This is the normal operating mode at the selected clock frequency. For the individual blocks the appropriate clocking mode is selected by the CCTRL\_REG. Power supplies are in the following status.

| Power Supply | Status                   |
|--------------|--------------------------|
| DVSU         | On                       |
| DVDD         | On                       |
| LVDD         | On, internal or external |
| TVDD         | On                       |
| DAVDD        | On                       |
| VRTC1        | LVDD                     |
| VRTC2        | DAVDD                    |

## 23.2 Stand By

The NJ1030A power supplies are in the same status as the fully active mode, while the CPU stops its own clock when no further activity is needed. The clocking of the peripherals is set according to their activity. The CPU clock is reactivated at the occurrence of any of the interrupts.

## STAND\_BY sequence:

1. The CPU sets the DMD\_EN bit for the CPU\_CLK and the MC\_CLK.

2. After the memory controller has finished any pending transfer operation it releases its clock demand signal, so that the clock of the CPU and the MC clocks are shut down.

3. As soon as an interrupt occurs, the DMD\_EN bits of the CPU and the memory controller are cleared so that program execution is resumed. Program execution restarts from the point where sleep mode was entered.

## 23.3 Sleep Mode

Under control of the CPU (setting the SYS\_GO\_SLEEP bit of SYS\_CTRL\_REG), the internal analog blocks are deactivated. If enabled, internal LVDD generation is shut down and the external EXT\_EN signal goes to 0. If used, the on chip oscillator is switched off while an external clock source is used, then the clock signal path is switched to the internal source.

Operation is resumed with a normal reset procedure, triggered by either a RTC\_WAKE, an EXT\_WAKE or a system reset. Resuming operation doesn't require the presence of a clock.

During SLEEP MODE, power supplies are in the following status:

| Power Supply | Status                                  |
|--------------|-----------------------------------------|
| DVSU         | On, necessary to recover                |
| DVDD         | Depends on external source              |
| LVDD         | Off when internally generated,          |
|              | otherwise it depends on the ext. source |
| TVDD         | Depends on external source              |
| DAVDD        | Depends on external source              |
| VRTC1        | VBAT                                    |
| VRTC2        | VBAT                                    |

When LVDD is off and DVDD is still present, the output and bidirectional signal pins are put into a pre-defined mode, as defined in the pinout table.

When NJ1030A is in sleep mode and only DVSU is provided, the total consumption will be of few tens nA (plus about 4uA for VBAT), but since DVDD, DAVDD, TVDD are off, is necessary to be sure that no activity is present on the pins under DVDD/DAVDD/TVDD domain, otherwise the chip could be damaged: if activity on digital or analog I/Os is unavoidable, then it is necessary to keep the necessary power supplies on.

Leaving DVDD, DAVDD or TVDD on during sleep mode will cause a further consumption of few tens nA if there is little activity on the pins under their domain. If the activity is bigger, the consumption can be of several uA.

## 23.4 Power Up unit

The fully asynchronous power up unit, in the DVSU power supply domain implements the following functions:

- Provide an asynchronous mechanism to resume from the SLEEP mode, which is entered by setting of the GO\_SLEEP bit by the CPU. Exit from this mode is possible from a status without clock and LVDD power by means of the RTC\_WAKE or the EXT\_WAKE or an EXT\_RESETN.
- Generate the enable signal for the analog blocks (voltage regulator, power supervisor and bandgap reference). The enable deactivates these blocks when the system enters SLEEP\_MODE.
- Generate the enable signal for the main oscillator that is always disabled when an external clock source is used and is disabled in SLEEP\_MODE if the on chip oscillator is used.
- Generate the select signal for the main oscillator so that when the system is in SLEEP\_MODE the internal clock is selected, otherwise the clock source is selected as a function of the CLK\_SOURCE.
- Generate the EXT\_EN signal to control external components when entering and exiting SLEEP mode.

## Figure 12: Powerup circuit



#### 24.1 Voltage Regulator Feedback Voltage (VFB)

When the internal voltage regulator is enabled, VFB is used to set its output voltage. A resistive divider (R1 and R2 in picture 13) must be placed between LVDD and VSS.

 $Vh = Vref^{(R1+R2)/R2}$ 

R1 is the top resistor and R2 the bottom one. The sum of R1 and R2 should be in the range of 10 k $\Omega$  to 100k $\Omega$ . Higher values might make the regulator more sensitive to noise on LVDD, smaller values will result in high load current. C<sub>comp</sub> = 1uF may be necessary if R1 is higher than 20k $\Omega$  or if high stray capacitance on pin VFB is anticipated.

## Figure 13 VFB connection diagram

A capacitor should be placed between LVDD and VFB if the resistor's values are high, in order to avoid lowpass behavior in the feedback circuit (1nF recommended).

A capacitor of at least 22nF (recommended 100nF) must be connected between LVDD and LVSS on both sides of the chip (C1 and C2), in addition to the usual 1uF (C3) decoupling capacitor. C3 may be increased if desired to reduce noise on LVDD.

When an external regulator is used, the internal voltage regulator must be disabled (pin EXT\_VREGN). VFB may be connected either to VSS, LVDD or any other voltage in between. VFB must not be left open.



Vh = Vref\*(R1+R2)/R2

 $VI = Vref^{*}(R1+R2)/R2 - I_{HYST}^{*}R1$ 

with  $I_{HYST} = 1.6 \mu A$  typically.

Where R1 is the top resistor and R2 the bottom one and

It is recommended to monitor DVDD or the earliest voltage that will fall, e.g. the supply of the on-board regulators.

#### 24.2 Voltage Supervisor Input (VSI)

This pin is used to set the trip voltage of the power supervisor. A resistive divider (R1 and R2) must be placed between the voltage that must be monitored and VSS.

If xVDD is the power supply to be supervised:

- $xVDD > Vh \rightarrow$  the power level is considered as OK.
- xVDD < VI → the power level is considered as NOT OK and the chip will be reset.

#### Figure 14. VSI connection diagram



## 24.3 Voltage Reference Output (VREF)

This is the voltage reference output. A 10nF capacitor must be placed between VREF and VSS.

## Figure 15. Vref connection diagram

The voltage reference can source about  $200\mu$ A. It cannot sink any current (no pulldown). It can be used externally, but no noise should be introduced on this pin.



#### 24.4 Main Oscillator (MXI and MXO).

The main oscillator of the NJ1030A can be configured as TCXO buffer, crystal oscillator or as digital input (CMOS swing). Figure 4 Clocking scheme shows these configurations.

#### a) TCXO

This option is the most common configuration of the NJ1030A and is recommended whenever possible. A TCXO with 0.8-1V peak-to-peak clipped sine output shall be used. Frequency accuracy directly affects GPS receiver performance (especially search time), thus high accuracy TCXOs are highly recommended. Rakon IT5300B with a temperature characteristic of +/-0.5ppm has been tested extensively and is recommended with the NJ1030A. The maximum frequency is 39.6MHz.

The connections of a TCXO are the following:

- Enable oscillator/TCXO buffer connect CLK\_SOURCE to DVSU,
- Connect TCXO to MXO via a 1nF capacitor,
- Decouple MXI to VSS with a 1nF capacitor.

## b) Crystal Oscillator

This option may be required in very low cost systems. Before selecting this option however, the user must be aware that system performance – especially search time - will be degraded by a less accurate clock source. The crystal oscillator is a parallel resonant Pierce type. MXI is the input and MXO is the output of the inverting amplifier.

The crystal unit shall be a high accuracy AT-cut device with temperature characteristic of +/-5ppm or better and an equivalent series resistance (ESR) less than  $100\Omega$ . The drive level will be about 10-20µW, which depends on the exact characteristics of the crystal. Fundamental resonant crystals with a maximum frequency of 39.6MHz

can be used. Types such as NDK 5032SA or TEW TSS-6 have been tested and work well with the NJ1030A. 3rd harmonic overtone crystals may also be accommodated if a trap at the fundamental frequency is inserted. Please follow the recommendations of the crystal manufacturer for suitable oscillator circuits and component values.

The load capacitors C1 and C2 determine the exact frequency of the crystal oscillator, and shall therefore be precision ceramic NPO capacitors.

The load capacitance recommended by the crystal manufacturer shall be scrupolously respected. Since C1 and C2 are effectively connected in series, their value (including PCB parasitic capacitances) shall be twice the total load capacitance specified by the crystal manufacturer. PCB parasitic capacitance has undefined temperature coefficient and shall therefore be minimized. Traces to the crystal and its load capacitors shall be kept as short as possible and well spaced from any ground/power plane. Fine frequency adjustment is mandatory. A trimmable capacitor can be used as C1, and adjustment to +/- 1ppm at ambient temperature is recommended.

The connections of a crystal are the following:

- Enable oscillator/TCXO buffer connect CLK\_SOURCE to DVSU
- Connect XTAL between MXI and MXO
- Connect load capacitors between MXI-VSS and MXO-VSS

#### c) CMOS Digital Clock Source

This option is required if the maximum operating frequency of the NJ1030A has to be realized. A signal with CMOS levels - <0.3DAVDD and >0.7DAVDD - shall be used. Its maximum frequency is 98.2MHz. This signal may be generated either by a TCXO/OCXO directly or via a PLL frequency synthesizer. Its accuracy defines

receiver performance and shall be selected accordingly. For best performance +/- 0.5ppm is recommended, with +/- 5ppm as maximum acceptable limit.

The connections of a digital clock source are the following:

- Disable oscillator/TCXO buffer CLK\_SOURCE to VSS.
- Connect clock source to MXI directly (DC, no capacitors).
- MXO may be left floating or connected to VSS. MXI and MXO are the input and output pins of the main oscillator.

## 24.5 RTC Oscillator (RXI and RXO).

The RTC oscillator is a Pierce oscillator. RXI is the input and RXO is the output of the inverting amplifier.

The crystal shall be a 32.768kHz tuning fork (watch) type. Crystals with equivalent series resistance around 50-80k $\Omega$  work best, while the maximum allowed value is 200k $\Omega$ . The drive level will be about 0.1-0.2 $\mu$ W, depending on the exact characteristics of the crystal.

Datasheet

The load capacitors C1 and C2 determine the exact frequency of the crystal oscillator, and shall therefore be high quality types such as ceramic NPO capacitors, with 5% tolerance or better. Since C1 and C2 are effectively connected in series, their value (including PCB parasitic capacitances) shall be twice the total load capacitance specified by the crystal manufacturer.

In order to achieve good RTC precision it is important that the crystal load capacitance is determined by the load capacitors and not by PCB strays. Traces to the RTC shall be kept short and well spaced from any ground/power plane. For improved precision an adjustable capacitor may be used for C1, or a TCXO such as DALLAS (MAXIM) DS32kHz may be used. Please follow the directions given in DS32kHz datasheet to connect it to the NJ1030A RTC.

Resistor R1 is a high ohmic DC bias resistor and is required in all applications. Its exact value is not important.  $10M\Omega$  works well in oscillator applications, while it can be reduced down to  $1M\Omega$  in TCXO applications.

# 25 Timings

# Figure 16 EBI Timing diagrams





| Parameter    | Description                                 | Min                | Max              | Unit |
|--------------|---------------------------------------------|--------------------|------------------|------|
| T_CLK_prop   | Propagation from external to internal clock |                    | 5                | ns   |
| T_ADDR       | Time for address to become valid            |                    | 2 + (90s/F) x Cl | ns   |
| T_CSN_f      | CSN fall time                               |                    | 2 + (60s/F) x Cl | ns   |
| T_CSN_r      | CSN raise time                              |                    | 3 + (90s/F) x Cl | ns   |
| T_OEN_f      | OEN fall time                               |                    | 2 + (60s/F) x Cl | ns   |
| T_OEN_r      | OEN raise time                              |                    | 3 + (90s/F) x Cl | ns   |
| T_DATA_setup | Data setup time                             | 6 + (0.45s/F) x Cl |                  | ns   |
| T_DATA_hold  | Data hold time                              | 0                  |                  | ns   |
| T_RWEN_f     | RWEN fall time                              |                    | 3 + (60s/F) x Cl | ns   |
| T_RWEN_r     | RWEN raise time                             |                    | 4 + (90s/F) x Cl | ns   |
| T_DIR_f      | DIR fall time                               |                    | 3 + (60s/F) x Cl | ns   |
| T_DIR_r      | DIR raise time                              |                    | 4 + (90s/F) x Cl | ns   |
| T_DATA_v     | Time for data to become valid               |                    | 3                | ns   |
| T_DATA_z     | Time for data to become invalid             | 4                  |                  | ns   |
| T_IOSN_f     | IOSN fall time                              |                    | 3 + (60s/F) x Cl | ns   |
| T_IOSN_r     | IOSN rise time                              |                    | 3 + (90s/F) x Cl | ns   |
| T_WRITEN_f   | WRITEN fall time                            |                    | 3 + (60s/F) x Cl | ns   |
| T WRITEN r   | WRITEN raise time                           |                    | 3 + (90s/F) x Cl | ns   |

# 26 PCB Layout Recommendations

The NJ1030A is a digital IC that may generate interference to a nearby antennaor front-end if the PCB is not laid out carefully. Operation of the analog portion of the NJ1030A (oscillators, AD converter inputs) could also be disturbed by an improper PCB design. In order to get good performance from the NJ1030A the following recommendations should be followed.

- Ground/power planes shall be used. All VSS supplies shall be connected to the ground plane with short lines (fan-outs and vias) and the ground plane shall be kept continuous and with as little interruptions as possible, in order to minimize stray inductance.
- All DVDD pins either to the NJ1030A or to external devices - shall be connected to a power plane, possibly placed just above or below the layer chosen as ground plane.
- The spacing between power and ground planes should be minimized by minimizing the thickness of the dielectric between them. This reduces leakage inductance between power and ground planes and thus radiated EMI. A good choice could be to use two layers separated by a single layer of prepreg as ground and power planes.
- The two LVDD pins shall be connected together with either a large track or a small power plane just under the IC. The same layer chosen for the DVDD power plane may be used also for LVDD.
- Decoupling capacitors shall be placed as close as possible to the IC packages (either the NJ1030A or the external devices) and connected with short vias to the ground/power planes.
- The tracks connecting the TCXO or the RTC crystal to the NJ1030A are sensitive to x-talk from digital signals. Please keep these connections as short as possible, mount the RTC crystal and its load capacitors close to the NJ1030A package and do not cross TCXO or RTC tracks with digital tracks. A RTC going too fast is in most cases the result of interference to the RTC crystal.
- Connections to the AD converter inputs shall also be kept short and routed away from digital tracks, especially if high impedance sources (e.g. high ohmic voltage dividers) are used. Capacitors from ADC input to AVSS may help reduce interference

from digital signals but are no replacement for a proper PCB layout.

• A very effective means to reduce radiated EMI is to keep all tracks carrying digital signals as short as possible and their capacitive load – including strays as small as possible. Stray capacitances may be reduced by increasing the spacing from the routing to the ground/power planes, e.g. by placing a thicker PCB core between them. This is obviously particularly important in modules with integrated antenna.

To guarantee proper mounting of the IC, it is recommended that the PCB land patterns shown in Figure 20 and Figure 21 are used. In particular the following requirements shall be adhered to:

- The PCB shall meet the solderability requirements of IPC/JEDEC J-STD-003A and shall be flat to within 0.1mm per cm.
- All BGA lands shall be connected with traces of similar size, such that they have a similar thermal mass. Ground/power planes shall not be connected directly to a land - a thermal trap (via, fan-out) is required. This is to improve soldering and to reduce the chance of cold solder joints.
- Vias inside PCB lands shall be plugged and metallized on top to prevent solder from wicking through the via hole. Unplugged vias inside PCB lands are not allowed.
- A solder mask with tight openings is recommended to ensure that some solder mask remains between the PCB lands.
- Any unrelated copper under the package (traces, fan-outs) shall be completely covered with solder mask. Via holes shall also be covered, no solder mask opening is allowed. This is to prevent that short-circuits between adjacent balls may occur.

PCB layout examples can be found in the NB1042A datasheet. PCB Gerber of data of sucha device is also available and can be used as recommended layout.

# 27 Mounting Recommendations

The NJ1030A shall be mounted on the PCB by reflow soldering. Please follow these recommendations:

- Stainless steel stencils with a thickness of 125-150 $\mu$ m are recommended for solder paste application. For improved solder paste release the walls of the apertures should be tapered.
- Pb-free solder paste shall be used. Sn/Ag/Cu alloys with a melting point of 217°C are recommended. A typical reflow temperature profile is shown in Figure 17. The recommendations given by the solder paste manufacturer should also be followed.

Typically, the area under the profile curve, bounded by the liquidus temperature, defines the quality of the solder joint. Too little area leads to cold solder joints, which are a reliability risk. Too much area could result in undesirable metallurgical issues that could also be a reliability risk.

Mounting the NJ1030A with Pb-containing alloys such as the old Sn60%-Pb40% alloy is possible but is not recommended and deprecated. The user will need to run appropriate experiments to define reflow conditions and possible reliability issues if alloys other than Sn/Ag/Cu are desired.

After assembly the board shall be cleaned to remove solder flux residue. Solder flux residue between pads or on RF components may cause high leakages which may increase RF losses to an unacceptable level. Ultrasonic cleaning shall not be used since many parts - especially crystals, SAW filters and TCXO - may be damaged. Noclean solder flux may be used to minimize cleaning requirements.

#### **Classification Reflow Profile**

| Profile Feature                                            | Pb-Free Assembly |
|------------------------------------------------------------|------------------|
| Average Ramp Up Rate                                       | 3 °C/second max. |
| Preheat                                                    |                  |
| Temperature Min (T <sub>Smin</sub> )                       | 150 °C           |
| Temperature Min (T <sub>Smax</sub> )                       | 200 °C           |
| Time (t <sub>Smin</sub> to t <sub>Smax</sub> )             | 60 to 180 s      |
| Time maintained above                                      |                  |
| TL                                                         | 217 °C           |
| tL                                                         | 60 to 150 s      |
| Peak/Classification Temperature (T <sub>P</sub> )          | 260 °C           |
| Time within 5 °C of actual Peak Temperature T <sub>P</sub> | 20 to 40 s       |
| Ramp-Down Rate                                             | 6 °C/second max. |
| Time 25°C to Peak Temperature                              | 8 minutes max.   |

## Figure 17: Recommended reflow profile for lead-free solder paste



# 28 Physical Dimensions





# NJ1030A-ds – Rev. 1.3 – April 2005







# Figure 20: NJ1030AU5 - 7x7mm 0.5mm package footprint (measures in mm)



# Figure 21: NJ1030AU8 - 10x10mm 0.8mm package footprint (all measures in mm)



## Notes:

## Ordering information

| Part      | Description            |
|-----------|------------------------|
| NJ1030AU5 | GPS Baseband Processor |
|           | BGA 7x7, 0.5mm pitch   |
| NJ1030AU8 | GPS Baseband Processor |
|           | BGA 10x10, 0.8mm pitch |

Related products
Part

| Part    | Description              |
|---------|--------------------------|
| NJ1006A | GPS RF Front-End         |
| DK1030A | Software Development Kit |
| NB1042A | Reference Design         |

NemeriX SA Headquarters Stabile Gerre 2000 PO Box 425 6928 Manno Switzerland

Phone +41 91 612 4700 Fax +41 91 612 4701

email sales@nemerix.com

# LEGAL NOTICE:

NEMERIX PRODUCTS ARE NOT AUTHORIZED FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR IN APPLICATIONS WHICH INVOLVE POTENTIAL RISK OF DEATH, PERSONAL INJURY OR SEVERE PROPERTY OR ENVIRONMENTAL DAMAGE IN CASE OF FAILURE OR MALFUNCTION OF THE PRODUCT.