



INNOVATOR IN ELECTRONICS

---

**DNT24M**

**2.4 GHz  
Spread Spectrum  
Wireless Transceiver**

**Integration Guide**

## Revision History

| <b>Revision</b> | <b>Date</b> | <b>Author</b> | <b>Change Description</b>                                  |
|-----------------|-------------|---------------|------------------------------------------------------------|
| 1.0             | 08/17/12    | F. Perkins    | Initial issue                                              |
| 2.0             | 01-13-17    | R. Willett    | Updated copyright and reformatted document for Murata V.I. |

## Important Regulatory Information

### RFM Product FCC ID: HSW-DNT24 IC 4492A-DNT24

---

**Note:** This equipment has been tested and found to comply with the limits for a Class B digital device, pursuant to Part 15 of the FCC Rules. These limits are designed to provide reasonable protection against harmful interference in a residential installation. This equipment generates, uses and can radiate radio frequency energy and, if not installed and used in accordance with the instructions, may cause harmful interference to radio communications. If this equipment does cause harmful interference to radio or television reception, which can be determined by turning the equipment off and on, the user is encouraged to try to correct the interference by one or more of the following measures:

- 1) Re-orientate or relocate the receiving antenna,
  - 2) Increase the separation between the equipment and the radiator,
  - 3) Connect the equipment into an outlet on a circuit different from that to which the receiver is connected,
  - 4) Consult the dealer or an experienced radio/TV technician for help.
- 

#### FCC Antenna Gain Restriction:

*The DNT24M has been designed to operate with any dipole antenna of up to 12 dBi of gain, any corner reflector antenna of up to 14 dBi gain, any patch antenna of up to 12 dBi gain, or any chip antenna of up to 0 dBi gain. The antenna(s) used for this transmitter must be installed to provide a separation distance of at least 20 cm from all persons and must not be co-located or operating in conjunction with any other antenna or transmitter.*

#### IC RSS-210 Detachable Antenna Gain Restriction:

*This radio transmitter, IC 4492A-DNT24M, has been approved by the Industry Canada to operate with the antenna types listed below with the maximum permissible gain and the required antenna impedance for each antenna type indicated. Antenna types not included in this list, having a gain greater than the maximum gain indicated for that type, are strictly prohibited for use with this device.*

*Le présent émetteur radio IC 4492A-DNT24M a été approuvé par Industrie Canada pour fonctionner avec les types d'antenne énumérés ci-dessous et ayant un gain admissible maximal et l'impédance requise pour chaque type d'antenne. Les types d'antenne non inclus dans cette liste, ou dont le gain est supérieur au gain maximal indiqué, sont strictement interdits pour l'exploitation de l'émetteur.*

| Type            | Model Number    | Gain    | Impedance |
|-----------------|-----------------|---------|-----------|
| Omnidirectional | OD12-2400       | 12 dBi  | 50 ohm    |
| Corner          | SCR14-2400CT    | 14 dBi  | 50 ohm    |
| Patch           | PA2412          | 12 dBi  | 50 ohm    |
| Chip            | FR05-S1-N-0-102 | 1.7 dBi | 50 ohm    |

*Under Industry Canada regulations, this radio transmitter may only operate using an antenna of a type and maximum (or lesser) gain approved for the transmitter by Industry Canada. To reduce potential radio interference to other users, the antenna type and its gain should be so chosen that the equivalent isotropically radiated power (e.i.r.p.) is not more than that permitted for successful communication.*

*Conformément à la réglementation d'Industrie Canada, le présent émetteur radio peut fonctionner avec une antenne d'un type et d'un gain maximal (ou inférieur) approuvé pour l'émetteur par Industrie Canada. Dans le but de réduire les risques de brouillage radioélectrique à l'intention des autres utilisateurs, il faut choisir le type d'antenne et son gain de sorte que la puissance isotrope rayonnée équivalente (p.i.r.e.) ne dépasse pas l'intensité nécessaire à l'établissement d'une communication satisfaisante.*

*This device complies with Industry Canada licence-exempt RSS standard(s). Operation is subject to the following two conditions: (1) this device may not cause interference, and (2) this device must accept any interference, including interference that may cause undesired operation of the device.*

*Le présent appareil est conforme aux CNR d'Industrie Canada applicables aux appareils radio exempts de licence. L'exploitation est autorisée aux deux conditions suivantes : (1) l'appareil ne doit pas produire de brouillage, et (2) l'utilisateur de l'appareil doit accepter tout brouillage radioélectrique subi, même si le brouillage est susceptible d'en compromettre le fonctionnement.*

See Section 6.8 of this manual for regulatory notices and labeling requirements. Changes or modifications to a DNT24M not expressly approved by MURATA may void the user's authority to operate the module.

## Table of Contents

|     |                                                      |    |
|-----|------------------------------------------------------|----|
| 1.0 | DNT24M Introduction.....                             | 9  |
| 1.1 | Why Spread Spectrum? .....                           | 9  |
| 1.2 | Frequency Hopping versus Direct Sequence .....       | 10 |
| 2.0 | DNT24M Network Overview .....                        | 12 |
| 2.1 | DNT24M Addressing .....                              | 13 |
| 2.2 | DN24M Transmission Error Control.....                | 13 |
| 2.3 | Transparent and Protocol-formatted Serial Data ..... | 13 |
| 3.0 | DNT24M Application Interfaces.....                   | 15 |
| 3.1 | Serial Ports .....                                   | 15 |
| 3.2 | SPI Port.....                                        | 15 |
| 3.3 | Digital I/O .....                                    | 18 |
| 3.4 | Analog I/O .....                                     | 18 |
| 3.5 | I/O Event Reporting and I/O Binding .....            | 19 |
| 4.0 | DNT24M System Configuration .....                    | 20 |
| 4.1 | Configuration Parameters.....                        | 20 |
| 4.2 | DNT24M Common Network Configurations.....            | 20 |
| 4.3 | DNT24M Default Network Configuration .....           | 21 |
| 4.4 | Customized DNT24M Network Configurations.....        | 21 |
| 5.0 | DNT24M Application Interface Configuration .....     | 23 |
| 5.1 | Configuring the Serial Port.....                     | 23 |
| 5.2 | Configuring the SPI Port.....                        | 23 |
| 5.3 | Configuring Digital I/O .....                        | 23 |
| 5.4 | Configuring Analog I/O.....                          | 24 |
| 5.5 | Configuring I/O Event Reporting and I/O Binding..... | 25 |
| 5.6 | Configuring Sleep Mode.....                          | 25 |
| 6.0 | DNT24M Hardware .....                                | 26 |
| 6.1 | Specifications .....                                 | 27 |
| 6.2 | Module Pin Out .....                                 | 29 |
| 6.3 | Antenna Connector .....                              | 30 |
| 6.4 | Power Supply and Input Voltages .....                | 31 |
| 6.5 | ESD and Transient Protection .....                   | 31 |
| 6.6 | Interfacing to 5 V Logic Systems .....               | 31 |
| 6.7 | Mounting and Enclosures .....                        | 32 |

|       |                                                       |    |
|-------|-------------------------------------------------------|----|
| 6.8   | Labeling and Notices.....                             | 33 |
| 7.0   | DNT24M Protocol-formatted Messages.....               | 34 |
| 7.1   | Protocol Formats.....                                 | 34 |
| 7.2   | Message Types.....                                    | 34 |
| 7.3   | Message Format Details.....                           | 35 |
| 7.4   | Configuration Parameter Registers.....                | 42 |
| 7.4.1 | Bank 0x00 - Transceiver Setup.....                    | 43 |
| 7.4.2 | Bank 0x01 - System Settings .....                     | 45 |
| 7.4.3 | Bank 0x02 - Status Parameters .....                   | 46 |
| 7.4.4 | Bank 0x03 - Serial and SPI Settings .....             | 47 |
| 7.4.5 | Bank 0x05 - I/O Parameters .....                      | 50 |
| 7.4.6 | Bank 0x06 - I/O Settings.....                         | 51 |
| 7.4.7 | Bank 0xFF - Special Functions .....                   | 57 |
| 7.5   | Protocol-formatted Message Examples.....              | 58 |
| 7.5.1 | Data Message.....                                     | 58 |
| 7.5.2 | Configuration Messages.....                           | 59 |
| 7.5.3 | Sensor Message .....                                  | 60 |
| 7.5.4 | Event Message .....                                   | 60 |
| 8.0   | DNT24MDK/DNT24MADK Developer's Kits.....              | 62 |
| 8.1   | Kit Contents.....                                     | 62 |
| 8.2   | Additional Items Needed .....                         | 63 |
| 8.3   | Developer's Kit Default Operating Configuration ..... | 63 |
| 8.4   | Developer's Kit Hardware Assembly.....                | 63 |
| 8.5   | Utility Program .....                                 | 65 |
| 8.6   | Initial Kit Operation.....                            | 65 |
| 8.6.1 | Serial Communication and Radio Configuration.....     | 68 |
| 8.7   | Interface Board Features .....                        | 74 |
| 9.0   | Troubleshooting.....                                  | 76 |
| 9.1   | Diagnostic Port Commands.....                         | 76 |
| 10.0  | 10.0 Appendices.....                                  | 77 |
| 10.1  | Ordering Information.....                             | 77 |
| 10.2  | Technical Support .....                               | 77 |
| 10.3  | DNT24M Mechanical Specifications .....                | 77 |
| 10.4  | DNT24M Development Board Schematic .....              | 82 |

|      |                |    |
|------|----------------|----|
| 11.0 | Warranty ..... | 85 |
|------|----------------|----|

## List of Figures

|             |                                                 |    |
|-------------|-------------------------------------------------|----|
| Figure 1-1  | Narrow-band vs. Spread Spectrum.....            | 10 |
| Figure 1-2  | Spread Spectrum Forms.....                      | 10 |
| Figure 2-1  | DNT24M Communications Paths.....                | 12 |
| Figure 3-1  | DNT24 Master Mode Signaling .....               | 15 |
| Figure 3-2  | DNT24 Master Mode Operation .....               | 16 |
| Figure 3-3  | DNT24 Slave Mode Signaling .....                | 16 |
| Figure 3-4  | DNT24 Slave Mode Message Load.....              | 17 |
| Figure 3-5  | DNT24 SPI Slave Mode RX Message Retrieval ..... | 17 |
| Figure 4-1  | DNT24 Point-to-Point Network.....               | 20 |
| Figure 4-2  | DNT24M Point-to-Multipoint (Star) Network.....  | 21 |
| Figure 6-1  | DNT24 Block Diagram .....                       | 26 |
| Figure 6-2  | Circuit Board Stripline Trace Detail.....       | 31 |
| Figure 6-3  | Resistor Divider Network.....                   | 32 |
| Figure 7-1  | Protocol Message Header Format .....            | 34 |
| Figure 8-1  | DNT24MDK Developer's kit .....                  | 62 |
| Figure 8-2  | DNT24MP Radio/Board/Antenna .....               | 63 |
| Figure 8-3  | Antenna Attached.....                           | 63 |
| Figure 8-4  | DNT24MDK with Serial and Power Connectors.....  | 64 |
| Figure 8-5  | DNT Demo Start-up Window .....                  | 65 |
| Figure 8-6  | Select Comm Port Settings .....                 | 66 |
| Figure 8-7  | Local Radion Column .....                       | 66 |
| Figure 8-8  | Start Button .....                              | 67 |
| Figure 8-9  | Transmit Tools Tab.....                         | 68 |
| Figure 8-10 | Configuration Window.....                       | 69 |
| Figure 8-11 | System Tab Contents .....                       | 70 |
| Figure 8-12 | Status Tab Contents .....                       | 70 |
| Figure 8-13 | Serial Tab Contents .....                       | 71 |
| Figure 8-14 | Protocol Tab Contents .....                     | 71 |
| Figure 8-15 | I/O Parameters Tab Contents .....               | 72 |
| Figure 8-16 | I/O Settings Tab .....                          | 72 |
| Figure 8-17 | 2 <sup>nd</sup> I/O Setup Tab Contents .....    | 73 |

|                                                           |    |
|-----------------------------------------------------------|----|
| Figure 8-18 3 <sup>rd</sup> I/O Setup Tab Contents .....  | 73 |
| Figure 8-19 File, Options, and Help Menus.....            | 74 |
| Figure 8-20 LED Locations.....                            | 74 |
| Figure 8-21 Connectors and Switches – on right .....      | 75 |
| Figure 8-22 Connectors and Swithcves – on left .....      | 75 |
| Figure 10-1 DNT24C Outline and Mounting Dimensions.....   | 77 |
| Figure 10-2 DNT24C Solder Pad Dimensions .....            | 78 |
| Figure 10-3 DNT24P Outline and Mounting Dimensions.....   | 78 |
| Figure 10-4 DNT24P Interface Connector/PCB Layout .....   | 79 |
| Figure 10-5 DNT24CA Outline and Mounting Dimensions ..... | 79 |
| Figure 10-6 DNT24CA Solder Pad Dimensions.....            | 80 |
| Figure 10-7 DNT24PA Solder Pad Dimensions.....            | 80 |
| Figure 10-8 DNT24PA Connector/PCB Layout Detail.....      | 81 |
| Figure 10-9 DNT24M Development Board Schematic - 1.....   | 82 |
| Figure 10-10 DNT24M Development Board Schematic - 2.....  | 83 |
| Figure 10-11 DNT24M Development Board Schematic – 3 ..... | 84 |

## **List of Tables**

|                                             |    |
|---------------------------------------------|----|
| Table 6-1 Absolute Maximum Rating.....      | 27 |
| Table 6-2 Operating Characteristics.....    | 27 |
| Table 6-3 Module Pin-Out.....               | 29 |
| Table 6-4 stripline Trace Length .....      | 31 |
| Table 7-1 DNT24M Protocol Messages.....     | 35 |
| Table 7-2 Enter Protocol Mode Command ..... | 36 |
| Table 7-3 Enter Protocol Mode Reply.....    | 36 |
| Table 7-4 Exit Protocol Mode Command .....  | 36 |
| Table 7-5 Device Reset Command .....        | 36 |
| Table 7-6 Device Reset Reply .....          | 37 |
| Table 7-7 Get Register Command .....        | 37 |
| Table 7-8 Get Register Reply.....           | 37 |
| Table 7-9 Set Register Command.....         | 38 |
| Table 7-10 Set Register Reply .....         | 38 |
| Table 7-11 TX Data Command .....            | 38 |
| Table 7-12 TX Data Reply .....              | 39 |

|                                                    |    |
|----------------------------------------------------|----|
| Table 7-13 Get Remote Register Command .....       | 39 |
| Table 7-14 Get Remote Register Reply .....         | 39 |
| Table 7-15 Set Remote Register Command .....       | 40 |
| Table 7-16 Set Remote Register Reply.....          | 40 |
| Table 7-17 RX Data Packet .....                    | 41 |
| Table 7-18 Startup Announcement or Error Code..... | 41 |
| Table 7-19 Heartbeat Announcement .....            | 41 |
| Table 7-20 RX Event Packet.....                    | 42 |
| Table 7-21 Bank 0x00 Transceiver Setup.....        | 43 |
| Table 7-22 Bank 0x01 System Settings .....         | 45 |
| Table 7-23 Bank 0x02 Status Parameters .....       | 46 |
| Table 7-24 Bank 0x03 Serial and SPI Settings ..... | 47 |
| Table 7-25 Bank 0x04 Host Protocol Settings .....  | 49 |
| Table 7-26 Bank 0x05 I/O Parameters .....          | 50 |
| Table 7-27 Bank 0x06 I/O Settings.....             | 51 |
| Table 7-28 GPIO Pins Alternate Functions .....     | 53 |
| Table 7-29 GPIO Bit Values Mapping .....           | 53 |
| Table 7-30 ADC Ave Select.....                     | 55 |
| Table 7-31 Bank 0xFF Special Functions .....       | 57 |

# 1.0 DNT24M Introduction

DNT24M transceivers provide low latency, highly reliable wireless connectivity for direct peer-to-peer network applications. Frequency hopping spread spectrum (FHSS) technology ensures maximum resistance to multipath fading and robustness in the presence of interfering signals, while operation in the 2.4 GHz ISM band allows license-free use in many regions of the world. The DNT24M supports serial data rates for host communications from 1.2 to 250.0 kbps, plus three SPI data rates from 125 to 500 kbps. On-board data buffering plus an error-correcting radio protocol provide smooth data flow and simplify the task of integration with existing applications. Key DNT24M features include:

- Multipath fade resistant frequency hopping technology with 15 frequency channels, 2406 to 2475 MHz
- Receiver protected by low-loss SAW filter, providing excellent receiver sensitivity and interference rejection important in outdoor applications
- Direct peer-to-peer radio communications provides very low message latency
- FCC 15.247 and IC RSS-210 certified for license-free operation
- Five mile plus range with omnidirectional antennas (antenna height dependent)
- Transparent ARQ protocol with data buffering ensures data integrity
- Analog and digital I/O supports wireless sensing applications
- Simple interface handles both data and control at up to 250.0 kbps on the serial port or 500 kbps on the SPI port
- 64 selectable hopping patterns support multiple co-located systems
- Plug-in or solder reflow versions with either U.FL antenna connector or integral antenna
- AES encryption provides protection from eavesdropping
- Nonvolatile memory stores DNT24M configuration when powered off
- Selectable 10 or 63 mW transmit power levels
- Automatic I/O event reporting mode simplifies application development
- I/O binding mode provides wireless transmission of analog and digital values

## 1.1 Why Spread Spectrum?

A radio channel can be very hostile, corrupted by noise, path loss and interfering transmissions from other radios. Even in an interference-free environment, radio performance faces serious degradation from a phenomenon known as multipath fading. Multipath fading results when two or more reflected rays of the transmitted signal arrive at the receiving antenna with opposing phases, thereby partially or completely canceling the signal. This problem is particularly prevalent in indoor installations. In the frequency domain, a multipath fade can be described as a frequency-selective notch that shifts in location and intensity over time as reflections change due to motion of the radio or objects within its range. At any given time, multipath fades will typically occupy 1% - 2% of the band. From a probabilistic viewpoint, a conventional radio system faces a 1% - 2% chance of signal impairment at any given time due to multipath fading.

Spread spectrum reduces the vulnerability of a radio system to both multipath fading and jammers by distributing the transmitted signal over a larger region of the frequency band than would otherwise be necessary to send the information. This allows the signal to be reconstructed even though part of it may be lost or corrupted in transmission.



Narrow-band versus spread spectrum transmission

**Figure 1-1 Narrow-band vs. Spread Spectrum**

## 1.2 Frequency Hopping versus Direct Sequence

