Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

...

Necessary Hardware

  • Microcontroller/development board of your choice
    • With necessary programmer
  • SmartMesh IP Mote (DC9003A-B)
    • With 6 female-female jumper cables
  • SmartMesh IP Manager (DC2274A-A)
  • SmartMesh Interface Board (DC9006A)
    • With USB-A to USB-micro cable
  • Computer (should support Python and Java)

Necessary Software

Downloading Libraries
Anchor
sec_download
sec_download

There are two ways to download the QuickStart Library:

a) Clone The Source Code

Clone the repository

...

Initialize and update the neccessary C Library submodule:

 

...

(...)/QuickStart_Library $ git submodule init
(...)/QuickStart_Library $ git submodule update

with git (or a git GUI client):

$ git clone https://github.com/dustcloud/QSL-for-sm_clib.git

Enter the repository:

$ cd QSL-for-sm_clib

Initialize and  update the necessary C Library submodule:

$ git submodule init
$ git submodule update


You can also checkout the latest release with subversion:

$ svn checkout https://github.com/dustcloud/QSL-for-sm_clib.git

but then you will also have to checkout the latest release of the C Library, since SVN does not support git submodules:

$ svn checkout https://github.com/dustcloud/sm_clib.git

b) Download Zip/Tar

  1. Go to the QSL release page and and download the  the latest zip/tarTODO: Add link when public repo created.
  2. Go to the C Library release page and download the  the latest zip/tar: TODO: Can possibly be added as attachment to QSL release. If not: Make a note about why it needs . The C Library is automatically generated from the SmartMesh IP stack library source, and so it may change with each stack release and needs to be downloaded separately.
  3. Unzip the files using your favourite compression tool.

Directory Structure

The QSL repository contains the following directories:

  • sm_qsl/ contains the QuickStart Library as a collection of headers (.h) and source code files (.c).
  • sm_clib/ is a submodule that contains the underlying C Library, with sample applications for its direct use.
    • sm_clib/ is the C Library itself as a collection of headers (.h) and source code files (.c).
      • ports/ contains an example of the necessary C Library ports.
    • examples/ contains sample applications which use the C Library directly.
  • examples/ contains sample applications utilizing the QSL
    • rpi/SimplePublish/ contains an example that connects and starts publishing random data, where the necessary porting functions have been implemented for the Raspberry Pi.
    • samc21_xplained_pro/SimplePublish/ contains the same example for the SAM C21 Xplained Pro evaluation board.
    • nucleo-l053r8/SimplePublish/ contains the same example for the NUCLEO-L053R8 development board.
       

...

Note

If you chose the zip download or subversion checkout, the sm_clib/ directory from the separate unzipped folder

...

/svn checkout should be copied into the QSL repository, as some example code will expect the above structure.


The SmartMesh QuickStart Library, and C Library it depends on, are both designed so you can drop their directories into your application without modification, i.e. these two folders from the structure above:

...

In addition to the files in these folders, you need to implement a handful of functions, as discussed in the next section.

...

Install FTDI Serial Drivers
Anchor
sec_serialDrivers
sec_serialDrivers

To be able to connect to and configure the mote and manager, your computer will need the necessary FTDI Serial Drivers. Most modern OSes come with FTDI drivers pre-installed (e.g. Linux), but you may have to install them manually if they do not configure automatically when you plug in the interface board or manager. Follow the installation guide corresponding to your OS if you have any trouble.

...

The ports of interest are the third and fourth, which map to the CLI and API, respectively, as defined by Table 1



Device

...

Device

Anchor

 

tab_serialPorts
tab_serialPorts

Serial Port NumberUsageBaudrateData BitsParityStop Bits
SmartMesh IP Managerthird*CLI96008No1
fourth*API115200**8**No**1**
SmartMesh IP Motethird*CLI96008No1
fourth*API115200**8**No**1**
 


Table 1: Serial port configurations

...


Note that for Windows, the COM port assignment will change whenever you connect the interface board (or manager) to a different USB port.

Prepare Mote

...

.

...

 

moteInterface2PCImage Removed

 

Figure 1: DC9003 mote board (left) connected to a computer via the DC9006 interface board (center).

 

By default, the motes in starter kits are configured for master mode; a demo mode where the API is disabled and an application is run that generates sample data and controls joining. To use the mote alongside an external MCU, the mote has to be configured for slave mode; the API is enabled and the mote expects a serially attached application to control it.

  1. Start by connecting the mote to your computer via the interface board, as shown in Figure 1.
  2. Identify the port name that maps to the CLI. For example, if you are in Windows and see the four COM ports pictured below, the CLI will be accessible through COM14.
    Image Removed 
  3. Connect to the mote CLI with a third-party serial terminal of your choice (e.g. putty). See Table 1 for configuration details.
  4. Use the get mode command to see the current mode:

     

    > get mode
    master
  5. Use the set mode command to switch to slave mode, followed by reset for the change to take effect. After rebooting, a new get mode should confirm the persistent mode change.

     

    > set mode slave
     
    > reset
      
    > SmartMesh IP mote, ver 1.3.3.1 (0x100)
    > get mode
    slave
  6. Disconnect the mote from the interface board and make sure to remove its battery (if any), as we will power the mote from the MCU.

4.2 Connect to Your Microcontroller

You will need to connect 4 wires between your MCU and the mote for power and serial communication, as shown in Table 2. In addition you need to ground the mote RX Request to Send (RTS) and TX Clear to Send (CTS); unless your MCU cannot wake on data and has to use these accordingly (the mote does not need incoming flow control).

Table 3 lists the names (equal to those found on the silkscreen) of the P1 pin header on the DC9003A mote board visible in Figure 2.

 

 

MCU
Mote
3.3 VVBAT
GroundGND
UART TXRX
UART RXTX

 

Table 2: MCU to mote pin mapping.

 

 

 

NamePin #Name
TX CTSn12TX RTSn
TX34GND
RX56RX RTSn
RX CTSn78CO TX
CO RX910GND
RESETn1112F P ENn
I MISO1314I MOSI
I SSn1516I SCK
GND1718TCK
TMS1920TDO
TDI2122VUSB_3V6
PGOOD2324GND
VBAT2526KEY
EHORBAT2728RSVD
I/O 12930I/O 2
V+3132+5V

 

Table 3: DC9003A (mote) P1 Pins

 

 

Image Removed
Figure 2: The DC9003A (mote) with the P1 pin header marked in red.

...