IridiumSBD

The Rock 7 RockBLOCK is a fascinating new communications module that gives TTL-level devices like Arduino access to the Iridium satellite network.  This is a big deal, because it means that your application can now easily and inexpensively communicate from any point on the surface of the globe, from the heart of the Amazon to the Siberian tundra.

This library, IridiumSBD, uses the RockBLOCK/Iridium’s SBD (“Short Burst Data”) protocol to send and receive short messages to/from the Iridium hub.  SBD is a “text message”-like technology that supports the transmission of text or binary messages up to a certain maximum size (270 bytes received, 340 bytes transmitted).

For more information, visit the Rock 7 website.

“3-Wire” Wiring

Rock 7 have made interfacing to the Arduino quite simple.  Each RockBLOCK ships with a 10-pin JST-terminated cable that snaps onto the RockBLOCK and conveniently exposes the various signal lines for the client device to connect to.  It’s actually only necessary to connect 4 or 5 of these to get your Arduino application up and running.   In our configuration we ignore the flow control lines and talk to the RockBLOCK over what Iridium calls a “3-wire” TTL serial interface.  In wiring table below, we assume that the RockBLOCK is being powered from the Arduino 5V power bus.

RockBLOCK Connection Arduino Connection
+5V (Power) +5V (Power)
GND GND
TX TX Serial Pin*
RX RX Serial Pin*
SLEEP +5V or GPIO pin*

A minimal “3-wire” connection to RockBLOCK

*The TX and RX lines are labeled on the RockBLOCK as viewed from the Arduino, so the TX line would be transmitting serial data to the RockBLOCK.  These lines support TTL-level serial (default 19200 baud), so you can either connect it directly to the/a built-in UART or create a “soft” serial on any two suitable pins.  We usually opt for the latter choice to free up the UART(s) for diagnostic and other console communications.  The active low SLEEP wire may be connected to a 5V line (indicating that the device is perpetually awake), but it’s a good power saving technique to connect it to a general-purpose pin,  allowing the library to put the RockBLOCK in a low power “sleep” state when its services are not needed.

Non-blocking Retry Strategy

The nature of satellite communications is such that it often takes quite a long time to establish a link.  Satellite communications are line-of-sight, so having a clear view of an unclouded sky greatly improves speed and reliability; however, establishing contact may be difficult even under ideal conditions for the simple reason that at a given time no satellite may immediately be overhead.  In these cases, the library initiates a moderately elaborate behind-the-scenes series of retries, waiting for a satellite to appear.

With a clear sky, transmissions almost always succeed after a few of these retries, but the entire process may take up to several minutes.  Since most microcontroller applications cannot tolerate blocking delays of this length, IridiumSBD provides a callback mechanism to ensure that the Arduino can continue performing critical tasks.  That is, if the library user provides a global C++ function with the signature

bool ISBDCallback();

(and this is highly recommended for all but the most trivial applications), then that function will be called repeatedly while the library is waiting for long operations to complete.  In it you can take care of activities that need doing while you’re waiting for the transmission to complete.  Simple example:

bool ISBDCallback()
{
   unsigned ledOn = (bool)((millis() / 1000) % 2);
   digitalWrite(ledPin, ledOn); // Blink LED every second
   return true;
}
...
// This transmission may take a long time, but the LED keeps blinking
isbd.sendSBDText("Hello, mother!");

Note: It is not permitted to call most IridiumSBD methods from within the callback.  Doing so will immediately return ISBD_REENTRANT.

Note: Your application can prematurely terminate a pending IridiumSBD operation by returning false from the callback.  Doing so causes the pending operation to return ISBD_CANCELLED.

Power Considerations

The RockBLOCK module uses a “super capacitor” to supply power to the Iridium 9602.  As the capacitor is depleted through repeated transmission retries, the host device’s power bus replenishes it.  Under certain low power conditions it is important that the library not retry too quickly, as this can drain the capacitor and render the 9602 inoperative.  In particular, when powered by a low-power 90 mA max USB supply, the interval between transmit retries should be extended to as much as 60 seconds, compared to 20 for, say, a high-current battery solution.

To transparently support these varying power profiles, IridiumSBD provides the ability to fine-tune the delay between retries.  This is done by calling

isbd.setPowerProfile(1); // For USB "low current" applications