The two primary approaches to spread spectrum are direct sequence spread spectrum (DSSS) and frequency hopping spread spectrum (FHSS), either of which can generally be adapted to a given application. Direct sequence spread spectrum is produced by multiplying the transmitted data stream by a much faster, noise-like repeating pattern. The ratio by which this modulating pattern exceeds the bit rate of the base-band data is called the processing gain, and is equal to the amount of rejection the system affords against narrow-band interference from multipath and jammers. Transmitting the data signal as usual, but varying the carrier frequency rapidly according to a pseudo-random pattern over a broad range of channels produces a frequency hopping spectrum system.



Forms of spread spectrum - direct sequence and frequency hopping

**Figure 1-2 Spread Spectrum Forms**

One disadvantage of direct sequence systems is that due to design issues related to broadband transmitters and receivers, they generally employ only a minimal amount of spreading, often no more than the minimum required by the regulating agencies. For this reason, the ability of DSSS systems to overcome

fading and in-band jammers is relatively weak. By contrast, FHSS systems are capable of hopping throughout the entire band, statistically reducing the chances that a transmission will be affected by fading or interference. This means that a FHSS system will degrade gracefully as the band gets noisier, while a DSSS system may exhibit uneven coverage or work well until a certain point and then give out completely.

Because it offers greater immunity to interfering signals, FHSS is often the preferred choice for co-located systems. Since direct sequence signals are very wide, they can offer only a few non-overlapping channels, whereas multiple hoppers can interleave, minimizing interference. Frequency hopping systems do carry some disadvantages, in that they require an initial acquisition period during which the receiver must lock on to the moving carrier of the transmitter before any data can be sent. In summary, frequency hopping systems generally feature greater coverage and channel utilization than comparable direct sequence systems. Of course, other implementation factors such as size, cost, power consumption and ease of implementation must also be considered before a final radio design choice can be made.

## 2.0 DNT24M Network Overview

A DNT24M network is referred to as *direct peer-to-peer* network. A transmission from a DNT24M can be directed to any other peer in its network (unicast), or to all other peers in its network (broadcast). Unless a DNT24M is transmitting or is in sleep mode, it is constantly scanning all the channels in its frequency hopping sequence for a transmission from another peer. When a DNT24M has data to transmit, it transmits a beacon that allows the other peers in its network to rapidly synchronize with its phase in the hopping sequence. After sending the beacon, the transmitting radio immediately sends its data packet. If the data packet is addressed to a specific peer and is received without errors, the destination peer transmits an acknowledgement (ACK) to the originating peer, completing the error-free transmission. If the data packet is being broadcast to all other peers in the system, it is transmitted several times on different channels to mitigate the chances of a reception error due to poor propagation or interference on one channel. Most DN24M unicast packets are transmitted and acknowledged in less than 16 milliseconds. This very low transmission latency is achieved without compromising the robustness inherent in FHSS communications. Figure 2.0.1 depicts the communication paths available in a network consisting of four DNT24M peers.



**Figure 2-1 DNT24M Communications Paths**

## 2.1 DNT24M Addressing

Each DNT24M has a unique three-byte *MAC address*, which is used to send unicast packets to it. A DNT24M can also send a packet to all other DNT24M's in its network by using the broadcast address 0xFFFFFFF. The MAC address can be read or bar-code scanned from the label on top of each DNT24M radio, or retrieved through the radio's serial port or SPI interface. There are four sources of destination MAC addresses a DNT24M can use when sending a packet:

- the broadcast MAC address, 0xFFFFFFF
- the MAC address in the transparent mode destination address (*RmtTransDestAddr*) parameter
- the MAC address included in a protocol-formatted message from the DNT24M's host
- the MAC address of the originator of the most recent packet received, when the *TransPtTo-PtMode* parameter is enabled.

Parameters related to MAC address selection are discussed in detail in Section 7.4 of this document.

All DNT24M radios hold a *system ID* parameter that can be used to distinguish between overlapping DNT24M networks. System IDs provide network filtering for broadcast packets. Also, a unique frequency hopping pattern is associated with each of the 64 available system IDs, minimizing the chances of transmission collisions between overlapping DNT24M networks.

## 2.2 DN24M Transmission Error Control

DNT24M packets include 24 error detection bits, allowing the integrity of a received packet to be tested with very high confidence. A received packet is discarded if an error is detected. Error-free unicast packets are acknowledged by an ACK message back to the originator from the destination radio. If the originator does not receive an ACK for a transmitted packet, it will resend it on the next channel in the frequency hop sequence, etc., up to a limit set by the *ArqAttemptLimit* parameter. The default value for this parameter is 10 attempts, which ensures message delivery in all but the most extreme conditions.

The number of times a broadcast packet is sent is controlled by the *BcstAttemptLimit* parameter. The radio moves to the next channel in the hopping sequence after each broadcast transmission to mitigate the chances of a reception error due to poor propagation or interference on one channel. The default value of the *BcstAttemptLimit* parameter is four.

To manage transmission collisions between multiple DNT24M radios trying to transmit at the same time, a progressive random delay is used to offset the time an unacknowledged packet is retransmitted as a radio progresses through the network's hopping sequence.

## 2.3 Transparent and Protocol-formatted Serial Data

A DNT24M can directly input and output data bytes and data strings on its serial port. This is referred to as *transparent* serial port operation. DNT24M radios also support *protocol-formatted messages*, which can also be used to carry data bytes and data strings, and must be used for:

- configuration commands and replies
- I/O event messages
- announcement messages including heartbeats

Protocol-formatted messages are discussed in detail in Section 7. Briefly, protocol-formatted messages include a start-of-messages character, message length and message type information, the destination MAC address for the message, and the message payload.

Transparent data is routed using the transparent mode destination address held in the *RmtTrans-DestAddr* parameter. The default value for this parameter is the broadcast MAC address, 0xFFFFFFF. The *TransPtToPtMode* parameter is enabled by default, which causes a radio to unicast a packet to the peer from which it most recently received a message. These two parameter defaults make a network consisting of two DNT24M radios “plug-and-play”, as they automatically select each other’s MAC addresses for transmitting transparent data back and forth efficiently.

## 3.0 DNT24M Application Interfaces

A DNT24M module provides a variety of application interfaces including two serial ports, an SPI port, six digital I/O ports (logic state), three 12-bit ADC input ports, and two 12-bit DAC output ports. Each of these interfaces is discussed below.

### 3.1 Serial Ports

The DNT24M includes two serial ports, one for communication and an optional one for diagnostics. The communication port is a full-duplex UART interface with hardware flow control on two of the digital I/O pins as an optional feature. One digital I/O pin can also be configured as an RS485 enable function. The serial communication port can be configured with baud rates from 1.2 to 250.0 kbps, with 9.6 kbps the default baud rate. The DNT24M communication port transmits/receives 8-bit data with a choice of even, odd or no parity and 1 or 2 stop bits. The default configuration is no parity and one stop bit. See Section 5.1 for recommendations on configuring the communication port, and Section 7.4.4 for detailed information on configuration parameters. The diagnostic port is enabled as an alternate function of the LINK and ACTIVITY pins, and can be configured with baud rates from 1.2 to 250.0 kbps, with 9.6 kbps the default baud rate. The diagnostic port transmits/receives 8-bit data with no parity and 1 stop bit. See Section 7.4.8 for diagnostic port configuration details.

### 3.2 SPI Port

The DNT24M serial peripheral interface (SPI) port can operate either as a master or a slave. The port includes the four standard SPI connections - MISO, MOSI, SCLK and /SS, plus three signals used to support SPI slave mode operation - /HOST\_RTS, /HOST\_CTS and DAV. The serial port and SPI master mode can run simultaneously. Serial port operation is disabled when the SPI port is configured for slave mode. Note that all SPI slave mode messages must be protocol formatted.



**Figure 3-1 DNT24 Master Mode Signaling**

The DNT24M SPI port can run at three clock rates in master mode - 125, 250 or 500 kbps. There are two message sources available to a DNT24M SPI master, a protocol-formatted *RxData* message or a stored command. The DNT24M master will clock a message from either source into its slave and return the bytes clocked out as a protocol-formatted *TxDATA* message. The DNT24M event timer triggers sending the stored command to the DNT24M's slave. The stored command can be up to 16 bytes in length. Figure 3.2.1 shows the required SPI master mode-signal connections, and Figure 3.2.2 shows the SPI master-mode timing.

### DNT24 SPI Master Mode Operation



**Figure 3-2 DNT24 Master Mode Operation**

In SPI slave mode, the host can stream data into DNT24M at up to 250 kbps, provided the host suspends clocking within 10 bytes following a low-to-high transition on /HOST\_CTS. The host can clock data into the DNT24M at up to 4 Mbps for data bursts of up to 50 bytes, provided the interval from the end of one burst to the start of the next burst is at least 2 ms, and the host suspends clocking on a low-to-high transition on /HOST\_CTS. See Figure 3.2.4.

### DNT24 SPI Slave Mode Signaling



**Figure 3-3 DNT24 Slave Mode Signaling**



**Figure 3-4 DNT24 Slave Mode Message Load**

The host should use the following steps to fetch data from a DNT24M SPI slave, as show in Figure 3.2.5:

1. The host sets the **/HOST\_RTS** signal high to allow the DNT24M to signal data available.
2. The DNT24M sets the data available (DAV) high to signal the host it has data.
3. The host set the **/SS** signal low to enable SPI operation.
4. The host clocks in one dummy byte (ignore the output byte) and then sets **/HOST\_RTS** low.
5. The host begins to clock out the data, which can include several messages.
6. The host continues to clock out data until a 0x00 byte occurs in the byte stream where a 0xFB start-of-message would be expected.
7. The host has now clocked out all messages and the 0x00 is discarded.
8. The host sets **/HOST\_RTS** and **/SS** high to allow the DNT24M to signal DAV the next time it has data.

Note that the DAV signal can go low before the last message is clocked out. It is not a reliable indication that the last byte of the message(s) has been clocked out. See Section 5.2 for recommendations on configuring the SPI port, and Section 7.4.4 for detailed information on SPI port configuration parameters.



**Figure 3-5 DNT24 SPI Slave Mode RX Message Retrieval**

### 3.3 Digital I/O

The DNT24M's six digital (state) I/O ports are labeled GPIO0 through GPIO5. GPIO5 has an alternate function of /HOST\_RTS and GPIO4 of /HOST\_CTS, providing hardware handshaking for the serial port and SPI slave mode operation. If serial port hardware handshaking is not required and SPI slave mode is not enabled, GPIO4 and GPIO5 can be used for other digital I/O functions. When SPI slave mode is enabled, GPIO5 and GPIO4 *must* be used for /HOST\_RTS and /HOST\_CTS respectively, and GPIO3 *must* be used to provide the DAV signal (SPI slave mode overrides any other configuration for these ports).

Except in SPI slave mode, GPIO0 through GPIO5 are available for customer-defined functions:

- The direction of each GPIO pin can be set for both active and sleep modes.
- The initial state (power on) of all GPIO pins configured as outputs can be set.
- The state of all GPIO pins configured as outputs in sleep mode can be set.
- GPIO triggering of I/O event reporting can be configured.
- GPIO level control of sleep hold-off can be configured.

See Section 5.3 for recommendations on configuring the digital I/O, and Sections 7.4.6 and 7.4.7 for detailed information on GPIO parameters.

### 3.4 Analog I/O

The DNT24M's three ADC input channels are labeled ADC0 through ADC2. The ADC can be disabled if unused to reduce current consumption. The ADC can be operated in either single-ended mode or differential mode. In single-ended mode, up to three sensor inputs can be measured. The negative sensor inputs are connected to ground and the positive sensor inputs are connected to ADC0, ADC1 and ADC2 respectively. Single-ended measurements are unsigned 11-bit values. In differential mode, one or two sensor inputs can be measured as 12-bit signed values. The first differential measurement is the difference between the voltage on ADC1 and the voltage on ADC0, and is referred to as the ADC0 differential measurement. The second differential measurement is the difference between ADC2 and ADC0, and is referred to as the ADC1 differential measurement. Operating the ADC in differential mode takes advantage of common mode rejection to provide the best measurement stability. Differential mode also incorporates a programmable gain preamplifier function, with gains settings from 1 to 64 available.

There are two options for the ADC full-scale reference:

1. The DNT24M regulated supply voltage divided by 1.6, or about 2.06 V
2. A low impedance voltage source applied to the DNT24M's ADC\_EXT\_REF input pin, 2.7 V maximum. If no connection is made to this pin, a voltage equal to about 2.7 V will be present.

Note that when differential ADC mode is used, the maximum output voltage available from the preamplifier at any gain setting is 2.4 V. So the maximum ADC reading that can be made using a 2.7 V ADC reference will be about 88.9% of full scale. The ADC channels are read each sample interval, which is configurable. High and low measurement thresholds can be set for each ADC channel to trigger I/O event reporting messages.

The DNT24M's two DAC outputs are labeled DAC0 and DAC1. The DACs can be disabled if unused to reduce current consumption. The DAC settings have 12-bit resolution. There are two options for the DAC full-scale reference:

1. The DNT24M regulated supply voltage, about 3.3 V
2. A low impedance voltage source applied to the DNT24M's ADC\_EXT\_REF input pin, 2.7 V maximum. If no connection is made to this pin, a voltage equal to about 2.7 V will be present.

See Section 5.4 for recommendations on configuring the analog I/O, and Sections 7.4.6 and 7.4.7 for detailed information on analog I/O parameters.

### 3.5 I/O Event Reporting and I/O Binding

The DNT24M's I/O event reporting function can generate a protocol-formatted *RxEvent* message when triggered by one of the following I/O events:

- A specific state change of GPIO0, GPIO1, GPIO2 or GPIO3.
- Firing of the periodic event report timer.
- A high or low threshold exceeded on a measurement by ADC0, ADC1 or ADC2.

An I/O report message includes:

- The states of GPIO0 through GPIO5.
- The latest measurements made by ADC0 through ADC2 .
- A set of flags indicating which event(s) triggered the I/O report.
- The settings of DAC0 and DAC1.

The I/O binding function works in conjunction with I/O event reporting. When I/O binding is enabled on a DNT24M, data received in an I/O event report it is mapped as follows:

- GPIO2 will output the state of GPIO0 in the last received event report.
- GPIO3 will output the state of GPIO1 in the last received event report.
- DAC0 will output the voltage read by ADC0 in the last received event report.
- DAC1 will output the voltage read by ADC1 in the last received event report.

I/O binding is used to transmit switch positions or analog signals from one location to another. Note that I/O binding cannot be used in a DNT24M when SPI slave mode is enabled or differential ADC mode is used. See Section 5.4 for recommendations on configuring I/O event reporting and binding, and Sections 7.4.6 and 7.4.7 for detailed information on I/O reporting and binding parameters.

## 4.0 DNT24M System Configuration

DNT24M radios feature an extensive set of configuration options that allows them to be adapted to a wide range of applications. Configuration defaults have been carefully selected to minimize the configuration effort for most applications, while providing the ability to individually adjust the configuration of each radio to achieve highly optimized system operation.

### 4.1 Configuration Parameters

The configuration of a DNT24M is controlled by a set of *parameters* (registers). Parameters that address a particular aspect of operation are grouped into a *bank*. All parameters can be accessed through a module's serial port and over the radio link. Most parameters are read/write. Read-only parameters include fixed values such as MAC addresses, firmware version numbers and parameters that are dynamically adjusted during system operation. Write-only parameters include security keys and certain action triggers such as reset. Incorrectly configuring certain parameters can disable a module's radio link, but the configuration can always be corrected through the serial port. The organization of the parameter register banks and the details of each parameter are covered in Section 7.4 of this guide. Sections 4.3 through 5.6 discuss which parameters apply to various aspects of configuring a DNT24M network or application interface.

### 4.2 DNT24M Common Network Configurations

DNT24M's direct peer-to-peer operation is readily adapted to two other common network configurations: point-to-point networks and point-to-multipoint networks.

A point-to-point network is shown in Figure 4-1. Point-to-point systems are often used to replace wired serial connections. Point-to-point networks are also used to transmit switch positions and/or analog signals from one location to another.



**Figure 4-1 DNT24 Point-to-Point Network**

Figure 4-2 shows the topology of a point-to-multipoint (star) network, where one DNT24M acts as a "base" unit connected to the computer running the network application, with the rest of the radios in the network communicating primarily with the base. Point-to-multipoint networks are typically used for data, sensor and alarm systems.



**Figure 4-2 DNT24M Point-to-Multipoint (Star) Network**

### 4.3 DNT24M Default Network Configuration

The default parameter values in a DNT24M provide “plug-and-play” operation for a point-to-point network. By default, DM24M radios are configured for transparent serial data communication at 9.6 kbps, 8 bit data, one stop bit, no parity. Data is routed using the transparent mode destination address held in the *RmtTransDestAddr* parameter. The default value for this parameter is the broadcast MAC address, 0xFFFFFFF. However, the *TransPtToPtMode* parameter is enabled by default, which causes a radio to unicast packets to the peer from which it most recently received a message. These two parameter defaults make a network consisting of two DNT24M radios “plug-and-play”, as they automatically select each other’s MAC addresses for transmitting transparent data back and forth efficiently.

### 4.4 Customized DNT24M Network Configurations

The DNT24M includes many configuration parameters that allow extensive network customization. Most applications will require only a few of these parameters be changed from their default values. But for those applications that need them, MURATA recommends the following configuration sequence. Skip the configuration steps where the default parameter value is satisfactory.

1. For any network configuration other than a point-to-point system, set the *TransPtToPtMode* parameter to 0x00 in each radio to disable the “reply to last received” feature.
2. For any DNT24M network communicating sensitive data, set the AES security key in all network radios by loading your selected 16-byte string into the *SecurityKey* parameter in Bank 0 (the default is 16 bytes of 0x00).
3. Configure the system ID in all radios by setting the *SystemID* parameter in Bank 0 (the default is OK if there is no chance of overlapping systems).
4. Set the transmitter power level as needed in all radios by setting the *TxPower* parameter in Bank 0 (the default is 63 mW).

5. For a peer-to-peer network (more than 2 radios), set the *ProtocolMode* parameter in Bank 4 of each radio to 0x01. Each radio's host application will require a database containing the MAC addresses of the other radios in the network, as discussed in Section 2.1 above.
6. For a point-to-multipoint network, set the *ProtocolMode* parameter in Bank 4 of the DNT24M acting as the network base to 0x01. The base radio will use protocol-formatted messages containing MAC addresses to communicate with the other radios in the network. Radios other than the base can set the *RmtTransDestAddr* parameter to the MAC address of the base unit and use transparent mode for sending serial data provided they only communicate with the base. If radios other than the base are sending I/O data, they must be in protocol mode and include the base MAC address in their protocol formatted messages. If SPI slave mode will be used, protocol mode must be enabled in all network radios.
7. If using transparent serial mode in the network:
  - a. Set the timeout for transmission of transparent data as needed. The parameter that controls the timeout is the *TxTimeout* in Bank 4 (the default is to send as soon as possible).
  - b. Set the minimum message length for transmission of transparent data in the remotes as needed. The parameter that controls the length is the *MinPacketLength* in Bank 4 (the default is one byte).
