Skip to main content

Firmware

info

If you purchased a Babble PCB (by itself, as part of the Base Kit, or the Supporter Kit) you do NOT need to follow the directions below IF YOU ARE USING IT IN WIRED MODE.

The following instructions are for users who have assembled their own hardware or people who wish to use the wireless mode of their Babble Kit.

Setup

Now that you've assembled your DIY Babble Tracker, you need to flash the firmware for it. This guide uses the wired/wireless wroom setup, although the setup process is similar for other boards.

info

At present moment wireless and wired firmware can only be used mutually exclusively, IE you can't switch them out on the fly.

Step 1

In order to flash your firmware, you'll need a copy of VSCode.

Step 2

Once VSCode has installed, you'll need to download the platformio-ide extension. You can get it from this link or by searching for it in VSCode's extension tab.

warning

In testing, sister projects like VSCodium do not support platformio-ide. If you can find a workaround for this let us know!

Step 3

Download/Clone the OpenIrirs repo from EyeTrackVR's Github.

Step 4

Open the OpenIris repo inside of VSCode. You may get a prompt to open to an ESP workspace, if you do click on it! You should now see something along the lines of this:

Step 5

At this point, click on the platformio-ide extension on the left toolbar. It's the icon with a bug!

At the bottom, you'll see an env: field followed by the firmware to build and upload. You must select the env appropriate to both your board type and wired/wireless type.

For a wroom board:

  • env:Babble_USB-wrooms-s3 for wired
  • env:Babble-wrooms-s3 for wireless

For Xiao Sense S3:

  • env:xiaosenses3_USB_release for wired
  • env:xiaosenses3_release for wireless

Other supported boards will appear in the selector in wired/wireless variants. Make sure you select the appropriate env for your board.

If flashing wireless firmware, you'll need to set your wifi's ssid, password and mdnsname.

You can change these under the user_config.ini file.

Where the mdnsname corresponds to the name of the device on the network. IE, a value of babbletracker would show up as http://babbletracker.local.

Platformio-ide will then download all the needed dependencies for your selected firmware. This might take a minute!

Step 6

Now, get ready to plug in your device. You'll need to put it in Boot Mode to write firmware to it. To do this, hold down the boot mode button on your board as you plug it in. You'll feel a click as the button presses in and out. On the wroom board, the button is pictured here:

Once you've plugged in the device, you can release this button.

Step 7

Once the above download has completed you're ready for upload! Click on the right-arrow button on the bottom ribbon, between the check mark and trash button. You'll see terminal output during the upload, if there are any errors or if the upload was successful.

Step 8

To use your device, unplug it and plug it back in again to get it out of boot mode. It should work now!

Troubleshooting

Step 1

To pull logs from your device, first download EyeTrackVR's firmware flashing tool from their Github.

Before moving onto the next steps, make sure your device is plugged in and/or connected (non-boot mode this time).

Step 2

Open EyeTrackVR's firmware flashing tool. Select any firmware here, it doesn't matter. Just go to the next page.

If prompted for wifi, just enter anything to move on. You don't need to deal with this either.

Step 3

Select your device on the corresponding COM port. Then, click on the left arrow next to the "Downloading logs..." button. Or you can download the logs and look at them in the text editor of your choice.

For more information on how to use EyeTrackVR's firmware flashing tool, please refer to their documentation.