Trouble interfacing XBee Pro S3B without X-CTU on an Arduino board

Hey everyone, I am new to XBees and interfacing them with microcontrollers, so bear with me. Right now I am trying to establish a simple serial connection between two Arduino-based boards (the Mayfly by Stroud Research Center) using XBee Pro S3B modules. My current set up includes one Mayfly logging air temperature and sending it to an XBee Pro S3B via the board’s Tx serial communication and an XBee’s DIN pin, then that data is sent over radio to another XBee Pro S3B in transparent mode, out the DOUT pin, and to the other board’s Rx port. I have the sender datalogger constantly powered, and I have no problems printing data to the sending XBee and sending the information out over radio.

The problem I’m running into is the XBee receiving data will not automatically kick it out the DOUT pin unless I add the device in X-CTU. I know the XBees work together because when I plug the receiving XBee into the X-CTU program, I can read the data in the console as it comes in. I have an XBee Serial Explorer breakout board from Sparkfun that lights up an LED when data is sent over the DOUT or DIN pins. I’ve noticed that even when I power up XBee module using this breakout board, the DOUT pin will not light up until I add the device on X-CTU. Once it is added, the DOUT pin begins to light up from the incoming data from the datalogger sending air temperature. I can connect the DOUT pin on the receiving XBee to a Mayfly, keeping the power to the breakout board on, and the Mayfly will read the serial data just fine. However, as soon as I cut power and turn it back on, the data no longer transfers through the DOUT pin to the datalogger on the receiver end. I have to go back into X-CTU, add the device, and keep the power supplied on the breakout board as I add some jumper pins to connect the DOUT pin to the Rx pin on the Mayfly.

I’m wondering if there are some commands that need to be issued to the XBee module from the datalogger if I were to just power the module up and have it function properly with the microcontroller without the help of X-CTU. Does adding the device in X-CTU issue any commands to the module that make it so it functions properly?

It should also be noted that my sender logger and XBee module work fine, with no need to connect to the X-CTU software to function properly. So I’m wondering if it is something to do with the receiving end of a transparent connection between modules.

Thanks!

What are the two full part numbers for the two XBee modules you are working with?

What firmware version is installed on both radios?

Part numbers: XBP9B-DMSTB002
Firmware: 8075

Is that what you are asking for? Yesterday afternoon my XBees started having trouble out of nowhere with changing certain settings, not remembering changes I had written, making me reset the module after certain changes or when I added a module to XCTU (and then not processing that I had reset it), and not recognizing MAC addresses. I’ve tried recovering the modules using the XCTU tool, but I get the following error messages:

  • Looking for active bootloader… [ERROR]
    There is not an active bootloader in the module.
  • Resetting and entering bootloader… [ERROR]
    There is not an active bootloader in the module.

It prompts me to push the reset button when I try to recover the device, but when I do, nothing happens. So I press close and then it throws the error messages. I’m not really sure why my modules are all having problems now since I wasn’t having this problem before. Here’s a screenshot of the firmware I try to recover to:

Screenshot 2023-08-03 094828

These are what we call a Programmable module. What that means is that it comes with a secondary processor built into the XBee placed between the RF processor and the modules Data lines. Think of it as a combined Arduino and XBee all in one.

What you really are looking for is the Non Programmable version of the product. That part number would be XBP9B-DMST-002. Notice the -002 as the B in that place indicates it as a Programmable module.

Okay, so are the XBees I’m using supposed to be used with XCTU at all, or are they meant for a different software?

They can be used with XCTU. But you need to load an application on the secondary processor first.

apologies for bringing back this old thread, but ive encountered precisely the same issue beginning last night.

I have the same programmable module as the OP as my receiver and a non-programmable one as my transmitter. im trying to read serial data out as its transmitted and it was working flawlessly until last night, when it stopped functioning for seemingly no reason. it will however begin receiving if i connect to it with XCTU, but stops if i reset it briefly. upon connecting to it, the “R” icon on the module list isnt present even though both CE and SM are set to 0. I reflashed the firmware and that didnt seem to change the behavior at all. would anyone know what could possibly explain this change in behavior of this module?

The Programmable module has a secondary processor between the RF processor and the modules pins. You will need to write and port over an application to this secondary processor for any data to be sent/received by the RF processor.

Does this application need to do anything specific like directly passing the data from the rf input to the xbee Dout? or does the xbee simply need there to be something on the secondary processor; for it to not be empty.

i’m just mainly confused why it would start needing this application so suddenly, as i was using the programmable module to receive serial data in transparent mode for the entire week before it started behaving strangely, as it is now. the only thing that changed from my transmission test where it was working to afterwards when it stopped working was that i used a usb adapter to connect it to a different usb port on my pc than the one i had been using before. that’s the singular thing i can identify as having changed the receiver’s behavior.

thanks for your advice

I suspect the default application is no longer running or it is not detecting the baud rate you need.

Could it be possible that the board you are working under does not have the flow control lines connected? If I recall, the sample transparent app uses the follow control lines to enable it or help detect the UART is being used.

if there originally was a default application installed on it, that explanation makes a lot sense. is it possible to write the default application back to the secondary processor?

i have it connected with a usb adapter made for the xbee (this one in particular). i have all of the serial communication settings set to default except for packetization timeout, which is set to 0. the programmable module is only acting as a receiver for telemetry, so it’s transmitting nothing.

You can try looking in XBee®-PRO 900HP and XSC RF Modules User Guide

But if you are not able to find any directions in the links in that manual for this function, you would need to use a board that has the needed headers on it as that board does not. You would want one like Interface board schematic | Digi International

Sorry for reviving this. I have also mistakenly bought two XBP9B-DMSTB002 radios.

Is there an application already made that will make it act in transparent mode?

I have the radios each connected to a Teensy 4.1 with a corresponding sending and receiving program over serial. Neither are receiving data however if I connect them both to XCTU, they can both send and receive packets.

No the Programmable modules do not come with an application on it that would allow it to act as a transparent radio.