8. Load an optional “friendly description” in each system radio in the *UserTag* parameter, Bank 0.

## 5.0 DNT24M Application Interface Configuration

DNT24M modules include a comprehensive set of application interfaces and related options that support a wide range of applications including wireless RS232/485 cable replacements, wireless sensor networks, wireless alarm systems and industrial remote control applications. Recommended configuration steps for each application interface are discussed in Sections 5.1 through 5.6 below.

### 5.1 Configuring the Serial Port

The default serial port configuration is 9.6 kbps, 8-bit data, no parity and 1 stop bit.

1. Configure the serial data rate as required from 1.2 to 250.0 kbps by setting the *SerialRate* parameter in Bank 3.
2. Configure the parity and number of stop bits by setting the *SerialParams* parameter in Bank 3.
3. Enable/disable serial port hardware flow control as required by setting the *GpioAlt* parameter in Bank 6. Hardware flow control is disabled by default, but is recommended when operating at higher baud rates and/or sending large blocks of data.

### 5.2 Configuring the SPI Port

1. Enable either SPI *master mode* or SPI *slave mode* by setting the *SpiMode* parameter in Bank 3. The serial port remains operational in SPI master mode but is disabled in SPI slave mode.
2. If using SPI master mode:
  - a. Select the SPI clock rate by setting the *SpiRateSel* parameter in Bank 3 (default is 125 kbps)
  - b. Set the SPI master command string and string length by setting the *SpiMasterCmdStr* and *SpiMasterCmdLen* parameters respectively in Bank 3.
3. Configure the edge trigger direction, bit-sampling edge and bit-order options by setting the *SpiOptions* parameter in Bank 3.

### 5.3 Configuring Digital I/O

1. GPIO2 through GPIO 5 have configurable alternate functions as discussed in Section 7.4.7. Select either digital (state) functionality or alternate functionality for each of these pins by setting the *GpioAlt* parameter in Bank 6. Note that selecting SPI slave mode overrides the *GpioAlt* parameter setting for GPIO3 though GPIO5.
2. Configure the direction of each GPIO pin as needed by setting the *GpioDir* parameter in Bank 6 (the default is all inputs).
3. Configure the direction of each GPIO pin for sleep mode as needed by setting the *GpioSleepDir* parameter in Bank 6 (the default is all inputs).
4. Set the initial state (power on) of all GPIO pins configured as outputs by setting the *GpioInit* parameter in Bank 6 (the default is all logic low).
5. Set the state of all GPIO pins configured as outputs in sleep mode by setting the *GpioSleepState* parameter in Bank 6 (the default is all logic low).
6. GPIO0 through GPIO3 can trigger I/O event reporting when functioning as digital inputs. Enable event report triggering and optional sleep hold-off for these pins by setting the *GpioEdgeTrigger* parameter in Bank 6.

## 5.4 Configuring Analog I/O

1. Select the ADC full-scale reference by setting the *AdcReference* parameter in Bank 6. This setting applies to all ADC channels. The default is the ADC\_EXT\_REF input. If ADC operation is not needed, setting this parameter to 0x03 disables ADC operation, reducing current consumption.
2. Select the ADC mode, either single-ended or differential by setting the *AdcDiffMode* parameter in Bank 6. The default is single-ended ADC operation.
3. If differential ADC mode is selected, set the desired ADC preamplifier gain for each ADC channel with the *AdcGainCh0* and *AdcGainCh1* parameters in Bank 6. The default gain is 1. Note that the full scale output voltage from the preamplifier is 2.4 V.
4. Reconfigure the ADC measurement interval as needed by setting the *AdcSampleIntvl* parameter. The default is 100 ms, and applies to all ADC channels.
5. Set the *AdcAveSelect* parameter to the number of ADC readings to be averaged to produce a measurement. The larger the *AdcAveSelect* parameter is set, the greater the noise filtering effect, but the longer it takes to produce a measurement. Setting this parameter to 8 or more when the ADC is operating in single-ended mode is especially helpful in stabilizing ADC measurements.
6. Measurements on each ADC input can be compared to high/low threshold values, triggering an I/O event report if the measurements go above/below the respective thresholds. The thresholds for each ADC channel are set by loading the *AdcXThresholdLo* and *AdcXThresholdHi*, where X refers to the ADC channel designator, 0 through 2. When the ADC is operating in differential mode, the ADC1 to ADC0 differential measurement is compared to the “0” high and low thresholds, and the ADC2 to ADC0 differential measurements is compared to the “1” high and low thresholds. In this case the “2” threshold values are not used.
7. Set the *IoPreDelay* parameter as needed in Bank 6 to allow signals to stabilize following a module wakeup event.
8. Set the *AdcSkipCount* parameter in Bank 6 as needed to allow internal transients in the ADC sample-and-hold circuit to settle out. This parameter must be set to at least 3 when *AdcDiffMode* is selected. Note that the *IoPreDelay* parameter discussed above provides a delay to allow signals *external* to the DNT24M to settle following a wake up event, while *AdcSkipCount* skips measurements that may be distorted because the *internal* voltage on the ADC sample-and-hold has not settled.
9. Select the DAC full scale reference by setting *DacReference* in Bank 6. This setting applies to both DAC channels. The default is the ADC\_EXT\_REF input. If DAC operation is not needed, setting this parameter to 0x03 will disable DAC operation, reducing current consumption.
10. Configure the initial (power on) output level for DAC0 and DAC1 by loading the initial settings in the *Dac0Init* and *Dac1Init* parameters respectively.

The ADC and DAC channels are factory calibrated. It may be desirable to fine tune these calibrations after the DNT24M has been integrated with the customer's hardware in some applications. For analog calibration support, contact MURATA technical support.

## 5.5 Configuring I/O Event Reporting and I/O Binding

1. Select the analog, digital and timing events that will trigger an I/O event report by setting the respective bits in the *IoReportTrigger* parameter in Bank 6. The default is no triggers set.
2. Configure the trigger behavior bits in the *GpioEdgeTrigger* parameter, Bank 6, for each GPIO input selected to generate an I/O event report.
3. For each ADC channel selected to generate an I/O event, set the high and low measurement threshold values. The *AdcThreshold* parameters are in Bank 6. When the ADC is operating in differential mode, the ADC1 to ADC0 differential measurement is compared to the “0” high and low thresholds, and the ADC2 to ADC0 differential measurements is compared to the “1” high and low thresholds. In this case the “2” threshold values are not used.
4. If the periodic timer has been selected to generate an event report, load the required timer report interval into the *IoReportInterval* parameter in Bank 6. The default timer interval is 30 seconds.
5. Set the *MaxQueuedEvents* parameter in Bank 6 as needed to limit the number of Event Reports that can be queued at one time by a DNT24M.
6. If I/O binding operation is desired, set the *IoBindingEnable* parameter in Bank 6 to 0x01. I/O binding is disabled by default, and cannot be used when the ADC is operating in differential mode.

## 5.6 Configuring Sleep Mode

Sleep mode can be used in conjunction with I/O reporting to greatly extend battery life on DNT24M radios. At least one I/O report trigger must be enabled to allow sleep mode to be used.

1. Enable sleep mode as desired by setting the *SleepModeEn* parameter in Bank 0 to 1.
2. Configure the maximum time a remote in sleep mode will remain awake after receiving an ACK, processing a message addressed to it, or receiving a serial or SPI message by setting the *Wake-ResponseTime* parameter. The default response time is 500 ms. Note that the setting of this parameter is overridden by some *GpioEdgeTrigger* parameter settings.

## 6.0 DNT24M Hardware

**Block Diagram - DNT24 Series Modules**



**Figure 6-1 DNT24 Block Diagram**

The major components of the DNT24M series modules include a 2.4 GHz FHSS transceiver and a low current 8-bit microcontroller. The DNT24M modules operate in the 2.4 GHz MHz ISM band. There are 64 selectable hopping patterns. DNT24M modules also have two selectable RF output power levels: 10 and 63 mW.

The DNT24M modules provide a variety of hardware interfaces. There are two serial ports plus one SPI port. Either the primary serial port or the SPI port can be selected for data communications. The second serial port is dedicated to diagnostics. The primary and diagnostic serial ports support most standard baud rates up to 250.0 kbps. The SPI port supports data rates up to 500 kbps. Also included are three ADC inputs, two DAC outputs and six general-purpose digital I/O ports. Four of the digital I/O ports support an optional interrupt-from-sleep mode when configured as inputs.

There are four module configurations in the DNT24M Series:

- The DNT24MC is designed for use with an external antenna and for solder reflow mounting.
- The DNT24MP is designed for use with an external antenna and for plug-in connector mounting.
- The DNT24MCA has a built-in chip antenna and is designed for solder reflow mounting.
- The DNT24MPA has a built-in chip antenna and is designed for plug-in connector mounting.

## 6.1 Specifications

**Table 6-1 Absolute Maximum Rating**

| Absolute Maximum Rating                 | Value        | Units |
|-----------------------------------------|--------------|-------|
| Power Supply Input                      | -0.5 to +6.5 | V     |
| All Input/Output Pins                   | -0.5 to +3.3 | V     |
| Input Power to RFIO Port                | 0            | dBm   |
| Non-operating Ambient Temperature Range | -40 to +85   | °C    |

**Table 6-2 Operating Characteristics**

| Operating Characteristic                                                    | Sym             | Minimum | Typical                                                               | Maximum | Units |
|-----------------------------------------------------------------------------|-----------------|---------|-----------------------------------------------------------------------|---------|-------|
| RF Communication Topology                                                   |                 |         | Direct Peer-to-Peer                                                   |         |       |
| Spread Spectrum Mode                                                        |                 |         | Frequency Hopping                                                     |         |       |
| Operating Frequency Range                                                   |                 | 2406    |                                                                       | 2475    | MHz   |
| Number of RF Channels                                                       |                 |         | 15                                                                    |         |       |
| Number of Hopping Patterns                                                  |                 |         | 64                                                                    |         |       |
| Hop Duration                                                                |                 |         |                                                                       | 400     | ms    |
| Modulation                                                                  |                 |         | FSK                                                                   |         |       |
| RF Data Transmission Rate                                                   |                 |         | 250                                                                   |         | kbps  |
| Packet Transmission Time Including FHSS Synchronization and Acknowledgement |                 |         | 16                                                                    |         | ms    |
| Receiver Sensitivity, $10^{-5}$ BER                                         |                 |         | -100                                                                  |         | dBm   |
| Transmitter RF Output Power                                                 |                 |         | 10 or 63                                                              |         | mW    |
| Antenna Impedance, DNT24MC and DNT24MP                                      |                 |         | 50                                                                    |         | Ω     |
| RF Connection, DNT24MC and DNT24MP                                          |                 |         | U.FL Connector                                                        |         |       |
| ADC Input Range                                                             |                 | 0       |                                                                       | 2.7     | V     |
| ADC Input Resolution                                                        |                 |         |                                                                       | 12      | bits  |
| ADC Sample Rate                                                             |                 |         | 100                                                                   |         | Hz    |
| Signal Source Impedance for ADC Reading                                     |                 |         |                                                                       | 10      | KΩ    |
| ADC External Reference Voltage Range                                        |                 | 1.0     |                                                                       | 2.7     | V     |
| DAC Output Range                                                            |                 | 0       |                                                                       | 3.3     | V     |
| DAC Output Resolution                                                       |                 |         |                                                                       | 12      | bits  |
| Primary and Diagnostic Serial Port Baud Rates                               |                 |         | 1.2, 2.4, 4.8, 9.6, 19.2, 14.4, 28.8, 38.4, 57.6, 115.2, 230.4, 250.0 |         | kbps  |
| Master Serial Peripheral Interface Data Rate                                |                 | 125     | 250                                                                   | 500     | kbps  |
| Slave Serial Peripheral Interface Data Rate                                 |                 |         |                                                                       | 4000    | kbps  |
| Digital I/O:                                                                |                 |         |                                                                       |         |       |
| Logic Low Input Level                                                       |                 | -0.5    |                                                                       | 0.8     | V     |
| Logic High Input Level                                                      |                 | 2.45    |                                                                       | 3.3     | V     |
| Logic Input Internal Pull-up Resistor                                       |                 |         | 20                                                                    |         | KΩ    |
| Power Supply Voltage Range                                                  | V <sub>CC</sub> | +3.3    |                                                                       | +5.5    | Vdc   |

|                                                   |  |     |    |     |                   |
|---------------------------------------------------|--|-----|----|-----|-------------------|
| Power Supply Voltage Ripple                       |  |     |    | 10  | mV <sub>P-P</sub> |
| Peak Transmit Mode Current, 63 mW Output          |  |     |    | 140 | mA                |
| Operating Receive Current                         |  |     | 40 |     | mA                |
| Sleep Current                                     |  |     | 3  | 6   | µA                |
| Operating Temperature Range                       |  | -40 |    | 85  | °C                |
| Operating Relative Humidity Range, Non-condensing |  | 10  |    | 90  | %                 |

## 6.2 Module Pin Out

Electrical connections to the DNT24MC are made through the I/O pads and through the I/O pins on the DNT24MP. The hardware I/O functions are detailed in the table below:

**Table 6-3 Module Pin-Out**

| Pin | Name                 | I/O        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|----------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | GND                  | -          | Power supply and signal ground. Connect to the host circuit board ground.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2   | ACT<br>(DIAG_TX)     | O<br>(O)   | This pin's default configuration is transmitter activity (ACT) output. The ACT signal is activated whenever any data packet other than just an ACK is transmitted. The alternate function for this pin is the diagnostic serial port output.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 3   | /DCD<br>(DIAG_RX)    | O<br>(I)   | The DCD signal is activated when a DNT24M receives a valid packet. If a radio is transmitting data and receiving ACKs, both LEDs will be on. If a radio is transmitting data and not receiving ACKs, then only the ACT LED will be on. If a radio is receiving packets only, then only the DCD LED will be on. The alternate function for this pin is the diagnostic serial port input.                                                                                                                                                                                                                                                                                 |
| 4   | GPIO0                | I/O        | Configurable digital I/O port 0. When configured as an input, an internal pull-up resistor can be selected and direct interrupt from sleep can be invoked. When configured as an output, the power-on state is configurable. In sleep mode the pin direction, input pull-up selection or output state are also separately configurable.                                                                                                                                                                                                                                                                                                                                 |
| 5   | RADIO_TXD            | O          | Serial data output from the radio.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 6   | RADIO_RXD            | I          | Serial data input to the radio.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7   | GPIO4<br>(/HOST_CTS) | I/O<br>(O) | GPIO4 with the same configuration options as GPIO0. Alternate pin function is UART/SPI flow control output. The module sets this line low when it is ready to accept data from the host on the RADIO_RXD or MOSI input. When the line goes high, the host must stop sending data.                                                                                                                                                                                                                                                                                                                                                                                       |
| 8   | GPIO5<br>(/HOST_RTS) | I/O<br>(I) | GPIO5 with the same configuration options as GPIO0. Alternate pin function is UART/SPI flow control input. The host sets this line low to allow data to flow from the module on the RADIO_TXD pin. When the host sets this line high, the module will stop sending data to the host.                                                                                                                                                                                                                                                                                                                                                                                    |
| 9   | DAC0                 | O          | 12-bit DAC 0 output. Full scale can be referenced to the voltage at pin 25, or the 3.3 V regulated module bus voltage.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 10  | GPIO2                | I/O        | Configurable digital I/O port 2. Same configuration options as GPIO0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 11  | GPIO1                | I/O        | Configurable digital I/O port 1. Same configuration options as GPIO0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 12  | GPIO3<br>(DAV)       | I/O<br>(O) | Default pin function is GPIO3 with the same configuration options as GPIO0. When SPI slave mode operation is enabled, a logic high on this pin indicates when data is available to be clocked out by the SPI master.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 13  | DAC1                 | O          | 12-bit DAC 1 output. Same specifications and configuration options as DAC0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 14  | VCC                  | I          | Power supply input, +3.3 to +5.5 Vdc.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 15  | GND                  | -          | Power supply and signal ground. Connect to the host circuit board ground.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 16  | GND                  | -          | Power supply and signal ground. Connect to the host circuit board ground.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 17  | /RESET               | I          | Active low module hardware reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 18  | ADC0                 | I          | ADC input 0. This pin is a direct ADC input when the ADC is operating in single-ended mode, or the differential negative input for positive inputs applied to ADC1 or ADC2 when the ADC is operating in differential mode. Full-scale reading can be referenced to Pin 25 for ratiometric measurements. For absolute measurements, the ADC can use the regulated supply voltage divided by 1.6 (about 2.06 V), or an external voltage applied to Pin 25. In single-ended mode, ADC measurements are 11-bit unsigned values with full scale nominally 2.7 V when referenced to a 2.7 V input on Pin 27. In differential mode, ADC measurements are 12-bit signed values. |
| 19  | ADC1                 | I          | ADC input 1. Direct input when the ADC is operating in single-ended mode, positive differential input relative to ADC0 when the ADC is operating in differential mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| <b>Pin</b> | <b>Name</b> | <b>I/O</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 20         | MISO        | I/O        | This pin is the SPI master mode input or slave mode output.                                                                                |
| 21         | MOSI        | I/O        | This pin is the SPI master mode output or slave mode input.                                                                                |
| 22         | /SS         | I/O        | SPI active low slave select. This pin is an output when the module is operating as a master, and an input when it is operating as a slave. |
| 23         | SCLK        | I/O        | SPI clock signal. This pin is an output when operating as a master, and an input when operating as a slave.                                |

| <b>Pin</b> | <b>Name</b> | <b>I/O</b> | <b>Description (continued)</b>                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24         | ADC2        | I          | ADC input 2. Direct input when the ADC is operating in single-ended mode, positive differential input relative to ADC0 when the ADC is operating in differential mode.                                                                                                                                                                                                    |
| 25         | ADC_EXT_REF | I/O        | ADC external reference voltage pin. The voltage at this pin can be used by the ADCs as a reference for ratiometric measurements. With no external voltage or load applied, this pin presents a nominal 2.7 V output through a 2.126 K source resistance. A low impedance external reference voltage in the range of 1.0 to 2.7 V may be applied to this pin as an option. |
| 26         | RSVD        | -          | Reserved pin. Leave unconnected.                                                                                                                                                                                                                                                                                                                                          |
| 27         | RSVD        | -          | Reserved pin. Leave unconnected.                                                                                                                                                                                                                                                                                                                                          |
| 28         | GND         | -          | Connect to the host circuit board ground plane.                                                                                                                                                                                                                                                                                                                           |
| 29         | RSVD        | -          | Reserved pin. Leave unconnected.                                                                                                                                                                                                                                                                                                                                          |
| 30         | GND         | -          | Connect to the host circuit board ground plane.                                                                                                                                                                                                                                                                                                                           |