or

isbd.setPowerProfile(0); // For "high current" applications

Construction and Startup

To begin using the library, first create an IridiumSBD object.  The IridiumSBD constructor binds the new object to an Arduino Stream (i.e. the RockBLOCK serial port) and, optionally, the RockBlock SLEEP line:

IridiumSBD(Stream &stream, int sleepPinNo = -1);

Example startup:

#include "IridiumSBD.h"
#include "SoftwareSerial.h"

SoftwareSerial ssIridium(18, 19); // RockBLOCK serial port on 18/19

IridiumSBD isbd(ssIridium, 10);   // RockBLOCK SLEEP pin on 10

void setup()
{
   isbd.setPowerProfile(1); // This is a low power application
   isbd.begin(); // Wake up the 9602 and prepare it to communicate.
   ...

Data transmission

The methods that make up the meat of the IridiumSBD public interface, are, naturally, those that enable the sending and receiving of data.  There are four such functions in IridiumSBD, two “send-only” functions (text and binary), and two “send-and-receive” functions (again, text and binary):

// Send a text message
int sendSBDText(const char *message);

// Send a binary message
int sendSBDBinary(const uint8_t *txData, size_t txDataSize);

// Send a text message and receive one (if available)
int sendReceiveSBDText(const char *message, uint8_t *rxBuffer, 
   size_t &rxBufferSize);

// Send a binary message and receive one (if available)
int sendReceiveSBDBinary(const uint8_t *txData, size_t txDataSize,
   uint8_t *rxBuffer, size_t &rxBufferSize);

Send-only and Receive-only applications

Note that at the lowest-level, SBD transactions always involve the sending and receiving of exactly one message (if one is available).  That means that if you call the simpler variants sendSBDText or sendSBDBinary and there happen to messages in your incoming (RX) message queue, the first of these is discarded and irrevocably lost.  This may be perfectly acceptable for a “send-only” application that never expects to receive messages, but if there is some chance that you will need to process an inbound message, call sendReceiveSBDText or sendReceiveSBDBinary instead.

If your application is receive-only, simply call sendReceiveSBDText with a NULL outbound message parameter.

If no inbound message is available, the sendReceive* messages indicate this by returning ISBD_SUCCESS and setting rxBufferSize to 0.

Diagnostics

IridiumSBD provides two methods for performing self-diagnostics.  These are

void attachConsole(Stream &stream);
void attachDiags(Stream &stream);

These allow the host application to provide a Stream object (serial port) that can be used to monitor the RockBLOCK serial traffic and diagnostic messages, respectively.  The typical usage is to simply use the Arduino serial port to monitor both of these—assuming that it is connected to a PC serial console and not otherwise used:

isbd.attachConsole(Serial);
isbd.attachDiags(Serial);

Receiving Multiple Messages

After every successful SBD send/receive operation, the Iridium satellite system informs the client how many messages remain in the inbound message queue.  The library reports this value with the getWaitingMessageCount method.  Here’s an example of a loop that reads all the messages in the inbound message queue:

do
{
   char rxBuffer[100];
   size_t bufferSize = sizeof(rxBuffer);
   int status = isbd.sendReceiveText("Hello?", rxBuffer, bufferSize);
   if (status != ISBD_SUCCESS)
   {
      /* ...process error here... */
      break;
   }
   if (bufferSize == 0)
      break; // all done!
   /* ...process message in rxBuffer here... */

} while (isbd.getWaitingMessageCount() > 0);

Erratum Workarounds and other Tweaks

In May, 2013, Iridium identified a potential problem that could cause a satellite modem like the RockBLOCK to lock up unexpectedly.  In a product bulletin they stated that though future versions of the Iridium firmware would resolve this issue, current software should work around it by adding an “MSSTM” software query to the device.  IridiumSBD employs this important workaround by default, but you can disable it with:

isbd.useMSSTMWorkaround(false);

Similarly, Iridium recommend that transmission be deferred until the signal quality has reached at least 2 (on a scale of 0 to 5, as reported by getSignalQuality()).  However, there are times when it is advantageous to use a lower (or higher) value than 2 as this default minimum.  To change the default minimum from 2, use:

isbd.setMinimumSignalQuality(1);

Error return codes

Many  IridiumSBD methods return an integer error status code, with ISBD_SUCCESS (0) indicating successful completion.  These include begin, sendSBDText, sendSBDBinary, sendReceiveSBDText, sendReceiveSBDBinary, getSignalQuality, and sleep.  Here is a complete list of the possible error return codes:

#define ISBD_SUCCESS             0
#define ISBD_ALREADY_AWAKE       1
#define ISBD_SERIAL_FAILURE      2
#define ISBD_PROTOCOL_ERROR      3
#define ISBD_CANCELLED           4
#define ISBD_NO_MODEM_DETECTED   5
#define ISBD_SBDIX_FATAL_ERROR   6
#define ISBD_SENDRECEIVE_TIMEOUT 7
#define ISBD_RX_OVERFLOW         8
#define ISBD_REENTRANT           9
#define ISBD_IS_ASLEEP           10
#define ISBD_NO_SLEEP_PIN        11

Interface Documentation

IridiumSBD(Stream &stream, int sleepPinNo = -1);

Description:   Creates an IridiumSBD library object
Returns:            N/A [constructor]
Parameter:      stream – The serial port that the RockBLOCK is connected to.
Parameter:      sleepPin – The number of the Arduino pin connected to the RockBLOCK SLEEP line.
Note: Connecting and using the sleepPin is recommended for battery-based solutions.  Use sleep() to put the RockBLOCK into a low-power state, and begin() to wake it back up.

int begin();

Description:   Starts (or wakes) the RockBLOCK modem.
Returns:            ISBD_SUCCESS if successful, a non-zero code otherwise.
Parameter:      None.
Notes

  • begin() also serves as the way to wake a RockBLOCK that is asleep.
  • At initial power up, this method make take several tens of seconds as the device charges.  When waking from sleep the process should be faster.
  • If provided, the user’s ISBDCallback function is repeatedly called during this operation.
  • This function should be called before any transmit/receive message

int sendSBDText(const char *message);

Description:   Transmits a text message to the global satellite system.
Returns:            ISBD_SUCCESS if successful, a non-zero code otherwise;
Parameter:      message – A 0-terminated string message.
Notes

  • The library calculates retries the operation for up to 300 seconds by default.  (To change this value, call adjustSendReceiveTimeout.)
  • The maximum size of a transmitted packet (including header and checksum) is 340 bytes.
  • If there are any messages in the RX queue, the first of these is discarded when this function is called.
  • If provided, the user’s ISBDCallback function is repeatedly called during this operation.

int sendSBDBinary(const uint8_t *txData, size_t txDataSize);

Description:   Transmits a binary message to the global satellite system.
Returns:            ISBD_SUCCESS if successful, a non-zero code otherwise;
Parameter:      txData – The buffer containing the binary data to be transmitted.
Parameter:      txDataSize – The size of the buffer in bytes.
Notes

  • The library calculates and transmits the required headers and checksums and retries the operation for up to 300 seconds by default.  (To change this value, call adjustSendReceiveTimeout.)
  • The maximum size of a transmitted packet (including header and checksum) is 340 bytes.
  • If there are any messages in the RX queue, the first of these is discarded when this function is called.
  • If provided, the user’s ISBDCallback function is repeatedly called during this operation.

int sendReceiveSBDText(const char *message, uint8_t *rxBuffer, size_t &rxBufferSize);

Description:   Transmits a text message to the global satellite system and receives a message if one is available.
Returns:            ISBD_SUCCESS if successful, a non-zero code otherwise;
Parameter:      message – A 0-terminated string message.
Parameter:      rxBuffer – The buffer to receive the inbound message.
Parameter:      rxBufferSize – The size of the buffer in bytes.
Notes

  • The library calculates retries the operation for up to 300 seconds by default.  (To change this value, call adjustSendReceiveTimeout.)
  • The maximum size of a transmitted packet (including header and checksum) is 340 bytes.
  • The maximum size of a received packet is 270 bytes.
  • If there are any messages in the RX queue, the first of these is discarded when this function is called.
  • If provided, the user’s ISBDCallback function is repeatedly called during this operation.
  • The library returns the size of the buffer actually received into rxBufferSize.  This value should always be set to the actual buffer size before calling sendReceiveSBDText.

int sendReceiveSBDBinary(const uint8_t *txData, size_t txDataSize, uint8_t *rxBuffer, size_t &rxBufferSize);

Description:   Transmits a binary message to the global satellite system and receives a message if one is available.
Returns:            ISBD_SUCCESS if successful, a non-zero code otherwise;
Parameter:      txData – The buffer containing the binary data to be transmitted.
Parameter:      txDataSize – The size of the outbound buffer in bytes.
Parameter:      rxBuffer – The buffer to receive the inbound message.
Parameter:      rxBufferSize – The size of the buffer in bytes.
Notes

  • The library calculates and transmits the required headers and checksums and retries the operation for up to 300 seconds by default.  (To change this value, call adjustSendReceiveTimeout.)
  • The maximum size of a transmitted packet (including header and checksum) is 340 bytes.
  • The maximum size of a received packet is 270 bytes.
  • If there are any messages in the RX queue, the first of these is discarded when this function is called.
  • If provided, the user’s ISBDCallback function is repeatedly called during this operation.

int sendReceiveSBDBinary(const uint8_t *txData, size_t txDataSize,

uint8_t *rxBuffer, size_t &rxBufferSize);
Description:   Transmits a binary message to the global satellite system and receives a message if one is available.
Returns:            ISBD_SUCCESS if successful, a non-zero code otherwise;
Parameter:      txData – The buffer containing the binary data to be transmitted.
Parameter:      txDataSize – The size of the outbound buffer in bytes.
Parameter:      rxBuffer – The buffer to receive the inbound message.
Parameter:      rxBufferSize – The size of the buffer in bytes.
Notes

  • The library calculates and transmits the required headers and checksums and retries the operation for up to 300 seconds by default.  (To change this value, call adjustSendReceiveTimeout.)
  • The maximum size of a transmitted packet (including header and checksum) is 340 bytes.
  • The maximum size of a received packet is 270 bytes.
  • If there are any messages in the RX queue, the first of these is discarded when this function is called.
  • If provided, the user’s ISBDCallback function is repeatedly called during this operation.

int getSignalQuality(int &quality);

Description:   Queries the signal strength and visibility of satellites
Returns:            ISBD_SUCCESS if successful, a non-zero code otherwise;
Parameter:      quality – Return value: the strength of the signal (0=nonexistent, 5=high)
Notes

  • If provided, the user’s ISBDCallback function is repeatedly called during this operation.
  • This method is mostly informational.  It is not strictly necessary for the user application to verify that a signal exists before calling one of the transmission functions, as these check signal quality themselves.

int getWaitingMessageCount();

Description:   Returns the number of waiting messages on the Iridium servers.
Returns:            The number of messages waiting.
Parameter:      None.
Notes

  • This number is only valid if one of the send[Receive] methods have previously completed successfully.  If not, the value returned from getWaitingMessageCount is -1 (“unknown”).

int sleep();

Description:   Puts the RockBLOCK into low power “sleep” mode
Returns:            ISBD_SUCCESS if successful, a non-zero code otherwise;
Parameter:      None.
Notes

  • This method gracefully shuts down the RockBLOCK and puts it into low-power standby mode by bringing the active low SLEEP line low.
  • Wake the device by calling begin.
  • If provided, the user’s ISBDCallback function is repeatedly called during this operation.

bool isAsleep();

Description:   indicates whether the RockBLOCK is in low-power standby mode.
Returns:            true if the device is asleep
Parameter:      None.

void setPowerProfile(int profileNo);

Description:   Defines the device power profile
Returns:            None.
Parameter:      profileNo – 1 for low-current USB power source, 0 for default power
Notes

  • This method defines the internal delays between retransmission.  Low current applications need longer delays.

void adjustATTimeout(int seconds);

Description:   Adjusts the internal timeout timer for serial AT commands
Returns:            None.
Parameter:      seconds – The maximum number of seconds to wait for a response to an AT command (default=20).
Notes

  • The Iridium 9602 frequently does not respond immediately to an AT command.  This value indicates the number of seconds IridiumSBD should wait before giving up.
  • It is not expected that this method will be commonly used.

void adjustSendReceiveTimeout(int seconds);

Description:   Adjusts the internal timeout timer for the library send[Receive] commands
Returns:            None.
Parameter:      seconds – The maximum number of seconds to continue attempting retransmission of messages (default=300).
Notes

  • This setting indicates how long IridiumSBD will continue to attempt to communicate with the satellite array before giving up.  The default value of 300 seconds (5 minutes) seems to be a reasonable choice for many applications, but higher values might be more appropriate for others.

void setMinimumSignalQuality(int quality);

Description:   Defines the minimum signal quality needed to begin a send/receive transmission.
Returns:            None.
Parameter:      quality – The minimum signal quality on a scale of 0 (nonexistent) to 5 (superb) needed before the library allows a transmission to begin. (default=2)
Notes

  • Iridium recommend using 2 for this value, although there are occasions where 1 might be used.

void useMSSTMWorkaround(bool useWorkaround);

Description:   Defines whether the library should use the technique described in the Iridium Product Advisor of 13 May 2013 to avoid possible lockout.
Returns:            None.
Parameter:      useWorkaround – “true” if the workaround should be employed; false otherwise.  This value is set internally to “true” by default, on the assumption that the attached device may have an older firmware.
Notes

  • Affected firmware versions include TA11002 and TA12003.  If your firmware version is later than these, you can save some time by setting this value to false.

void attachConsole(Stream &stream)

Description:   Binds stream as the library output console.
Returns:            None.
Parameter:      stream – The stream object (typically a serial port) that will monitor the serial traffic to/from the RockBLOCK device.
Notes

  • This is a diagnostic routine.  Use it to monitor traffic on a PC console.

void attachDiags(Stream &stream)

Description:   Binds stream as the library diagnostic stream
Returns:            None.
Parameter:      stream – The stream object (typically a serial port) that will display library diagnostic messages.
Notes

  • This is a diagnostic routine.  Use it to monitor debug messages on a PC console.
  • If this functionality is no longer needed, you can recover system resources by recompiling the library source without diagnostics.  Change the line near the top of IridiumSBD.h to
#define ISBD_DIAGS             0

bool ISBDCallback()

Description:   This is not a library method, but an (optional) user-provided callback
Returns:            true if the operation should continue, false to terminate it.
Parameter:      None.
Notes

  • If this function is not provided the library methods will block.

License

This library is distributed under the terms of the GNU LGPL license.

Download

The latest revision of the library is 1.0. Download from GitHub.

Revision history

0.1   – Initial draft submitted to Rock 7 for review
0.2   – Added text about the AT-MSSTM erratum/workaround and changing the minimum required signal quality.  Also documented related new methods setMinimumSignalQuality()  and useMSSTMWorkaround().
1.0 – Posted initial version.

 

Page last updated on August 31, 2013 at 6:49 pm
130 Responses → “IridiumSBD”

  1. Phil Smith

    7 years ago

    Mikal,

    I’ve been using your library to send messages to RockBlock from my Arduino successfully for a while. I’m now trying to receive text messages (using sendReceiveSBDText). However, I get an ISBD_PROTOCOL_ERROR instead of the received message: the sent message goes OK.

    I wonder if it is due to the waitForATResponse() failing at the start of doSRDRB(). Ie in these few lines:
    533 int IridiumSBD::doSBDRB(uint8_t *rxBuffer, size_t *prxBufferSize)
    534 {
    535 bool rxOverflow = false;
    536

    537 send(F(“AT+SBDRB\r”));
    538 if (!waitForATResponse(NULL, 0, NULL, “AT+SBDRB\r”)) // waits for its own echo
    539 return cancelled() ? ISBD_CANCELLED : ISBD_PROTOCOL_ERROR;
    540

    .

    So several questions:

    why is the doSRBRB used to receive text messages? (This function is used for binary messages.)
    In the RB documentation, the SBDRB command doesn’t send back any echo, so I don’t think the waitForATResponse should have the last parameter set to “AT+SBDRB\r” .
    I would have thought that the first two parameters of waitForATResponse should be set, in order to collect the message (both for binary and text).

    Of course, I could be way off track with my trying to understand your code, but there aren’t many places that produce a ISBD_PROTOCOL_ERROR, and I’m pretty sure that the console report of error code 3 is correct.

    The text message has been sent to the RockBlock, as it shows up on the console correctly, as part of the debugging information. So it isn’t a problem with the satellite link.

    Do you have any arduino code examples showing how to receive a text (or binary) message)?

    Any help gratefully received.

    Phil


  2. DanL

    7 years ago

    @PlumB,

    I had the same problem with my project and used your solution. It worked wonderfully, so THANK YOU!!!!

    Also, I noticed that if I tried to send a command to the RockBLOCK after receiving a message, I was getting errors. Turns out the doSBDRB() function doesn’t process the “OK\r\n” at the end of the iridium response. The iridium module will respond with
    “<<AT+SBDRB[size]____________[checksum]OK\r\n"
    but the code only processes up to "…[checksum]". Issuing another command afterwards means the "OK\r\n" is still in the "stream" buffer and it gets confused.

    I solved this by simply placing a waitForATResponse() after the checksum processes. (No parameters means it only looks for the terminator "OK\r\n"). See below:

    uint16_t checksum = 256 * stream.read() + stream.read();
    console(F("[csum:"));
    console(checksum);
    console(F("]"));

    // Return actual size of returned buffer
    if (prxBufferSize)
    *prxBufferSize = (size_t)size;

    console("\r\n"); //added this line to skip to next line in terminal
    waitForATResponse(); //added this line to process "OK\r\n"

    return rxOverflow ? ISBD_RX_OVERFLOW : ISBD_SUCCESS;


  3. Santi

    7 years ago

    Hello there:

    I am trying to use RockBlock with an Arduino Uno and i have problems to send more than 17 characters. When I try to send more than 17, then it appear garbage characters, as you can see as follows:

    …………………………………………….
    internalSendReceive
    >> AT+SBDWT

    Waiting for response READY

    << AT+SBDWT

    READY
    This is a message with more than 17 characters

    Waiting for response 0

    OK

    << TÒ@æ��•Í…e ÒÐ�½É�¡¹ 17 characters
    0

    OK

    ……………………………………………

    How is it possible?


  4. Mikal

    7 years ago

    @Santi, are you connecting to Arduino via SoftwareSerial? I have noticed garbled characters sometimes myself when the response from AT+SBDWT comes back from the modem.


  5. Maj

    7 years ago

    Hi,
    I am going to connect Arduino UNO to RockBlock. If I change this line
    SoftwareSerial nss(18, 19);
    to for example
    SoftwareSerial nss(6, 7);
    and connect TX and RX to pin 6 and 7 is enough?
    or should I connect TX and RX of RockBlock to TX and RX of Arduino?


  6. lakshay

    7 years ago

    Hello All,
    Please help me to clear MO Buffer
    Because if sky is not clear & my message failed to send then in next attempt double message i.e the previous one & new one is sent which cost me more credits
    so i want to clear MO buffer so that i can send my data properly

    thanks


  7. Miriam

    7 years ago

    Hello Mikal,

    Thank you very much for the library, very useful.
    I use it to send messages to an Arduino board located in a remote place, but I have a problem with it.
    I use the function sendReceiveSBDText to make the Rockblock change one Arduino pin value when a specific message is received and then send a confirmation saying the message was received. The Arduino pin is changed but I never get the confirmation.

    Is that something common? Do you know what I’m doing wrong or have you got any code example with this function that you know it works?

    Thank you very much,

    Miriam.


  8. Misha

    7 years ago

    Hi! I’ve been using your excellent SBD Library for a couple of weeks now and I am meeting with great success! The library is lean and mean and I love it! Well done! However, I have 2 very pressing problems! The first is that I cannot tell from the online docs how to enable the ring alert. I understand what it is and how it works from the Iridium developer manuals, however, what I don’t understand is how to enable the hardware interrupt properly to cause the 9602 to wake up and process on a ring alert. Any help in this respect would be very greatly appreciated! The second issue is a problem with the rxBuffer size in a send/receive text call and the actual size of the message delivered to the buffer from the Iridium satellite stellium. No matter how I change the size of the buffer the message received into the buffer is always truncated, except for very small (20 or 30 bytes or so) inbound messages. Even with overhead like checksums, etc. the payload should be at least in the 100-140 byte range? Perhaps there are special characters that are taboo? But in my case, even straight ASCII text still produce this problem. I am developing on several arduino platforms, but primarily the Mega 2560. Also, it have the 9602 provisioned not to send geo data. So I’m stumped! Please help. Thank you very much for any assistance. Great job Mikal! Misha.


  9. Jende

    7 years ago

    You seriously need to stop writing tutorials and libraries, you simply just suck at it. You explained things terribly and I got cancer trying to figure out what you wrote. Please stop.


  10. zms

    6 years ago

    Hello Iridium Fans,

    Mikal – thank you for your work on Iridium SBD Master. Awesome stuff –

    I’m hoping to glean some help for obtaining and applying system time from Iridium network connections in order to set local time on my station. In 2.0, I’m trying to utilize getSystemTime() to grab a time per time.h syntax, however am a relative freshman with Arduino.

    Would anyone be able to provide some example syntax for getSystemTime() that might help me grab timestamps for outgoing messages?

    Thank you!!

    Best,
    Zach


  11. Mikal

    6 years ago

    @Jende, what would you like to see improved?


  12. Mikal

    6 years ago

    @zms, check out the example sketch File/Examples/Iridium SBD/Time. That should get you going.

    M


  13. Mikal

    6 years ago

    @Misha, sorry for the late reply. Would you try again with the new version 2 library? I think this may be fixed.


  14. zms

    6 years ago

    Thanks Mikal –

    Apologies I did not see that example in there! I will check it out.

    Best,
    Zach


  15. David

    6 years ago

    Mikal – Thank you for this library. I am attempting to connect an Adafruit M0 RFM95 (LoRa) to the new RockBLOCK 9603. The M0 does not have or allow SoftwareSerial ports. The ports are Serial and Serial1 and are both hardware.

    https://www.adafruit.com/product/3178

    Can you tell me how to pass the Serial1 port information for the M0 into your library?

    //#include
    //SoftwareSerial nss(18, 19);
    IridiumSBD isbd(Serial1, 10); // creates compiler errors


  16. Mikal

    6 years ago

    @David, download the latest version of the library from github. The new examples all use the hardware Serial ports.

    M


  17. Adam

    6 years ago

    Mikal,

    Thanks for an amazing library! Your beacon example has be invaluable in the development of a several of projects I’m working on. I was excited to see in Version 2.0 that PString wasn’t required, until I realized you hadn’t selected any of the TinyGPS++ double/float variables. Would you recommend to simply use PString to transmit these variables?

    I was also curious: would it be possible to utilize a form of data compression to reduce the size of the transmitted data packets? I came across a beacon that’s able to squeeze several timestamps/data samples into 37-byte packet using packed binary compression, though I’m not exactly sure how to go about doing so.

    @Jende Thanks for the laugh! I almost spit out my coffee while reading your (what I assume was sarcastic) comment!

    Cheers,
    A


  18. Zach

    6 years ago

    Hi Mikal,

    Thank you again for the killer library!

    A quick question – can you recommend a means to pull a retry value from your sendreceive subroutine? For example, if the modem is executing retries to send text, I’d like to be able to obtain how many retries were cycled through before successful transmission.

    I appreciate any thoughts!

    Best
    Zach


  19. Mikal

    6 years ago

    @Zach, if you’re just interested in that information for diagnostic purposes, it’s not too hard to glean it from the logs that are produced. But that’s not a value that is easy to get programatically.


  20. Zach

    6 years ago

    Right on –

    No worries. Historically, on other platforms (non-arduino) I have included # retries in my out message to assess/confirm whether there is an issue with my station. Can you confirm how many retries occur until time-out within your library, please?

    Thank you!
    zach


  21. JongWon Lee

    6 years ago

    Hi Mikal

    Thank you for your awesome library.
    I have a question – Is it possible to turn on an LED to send a message to Rockblock using arduino?
    This is what I want to do:
    1. Send a message to the rockblock(e.g. “a” or “turn on the LED”) through rockblock homepage.
    2. The Arduino which is connected to the rockblock reads a message.
    3. Turn on an LED.

    I think arduino need to catch message which is in the buffer but i’m not sure and i don’t know what to do. A small tip will be greatly helpful.

    Thank you


  22. Mikal

    6 years ago

    @JongWon Lee: Sure! This should be pretty easy. Using RB console, send a 1-character message ‘1’ for LED on or ‘0’ for LED off. In your Arduino code call

    modem.sendReceiveSBDText(NULL, buffer, sizeof(buffer));

    to receive messages (without sending any). Then

    if (buffer[0] == ‘1’)
    digitalWrite(13, HIGH);
    else if (buffer[0] == ‘0’)
    digitalWrite(13, LOW);

    Mikal


  23. Jongwon Lee

    6 years ago

    Thank you for quick answer.

    But I still wonder that rockblock has a ‘multiple’ buffer.
    I am also using gps module. I am using ‘beacon’ file which you uploaded as an example.
    as gps is using rockblock’s buffer, I am wondering if I send a message to rockblock, then what happens to rockblock’s buffer? Doesn’t it mix with gps’s signal and my sending message?

    Thank you


  24. Haim Rodrik

    6 years ago

    Does anyone have Arduino Iridium Shield Schematic ?

    Thank you


  25. JP KANG

    6 years ago

    Nice to meet you Mikal. Thanks to you library, I got a lot of help.
    Thanks.
    My question is – ISBDcallback function is continually working eventhough the delay of the transmission. This is what I understood.

    My arduino is located in the sea and send its position data by Iridium. To prevent unexpected code or hardware failure,it needs to be reset by itself. Thus, I used the watchdog timer library by using your ISBDcallback function.

    However, whenever It transmits it data.

    >> AT+SBDWT= 37.449589 126.952800 24430 1.22 140518 6282500

    Waiting for response OK

    << AT+SBDWT= 37.449589 126.952800 24430 1.22 140518 6282500

    then it jumped next line without transmit its message

    without AT+SBDIX TRANSMISSION and receiving

    if I erase the ISBDcallback function , it works fine as normal.
    How can I solve this problem. I definitely need to insert the watchdog timer function for my gps tracker in case of malfunction in the sea.

    Could you help me? Thanks in advance.

    ———————————————————————–
    "wdt_enable(WDTO_8S) // 8 seconds period reset "

    Void loop()
    {…
    ISBDcallback();
    isbd.sendSBDText(OUTBuffer);
    ..
    }

    bool ISBDCallback()
    {
    wdt_reset();
    }
    —————————-


  26. Dan L

    6 years ago

    Hey Mikal,

    Binary data sending solved.

    I know you’ve updated the library to solve this this and posted it on Github already, but there is an error in IridiumSBD.cpp which prevents binary data from being sent properly. Just thought I’d comment in case anyone else is still using this library and having trouble.

    This is easily fixed by changing the function:

    void IridiumSBD::send(uint16_t n)
    {
    console(n);
    stream.write(n);
    }

    to

    void IridiumSBD::send(uint16_t n)
    {
    console(n);
    stream.print(n);
    }

    After the library send the command “AT+SBDWB=” (send SBD Write Binary), the iridium module expects to get the length of the binary data. Without the change, the library writes the length to the serial port as binary data, whereas the iridium module is expecting ascii/text.

    Thanks for all your work writing this. It has done wonders for me.


  27. Thomas Chase Allen

    5 years ago

    Hi, I have been trying to use your serial Passthru example sketch to test my Iridium Module and I keep getting a compiler error:

    lto1.exe: internal compiler error: in lto_output_varpool_node, at lto-cgraph.c:624

    The only modification to the code I made was to use Software Serial for an Uno instead of a Mega. Is this something that has been resolved?


  28. Adam Garbo

    5 years ago

    Hi Mikal,

    I noticed in version 2.0 of your IridiumSBD library that you’ve removed the minimum signal quality functionality provided by void setMinimumSignalQuality(int quality); I’m curious what the rationale behind this was, as it now appears the library disregards the signal quality when attempting to transmit a message. Should we instead be manually programming a signal quality check before attempting transmissions?

    Cheers,
    Adam


  29. Mikal

    5 years ago

    @Adam Garbo,

    When we built v 1.0 the guidance from Rock7 was that we ought to check the signal quality before sending (per Iridium I believe) so as to avoid congesting the network. However, this guidance changed, so that when v2.0 came along it was no longer deemed necessary. There being no need for such a function we decided to unclutter the API by removing it.

1 Trackbacks For This Post
  1. Saber Más Iniciación Arduino 2017 | Aprendiendo Arduino

    […] librería módulo iridium: http://arduiniana.org/libraries/iridiumsbd/ […]

Leave a Reply