- Purpose
- Recommendations
- Update possibilities
- Update via USB
- Use the browser
- Flash Layout Information
- Issues, Ideas And Bugs
- License
- Contribution
The software can be uploaded/updated to the development board in 4 different ways. Not all of them can be used in any case. Take a look to the recommendations which variant might be the best for you.
The recommeded way how to program the software to the board depends on the skill level, as well as the available toolchain. Hopefully it helps you to choose the right one.
Use Case | Recommended To Use |
---|---|
Brand new development board, with only the preinstalled software on it. | Windows: Espressif Flash Download Tool Linux: esptool |
A development board already used by you. | Windows: Espressif Flash Download Tool Linux: esptool |
Pixelix is already running on the development board. Its webinterface is accessible. | Browser |
Use Case | Recommended To Use |
---|---|
Development board, not running Pixelix and you don't like to install VSCode and PlatformIO. | Windows: Espressif Flash Download Tool Linux: esptool |
Development board, not running Pixelix and you like to go the developers way. | VSCode and PlatformIO |
You like to develop a plugin or change code for a pull request. | VSCode and PlatformIO |
Pixelix is already running on the development board. | Browser |
- Download binaries (
Pixelix-v6.0.0.zip
) from the latest release. - Unzip to a local folder.
- Download the Espressif Flash Download Tool.
- Unzip to a local folder.
- Connect your development board with the PC.
- Start the Espressif Flash Download Tool with the executable
flash_download_tool_<version>.exe
. - Choose ChipType, depended on the development board you have.
- Choose WorkMode "Develop".
- Choose LoadMode "UART".
- Click on OK.
- Select binaries in the order and with the addresses of the flash layout table.
- Choose SPI SPPED: 40 MHz
- Choose SPI MODE:
- esp32: DIO
- esp32-s3: QIO
- Choose COM, e.g. COM4 which depends how the virtual COM port was mounted for the plugged in development board.
- Start flashing by clicking on START in the DownloadPanel 1.
- The state will change from IDLE to SYNC.
- Keep BOOT button on the development board pressed, until the state changes to DOWNLOAD.
- Now wait until state changes to FINISH.
- Its complete, close the tool.
- Update system packages:
sudo apt-get update
- Install python toolchain:
sudo apt-get install python3-pip
- Verify successful installation:
pip3 --version
- Install esptool:
sudo pip3 install esptool
- Download and install latest Python version.
- During the installation ensure that Python will be set on the path.
- Install esptool:
pip install esptool
- Verify successful esptool installation:
esptool --version
- Erase flash:
esptool -c <chip-type> -p <port> erase_flash
- Note: Replace <chip-type> with the chip type of your development board, e.g. esp32. Replace <port> with the serial port the development board is connected too, e.g.
COM4
on Windows or/dev/ttyUSB0
on Linux.
- Note: Replace <chip-type> with the chip type of your development board, e.g. esp32. Replace <port> with the serial port the development board is connected too, e.g.
- After the "Connecting" message appears, keep BOOT button on the development board pressed until procedure starts.
- Write binaries to flash and choose the addresses from the flash layout table:
esptool -p <port> write_flash --flash_mode <spi-mode> --flash_size <flash-size> <bootloader-address> bootloader.bin <partitions-address> partitions.bin <firmware-address> firmware.bin <littlefs-address> littlefs.bin
- Replace <port> with the serial port the development board is connected too, e.g.
COM4
on Windows or/dev/ttyUSB0
on Linux. - Use DIO for <spi-mode> in case of esp32, except esp32-s3 use QIO.
- Replace <port> with the serial port the development board is connected too, e.g.
If your board is not available out of the box, have a look for the supported boards by platformio. Copy a board configuration block in the platformio.ini
and overwrite the board configuration (board = ...
) by using the right board id from supported boards by platformio.
The update consists of two parts:
- The software.
- The filesystem.
Steps:
- Load workspace in VSCode.
- Change to PlatformIO toolbar (click on the head of the ant in the left column).
- Software:
- Project Tasks -> env:
<choose-your-board>
-> General -> Build - Project Tasks -> env:
<choose-your-board>
-> General -> Upload
- Project Tasks -> env:
- Filesystem:
- Project Tasks -> env:
<choose-your-board>
-> Platform -> Build Filesystem Image - Project Tasks -> env:
<choose-your-board>
-> Platform -> Upload Filesystem Image
- Project Tasks -> env:
Example:
Note: Sometimes it happens that the Platform sub-menu in the PlatformIO Project Tasks is missing. In this case restart VSCode and it should appear.
Preconditions:
- PIXELIX runs already on the target.
Steps:
- Build the software via Project Tasks -> General -> Build All
- Build the filesystem via Project Tasks -> env:
<choose-your-board>
-> Platform -> Build File System Image. - Now in the
.pio/build/<choose-your-board>
folder there are two important files:- The software for the device:
firmware.bin
- The prebuilt filesystem for the device:
littlefs.bin
(orspiffs.bin
for Pixelix < 6.x.x)
- The software for the device:
- Open browser add enter ip address of the device.
- Jump to Update site.
- Select firmware binary (
firmware.bin
) or filesystem binary (spiffs.bin
/littlefs.bin
) and click on upload button. Since Pixelix v6.x its possible to update the firmware and filesystem at once. Multi-select both binaries in this case.
Binary | Address (hex) |
---|---|
bootloader.bin | 0x1000 |
partitions.bin | 0x8000 |
firmware.bin | 0x10000 (ota_0) |
littlefs.bin | see filesystem table |
Binary | Address (hex) |
---|---|
bootloader.bin | 0x0000 |
partitions.bin | 0x8000 |
firmware.bin | 0x10000 (ota_0) |
littlefs.bin | see filesystem table |
Development Board | Flash size in MByte | Address (hex) of littlefs.bin | Partition table |
---|---|---|---|
adafruit_feather_esp32_v2 | 8 | 0x670000 | default_8MB.csv |
adafruit_matrixportal_s3 | 8 | 0x450000 | partitions-8MB-tinyuf2.csv |
az-delivery-devkit-v4 | 4 | 0x2d0000 | custom_4MB_no_coredump.csv |
esp32doit-devkit-v1 | 4 | 0x2d0000 | custom_4MB_no_coredump.csv |
esp32-s3-devkitc-1-n16r8v | 16 | 0xc90000 | default_16MB.csv |
esp32-nodemcu | 4 | 0x2d0000 | custom_4MB_no_coredump.csv |
lilygo-ttgo-t-display | 8 | 0x670000 | default_8MB.csv |
lilygo-t-display-s3 | 16 | 0xc90000 | default_16MB.csv |
m5stack_core | 16 | 0xc90000 | default_16MB.csv |
ulanzi-tc001 | 4 | 0x2d0000 | custom_4MB_no_coredump.csv |
wemos_lolin_s2_mini | 4 | 0x2d0000 | custom_4MB_no_coredump.csv |
If you have further ideas or you found some bugs, great! Create a issue or if you are able and willing to fix it by yourself, clone the repository and create a pull request.
The whole source code is published under the MIT license. Consider the different licenses of the used third party libraries too!
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, shall be licensed as above, without any additional terms or conditions.