### 6.3 Antenna Connector

A U.FL miniature coaxial connector is provided on the DNT24MC and DNT24MP for connection to the RFIO port. A short U.FL coaxial cable can be used to connect the RFIO port directly to an antenna. In this case the antenna should be mounted firmly to avoid stressing the U.FL coaxial cable due to antenna mounting flexure. Alternately, a U.FL coaxial jumper cable can be used to connect the DNT24M module to a U.FL connector on the host circuit board. The connection between the host circuit board U.FL connector and the antenna or antenna connector on the host circuit board should be implemented as a 50 ohm stripline. Referring to Figure 6-2, the width of this stripline depends on the thickness of the circuit board between the stripline and the groundplane. For FR-4 type circuit board materials (dielectric constant of 4.7), the width of the stripline is equal to 1.75 times the thickness of the circuit board. Note that other circuit board traces should be spaced away from the stripline to prevent signal coupling, as shown in Table 6-4. The stripline trace should be kept short to minimize its insertion loss.



**Figure 6-2 Circuit Board Stripline Trace Detail**

**Table 6-4 Stripline Trace Length**

| Trace Separation from<br>50 ohm Microstrip | Length of Trace Run<br>Parallel to Microstrip |
|--------------------------------------------|-----------------------------------------------|
| 100 mil                                    | 125 mill                                      |
| 150 mil                                    | 200 mil                                       |
| 200 mil                                    | 290 mil                                       |
| 250 mil                                    | 450 mil                                       |
| 300 mil                                    | 650 mil                                       |

## 6.4 Power Supply and Input Voltages

DNT24M radio modules can operate from an unregulated DC input (Pad 19) in the range of 3.3 to 5.5 V with a maximum ripple of 5% over the temperature range of -40 to 85 °C. Applying AC, reverse DC, or a DC voltage outside the range given above can cause damage and/or create a fire and safety hazard. Further, care must be taken so logic inputs applied to the radio stay within the voltage range of 0 to 3.3 V. Signals applied to the analog inputs must be in the range of 0 to ADC\_EXT\_REF (Pad/Pin 25). Applying a voltage to a logic or analog input outside of its operating range can damage the DNT24M module.

## 6.5 ESD and Transient Protection

The DNT24MC and DNT24MP circuit boards are electrostatic discharge (ESD) sensitive. ESD precautions must be observed when handling and installing these components. Installations must be protected from electrical transients on the power supply and I/O lines. This is especially important in outdoor installations, and/or where connections are made to sensors with long leads. Inadequate transient protection can result in damage and/or create a fire and safety hazard.

## 6.6 Interfacing to 5 V Logic Systems

All logic signals including the serial ports on the DNT24M are 3.3 V signals. To interface to 5 V signals, the resistor divider network shown in Figure 6-3 below must be placed between the 5 V signal outputs and the DNT24M signal inputs. The output voltage swing of the DNT24M 3.3 V signals is sufficient to drive 5 V logic inputs.



**Figure 6-3 Resistor Divider Network**

## 6.7 Mounting and Enclosures

DNT24MC and DNT24MCA radio modules are mounted by reflow soldering them to a host circuit board. DNT24MP and DNT24MPA modules are mounted by plugging their pins into a set of mating connectors on the host circuit board. Refer to Section 10.3 for DNT24MP connector details.

DNT24M enclosures must be made of plastics or other materials with low RF attenuation to avoid compromising antenna performance where antennas are internal to the enclosure. Metal enclosures are not suitable for use with internal antennas as they will block antenna radiation and reception. Outdoor enclosures must be water tight, such as a NEMA 4X enclosure.

## **6.8 Labeling and Notices**

DNT24M FCC Certification - The DNT24M hardware has been certified for operation under FCC Part 15 Rules, Section 15.247. *The antenna(s) used for this transmitter must be installed to provide a separation distance of at least 20 cm from all persons and must not be co-located or operating in conjunction with any other antenna or transmitter.*

DNT24M FCC Notices and Labels - *This device complies with Part 15 of the FCC rules. Operation is subject to the following two conditions: (1) this device may not cause harmful interference, and (2) this device must accept any interference received, including interference that may cause undesired operation.*

A clearly visible label is required on the outside of the user's (OEM) enclosure stating the following text:

*Contains FCC ID: HSW-DNT24*

*Contains IC: 4492A-DNT24*

*MURATA (Insert Model Designation DNT24MC, DNT24MCA, DNT24MP or DNT24MPA depending on the model used): This device complies with Part 15 of the FCC Rules. Operation is subject to the following two conditions: (1) This device may not cause harmful interference, and (2) this device must accept any interference received, including interference that may cause undesired operation.*

**WARNING:** This device operates under Part 15 of the FCC rules. Any modification to this device, not expressly authorized by MURATA, Inc., may void the user's authority to operate this device.

This apparatus complies with Health Canada's Safety Code 6 / IC RSS 210.

**IC RSS-210 Notice** - *Operation is subject to the following two conditions: (1) this device may not cause interference, and (2) this device must accept any interference, including interference that may cause undesired operation of the device.*

### **ICES-003**

This digital apparatus does not exceed the Class B limits for radio noise emissions from digital apparatus as set out in the radio interference regulations of Industry Canada.

Le present appareil numerique n'emett pas de bruits radioelectriques depassant les limites applicables aux appareils numeriques de Classe B prescrites dans le reglement sur le brouillage radioelectrique edicte par Industrie Canada.

## 7.0 DNT24M Protocol-formatted Messages

### 7.1 Protocol Formats

DNT24M modules can work in one of two serial data modes - transparent or protocol. Transparent mode requires no data formatting, but is limited to sending data to either a single destination or broadcasting data to all destinations. A node that needs to send messages to multiple individual destinations must use protocol formatting unless the data being sent includes addressing information. Protocol formatting is also required for configuration commands and replies, and sensor I/O commands, replies and events. All protocol-formatted messages have a common header as shown in Figure 7-1:

|     |        |         |                                  |
|-----|--------|---------|----------------------------------|
| 0   | 1      | 2       | 3 ...                            |
| SOP | Length | PktType | variable number of arguments ... |

Figure 7-1 Protocol Message Header Format

The scale above is in bytes.

The *Start-of-Packet* (SOP) character, 0xFB, is used to mark the beginning of a protocol-formatted message and to assure synchronization in the event of a glitch on the serial port at startup.

The *Length* byte is defined as the length of the remainder of the message following the length byte itself, or the length of the entire message - 2.

The *Packet Type* (PktType) byte specifies the type of message. It is a bitfield-oriented specifier, decoded as follows:

|           |                                                          |
|-----------|----------------------------------------------------------|
| Bits 7..6 | Reserved for future use                                  |
| Bit 5     | Event - this bit is set to indicate an event message     |
| Bit 4     | Reply - this bit is set to indicate a message is a reply |
| Bits 3..0 | Type - these bits indicate the message type              |

As indicated, the lower four bits (3..0) specify a message type. Bit 4 indicates that the message is a reply. A reply message has the original command type in bits 3..0, with Bit 4 set to one. Bit 5 indicates an event message. Arguments vary in size and number depending on the type of message and whether it is a message sent from the host, or is a reply or event message from the radio. See Section 7.3 below.

### 7.2 Message Types

Messages sent to the module on the serial interface by the user are referred to as *host* messages. Messages generated on the serial interface by the radio are referred to as *reply* or *event* messages. Host messages carry commands. For most commands, there is a corresponding reply message. For example, when the host sends a *TxData* command message, the radio can return a *TxDataReply* message to indicate the status of the transmission - whether it succeeded or failed. To assist in interpreting the command-reply data flow, the direction is indicated by the high nibble in the message type. For example, an *EnterProtocolMode* command from the host is a message type 0x00, and the *EnterProtocolModeReply* from the radio is a message type 0x10.

Event messages from a DNT24M, such as received data or status announcements make up a third category of messages. Event messages, including *RxData*, *RxEVENT* and *Announce* packets are indicated by 0x20 in the high nibble of the type byte. If multiple arguments are to be provided, they are to be concatenated.

nated in the order shown in Section 7.3 below. Little-Endian byte order is used for all multi-byte arguments except text strings. Little-Endian byte order places the lowest order byte in the left-most byte of the argument and the highest order byte in the right-most byte of the argument.

### 7.3 Message Format Details

Table 7.3.1 below summarizes the DNT24M protocol-formatted messages:

**Table 7-1 DNT24M Protocol Messages**

| Command | Reply | Event | Type                          | Direction  |
|---------|-------|-------|-------------------------------|------------|
| 0x00    | -     | -     | <i>EnterProtocolMode</i>      | from Host  |
| -       | 0x10  | -     | <i>EnterProtocolModeReply</i> | from Radio |
| 0x01    | -     | -     | <i>ExitProtocolMode</i>       | from Host  |
| 0x02    | -     | -     | <i>DeviceReset</i>            | from Host  |
| -       | 0x12  | -     | <i>DeviceResetReply</i>       | from Radio |
| 0x03    | -     | -     | <i>GetRegister</i>            | from Host  |
| -       | 0x13  | -     | <i>GetRegisterReply</i>       | from Radio |
| 0x04    | -     | -     | <i>SetRegister</i>            | from Host  |
| -       | 0x14  | -     | <i>SetRegisterReply</i>       | from Radio |
| 0x05    | -     | -     | <i>TxDATA</i>                 | from Host  |
| -       | 0x15  | -     | <i>TxDATAReply</i>            | from Radio |
| 0x06    | -     | -     | <i>GetRemoteRegister</i>      | from Host  |
| -       | 0x16  | -     | <i>GetRemoteRegisterReply</i> | from Radio |
| 0x07    | -     | -     | <i>SetRemoteRegister</i>      | from Host  |
| -       | 0x17  | -     | <i>SetRemoteRegisterReply</i> | from Radio |
| -       | -     | 0x26  | <i>RxDATA</i>                 | from Radio |
| -       | -     | 0x27  | <i>Announce/Error</i>         | from Radio |
| -       | -     | 0x28  | <i>RxEVENT</i>                | from Radio |

*EnterProtocolMode* command and reply format details are presented in Tables 7-2 and 7-3:

**Table 7-2 Enter Protocol Mode Command**

| Enter Protocol Mode Command |                 |                                                       |
|-----------------------------|-----------------|-------------------------------------------------------|
| Byte Offset                 | Field           | Description                                           |
| 0x00                        | Start-of-Packet | 0xFB = Indicates start of protocol formatted message  |
| 0x01                        | Length          | 0x07 = Number of bytes in message following this byte |
| 0x02                        | Packet Type     | 0x00 = EnterProtocolMode                              |
| 0x03 - 0x08                 | Payload         | String = "DNTCFG" or 0x44 0x4E 0x54 0x43 0x46 0x47    |

**Table 7-3 Enter Protocol Mode Reply**

| Enter Protocol Mode Reply |                 |                                                       |
|---------------------------|-----------------|-------------------------------------------------------|
| Byte Offset               | Field           | Description                                           |
| 0x00                      | Start-of-Packet | 0xFB = Indicates start of protocol formatted message  |
| 0x01                      | Length          | 0x01 = Number of bytes in message following this byte |
| 0x02                      | Packet Type     | 0x10 = EnterProtocolModeReply                         |

**Table 7-4 Exit Protocol Mode Command**

*ExitProtocolMode* command format details are shown below:

| Exit Protocol Mode Command |                 |                                                       |
|----------------------------|-----------------|-------------------------------------------------------|
| Byte Offset                | Field           | Description                                           |
| 0x00                       | Start-of-Packet | 0xFB = Indicates start of protocol formatted message  |
| 0x01                       | Length          | 0x01 = Number of bytes in message following this byte |
| 0x02                       | Packet Type     | 0x01 = ExitProtocolMode                               |

**Table 7-5 Device Reset Command**

*DeviceReset* command and reply format details are shown in Tables 7-5 and 7-6:

| Device Reset Command |                 |                                                                                                            |
|----------------------|-----------------|------------------------------------------------------------------------------------------------------------|
| Byte Offset          | Field           | Description                                                                                                |
| 0x00                 | Start-of-Packet | 0xFB = Indicates start of protocol formatted message                                                       |
| 0x01                 | Length          | 0x02 = Number of bytes in message following this byte                                                      |
| 0x02                 | Packet Type     | 0x02 = DeviceReset                                                                                         |
| 0x03                 | Reset Type      | 0x00 = Normal Device Reset<br>0x01 = Reset to Serial Bootloader<br>0x02 = Reset to Over-the-Air Bootloader |

**Table 7-6 Device Reset Reply**

| Device Reset Reply |                 |                                                       |
|--------------------|-----------------|-------------------------------------------------------|
| Byte Offset        | Field           | Description                                           |
| 0x00               | Start-Of-Packet | 0xFB = Indicates start of protocol formatted message  |
| 0x01               | Length          | 0x01 = Number of bytes in message following this byte |
| 0x02               | Packet Type     | 0x12 = DeviceResetReply                               |

**Table 7-7 Get Register Command**

*GetRegister* command and reply format details are shown in Tables 7-7 and 7-8:

| Get Register Command |                 |                                                                                                           |
|----------------------|-----------------|-----------------------------------------------------------------------------------------------------------|
| Byte Offset          | Field           | Description                                                                                               |
| 0x00                 | Start-of-Packet | 0xFB = Indicates start of protocol formatted message                                                      |
| 0x01                 | Length          | 0x04 = Number of bytes in message following this byte                                                     |
| 0x02                 | Packet Type     | 0x03 = GetRegister                                                                                        |
| 0x03                 | Register Offset | Register offset in its bank                                                                               |
| 0x04                 | Register Bank   | Register bank number                                                                                      |
| 0x05                 | Register Size   | Register size in bytes, only one parameter at a time (wrong register size will produce an error response) |

**Table 7-8 Get Register Reply**

| Get Register Reply |                 |                                                                          |
|--------------------|-----------------|--------------------------------------------------------------------------|
| Byte Offset        | Field           | Description                                                              |
| 0x00               | Start-of-Packet | 0xFB = Indicates start of protocol formatted message                     |
| 0x01               | Length          | 0x05 to 0x14 = Number of bytes in message following this byte            |
| 0x02               | Packet Type     | 0x13 = GetRegisterReply                                                  |
| 0x03               | Register Offset | Register offset in its bank                                              |
| 0x04               | Register Bank   | Register bank number                                                     |
| 0x05               | Register Size   | Register size in bytes                                                   |
| 0x06 - 0x15        | Register Value  | Register value, all bytes in the register (only one parameter at a time) |

Note: an *Error* message will be returned instead of a *GetRegisterReply* in case of a format error.

**Table 7-9 Set Register Command**

*SetRegister* command and reply format details are shown in Tables 7-9 and 7-10:

| Set Register Command |                 |                                                                          |
|----------------------|-----------------|--------------------------------------------------------------------------|
| Byte Offset          | Field           | Description                                                              |
| 0x00                 | Start-of-Packet | 0xFB = Indicates start of protocol formatted message                     |
| 0x01                 | Length          | 0x05 to 0x14 = Number of bytes in message following this byte            |
| 0x02                 | Packet Type     | 0x04 = SetRegister                                                       |
| 0x03                 | Register Offset | Register offset in its bank                                              |
| 0x04                 | Register Bank   | Register bank number                                                     |
| 0x05                 | Register Size   | Register size in bytes                                                   |
| 0x06 - 0x15          | Register Value  | Register value, all bytes in the register (only one parameter at a time) |

**Table 7-10 Set Register Reply**

| Set Register Reply |                 |                                                       |
|--------------------|-----------------|-------------------------------------------------------|
| Byte Offset        | Field           | Description                                           |
| 0x00               | Start-of-Packet | 0xFB = Indicates start of protocol formatted message  |
| 0x01               | Length          | 0x01 = Number of bytes in message following this byte |
| 0x02               | Packet Type     | 0x14 = SetRegisterReply                               |

Note: an *Error* message will be returned instead of a *SetRegisterReply* in case of a format error.

**Table 7-11 TX Data Command**

*TXData* command and reply format details are shown in Tables 7-11 and 7-12:

| TX Data Command |                         |                                                               |
|-----------------|-------------------------|---------------------------------------------------------------|
| Byte Offset     | Field                   | Description                                                   |
| 0x00            | Start-of-Packet         | 0xFB = Indicates start of protocol formatted message          |
| 0x01            | Length                  | 0x04 to 0x6B = Number of bytes in message following this byte |
| 0x02            | Packet Type             | 0x05 = TxData                                                 |
| 0x03 - 0x05     | Destination MAC Address | Destination MAC address, in Little Endian byte order          |
| 0x06 - 0x6C     | Tx Data                 | Up to 103 data bytes                                          |

**Table 7-12 TX Data Reply**

| TX Data Reply |                         |                                                                                       |
|---------------|-------------------------|---------------------------------------------------------------------------------------|
| Byte Offset   | Field                   | Description                                                                           |
| 0x00          | Start-of-Packet         | 0xFB = Indicates start of protocol formatted message                                  |
| 0x01          | Length                  | 0x06 = Number of bytes in message following this byte                                 |
| 0x02          | Packet Type             | 0x15 = TxDataReply                                                                    |
| 0x03 - 0x05   | Destination MAC Address | Destination MAC address, in Little Endian byte order                                  |
| 0x06          | Status                  | 0x00 = ACK received from destination<br>0x01 = no ACK received from destination (NAK) |
| 0x07          | RSSI                    | Packet RX power in dBm, -128 to 126 or 127 if invalid                                 |

Note: *TxDataReply* messages are only returned to the host when the *EndToEndAckEnable* parameter is set to 0x01.

**Table 7-13 Get Remote Register Command**

*GetRemoteRegister* command and reply details are shown in Tables 7-13 and 7-14:

| Get Remote Register Command |                         |                                                                                                           |
|-----------------------------|-------------------------|-----------------------------------------------------------------------------------------------------------|
| Byte Offset                 | Field                   | Description                                                                                               |
| 0x00                        | Start-of-Packet         | 0xFB = Indicates start of protocol formatted message                                                      |
| 0x01                        | Length                  | 0x07 = Number of bytes in message following this byte                                                     |
| 0x02                        | Packet Type             | 0x06 = GetRemoteRegister                                                                                  |
| 0x03 - 0x05                 | Destination MAC Address | Destination MAC address, in Little Endian byte order                                                      |
| 0x06                        | Register Offset         | Register offset in its bank                                                                               |
| 0x07                        | Register Bank           | Register bank number                                                                                      |
| 0x08                        | Register Size           | Register size in bytes, only one parameter at a time (wrong register size will produce an error response) |

**Table 7-14 Get Remote Register Reply**

| Get Remote Register Reply |                        |                                                               |
|---------------------------|------------------------|---------------------------------------------------------------|
| Byte Offset               | Field                  | Description                                                   |
| 0x00                      | Start-of-Packet        | 0xFB = Indicates start of protocol formatted message          |
| 0x01                      | Length                 | 0x0A to 0x19 = Number of bytes in message following this byte |
| 0x02                      | Packet Type            | 0x16 = GetRemoteRegisterReply                                 |
| 0x03                      | Status                 | Error status (0x00 = No Error, 0xE1 = Invalid Argument)       |
| 0x04 - 0x06               | Originator MAC Address | Originator's MAC address, in Little Endian byte order         |
| 0x07                      | RSSI                   | (-128 to 126 or 127 if invalid)                               |

**Table 7-14 (cont.)**

|             |                  |                                                                          |
|-------------|------------------|--------------------------------------------------------------------------|
| 0x08        | Register Offset* | Register offset in its bank                                              |
| 0x09        | Register Bank*   | Register bank number                                                     |
| 0x0A        | Register Size*   | Register size in bytes                                                   |
| 0x0B - 0x1A | Register Value*  | Register value, all bytes in the register (only one parameter at a time) |

\*Bytes eight through the end of the message will not be returned in case of an error

**Table 7-15 Set Remote Register Command**

*SetRemoteRegister* command and reply format details are shown in Tables 7-15 and 7-16:

| Set Remote Register Command |                         |                                                      |
|-----------------------------|-------------------------|------------------------------------------------------|
| Byte Offset                 | Field                   | Description                                          |
| 0x00                        | Start-of-Packet         | 0xFB = Indicates start of protocol formatted message |
| 0x01                        | Length                  | Number of bytes in message following this byte       |
| 0x02                        | Packet Type             | 0x07 = SetRemoteRegister                             |
| 0x03 - 0x05                 | Destination MAC Address | Destination MAC address, in Little Endian byte order |
| 0x06                        | Register Offset         | Register offset in its bank                          |
| 0x07                        | Register Bank           | Register bank number                                 |
| 0x08                        | Register Size           | Register size in bytes                               |
| 0x09 - 0x18                 | Register Value          | Register contents                                    |

**Table 7-16 Set Remote Register Reply**

| Set Remote Register Reply |                        |                                                        |
|---------------------------|------------------------|--------------------------------------------------------|
| Byte Offset               | Field                  | Description                                            |
| 0x00                      | Start-of-Packet        | 0xFB = Indicates start of protocol formatted message   |
| 0x01                      | Length                 | 0x06 = Number of bytes in message following this byte  |
| 0x02                      | Packet Type            | 0x17 = SetRemoteRegisterReply                          |
| 0x03                      | Status                 | Error status: 0x00 = no error, 0xE1 = invalid argument |
| 0x04 - 0x06               | Originator MAC Address | Originator's MAC address, in Little Endian byte order  |
| 0x07                      | RSSI                   | Packet RX power in dBm, -128 to 126, or 127 if invalid |

**Table 7-17 RX Data Packet**

*RxData* event packet format details are shown below:

| RX Data Packet |                        |                                                               |
|----------------|------------------------|---------------------------------------------------------------|
| Byte Offset    | Field                  | Description                                                   |
| 0x00           | Start-of-Packet        | 0xFB = Indicates start of protocol formatted message          |
| 0x01           | Length                 | 0x05 to 0x6C = Number of bytes in message following this byte |
| 0x02           | Packet Type            | 0x26 = RxData event message                                   |
| 0x03 - 0x05    | Originator MAC Address | Originator's MAC address, in Little Endian byte order         |
| 0x06           | RSSI                   | Packet RX power in dBm, -128 to 126, or 127 if invalid        |
| 0x07 - 0x6D    | Rx Data                | Up to 103 data bytes                                          |

**Table 7-18 Startup Announcement or Error Code**

*Announce/Error* message format details are shown in Tables 7-18 through 7-21:

| Startup Announcement or Error Code |                 |                                                                                                                                                                                                          |
|------------------------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Byte Offset                        | Field           | Description                                                                                                                                                                                              |
| 0x00                               | Start-of-Packet | 0xFB = Indicates start of protocol formatted message                                                                                                                                                     |
| 0x01                               | Length          | 0x02 = Number of bytes in message following this byte                                                                                                                                                    |
| 0x02                               | Packet Type     | 0x27 = Indicates this is an Announce/Error message                                                                                                                                                       |
| 0x03                               | Announce Status | 0xA0 = Startup initialization complete<br>0xE1 = Invalid argument<br>0xE4 = Register read only error<br>0xEC = Brownout reset<br>0xED = Watchdog reset<br>0xEE = Hardware Error (Crystal or Radio Error) |

**Table 7-19 Heartbeat Announcement**

| Heartbeat Announcement |                        |                                                                                                      |
|------------------------|------------------------|------------------------------------------------------------------------------------------------------|
| Byte Offset            | Field                  | Description                                                                                          |
| 0x00                   | Start-of-Packet        | 0xFB = Indicates start of protocol formatted message                                                 |
| 0x01                   | Length                 | 0x07 = Number of bytes in message following this byte                                                |
| 0x02                   | Packet Type            | 0x27 = Indicates this is an Announce/Error message                                                   |
| 0x03                   | Announce Status        | 0xA8 = Heartbeat message                                                                             |
| 0x04 - 0x06            | Originator MAC Address | MAC address of originator, in Little Endian byte order                                               |
| 0x07                   | RSSI                   | Received power in dBm, -128 to 126, or 127 if invalid                                                |
| 0x08                   | Beacon RX Power        | Average beacon RX power in dBm, uses 0.0625 "alpha" averaging filter, -128 to 126, or 127 if invalid |

**Table 7-20 RX Event Packet**

*RxEvent* message format details are shown below:

| RX Event Packet |                        |                                                                                                                                                                                                                                                                                                                               |
|-----------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Byte Offset     | Field                  | Description                                                                                                                                                                                                                                                                                                                   |
| 0x00            | Start-of-Packet        | 0xFB = Indicates start of protocol formatted message                                                                                                                                                                                                                                                                          |
| 0x01            | Length                 | 0x12 = Number of bytes in message following this byte                                                                                                                                                                                                                                                                         |
| 0x02            | Packet Type            | 0x28 = RxEvent                                                                                                                                                                                                                                                                                                                |
| 0x03 - 0x05     | Originator MAC Address | Originator's MAC address, in Little Endian byte order                                                                                                                                                                                                                                                                         |
| 0x06            | RSSI                   | Packet RX power in dBm (-128 to 127)                                                                                                                                                                                                                                                                                          |
| 0x07            | GPIO Readings          | Bit field (GPIO0..GPIO5) indicating GPIO readings                                                                                                                                                                                                                                                                             |
| 0x08 - 0x09     | ADC0 Reading           | ADC0 Reading, 0x0000 - 0x0FFF, in Little Endian byte order                                                                                                                                                                                                                                                                    |
| 0x0A - 0x0B     | ADC1 Reading           | ADC1 Reading, 0x0000 - 0x0FFF, in Little Endian byte order                                                                                                                                                                                                                                                                    |
| 0x0C - 0x0D     | ADC2 Reading           | ADC2 Reading, 0x0000 - 0x0FFF, in Little Endian byte order                                                                                                                                                                                                                                                                    |
| 0x0E - 0x0F     | Event Flags            | Bit field indicating which events have occurred:<br>Bit 0: GPIO0 Triggered<br>Bit 1: GPIO1 Triggered<br>Bit 2: GPIO2 Triggered<br>Bit 3: GPIO3 Triggered<br>Bit 4: Periodic Report Interval<br>Bit 5: ADC0 Threshold Triggered<br>Bit 6: ADC1 Threshold Triggered<br>Bit 7: ADC2 Threshold Triggered<br>Bits 8-15: unused (0) |
| 0x10 - 0x11     | DAC0 Setting           | DAC0 setting, 0x0000 - 0x0FFF, in Little Endian byte order                                                                                                                                                                                                                                                                    |
| 0x12 - 0x13     | DAC1 Setting           | DAC1 setting, 0x0000 - 0x0FFF, in Little Endian byte order                                                                                                                                                                                                                                                                    |

## 7.4 Configuration Parameter Registers

The configuration parameters in a DNT24M module are stored in a set of variable length *registers*. Most registers are read-write, with a few read-only or write-only. Changes made to the register settings are temporary until a *MemorySave* command is executed. Resetting or power-cycling the module will clear any changes that have not been saved to permanent memory using the *MemorySave* command.

DNT24M modules can be configured to start in protocol mode at power-up, in which case the *EnterProtocolMode* command is not required.

## 7.4.1 Bank 0x00 - Transceiver Setup

Table 7-21 Bank 0x00 Transceiver Setup

| Bank | Location | Name             | R/W | Size | Range      | Default           |
|------|----------|------------------|-----|------|------------|-------------------|
| 0x00 | 0x00     | Reserved         | -   | 1    | -          | -                 |
| 0x00 | 0x01     | Reserved         | -   | 1    | -          | -                 |
| 0x00 | 0x02     | Reserved         | -   | 1    | -          | -                 |
| 0x00 | 0x03     | SecurityKey      | W   | 16   | 0..2^128-1 | 0                 |
| 0x00 | 0x13     | SleepModeEn      | R/W | 1    | 0..2       | 0 (off)           |
| 0x00 | 0x14     | WakeResponseTime | R/W | 2    | 0..30000   | 100 (100 ms)      |
| 0x00 | 0x16     | Reserved         | -   | 1    | -          | -                 |
| 0x00 | 0x17     | Reserved         | -   | 1    | -          | -                 |
| 0x00 | 0x18     | TxPower          | R/W | 1    | 0..1       | 1 (63 mW)         |
| 0x00 | 0x19     | UserTag          | R/W | 16   | string     | "DNT24M"          |
| 0x00 | 0x29     | RmtTransDestAddr | R/W | 3    | 0..0xFFFFF | 0xFFFFF           |
| 0x00 | 0x2C     | Reserved         | -   | 1    | -          | -                 |
| 0x00 | 0x2D     | Reserved         | -   | 1    | -          | -                 |
| 0x00 | 0x2E     | HeartbeatIntrvl  | R/W | 2    | 0..0xFFFF  | 0xFFFF (disabled) |
| 0x00 | 0x30     | SystemId         | R/W | 1    | 0..63      | 0                 |
| 0x00 | 0x31     | AckEnable        | R/W | 1    | 0..1       | 0 (disabled)      |
| 0x00 | 0x32     | Reserved         | -   | 2    | -          | -                 |
| 0x00 | 0x34     | Reserved         | -   | 2    | -          | -                 |
| 0x00 | 0x36     | Reserved         | -   | 1    | -          | -                 |
| 0x00 | 0x37     | MaxUnicastFrames | R/W | 1    | 1..40      | 5                 |
| 0x00 | 0x38     | MaxBcstFrames    | R/W | 1    | 1..40      | 5                 |

**Security Key** - this 16-byte parameter sets the 128-bit AES encryption key. To protect the key, it is a write-only parameter for the user. It always reads back as 0x2A.

**SleepModeEn** - this parameter enables/disables sleep mode. Sleep mode is used in conjunction with the automatic I/O reporting feature to wake up on specific triggers. The default value for this parameter is 0 (off). Setting this parameter to 1 invokes sleep mode immediately. Setting this parameter to 2 invokes sleep mode following reset, allowing this and other parameter updates to be stored before sleep mode is invoked.

*WakeResponseTime* - this parameter set how long sleep is deferred in a DNT24M configured for sleep mode after:

- receiving an ACK
- receiving a packet that requires processing by the device
- receiving a protocol formatted message from the device's local host.

*TxPower* - this parameter sets the transmit power level (default is 1):

- 0 = +10 dBm or 10 mW
- 1 = +18 dBm or 63 mW

*UserTag* - this parameter is a user definable field intended for use as a location description or other identifying tag such as a "friendly name".

*RmtTransDestAddr* - this parameter holds the default destination for transparent mode data packets and event packets. This parameter defaults to the broadcast address, 0xFFFFFFF.

*HeartbeatInterval* - when set to 0x0000, all heartbeats are disabled. When set to 0xFFFF (default), periodic heartbeats are disabled but the initial heartbeat at power up is enabled. The periodic heartbeat interval is scaled 1 second/count, and applies to DNT24Ms where sleep mode is disabled. DM24M radios with sleep mode enabled must have periodic reports and/or ADC sampling enabled for heartbeats to be generated.

*SystemId* - this parameter holds the ID for a DNT24M system. DNT24M systems that may physically overlap must have different system IDs.

*AckEnable* - when this parameter is set to 1 and the DNT24M is in protocol mode, the originator will indicate in its transmitted packet that an ACK message is expected from the packet's destination node, which is passed on to the originator's host.

*MaxUnicastFrames* - this parameter sets the maximum number of packets addressed to a specific node that will be transmitted on a channel before switching to the next channel in the frequency hopping sequence.

*MaxBcstFrames* - this parameter sets the maximum number of different broadcast packets that will be transmitted on a channel before switching to the next channel in the frequency hopping sequence.

## 7.4.2 Bank 0x01 - System Settings

Table 7-22 Bank 0x01 System Settings

| Bank | Location | Name             | R/W | Size | Range  | Default       |
|------|----------|------------------|-----|------|--------|---------------|
| 0x01 | 0x00     | Reserved         | R/W | 1    | -      | -             |
| 0x01 | 0x01     | Reserved         | R/W | 1    | -      | -             |
| 0x01 | 0x02     | Reserved         | R/W | 1    | -      | -             |
| 0x01 | 0x03     | Reserved         | R/W | 1    | -      | -             |
| 0x01 | 0x04     | BcstAttemptLimit | R/W | 1    | 0..254 | 4             |
| 0x01 | 0x05     | ArqAttemptLimit  | R/W | 1    | 1..255 | 10            |
| 0x01 | 0x06     | Reserved         | R/W | 1    | -      | -             |
| 0x01 | 0x07     | P2PReplyTimeout  | R/W | 1    | 0..255 | 10 (1 second) |
| 0x01 | 0x08     | RegistryTimeout  | R/W | 1    | 0..255 | 5 (seconds)   |
| 0x01 | 0x09     | Reserved         | R/W | 1    | -      | -             |

*BcstAttemptLimit* - setting this parameter to 0 enables automatic broadcast message repeats based on the *ArqAttemptLimit* parameter value. Setting this parameter to a value between 1 and 254 specifies the number of broadcast message repeats independent of the *ArqAttemptLimit*. This parameter should not be set to 0 if *ArqAttemptLimit* is set to 255.

*ArqAttemptLimit* - this sets the maximum number of attempts that will be made to send a message on the RF link. Setting this parameter to the maximum value of 255 is a flag value indicating that there should be no limit to the number of attempts to send each packet (infinite number of attempts). This mode is intended for point-to-point networks in serial data cable replacement applications where absolutely no packets can be lost.

*P2PReplyTimeout* - this parameter sets the reply timeout for messages sent from one node to another.

*RegistryTimeout* - this parameter sets the number of seconds a DNT24M will hold the Transaction ID (TID) history for another DNT24M before discarding the history. Any communication between these radios before the timeout occurs restarts the timeout counter. The TID is used to filter out duplicate packets.

### 7.4.3 Bank 0x02 - Status Parameters

Table 7-23 Bank 0x02 Status Parameters

| Bank | Location | Name              | R/W | Size | Range          | Default         |
|------|----------|-------------------|-----|------|----------------|-----------------|
| 0x02 | 0x00     | MacAddress        | R   | 3    | 0..0xFFFFF     | Fixed value     |
| 0x02 | 0x03     | Reserved          | R   | 1    | -              | -               |
| 0x02 | 0x04     | Reserved          | R   | 1    | -              | -               |
| 0x02 | 0x05     | Reserved          | R   | 1    | -              | -               |
| 0x02 | 0x06     | Reserved          | R   | 1    | -              | -               |
| 0x02 | 0x07     | Reserved          | R   | 1    | -              | -               |
| 0x02 | 0x08     | HardwareVersion   | R/W | 1    | 0x41..0x5A     | Current HW      |
| 0x02 | 0x09     | FirmwareVersion   | R   | 1    | 0x00..0xFF     | Current FW load |
| 0x02 | 0x0A     | FirmwareBuildNum  | R   | 2    | 0..65535       | Current FW load |
| 0x02 | 0x0C     | FirmwareBuildDate | R   | 3    | BCD ("YYMMDD") | Current FW load |
| 0x02 | 0x0F     | FirmwareBuildTime | R   | 3    | BCD ("HHMMSS") | Current FW load |
| 0x02 | 0x12     | Rssidle           | R   | 1    | -128..127      | Current Value   |
| 0x02 | 0x13     | RssiLast          | R   | 1    | -128..127      | Current Value   |
| 0x02 | 0x14     | AvgBeaconPower    | R   | 1    | -128..127      | Current Value   |
| 0x02 | 0x15     | Reserved          | R   | 3    | -              | -               |
| 0x02 | 0x18     | ModelNumber       | R   | 1    | 0x24, 0x90     | 0x24 = DNT24M   |
| 0x02 | 0x19     | OtaTxQueueBusy    | R   | 1    | 0..1           | Current Value   |

*MacAddress* - this parameter holds the radio's unique 24-bit MAC address.

*HarwareVersion* - this parameter holds an identifier indicating the hardware revision (ASCII character).

*FirmwareVersion* - this parameter holds the firmware version of the radio in 2-digit BCD format.

*FirmwareBuildNum* - this parameter holds the firmware build number, in binary format.

*FirmwareBuildDate* - this parameter holds the date of firmware build in MM/DD/YY format.

*FirmwareBuildTime* - this parameter holds the time of the firmware build in HH:MM:SS format.

*Rssidle* - this 2's compliment parameter holds the last RSSI measurement in dBm made during a time when the RF channel was idle. This parameter is useful for detecting interferers.

*RssiLast* - this 2's compliment parameter holds the last RSSI measurement in dBm made during the receipt of an RF packet with a valid CRC. This parameter is useful for network commissioning/diagnostics.

*AvgBeaconPower* - this 2's compliment parameter holds the alpha-filtered beacon power (dBm) received from a device's parent, where alpha = 0.0625.

*ModelNumber* - this parameter specifies the DNT model, in this case a DNT24M.

*OtaTxQueueBusy* - this parameter indicates if the transmitter queue is currently holding bytes to transmit. If bytes are present in the queue the value is 1. If the queue is empty the value is 0.

#### 7.4.4 Bank 0x03 - Serial and SPI Settings

Table 7-24 Bank 0x03 Serial and SPI Settings

| Bank | Location | Name            | R/W | Size | Range             | Default          |
|------|----------|-----------------|-----|------|-------------------|------------------|
| 0x03 | 0x00     | SerialRate      | R/W | 1    | 0..10             | 3 (9600 baud)    |
| 0x03 | 0x01     | SerialParams    | R/W | 1    | 0..7              | 0 (8-N-1)        |
| 0x03 | 0x02     | SpiMode         | R/W | 1    | 0..2              | 0 (SPI disabled) |
| 0x03 | 0x03     | SpiRateSel      | R/W | 1    | 0..2              | 0 (125 kHz)      |
| 0x03 | 0x04     | SpiOptions      | R/W | 1    | 0..7              | 0                |
| 0x03 | 0x05     | SpiMasterCmdLen | R/W | 1    | 0..16             | 0                |
| 0x03 | 0x06     | SpiMasterCmdStr | R/W | 16   | 0..16 byte string | All 0x00 bytes   |

*SerialRate* - this parameter sets the serial data rate as shown below:

**Setting      Serial rate**

|      |            |
|------|------------|
| 0x00 | 1.2 kbps   |
| 0x01 | 2.4 kbps   |
| 0x02 | 4.8 kbps   |
| 0x03 | 9.6 kbps   |
| 0x04 | 14.4 kbps  |
| 0x05 | 19.2 kbps  |
| 0x06 | 28.8 kbps  |
| 0x07 | 38.4 kbps  |
| 0x08 | 57.6 kbps  |
| 0x09 | 115.2 kbps |
| 0x0A | 230.4 kbps |
| 0x0B | 250.0 kbps |

*SerialParams* - this parameter sets the serial mode options for parity and stop bits:

| <b>Setting</b> | <b>Mode</b>                                  |
|----------------|----------------------------------------------|
| 0x00           | No parity, 8 data bits, 1 stop bit (default) |
| 0x01           | No parity, 8 data bits, 2 stop bits          |
| 0x02           | Reserved                                     |
| 0x03           | Reserved                                     |
| 0x04           | Even parity, 8 data bits, 1 stop bit         |
| 0x05           | Even parity, 8 data bits, 2 stop bits        |
| 0x06           | Odd parity, 8 data bits, 1 stop bit          |
| 0x07           | Odd parity, 8 data bits, 2 stop bits         |

Note that 8-bit data with no parity is capable of carrying 7-bit data with parity for compatibility without loss of generality for legacy applications that may require it. *SpiMode* - this parameter sets the SPI operating mode:

| <b>Setting</b> | <b>Mode</b>                               |
|----------------|-------------------------------------------|
| 0x00           | SPI disabled - serial UART mode (default) |
| 0x01           | SPI Slave mode                            |
| 0x02           | SPI Master mode                           |

*SpiRateSel* - this parameter sets the SPI master mode clock rate:

| <b>Setting</b> | <b>Mode</b> |
|----------------|-------------|
| 0x00           | 125 kbps    |
| 0x01           | 250 kbps    |
| 0x02           | 500 kbps    |

*SpiOptions* - this parameter allows the SPI to be configured with the following options:

| <b>Setting</b> | <b>Option</b>                                              |
|----------------|------------------------------------------------------------|
| 0x00           | Leading edge rising, sample leading edge, MSBs sent first  |
| 0x01           | Leading edge rising, sample falling edge, MSBs sent first  |
| 0x02           | Leading edge falling, sample leading edge, MSBs sent first |
| 0x03           | Leading edge falling, sample falling edge, MSBs sent first |
| 0x04           | Leading edge rising, sample leading edge, LSBs sent first  |
| 0x05           | Leading edge rising, sample falling edge, LSBs sent first  |
| 0x06           | Leading edge falling, sample leading edge, LSBs sent first |
| 0x07           | Leading edge falling, sample falling edge, LSBs sent first |

*SpiMasterCmdLen* - this parameter sets the length for the SPI master command string that will be used to interrogate the slave peripheral, when SPI master mode is selected with periodic I/O reporting enabled.

*SpiMasterCmdStr* - this parameter holds the SPI master command string that is used to interrogate the slave peripheral when SPI master mode is selected and periodic I/O reporting is enabled.

#### 7.4.5 Bank 0x04 - Host Protocol Settings

Table 7-25 Bank 0x04 Host Protocol Settings

| Bank | Location | Name             | R/W | Size | Range  | Default         |
|------|----------|------------------|-----|------|--------|-----------------|
| 0x04 | 0x00     | ProtocolMode     | R/W | 1    | 0..1   | 0 (Transparent) |
| 0x04 | 0x01     | TxTimeout        | R/W | 1    | 0..255 | 0 (No timeout)  |
| 0x04 | 0x02     | MinPacketLength  | R/W | 1    | 0..255 | 1 (byte)        |
| 0x04 | 0x03     | TransPtToPtMode  | R/W | 1    | 0..1   | 1 (Last RX)     |
| 0x04 | 0x04     | MsgsPerOtaPacket | R/W | 1    | 1..8   | 8               |

*ProtocolMode* - this parameter selects the host protocol mode. The default is 0x00, which is transparent mode, meaning the radio conveys whatever characters that are sent to it *transparently*, without requiring the host to understand or conform to the DNT24M's built-in protocol. This setting is recommended for point-to-point networks for legacy applications such as wire replacements where another serial protocol may already exist. Setting this parameter to 0x01 enables the DNT24M protocol formatting. It is not necessary to define the same protocol mode for all radios in a network. It is frequently useful to configure all radios in a point-to-multipoint network for transparent mode except the base, which should be in protocol mode. Note that it is possible for the host to switch the radio from transparent mode to protocol mode by transmitting an *EnterProtocolMode* command, and switching back to transparent mode by transmitting an *ExitProtocolMode* command.

*TxTimeout* - this parameter is used to group transparent data to be sent in a single transmission rather than being split over two hops. Messages sent over two hops can have gaps in the received data stream that can cause problems for the receiving application - for example, Modbus RTU. This parameter is the amount of time the DNT24M will wait without receiving a byte through the serial port before transmitting the data. Parameter units are in milliseconds. A message boundary is determined whenever a gap between consecutive characters is equal to or greater than the *TxTimeout* value, or the number of bytes reaches the *MinPacketLength*. Either condition will trigger a transmission. The default *TxTimeout* value is 0 ms, which means data will be sent as soon as the *MinPacketLength* requirement is met.

*MinPacketLength* - this parameter is similar to *TxTimeout* except it uses the number of bytes received instead of the amount of time without receiving a byte. The default is one byte. A transmission is triggered when either the number of bytes reaches *MinPacketLength* or a gap is detected between consecutive characters greater than *TxTimeout*.

*TransPtToPtMode* - when this parameter is set to 0, the destination address of transparent mode packets will be the configured *RemoteDestAddr*. When set to 1, the destination address will first be the *RemoteDestAddr*, but then will update to the originator of the most recent RX packet processed.

*MsgsPerOtaPacket* - this parameter sets the maximum number of messages a DNT24M can send in one packet. The default value is 8 messages, which is suitable for most applications.

#### 7.4.5 Bank 0x05 - I/O Parameters

Table 7-26 Bank 0x05 I/O Parameters

| Bank | Location | Name       | R/W | Size | Range In Bits | Default |
|------|----------|------------|-----|------|---------------|---------|
| 0x05 | 0x00     | All-IO     | R/W | 13   | 104           | N/A     |
| 0x05 | 0x0D     | Gpio0      | R/W | 1    | 1             | 0       |
| 0x05 | 0x0E     | Gpio1      | R/W | 1    | 1             | 0       |
| 0x05 | 0x0F     | Gpio2      | R/W | 1    | 1             | 0       |
| 0x05 | 0x10     | Gpio3      | R/W | 1    | 1             | 0       |
| 0x05 | 0x11     | Gpio4      | R/W | 1    | 1             | 0       |
| 0x05 | 0x12     | Gpio5      | R/W | 1    | 1             | 0       |
| 0x05 | 0x13     | Adc0       | R   | 2    | 12            | N/A     |
| 0x05 | 0x15     | Adc1       | R   | 2    | 12            | N/A     |
| 0x05 | 0x17     | Adc2       | R   | 2    | 12            | N/A     |
| 0x05 | 0x19     | EventFlags | R/W | 2    | 16            | N/A     |
| 0x05 | 0x1B     | Dac0       | R/W | 2    | 12            | 0       |
| 0x05 | 0x1D     | Dac1       | R/W | 2    | 12            | 0       |

*All-IO* - this 13-byte parameter packs all the following parameters into a single value. Note that the information in parameters GPIO0 through GPIO5 is compressed into a single byte to save space in the All-IO parameter. When the ADC is operating in differential mode, the ADC1 to ADC0 differential reading is stored in the ADC0 position, and the ADC2 to ADC0 differential reading is stored in the ADC1 position. The ADC2 reading is not used in ADC differential mode and this position is set to 0.

*Gpio0 through Gpio5* - if a pin is configured as an output, writing to its corresponding parameter to sets the pin's logic state. If a pin is configured as an input, writing to its corresponding parameter enables or disables the pin's internal pull-up. Reading these registers returns the current level detected on the corresponding pins.

*Adc0 through Adc2* - these read-only parameters return the current reading for the selected ADC channel (Little-Endian byte order). When the ADC is operating in differential mode, the ADC1 to ADC0 differential reading is stored in the ADC0 position, and the ADC2 to ADC0 differential reading is stored in the ADC1 position. The ADC2 reading is not used in ADC differential mode and this position is set to 0. Also, see the discussion of the *AdcSampleIntvl* parameter below.

*EventFlags* - used with the automatic I/O reporting feature, this parameter indicates which I/O events have been triggered since the last report (write 0x0000 to reset):

|                   |                                   |
|-------------------|-----------------------------------|
| <i>bits 15..8</i> | Reserved                          |
| <i>bit 7</i>      | ADC2 high/low threshold excursion |
| <i>bit 6</i>      | ADC1 high/low threshold excursion |
| <i>bit 5</i>      | ADC0 high/low threshold excursion |
| <i>bit 4</i>      | Periodic timer report             |
| <i>bit 2</i>      | GPIO2 edge transition             |
| <i>bit 1</i>      | GPIO1 edge transition             |
| <i>bit 0</i>      | GPIO0 edge transition             |

*Dac0* through *Dac1* - sets the DAC outputs. The range of this parameter is 0x0000 to 0xFFFF.

#### 7.4.6 Bank 0x06 - I/O Settings

Table 7-27 Bank 0x06 I/O Settings

| Bank | Location | Name             | R/W | Size | Range In Bits | Default           |
|------|----------|------------------|-----|------|---------------|-------------------|
| 0x06 | 0x00     | GpioDir          | R/W | 1    | 6             | 0x00 (All inputs) |
| 0x06 | 0x01     | GpioInit         | R/W | 1    | 6             | 0x00 (All zeros)  |
| 0x06 | 0x02     | GpioAlt          | R/W | 1    | 6             | 0x00              |
| 0x06 | 0x03     | GpioEdgeTrigger  | R/W | 1    | 8             | 0x01              |
| 0x06 | 0x04     | GpioSleepMode    | R/W | 1    | 6             | 0x00 (Off)        |
| 0x06 | 0x05     | GpioSleepDir     | R/W | 1    | 6             | 0x00 (All inputs) |
| 0x06 | 0x06     | GpioSleepState   | R/W | 1    | 6             | 0x00 (All zero)   |
| 0x06 | 0x07     | Dac0Init         | R/W | 2    | 12            | 0x0000            |
| 0x06 | 0x09     | Dac1Init         | R/W | 2    | 12            | 0x0000            |
| 0x06 | 0x0B     | AdcSampleIntvl   | R/W | 4    | 32            | 0x0A (100 ms)     |
| 0x06 | 0x0F     | Adc0ThresholdLo  | R/W | 2    | 12            | 0xF800            |
| 0x06 | 0x11     | Adc0ThresholdHi  | R/W | 2    | 12            | 0x07FF            |
| 0x06 | 0x13     | Adc1ThresholdLo  | R/W | 2    | 12            | 0xF800            |
| 0x06 | 0x15     | Adc1ThresholdHi  | R/W | 2    | 12            | 0x07FF            |
| 0x06 | 0x17     | Adc2ThresholdLo  | R/W | 2    | 12            | 0xF800            |
| 0x06 | 0x19     | Adc2ThresholdHi  | R/W | 2    | 12            | 0x07FF            |
| 0x06 | 0x1B     | IoReportTrigger  | R/W | 1    | 8             | 0x01 (GPIO0)      |
| 0x06 | 0x1C     | IoReportInterval | R/W | 4    | 32            | 30000 (ms)        |
| 0x06 | 0x20     | IoPreDelay       | R/W | 1    | 8             | 8 (ms)            |
| 0x06 | 0x21     | IoBindingEnable  | R/W | 1    | 1             | 0 (Disabled)      |
| 0x06 | 0x22     | DacReference     | R/W | 1    | 2             | 0 (ADC_EXT_REF)   |
| 0x06 | 0x23     | AdcReference     | R/W | 1    | 2             | 0 (ADC_EXT_REF)   |

| 0x06 | 0x24     | AdcAveSelect          | R/W | 1    | 8                   | 0x01             |
|------|----------|-----------------------|-----|------|---------------------|------------------|
| 0x06 | 0x25     | ExtAdcScaleFactor     | R/W | 2    | 16                  | 0x8000           |
| 0x06 | 0x27     | ExtAdcOffset          | R/W | 2    | 16                  | 0x0000           |
| 0x06 | 0x29     | ExtDacScaleFactor     | R/W | 2    | 16                  | 0x8000           |
| 0x06 | 0x2B     | ExtDacOffset          | R/W | 2    | 16                  | 0x0000           |
| 0x06 | 0x2D     | VccAdcScaleFactor     | R/W | 2    | 16                  | 0x8000           |
| 0x06 | 0x2F     | VccAdcOffset          | R/W | 2    | 16                  | 0x0000           |
| 0x06 | 0x31     | VccDacScaleFactor     | R/W | 2    | 16                  | 0x8000           |
| 0x06 | 0x33     | VccDacOffset          | R/W | 2    | 16                  | 0x0000           |
| 0x06 | 0x35     | 1VAdcScaleFactor      | R/W | 2    | 16                  | 0x8000           |
| Bank | Location | Name                  | R/W | Size | Range In Bits       | Default          |
| 0x06 | 0x37     | 1VAdcOffset           | R/W | 2    | 16                  | 0x0000           |
| 0x06 | 0x39     | 1VDacScaleFactor      | R/W | 2    | 16                  | 0x8000           |
| 0x06 | 0x3B     | 1VDacOffset           | R/W | 2    | 16                  | 0x0000           |
| 0x06 | 0x3D     | AdcDiffMode           | R/W | 1    | 8                   | 0 (single-ended) |
| 0x06 | 0x3E     | AdcGainCh0            | R/W | 1    | 8                   | 0 (gain = 1)     |
| 0x06 | 0x3F     | AdcGainCh1            | R/W | 1    | 8                   | 0 (gain = 1)     |
| 0x06 | 0x40     | AdcDiffScaleFactorCh0 | R/W | 2    | 16                  | 0x8000           |
| 0x06 | 0x42     | AdcDiffOffsetCh0      | R/W | 2    | 16                  | 0x0000           |
| 0x06 | 0x46     | AdcDiffOffsetCh1      | R/W | 2    | 16                  | 0x0000           |
| 0x06 | 0x47     | FastAdcPrescaler      | R/W | 1    | 1 byte, range 1..7  | 5 ( $\div 128$ ) |
| 0x06 | 0x48     | SlowAdcPrescaler      | R/W | 1    | 1 byte, range 0..7  | 2 ( $\div 16$ )  |
| 0x06 | 0x49     | MaxQueuedEvents       | RW  | 1    | 1 byte, range 0..20 | 8 (reports)      |
| 0x06 | 0x50     | AdcSkipCount          | R/W | 1    | 1 byte              | 0 (samples)      |

*GpioDir* - this parameter is a bitmask that sets whether each GPIO is an input (0) or outputs (1). The default is all inputs.

*GpioInit* - this parameter is a bitmask that sets the initial value for any GPIOs which are enabled as outputs. For GPIOs enabled as inputs, this sets the initial pull-up setting.

*GpioAlt* - specifies which GPIO pins will have their alternate functions enabled: Bit 2 - diversity toggle enable, Bit 3 - RS485 enable, Bit 4 - /HOST\_CTS enable, Bit5 - /HOST\_RTS enable.

**Table 7-28 GPIO Pins Alternate Functions**

| <b>Bit</b> | <b>Alternate Function</b>         | <b>Default</b> | <b>Bit Mask</b> |
|------------|-----------------------------------|----------------|-----------------|
| 0          | (none)                            | 0              | 0x01            |
| 1          | (none)                            | 0              | 0x02            |
| 2          | Diversity Toggle                  | 0              | 0x04            |
| 3          | RS485 (N/A in SPI Slave mode)     | 0              | 0x08            |
| 4          | /Host_CTS (N/A in SPI Slave mode) | 1              | 0x10            |
| 5          | /HOST_RTS (N/A in SPI Slave mode) | 1              | 0x20            |

*GpioEdgeTrigger* -this parameter consists of a set of four 2-bit fields that define when GPIO triggers are enabled for I/O event reporting:

- bits 7..6*    GPIO3 edge function
- bits 5..4*    GPIO2 edge function
- bits 3..2*    GPIO1 edge function
- bits 1..0*    GPIO0 edge function

The bit values for each GPIO map to the following settings:

**Table 7-29 GPIO Bit Values Mapping**

| <b>Value</b> | <b>GPIO edge behavior</b>                                    |
|--------------|--------------------------------------------------------------|
| 11           | Rising edge trigger, neither level keeps remote awake        |
| 10           | Bidirectional edge trigger, neither level keeps remote awake |
| 01           | Rising edge trigger, holding high keeps remote awake         |
| 00           | Falling edge trigger, holding low keeps remote awake         |

*GpioSleepMode* - this parameter is a bitmask that enables configuring the I/O direction and state of GPIO0..GPIO5 when the module is sleeping. Bits 0..5 correspond to GPIO0..GPIO5. Setting a *GpioSleepMode* bit to 1 enables sleep mode configuration of the corresponding GPIO. Setting a *GpioSleepMode* bit to 0 causes the corresponding GPIO to remain configured as in active mode. Note that when the *GpioAlt* bit is set for GPIO4, the corresponding *GpioSleepMode* bit is ignored and GPIO4 is controlled directly by the *GpioSleepState* parameter bit 7.

*GpioSleepDir* - when *GpioSleepMode* is enabled, this parameter functions to set the direction of the GPIOs during a device's sleep period. This enables the user to provide alternate configurations during sleep that will help minimize current consumption. Bits 0..5 correspond to GPIO0..GPIO5. Setting a *GpioSleepDir* bit to 1 specifies an output; 0 specifies an input.

*GpioSleepState* - when *GpioSleepMode* is enabled, this parameter functions as a bitmask to control the states of the GPIOs, the RADIO\_TXD output, and the /HOST\_CTS and /DCD outputs during a device's sleep period. This allows the user to set alternate configurations during sleep to minimize current consumption. Bits 0..5 correspond to GPIO0..GPIO5 respectively. Bit 6 sets the state of RADIO\_TXD, and bit 7 sets the states of /HOST\_CTS and /DCD. A sleep state bit is set to 1 to specify a high output or an internal pull-up on an input, or to 0 to specify a low output or no internal pull-up on an input. Bit 6 must be

set low in order to achieve minimum sleep current (high impedance load assumed), and the other bits may need to be set low or high depending on their external loads. When bit 6 is set low, expect a serial “break” condition to occur as the module wakes from sleep. The serial break condition can be eliminated by setting bit 6 high, but sleep current will be increased.

*Dac0Init* - this parameter sets the initial value for DAC0 at startup.

*Dac1Init* - this parameter sets the initial value for DAC1 at startup.

*AdcSampleIntvl* - this parameter sets the frequency (sample interval) of ADC measurements used to determine if a threshold has been exceeded or in calculating an average measurement value. The three ADC channels are read on each ADC cycle, along with the states of GPIO2 and GPIO3. Each *AdcSampleIntvl* count equals 10 ms. The default is 100 ms. This interval will be the worst-case latency for ADC generated interrupts. Note that *AdcSampleIntvl* is independent of *IoReportInterval* as the ADCs are read on both intervals.

*Adc0..2ThresholdLo/Hi* - these parameters set the thresholds to trigger an I/O report based on ADC measurements. If I/O reporting is enabled, a single event report containing the contents of the I/O bank is generated when a threshold is crossed. Reporting is edge-triggered with respect to threshold boundaries, not level-triggered. Additional reports are not triggered unless the ADC measurement first returns inside the threshold boundary and then crosses the threshold again. Triggers occur whenever one of the following inequalities is satisfied:

ADCx < ADCx\_ThresholdLo

ADCx > ADCx\_ThresholdHi

*IoReportTrigger* - a trigger event on any enabled trigger source will cause a DNT24M to send an event message containing the entire current values of the Bank 5.

*bit 7*      ADC2 high/low thresholds

*bit 6*      ADC1 high/low thresholds

*bit 5*      ADC0 high/low thresholds

*bit 4*      Periodic timer

*bit 3*      GPIO3 edge

*bit 2*      GPIO2 edge

*bit 1*      GPIO1 edge

*bit 0*      GPIO0 edge

*IoReportInterval* - when periodic timer I/O reporting is enabled, this parameter sets the interval between reports. The parameter scaling is 10 ms/count, and the default report interval is every 30 seconds.

*IoPreDelay* - this parameter sets the time in milliseconds to delay collection of ADC readings after an event occurs, to allow settling of ADC input voltages.

*IoBindingEnable* - this parameter enables I/O binding. Setting this parameter to 0x00 disables I/O binding (I/O mirroring) from a remote device. Setting this parameter 0x01 enables I/O mirroring. When enabled, the data from any received event report is used to drive the device’s own outputs. GPIO2 will be set to the event report’s GPIO0 reading, GPIO3 will be set to the event report’s GPIO1 reading, and DAC0 and

DAC1 will be set with the ADC0 and ADC1 readings respectively. Note that if the *AdcDiffMode* parameter is set to 1, I/O binding cannot be used.

*DacReference* - this parameter selects the reference voltage for the DACs:

| <b>Setting</b> | <b>Reference</b>      |
|----------------|-----------------------|
| 0x00           | ADC_EXT_REF           |
| 0x01           | AVCC (Analog Vcc)     |
| 0x02           | Reserved              |
| 0x03           | Disable DAC operation |

*AdcReference* - this parameter selects the reference voltage for the ADCs:

| <b>Setting</b> | <b>Reference</b>            |
|----------------|-----------------------------|
| 0x00           | ADC_EXT_REF                 |
| 0x01           | Internal Vcc divided by 1.6 |
| 0x02           | Reserved                    |
| 0x03           | Disable ADC operation       |

*AdcAveSelect* - this parameter selects the number of ADC measurements to average to produce each ADC reading, from 1 to 255 samples. Averaging over a larger number of measurements increases noise filtering but also increases the time it takes to generate a set of readings:

**Table 7-30 ADC Ave Select**

| <b>ADC Mode</b>                          | <b>Module Awake</b> | <b>Module Sleeping</b> |
|------------------------------------------|---------------------|------------------------|
| Single-ended, reading all three channels | 216 $\mu$ s         | 381 $\mu$ s            |
| Differential, reading both channels      | 160 $\mu$ s         | 273 $\mu$ s            |

*ExtAdcScaleFactor* - this parameter is the scale factor applied to an ADC measurement when the ADC reference is an external voltage. The scale factor parameter is multiplied by 32768. For example, the parameter value for a scale factor of 1.12 = 1.12 \* 32768 = 36700.16 or 0x8F5C.

*ExtAdcOffset* - this parameter is the 2's complement offset added to the scaled ADC measurement when the ADC reference is an external voltage.

*ExtDacScaleFactor* - this parameter is the scale factor applied to a DAC measurement when the DAC reference is an external voltage. The scale factor parameter is multiplied by 32768. For example, the parameter value for a scale factor of 1.12 = 1.12 \* 32768 = 36700.16 or 0x8F5C.

*ExtDacOffset* - this parameter is 2's complement the offset added to the scaled DAC measurement when the DAC reference is an external voltage.

*VccAdcScaleFactor* - this parameter is the scale factor applied to an ADC measurement when the ADC reference is Vcc/1.6. The scale factor parameter is multiplied by 32768. For example, the parameter value for a scale factor of 1.12 = 1.12 \* 32768 = 36700.16 or 0x8F5C.

*VccAdcOffset* - this parameter is the 2's complement offset added to the scaled ADC measurement when the ADC reference is derived from Vcc/1.6.

*VccDacScaleFactor* - this parameter is the scale factor applied to a DAC measurement when the DAC

reference is Vcc. The scale factor parameter is multiplied by 32768. For example, the parameter value for a scale factor of 1.12 =  $1.12 * 32768 = 36700.16$  or 0x8F5C.

*VccDacOffset* - this parameter is the 2's complement offset added to the scaled DAC measurement when the DAC reference is Vcc.

*1VAdcScaleFactor* - this parameter is the scale factor applied to an ADC measurement when using the internal 1 volt reference. The scale factor parameter is multiplied by 32768. For example, the parameter value for a scale factor of 1.12 =  $1.12 * 32768 = 36700.16$  or 0x8F5C.

*1VAdcOffset* - this parameter is the 2's complement offset added to the scaled ADC measurement when using the internal 1 volt reference.

*1VDacScaleFactor* - this parameter is the scale factor applied to a DAC measurement when the DAC reference is the internal 1 volt reference. The scale factor parameter is multiplied by 32768. For example, the parameter value for a scale factor of 1.12 =  $1.12 * 32768 = 36700.16$  or 0x8F5C.

*1VDacOffset* - this parameter is the 2's complement offset added to the scaled DAC measurement when the DAC reference is the internal 1 V reference.

*AdcDiffMode* - a parameter value of 0 selects single-ended ADC mode. In this mode, negative sensor inputs are connected to ground and positive sensor inputs to ADC0, ADC1 and ADC2 respectively. Three ADC measurements are made in this mode with a range of 0x0000 to 0x07FF. A parameter value of 1 selects signed differential mode with gain. In this mode, the negative sensor inputs are connected to ADC0 and the positive inputs are connected to ADC1 and ADC2. Two ADC measurements are made in this mode, ADC1 to ADC0 and ADC2 to ADC0, with a range (signed) from 0xF800 to 0x07FF. In differential mode, the *AdcGainCh0* and *AdcGainCh1* parameters can change the selected gain for the two ADC readings, and the *AdcDiff* scale factors and offsets, both supplied by the customer, are used.

*AdcGainCh0* - this parameter sets the preamplifier gain applied when making a differential measurement of ADC1 relative to ADC0. Setting this parameter to 0x00 sets the gain to 1, 0x01 sets the gain to 2, 0x02 sets the gain to 4 and so on, up to 0x06 which sets the gain to 64. Note that the preamplifier output voltage saturates at 2.4 V regardless of the gain setting.

*AdcGainCh1* - this parameter sets the gain applied when making a differential measurement of ADC2 relative to ADC0. Setting this parameter to 0x00 sets the gain to 1, 0x01 sets the gain to 2, 0x02 sets the gain to 4 and so on, up to 0x06 which sets the gain to 64. Note that the preamplifier output voltage saturates at 2.4 V regardless of the gain setting.

*AdcDiffScaleFactorCh0/1* and *AdcDiffOffsetCh0/1* - these parameters are applied to the raw ADC readings in differential mode. These values are not factory calibrated, but can be calibrated by the user.

*FastAdcPrescaler* - this parameter is the system clock divisor used to generate the ADC clock when the system is being clocked at 16 MHz. Default value is 0x05 (system clock  $\div 128$ ). Higher values correspond to slower ADC clock rates. For example, 0x07 =  $\div 512$ , and 0x00 =  $\div 4$ . Note that larger prescalers will increase the amount of time it takes to collect all readings. DIV4 is not valid when running at 16 MHz because the maximum ADC clock rate is 2 MHz, so DIV8 is the lowest allowed.

*SlowAdcPrescaler* - System clock divisor used to generate the ADC clock when the system is being clocked at 2 MHz, when exiting sleep mode. Default value is 0x02 (system clock  $\div 16$ ). Higher values correspond to slower ADC clock rates. For example, 0x07 = DIV512, and 0x00 = DIV4.

*MaxQueuedEvents* - this parameter sets the maximum number of Event Reports that can be queued at one time by a DNT24M.

*AdcSkipCount* - this parameter sets the number of measurements to skip (discard) when switching to a new ADC channel. The skipped measurements allow transients in the ADC sample-and-hold circuit to

settle out. This parameter must be set to at least 0x03 when *AdcDiffMode* is selected. Note that the *IoPreDelay* parameter discussed above provides a delay to allow signals *external* to the DNT24M to settle following a wake up event, while *AdcSkipCount* skips measurements that may be distorted because the *internal* voltage on the ADC sample-and-hold has not settled.

#### 7.4.7 Bank 0xFF - Special Functions

**Table 7-31 Bank 0xFF Special Functions**

| Bank | Location | Name           | R/W | Size | Range      | Default        |
|------|----------|----------------|-----|------|------------|----------------|
| 0xFF | 0x00     | UcReset        | W   | 1    | 0..2       | N/A            |
| 0xFF | 0x01     | MemorySave     | W   | 1    | 0xD0..0xD3 | N/A            |
| 0xFF | 0x04     | DiagSerialRate | R/W | 1    | 0..11      | 7 (38400 kbps) |
| 0xFF | 0x0C     | ForceDiscover  | W   | 1    | 0..255     | 0.1 s/count    |
| 0xFF | 0x0E     | DiagPortEn     | R/W | 1    | 0..1       | 0 (disabled)   |

*UcReset* - writing a 0 to this parameter initiates a full reset, writing 1 initiates a reset to the serial bootloader (not by an over the air command), or writing a 2 to initiates a reset to the OTA bootloader client.

*MemorySave* - writing 0xD0 to this parameter reloads default parameter values, writing 0xD1 saves the current parameter values to EEPROM, or writing 0xD2 saves current parameter values to the EEPROM and resets the module, and 0xD3 saves the default values to EEPROM and resets the module.

*DiagSerialRate* - this parameter sets the diagnostic port serial data rate as shown below:

| <b>Setting</b> | <b>Serial rate</b>  |
|----------------|---------------------|
| 0x00           | 1.2 kbps            |
| 0x01           | 2.4 kbps            |
| 0x02           | 4.8 kbps            |
| 0x03           | 9.6 kbps            |
| 0x04           | 14.4 kbps           |
| 0x05           | 19.2 kbps           |
| 0x06           | 28.8 kbps           |
| 0x07           | 38.4 kbps (default) |
| 0x08           | 57.6 kbps           |
| 0x09           | 115.2 kbps          |
| 0x0A           | 230.4 kbps          |
| 0x0B           | 250.0 kbps          |

*ForceDiscover* - writing to this register forces a heartbeat reply. The timing of the reply is a random interval from 0 to the time implied by the value in the ForceDiscover register (0.1 second/count). A ForceDiscover register write is usually sent as a broadcast packet and is used to discover the DNT24M radios in range of the sender.

*DiagPortEn* - setting this parameter to 0x01 enables diagnostic port operation.

## 7.5 Protocol-formatted Message Examples

### 7.5.1 Data Message

In this example, the ASCII text “Hello” is sent to a DNT24M radio using the *TxDATA* command. The MAC address of the radio is 0x123456. The protocol formatting for the host message is:

| SOP  | Length | PktType | Lo MAC | MAC  | Hi MAC | “H”  | “e”  | “l”  | “l”  | “o”  |
|------|--------|---------|--------|------|--------|------|------|------|------|------|
| 0xFB | 0x09   | 0x05    | 0x56   | 0x34 | 0x12   | 0x48 | 0x65 | 0x6C | 0x6C | 0x6F |

There are 9 bytes following the length byte, so the length byte is set to 0x09. Note that the 0x123456 network address is entered in Little-Endian byte order, 56 34 12. When an ACK to this message is received from the destination radio, the sender outputs a *TxDATAREPLY* message to its host:

| SOP  | Length | PktType | Lo MAC | MAC  | Hi MAC | Status | RSSI |
|------|--------|---------|--------|------|--------|--------|------|
| 0xFB | 0x06   | 0x15    | 0x56   | 0x34 | 0x12   | 0x00   | 0xB0 |

The 0x00 *TxStatus* byte value indicates the ACK reception from the destination. The *RSSI* value of the received ACK is 0xB0, indicating a received signal strength of approximately -80 dBm .

The ASCII “Hello” message is output as a 0x26 *RxDATA* event. The address field contains the originator’s address, 0x00 0x00 0x20. The *RSSI* value of the received message is 0xB4, indicating a received signal strength of approximately -76 dBm. The data following the *RSSI* value is the “Hello” text.

| SOP  | Length | PktType | Lo MAC | MAC  | Hi MAC | RSSI | “H”  | “e”  | “l”  | “l”  | “o”  |
|------|--------|---------|--------|------|--------|------|------|------|------|------|------|
| 0xFB | 0x0A   | 0x26    | 0x20   | 0x00 | 0x00   | 0x35 | 0x48 | 0x65 | 0x6C | 0x6C | 0x6F |

Note that if the destination was in transparent mode, only the “Hello” text would be output.

## 7.5.2 Configuration Messages

In this example, the radio with MAC address 0x123456 is configured by the sender to generate *RxEVENT* messages every 10 seconds. To do this, the *IoReportInterval* in the responder is set to 10 seconds and the *periodic report timer* bit in the *IoReportTrigger* parameter is set ON. The *IoReportInterval* and the *IoReportTrigger* parameters are loaded using *SetRemoteRegister* commands. The command to set the *IoReportInterval* to 10 seconds is:

| SOP  | Length | PktType | Lo MAC | MAC  | Hi MAC | Reg  | Bank | Size | Lo Val | Val  | Val  | Hi Val |
|------|--------|---------|--------|------|--------|------|------|------|--------|------|------|--------|
| 0xFB | 0x0B   | 0x07    | 0x56   | 0x34 | 0x12   | 0x1C | 0x06 | 0x04 | 0x10   | 0x27 | 0x00 | 0x00   |

The *IoReportInterval* parameter starts in location 0x1C of Bank 6. The report interval scaling is 1 ms/count, so a 10 second report interval is 10,000 units or 0x00002710 (Little-Endian format 10 27 00 00). The *IoReportInterval* parameter is updated and *SetRemoteRegisterReply* is returned:

| SOP  | Length | PktType | Status | Lo MAC | MAC  | Hi MAC | RSSI |
|------|--------|---------|--------|--------|------|--------|------|
| 0xFB | 0x06   | 0x17    | 0x00   | 0x00   | 0x00 | 0x00   | 0xB2 |

The command to set the *periodic report timer* bit in *IoReportTrigger* is:

| SOP  | Length | PktType | Lo Mac | MAC  | Hi MAC | Reg  | Bank | Size | Val  |
|------|--------|---------|--------|------|--------|------|------|------|------|
| 0xFB | 0x08   | 0x07    | 0x56   | 0x34 | 0x12   | 0x1B | 0x06 | 0x01 | 0x10 |

The *IoReportTrigger* parameter is in location 0x1B of Bank 6. The *periodic report timer* bit in *IoReportTrigger* is located in bit position four (00010000b) or 0x10. The *IoReportTrigger* parameter is updated and *SetRemoteRegisterReply* is returned:

| SOP  | Length | PktType | Status | Lo MAC | MAC  | Hi MAC | RSSI |
|------|--------|---------|--------|--------|------|--------|------|
| 0xFB | 0x06   | 0x17    | 0x00   | 0x00   | 0x00 | 0x00   | 0xB4 |

### 7.5.3 Sensor Message

In this example, the sender requests an ADC1 reading from a responder using the *GetRemoteRegister* command, type 0x06. The MAC address of the responder is 0x123456. The current ADC1 measurement parameter is read starting at register location 0x15 and Bank 5. The ADC reading spans two bytes. The protocol formatting for this command is:

| SOP  | Length | PktType | Lo Mac | MAC  | Hi MAC | Reg  | Bank | Size |
|------|--------|---------|--------|------|--------|------|------|------|
| 0xFB | 0x07   | 0x06    | 0x56   | 0x34 | 0x12   | 0x15 | 0x05 | 0x02 |

Note the responder MAC address is entered in Little-Endian byte order, 56 34 12.

The ADC reading is returned in a *GetRemoteRegisterReply* message:

| SOP  | Length | PktType | Status | Lo MAC | MAC  | Hi MAC | RSSI | Reg  | Bank | Size | Lo Val | Hi Val |
|------|--------|---------|--------|--------|------|--------|------|------|------|------|--------|--------|
| 0xFB | 0x0B   | 0x16    | 0x00   | 0x00   | 0x00 | 0x00   | 0xB7 | 0x1C | 0x06 | 0x02 | 0x7B   | 0x08   |

Substantial information is returned in the message. The last two bytes of the message give the ADC reading in Little-Endian format, 7B 08. The ADC reading is thus 0x087B (2171). The RSSI value is the byte following the address, 0xB7 (-73 dBm). The *TxStatus* byte to the right of the *GetRemoteRegisterReply* Packet Type is 0x00, showing the packet was acknowledged on the RF channel.

### 7.5.4 Event Message

The configuration example shown in Section 7.5.2 above causes the responder with MAC address 0x123456 to start sending event messages every 10 seconds as shown in the log below:

```
FB 12 28 56 34 12 B8 00 7A 01 36 01 FF 01 10 00 20 01 40 01
FB 12 28 56 34 12 B0 00 79 01 35 01 C0 01 10 00 20 01 40 01
FB 12 28 56 34 12 A9 00 72 01 35 01 D3 01 10 00 20 01 40 01
FB 12 28 56 34 12 AC 00 75 01 36 01 E7 01 10 00 20 01 40 01
```

The first received message in the above log is constructed as follows:

| SOP  | Length | PktType | Addr | Addr | Addr | RSSI | Data |
|------|--------|---------|------|------|------|------|------|
| 0xFB | 0x12   | 0x28    | 0x56 | 0x34 | 0x12 | B8   |      |

| GPIO | ADC0 |      | ADC1 |      | ADC2 |      | Event Flags |      | DAC0 |      | DAC1 |      |
|------|------|------|------|------|------|------|-------------|------|------|------|------|------|
| 0x00 | 0x7A | 0x01 | 0x36 | 0x01 | FF   | 0x01 | 0x10        | 0x00 | 0x20 | 0x01 | 0x40 | 0x01 |

*RxEvent* messages are *PktType* 0x28. The message payload consists of the states of GPIO0 through GPIO5, the input voltages measured by ADC0 through ADC2, the event trigger(s), and the DAC output settings. Note the ADC readings, event flags and DAC settings are presented in Little-Endian order. The responder is assumed to be always ON in this example. If the responder is placed in periodic sleep mode (*SleepMode* = 1), a suitable value of the *WakeResponseTime* parameter should be set to allow the sender application to analyze the I/O report and send back a command to the responder as needed.

## 8.0 DNT24MDK/DNT24MADK Developer's Kits

Figure 8-1 shows the main contents of a DNT24MDK Developer's kit:



**Figure 8-1 DNT24MDK Developer's kit**

### 8.1 Kit Contents

- DNT24MDK - 2 DNT24MP radios installed in DNT24M interface boards, labeled *Base* and *Remote*
- DNT24MDK - 2 patch antennas and two 2 dBi dipole antennas with MMCX/RSMA adaptor cables
- DNT24MADK - 2 DNT24MPA radios installed in DNT24M interface boards, labeled *Base* and *Remote*
- All Kits - 2 wall-plug power suppliers, 9 VDC, 120/240 VAC, plus 2 batteries, 9 VDC (not shown above)
- All Kits - 2 RJ-45/DB-9F cable assemblies and two A/B USB cables
- All Kits - 1 DNT24MDK/DNT24MADK documentation and software CD

## 8.2 Additional Items Needed

To operate the kit, the following additional item is needed:

- One PC with Microsoft Windows XP, Vista or Windows 7 operating system. The PC must be equipped with a USB port or a serial port capable of operation at 9600 bps.

## 8.3 Developer's Kit Default Operating Configuration

The default operating configuration of the DNT24MDK developer's kit is point-to-point with transparent serial data at 9600 bps, 8N1. One DNT24M is preconfigured as a base and the other as a remote. Labels on the bottom of the interface boards specify *Base* or *Remote*.

## 8.4 Developer's Kit Hardware Assembly

1. Figure 8-2 shows a DNT24MP radio installed on an interface board, and a patch antenna. Observe ESD precautions when handling the kit circuit boards. Install a patch antenna on each interface board by pressing the antenna into the interface board RF connector with moderate pressure until the antenna snaps onto the connector, as shown in Figure 8-3. Note that no external antenna is required when using the DNT24MPA radios supplied in the DNT24MA Kits.

2. As shown in Figure 8-4 on the next page, there are three serial connectors and a power connector on the end of each interface board. The RJ-45 connector provides an RS232 interface to the DNT24M main serial port. The USB connector provides an optional interface to the radio's main serial port.



Figure 8-2 DNT24MP Radio/Board/Antenna



Figure 8-3 Antenna Attached



**Figure 8-4 DNT24MDK with Serial and Power Connectors**

3. If using a serial cable, connect the Base interface board to the PC using a RJ-45/DB-9F cable assembly (labels on the bottom of the interface boards specify *Base* or *Remote*). Then power the *Base* with a supplied wall-plug power supply. Continue at Step 5 below.
4. If using a USB cable continue with this Step to install the USB drivers, else continue at Step 5. Plugging in the USB cable automatically switches operation to the USB connector. The USB interface is based on an FT232RL serial-to-USB converter IC manufactured by FTDI. The FT232RL driver files are located in the i386 and AMD64 folders on the CD, and the latest version of the drivers can be downloaded from the FTDI website, [www.ftdichip.com](http://www.ftdichip.com). The drivers create a virtual COM port on the host PC.
  - a. Power the *Base* using one of the supplied wall-plug power supplies.
  - b. Next connect the *Base* to the PC with a USB cable. The PC will find the new USB hardware and open a driver installation dialog box. Enter the letter of the drive holding the kit CD and click *Continue*. The installation dialog will run *twice* to complete the driver installation.

## 8.5 Utility Program

The DNT Demo utility program requires only one PC for initial kit operation and sensor applications (ADC, DAC and digital I/O). Two serial/USB ports are required for bidirectional serial communications.

Section 8-6 below covers using the DNT24M Demo utility program for initial kit operation and familiarization. Section 8.6.1 covers serial message communication and radio configuration.

## 8.6 Initial Kit Operation

The DNT Demo utility program is located in the *PC Programs* folder on the kit CD. The DNT Demo requires no installation and can be simply copied to the PC and run.



Figure 8-5 DNT Demo Start-up Window

1. Start the Demo on the PC. The Demo program start-up window is shown in Figure 8-5.

2. Click on *Connect* to open the *Select Comm Port Settings* dialog box, as shown in Figure 8-6. If necessary, set the baud rate to 9600 bps. Set the *CommPort* to match the serial port connected to the Base, either the hardware port or the USB virtual serial port. Then click *OK* to activate the connection.



**Figure 8-6 Select Comm Port Settings**

3. At this point the utility program will collect data from the Base, filling in the *Local Radio* column as shown in Figure 8-7.



**Figure 8-7 Local Radio Column**

4. Next power up the *Remote* using a wall-plug power supply. The Remote will transmit a “heartbeat” message on power up.

5. Click on the drop-down box at the top of the *Radio 1* column and click on the *MAC Address* (preloaded when the Remote is turned on after the Base), or load the *MAC Address* for the Remote from the heartbeat message.

6. Next press the *Start* button using the default 1 second *Refresh Delay*.



**Figure 8-8 Start Button**

7. The Demo will display data on the *Remote* in the *Radio 1* column, including bar graphs of *RSSI* (signal strength) and *percent packet success rate*, as shown in Figure 8-8. Adjusting the pot on the *Remote* can be observed in the *Potentiometer (ADC0)* data. You can change the *Refresh* setting from the drop down menu at the bottom left. Adjusting the pot on the base can be observed in the *Potentiometer (ADC0)* data in the *Local Radio* column.

If any difficulty is encountered in setting up the DNT24MDK development kit, contact Murata's module technical support group. The phone number is +1.678.684.2004. Phone support is available from 8:30 AM to 5:30 PM US Eastern Time Zone, Monday through Friday.

### 8.6.1 Serial Communication and Radio Configuration

Connect PCs to both the Base and the Remote for serial communication testing (alternately one PC can be used with two serial ports and two instances of the DNT24M Demo program running). Click the *Stop* button under the *Refresh Delay* label on the *I/O Tools* tab and move to the *Transmit Tools* tab, as shown in Figure 8-9.



**Figure 8-9 Transmit Tools Tab**

Pressing the *Transmit* button on this screen sends the message in the *Data to Transmit* text box to the selected *MAC Address*. Note that the *MAC address* a remote uses for the base is 0x000000. Data sent to the local radio is displayed in the *Received Data* text box. Received data can be displayed as ASCII (default) or in Hexadecimal format by checking the *Hex Mode* check box. When the *Transmit Interval* is set to zero, *Data to Transmit* is sent once when the *Transmit* button is clicked. When the *Transmit Interval* is set to a positive number, Pressing the *Transmit* button once will cause a transmission each transmit interval (seconds) until the button is pressed again.

Returning to the *I/O Tools* tab, the multi-tab *Configuration* window for each radio can be accessed by clicking on its *Config* button. The data presented on the first six tabs corresponds to configuration register Banks 0 through 5 as discussed in Section 4.2 above, with the data on the next two tabs corresponding to configuration register Bank 6.



**Figure 8-10 Configuration Window**

The *Transceiver Setup Tab* is shown in Figure 8-10 and corresponds to Bank 0. The current values of each Bank 0 parameter are displayed and can be updated by selecting from the drop-down menus or entering data from the keyboard, and then pressing the *Apply Changes* button. Note that data is *displayed and entered in Big-Endian order*. The utility program automatically reorders multi-byte data to and from Little-Endian order when building or interpreting messages.



**Figure 8-11 System Tab Contents**

Figure 8-11 shows the *Status* tab contents, corresponding to Bank 1. The current values of each parameter are displayed and can be updated by selecting from the drop-down menu or entering data from the keyboard, and then pressing the *Apply Changes* button. Note that Bank 1 holds configuration parameters for the base only except for *Broadcast Mode*, which applies to both the base and the remotes.



**Figure 8-12 Status Tab Contents**

Figure 8-12 shows the *Status* tab contents, corresponding to Bank 2. Note the *Status* tab contains read-only parameters.



**Figure 8-13 Serial Tab Contents**

Figure 8-13 shows the *Serial* tab contents corresponding to the serial parameters in Bank 3. The values shown are the defaults for serial port operation.



**Figure 8-14 Protocol Tab Contents**

Figure 8-14 shows the *Protocol* tab contents, corresponding to Bank 4. Transparent serial data communication is currently chosen.



Figure 8-15 I/O Parameters Tab Contents

Figure 8-15 shows the *I/O Parameters* tab contents, corresponding to Bank 5. All GPIO ports are configured as inputs. The 12-bit ADC input readings and DAC output settings are given in *Big-Endian* byte order. Event flags are presented on the right side of the window.



Figure 8-16 I/O Settings Tab

Figure 8-16 shows the first *I/O Settings* tab contents, corresponding to Bank 6 GPIO configurations other than alternate GPIO functions. This tab allows the direction of the GPIO ports to be set both for active and sleep modes, and in the case of GPIO outputs, the initial power up states and sleep mode states to be set. When GPIO ports 0 - 3 are configured as inputs, event interrupts can be set for them with check boxes. The type of interrupt trigger is selected from the drop-down boxes to the right of the check boxes. Periodic I/O reporting, reporting interval and enable/disable sleep I/O states and I/O binding can also be configured under this tab.



**Figure 8-17 2<sup>nd</sup> I/O Setup Tab Contents**

Figure 8-17 shows the second I/O Setup tab contents, corresponding to Bank 6 ADC input and DAC output parameters. The ADC and DAC reference voltages, the ADC sampling interval, the high and low ADC thresholds for event reporting and event reporting triggers on each ADC channel can be set, along with the initial output values for each DAC channel. The event reporting I/O predelay and alternate GPIO functions can also be set from this tab.



**Figure 8-18 3<sup>rd</sup> I/O Setup Tab Contents**

Figure 8-18 shows the third I/O Setup tab contents, corresponding to Bank 6 ADC input and DAC output scaling, offset and related parameters. These parameters should not be changed from their defaults unless precision inputs are available to calibrate the ADC and DAC functions.

The Demo Utility *File*, *Options* and *Help* menus are shown in Figure 8-19.



**Figure 8-19 File, Options, and Help Menus**

## 8.7 Interface Board Features

The locations of the LEDs on the interface board that are used by the DNT24M are shown in Figure 8-20.



**Figure 8-20 LED Locations**

DCD LED, D11, illuminates when a DNT24M receives a valid packet. Activity LED, D10, illuminates when transmitting RF data. Power LED, D1, illuminates when the DNT24M and its interface board are powered. GPIO2 LED, D5, and GPIO3 LED, D4, can be controlled by configuring GPIO2 and GPIO3 as outputs on the DNT24M. These LEDs are illuminated with a logic high signal.



**Figure 8-21 Connectors and Switches – on right**

Figure 8-21 shows the connectors and switches to the right of the DNT24MP mounting socket. JP3 and JP4 normally have shorting plugs installed as shown in Figure 8-21. JP3 connects ADC0 to the yellow potentiometer. Clockwise rotation of the potentiometer increases the voltage. JP4 connects ADC1 to a thermistor temperature sensor. The DNT24M has its own boot loader utility that allows the protocol firmware to be installed with a terminal program that supports YMODEM. The boot loader is activated with a shorting plug on JP13. Pin strip J6 provides access to various DNT24M pins as shown on the silkscreen. Pressing switch SW3 will reset the DNT24MP. Switch S4 is not used with the DNT24M.



**Figure 8-22 Connectors and Swithcves – on left**

Figure 8-22 shows the connectors to the left of the DNT24MP mounting socket. Pressing switch SW1 switches GPIO0 from logic high to low, and pressing SW2 switches GPIO1 from logic high to low. The DNT24MP interface board includes a 5 V regulator to regulate the input from the 9 V wall-plug power supply. Do not attempt to use the 9 V wall-plug power supply to power the DNT24MP directly. The maximum allowed voltage input to the DNT24MP is 5.5 V.

## 9.0 Troubleshooting

*DNT24M not responding* - make sure /RESET is not asserted (logic low). Make sure the host serial port settings match the DNT24M serial port settings.

*Cannot enter protocol mode* - make sure the host data rate is correct. The DNT24M defaults to 9.6 kbps. If using the *EnterProtocolMode* command, send the complete protocol format for this command.

*Carrier is detected, but no data appears to be received* - if /HOST\_RTS is enabled, make sure it is asserted (logic low) to enable character flow from the DNT24M.

*Range is extremely limited* - this is usually a sign of a poor antenna connection or the wrong antenna. Check that the antenna is firmly connected. If possible, remove any obstructions near the antenna.

### 9.1 Diagnostic Port Commands

The diagnostic port shares its RX and TX signal lines with the Activity and DCD indications, respectively. Consequently, the debug port feature must be enabled before being used (Bank 0xFF). The change must be saved and the module then needs to be reset for this to take effect. The diagnostic port is defaulted to 38.4 kbps, 8N1.

The diagnostic port supports the following user commands:

**rbr <bank> <reg> <span>** - read a parameter register's value from the module.

**rbw <bank> <reg> <span> <value> [<value> <value>]** - write a parameter register's value with a span of up to 3 bytes

**stat <option>** - option = 0 is off, option = 1 displays DataTx/AckRx for a hop sequence in time order, and option = 2 displays any packet RX or packet error for a hop sequence in frequency order.

## 10.0 10.0 Appendices

### 10.1 Ordering Information

DNT24MC: Direct peer-to-peer transceiver for solder-pad mounting, for use with external antenna

DNT24MP: Direct peer-to-peer transceiver for pin-socket mounting, for use with external antenna

DNT24MCA: Direct peer-to-peer transceiver for solder-pad mounting, includes on-board chip antenna

DNT24MPA: Direct peer-to-peer transceiver for pin-socket mounting, includes on-board chip antenna

### 10.2 Technical Support

For DNT24M technical support call Murata at (678) 684-2004 between the hours of 8:30 AM and 5:30 PM Eastern Time

### 10.3 DNT24M Mechanical Specifications



Figure 10-1 DNT24C Outline and Mounting Dimensions

### DNT24C Solder Pad Dimensions



Figure 10-2 DNT24C Solder Pad Dimensions

### DNT24P Outline and Mounting Dimensions



Figure 10-3 DNT24P Outline and Mounting Dimensions



**Figure 10-4 DNT24P Interface Connector/PCB Layout**

### **DNT24CA Outline and Mounting Dimensions**



**Figure 10-5 DNT24CA Outline and Mounting Dimensions**

### DNT24CA Solder Pad Dimensions



Figure 10-6 DNT24CA Solder Pad Dimensions

### DNT24PA Outline and Mounting Dimensions



Figure 10-7 DNT24PA Solder Pad Dimensions



**Figure 10-8 DNT24PA Connector/PCB Layout Detail**

## 10.4 DNT24M Development Board Schematic



**Figure 10-9 DNT24M Development Board Schematic - 1**



**Figure 10-10 DNT24M Development Board Schematic - 2**



**Figure 10-11 DNT24M Development Board Schematic – 3**

## **11.0 Warranty**

Seller warrants solely to Buyer that the goods delivered hereunder shall be free from defects in materials and workmanship, when given normal, proper and intended usage, for twelve (12) months from the date of delivery to Buyer. Seller agrees to repair or replace at its option and without cost to Buyer all defective goods sold hereunder, provided that Buyer has given Seller written notice of such warranty claim within such warranty period. All goods returned to Seller for repair or replacement must be sent freight prepaid to Seller's plant, provided that Buyer first obtain from Seller a Return Goods Authorization before any such return. Seller shall have no obligation to make repairs or replacements which are required by normal wear and tear, or which result, in whole or in part, from catastrophe, fault or negligence of Buyer, or from improper or unauthorized use of the goods, or use of the goods in a manner for which they are not designed, or by causes external to the goods such as, but not limited to, power failure. No suit or action shall be brought against Seller more than twelve (12) months after the related cause of action has occurred. Buyer has not relied and shall not rely on any oral representation regarding the goods sold hereunder, and any oral representation shall not bind Seller and shall not be a part of any warranty.

**THE PROVISIONS OF THE FOREGOING WARRANTY ARE IN LIEU OF ANY OTHER WARRANTY, WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL (INCLUDING ANY WARRANTY OR MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE). SELLER'S LIABILITY ARISING OUT OF THE MANUFACTURE, SALE OR SUPPLYING OF THE GOODS OR THEIR USE OR DISPOSITION, WHETHER BASED UPON WARRANTY, CONTRACT, TORT OR OTHERWISE, SHALL NOT EXCEED THE ACTUAL PURCHASE PRICE PAID BY BUYER FOR THE GOODS. IN NO EVENT SHALL SELLER BE LIABLE TO BUYER OR ANY OTHER PERSON OR ENTITY FOR SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES, INCLUDING, BUT NOT LIMITED TO, LOSS OF PROFITS, LOSS OF DATA OR LOSS OF USE DAMAGES ARISING OUT OF THE MANUFACTURE, SALE OR SUPPLYING OF THE GOODS. THE FOREGOING WARRANTY EXTENDS TO BUYER ONLY AND SHALL NOT BE APPLICABLE TO ANY OTHER PERSON OR ENTITY INCLUDING, WITHOUT LIMITATION, CUSTOMERS OF BUYERS.**