Skip to content

Releases: adafruit/circuitpython

CircuitPython 9.1.0

10 Jul 17:12
937cfa6
Compare
Choose a tag to compare

This is CircuitPython 9.1.0, the latest minor revision of CircuitPython, and is a new stable release.

WARNING for nRF52 boards only: If your board has an nRF52 UF2 bootloader whose version is before 0.6.1, you will not be able to load CircuitPython 8.2.0 and later, due to increased size of the firmware. See these instructions for updating your bootloader.

Notable changes since 9.0.0

Incompatibility warnings

  • API changes to floppyio.
  • String values in settings.toml must be quoted.

Audio

  • RP2040 I2SOut supports BLCK and LRCLK in either order.
  • ESP32-S3 supports audiomp3.
  • audiomp3 supports streaming from HTTP servers.

Bluetooth

  • BLE GATT server support on Espressif.
  • Pairing and bonding support on Espressif.

Built-in modules

  • Enhance collections.deque functionality.
  • Add keypad_demux.DemuxKeyMatrix: use multiplexer for one side of a keypad matrix.
  • Add integration-based debouncing to keypad.
  • supervisor.Runtime.serial_bytes_available now returns a count instead of a bool.
  • Incompatible change: floppyio improvements, including API changes.
  • Espressif: microcontroller.cpu.frequency is settable.

Graphics

  • fourwire.FourWire: chip_select pin is now optional.
  • picodvi now supports 640x240 and 800x240 resolutions.
  • Enable _eve on Espressif boards with more than 4MB flash.

Internal

  • Espressif: update to ESP-IDF v5.2.2.
  • Espressif: Change task-switching quantum to 1 millisecond from 10 milliseconds.

Networking

  • Implement ssl module for anything that provides socket.
  • Add stream protocol support to SSLSocket.

Ports

  • New port for renode hardware simulator.

Power

  • Enable deep sleep on all supported Espressif chips.

Supervisor

  • String values in settings.toml must be quoted.

USB

  • max3421e USB host support.
  • Allow user-specified names for usb_midi interfaces and jacks.

Download from circuitpython.org

Firmware downloads are available from the downloads page on circuitpython.org. The site makes it easy to select the correct file and language for your board.

Installation

To install follow the instructions in the Welcome to CircuitPython! guide. To install the latest libraries, see this page in that guide.

Try the latest version of the Mu editor for creating and editing your CircuitPython programs and for easy access to the CircuitPython serial connection (the REPL).

Documentation

Documentation is available in readthedocs.io.

Port status

CircuitPython has a number of "ports" that are the core implementations for different microcontroller families. Stability varies on a per-port basis. As of this release, these ports are consider stable (but see Known Issues below):

  • atmel-samd: Microchip SAMD21, SAMx5x
  • cxd56: Sony Spresense
  • espressif: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C2, ESP32-C3, ESP32-C6
  • nordic: Nordic nRF52840, nRF52833
  • raspberrypi: Raspberry Pi RP2040
  • stm: ST STM32F4 chip family

These ports are considered alpha and will have bugs and missing functionality:

  • broadcom: Raspberry Pi boards such as RPi 4, RPi Zero 2W
  • litex: fomu
  • mimxrt10xx: NXP i.MX RT10xxx
  • renode: hardware simulator
  • silabs: Silicon Labs MG24 family
  • stm: ST non-STM32F4 chip families

Changes since 9.1.0-rc.0

This release is a relabeling of 9.1.0-rc.0 and is otherwise identical to that release.

Known issues

Thanks

Thank you to all who used, tested, and contributed since 9.1.0-beta.4, including the contributors above, and many others on GitHub and Discord. Join us on the Discord chat to collaborate.

CircuitPython 9.1.0-rc.0

09 Jul 19:49
937cfa6
Compare
Choose a tag to compare
Pre-release

This is CircuitPython 9.1.0-rc.0, a release candidate for 9.1.0 final. This release is believed to be stable, and is meant for testing before the final release of 9.1.0.

WARNING for nRF52 boards only: If your board has an nRF52 UF2 bootloader whose version is before 0.6.1, you will not be able to load CircuitPython 8.2.0 and later, due to increased size of the firmware. See these instructions for updating your bootloader.

Notable changes since 9.0.0

Incompatibility warnings

  • API changes to floppyio.
  • String values in settings.toml must be quoted.

Audio

  • RP2040 I2SOut supports BLCK and LRCLK in either order.
  • ESP32-S3 supports audiomp3.
  • audiomp3 supports streaming from HTTP servers.

Bluetooth

  • BLE GATT server support on Espressif.
  • Pairing and bonding support on Espressif.

Built-in modules

  • Enhance collections.deque functionality.
  • Add keypad_demux.DemuxKeyMatrix: use multiplexer for one side of a keypad matrix.
  • Add integration-based debouncing to keypad.
  • supervisor.Runtime.serial_bytes_available now returns a count instead of a bool.
  • Incompatible change: floppyio improvements, including API changes.
  • Espressif: microcontroller.cpu.frequency is settable.

Graphics

  • fourwire.FourWire: chip_select pin is now optional.
  • picodvi now supports 640x240 and 800x240 resolutions.
  • Enable _eve on Espressif boards with more than 4MB flash.

Internal

  • Espressif: update to ESP-IDF v5.2.2.
  • Espressif: Change task-switching quantum to 1 millisecond from 10 milliseconds.

Networking

  • Implement ssl module for anything that provides socket.
  • Add stream protocol support to SSLSocket.

Ports

  • New port for renode hardware simulator.

Power

  • Enable deep sleep on all supported Espressif chips.

Supervisor

  • String values in settings.toml must be quoted.

USB

  • max3421e USB host support.
  • Allow user-specified names for usb_midi interfaces and jacks.

Download from circuitpython.org

Firmware downloads are available from the downloads page on circuitpython.org. The site makes it easy to select the correct file and language for your board.

Installation

To install follow the instructions in the Welcome to CircuitPython! guide. To install the latest libraries, see this page in that guide.

Try the latest version of the Mu editor for creating and editing your CircuitPython programs and for easy access to the CircuitPython serial connection (the REPL).

Documentation

Documentation is available in readthedocs.io.

Port status

CircuitPython has a number of "ports" that are the core implementations for different microcontroller families. Stability varies on a per-port basis. As of this release, these ports are consider stable (but see Known Issues below):

  • atmel-samd: Microchip SAMD21, SAMx5x
  • cxd56: Sony Spresense
  • espressif: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C2, ESP32-C3, ESP32-C6
  • nordic: Nordic nRF52840, nRF52833
  • raspberrypi: Raspberry Pi RP2040
  • stm: ST STM32F4 chip family

These ports are considered alpha and will have bugs and missing functionality:

  • broadcom: Raspberry Pi boards such as RPi 4, RPi Zero 2W
  • litex: fomu
  • mimxrt10xx: NXP i.MX RT10xxx
  • renode: hardware simulator
  • silabs: Silicon Labs MG24 family
  • stm: ST non-STM32F4 chip families

Changes since 9.1.0-beta.4

Fixes and enhancements

Port and board-specific changes

Broadcom

Espressif

  • Add ringbuf atomicity for USB/JTAG serial operations. #9409. Thanks @dhalbert.
  • Espressif: microcontroller.cpu.frequency is now settable. #9432. Thanks @Sola85.

i.MX

nordic

renode

RP2040

SAMx

SiLabs

Spresense

STM

Individual boards

Documentation changes

Build and infrastructure changes

Translation additions and improvements

  • Thanks for translations:

New boards since 9.1.0-beta.4

Known issues

Thanks

Thank you to all who used, tested, and contributed since 9.1.0-beta.4, including the contributors above, and many others on GitHub and Discord. Join us on the Discord chat to collaborate.

CircuitPython 9.1.0-beta.4

03 Jul 20:07
1493104
Compare
Choose a tag to compare
Pre-release

This is CircuitPython 9.1.0-beta.4, a beta for CircuitPython 9.1.0, and is a new unstable release. This release has known bugs that will be addressed before 9.1.0 final.

WARNING for nRF52 boards only: If your board has an nRF52 UF2 bootloader whose version is before 0.6.1, you will not be able to load CircuitPython 8.2.0 and later, due to increased size of the firmware. See these instructions for updating your bootloader.

Notable changes since 9.0.0

Incompatibility warnings

  • API changes to floppyio.
  • String values in settings.toml must be quoted.

Audio

  • RP2040 I2SOut supports BLCK and LRCLK in either order.
  • ESP32-S3 supports audiomp3.
  • audiomp3 supports streaming from HTTP servers.

Bluetooth

  • BLE GATT server support on Espressif.
  • Pairing and bonding support on Espressif.

Built-in modules

  • Enhance collections.deque functionality.
  • Add keypad_demux.DemuxKeyMatrix: use multiplexer for one side of a keypad matrix.
  • Add integration-based debouncing to keypad.
  • supervisor.Runtime.serial_bytes_available now returns a count instead of a bool.
  • Incompatible change: floppyio improvements, including API changes.

Graphics

  • fourwire.FourWire: chip_select pin is now optional.
  • picodvi now supports 640x240 and 800x240 resolutions.
  • Enable _eve on Espressif boards with more than 4MB flash.

Internal

  • Espressif: update to ESP-IDF v5.2.2.
  • Espressif: Change task-switching quantum to 1 millisecond from 10 milliseconds.

Networking

  • Implement ssl module for anything that provides socket.
  • Add stream protocol support to SSLSocket.

Ports

  • New port for renode hardware simulator.

Power

  • Enable deep sleep on all supported Espressif chips.

Supervisor

  • String values in settings.toml must be quoted.

USB

  • max3421e USB host support.
  • Allow user-specified names for usb_midi interfaces and jacks.

Download from circuitpython.org

Firmware downloads are available from the downloads page on circuitpython.org. The site makes it easy to select the correct file and language for your board.

Installation

To install follow the instructions in the Welcome to CircuitPython! guide. To install the latest libraries, see this page in that guide.

Try the latest version of the Mu editor for creating and editing your CircuitPython programs and for easy access to the CircuitPython serial connection (the REPL).

Documentation

Documentation is available in readthedocs.io.

Port status

CircuitPython has a number of "ports" that are the core implementations for different microcontroller families. Stability varies on a per-port basis. As of this release, these ports are consider stable (but see Known Issues below):

  • atmel-samd: Microchip SAMD21, SAMx5x
  • cxd56: Sony Spresense
  • espressif: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C2, ESP32-C3, ESP32-C6
  • nordic: Nordic nRF52840, nRF52833
  • raspberrypi: Raspberry Pi RP2040
  • stm: ST STM32F4 chip family

These ports are considered alpha and will have bugs and missing functionality:

  • broadcom: Raspberry Pi boards such as RPi 4, RPi Zero 2W
  • litex: fomu
  • mimxrt10xx: NXP i.MX RT10xxx
  • renode: hardware simulator
  • silabs: Silicon Labs MG24 family
  • stm: ST non-STM32F4 chip families

Changes since 9.1.0-beta.3

Fixes and enhancements

Port and board-specific changes

Broadcom

Espressif

i.MX

nordic

renode

RP2040

SAMx

SiLabs

Spresense

STM

Individual boards

Documentation changes

Build and infrastructure changes

Translation additions and improvements

New boards since 9.1.0-beta.3

Known issues

Thanks

Thank you to all who used, tested, and contributed since 9.1.0-beta.3, including the contributors above, and many others on GitHub and Discord. Join us on the Discord chat to collaborate.

CircuitPython 9.1.0-beta.3

22 May 19:49
5339e96
Compare
Choose a tag to compare
Pre-release

This is CircuitPython 9.1.0-beta.3, a beta for CircuitPython 9.1.0, and is a new unstable release. This release has known bugs that will be addressed before 9.1.0 final.

WARNING for nRF52 boards only: If your board has an nRF52 UF2 bootloader whose version is before 0.6.1, you will not be able to load CircuitPython 8.2.0 and later, due to increased size of the firmware. See these instructions for updating your bootloader.

Notable changes since 9.0.0

Incompatibility warnings

  • API changes to floppyio.
  • String values in settings.toml must be quoted.

Audio

  • RP2040 I2SOut supports BLCK and LRCLK in either order.
  • ESP32-S3 supports audiomp3.

Bluetooth

  • Initial implementation of BLE GATT server support on Espressif chips. Pairing/bonding is not yet implemented.

Built-in modules

  • Enhance collections.deque functionality.
  • Add keypad_demux.DemuxKeyMatrix: use multiplexer for one side of a keypad matrix.
  • Add integration-based debouncing to keypad.
  • supervisor.Runtime.serial_bytes_available now returns a count instead of a bool.
  • Incompatible change: floppyio improvements, including API changes.

Graphics

  • fourwire.FourWire: chip_select pin is now optional.
  • picodvi now supports 640x240 and 800x240 resolutions.

Internal

  • Espressif: update to ESP-IDF v5.2.1.
  • Espressif: Change task-switching quantum to 1 millisecond from 10 milliseconds.

Networking

  • Implement ssl module for anything that provides socket.

Ports

  • New port for renode hardware simulator.

Supervisor

  • String values in settings.toml must be quoted.

USB

  • max3421e USB host support.
  • Allow user-specified names for usb_midi interfaces and jacks.

Download from circuitpython.org

Firmware downloads are available from the downloads page on circuitpython.org. The site makes it easy to select the correct file and language for your board.

Installation

To install follow the instructions in the Welcome to CircuitPython! guide. To install the latest libraries, see this page in that guide.

Try the latest version of the Mu editor for creating and editing your CircuitPython programs and for easy access to the CircuitPython serial connection (the REPL).

Documentation

Documentation is available in readthedocs.io.

Port status

CircuitPython has a number of "ports" that are the core implementations for different microcontroller families. Stability varies on a per-port basis. As of this release, these ports are consider stable (but see Known Issues below):

  • atmel-samd: Microchip SAMD21, SAMx5x
  • cxd56: Sony Spresense
  • espressif: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C2, ESP32-C3, ESP32-C6
  • nordic: Nordic nRF52840, nRF52833
  • raspberrypi: Raspberry Pi RP2040
  • stm: ST STM32F4 chip family

These ports are considered alpha and will have bugs and missing functionality:

  • broadcom: Raspberry Pi boards such as RPi 4, RPi Zero 2W
  • litex: fomu
  • mimxrt10xx: NXP i.MX RT10xxx
  • renode: hardware simulator
  • silabs: Silicon Labs MG24 family
  • stm: ST non-STM32F4 chip families

Changes since 9.1.0-beta.2

Fixes and enhancements

  • Update frozen libraries. In particular, fixes an issue introduced in 9.1.0-beta.2 with the adafruit_esp32spi library. #9271. Thanks @dhalbert.
  • Fix exception chaining for non-built-in exceptions #9269, #9266. Thanks @jepler.
  • Update TinyUSB; includes USB host fixes. #9252. Thanks @todbot.
  • Calculate synthio.LFO.value at construction. #9247. Thanks @jepler.

Port and board-specific changes

Broadcom

Espressif

  • Initial implementation of BLE GATT server support on Espressif chips. Pairing/bonding is not yet implemented. #9222. Thanks @tannewt.

i.MX

nordic

renode

RP2040

  • Pico W: set socket connected status after UDP and raw connect. #9251. Thanks @jepler.

SAMx

SiLabs

Spresense

STM

Individual boards

  • Espressif ESP2-S3-DevKitM-1: add GPIO34 pin. #9259. Thanks @fetsnleds.
  • M5Stack CoreS3: enable on-board camera and microphone. #9255. Thanks @CDarius.

Documentation changes

Build and infrastructure changes

  • Use raw strings for Python regular expressions. #9267. Thanks @dhalbert.
  • Replace all uses of STATIC with static in CircuitPython-only C source files. #9263. Thanks @dhalbert.
  • Replace include guards with #pragma once in CircuitPython-only C header files. #9262, #9260. Thanks @dhalbert.
  • Mark all CircuitPython-only C sources files as being part of the CircuitPython project. Change to use SPDX for copyright lines and licenses for these files. Remove in-line MIT license text. Add headers to files that did not have them. #9257. Thanks @dhalbert.

Translation additions and improvements

New boards since 9.1.0-beta.2

  • Bradán Lane STUDIO Explorer Badge. #9256. Thanks @bradanlane.
  • Freenove ESP32-WROVER-DEV-CAM (and other similar generic boards). #9233. Thanks @gitcnd.

Known issues

Thanks

Thank you to all who used, tested, and contributed since 9.1.0-beta.2, including the contributors above, and many others on GitHub and Discord. Join us on the Discord chat to collaborate.

CircuitPython 9.0.5

22 May 13:59
1a3c471
Compare
Choose a tag to compare

This is CircuitPython 9.0.5, the latest bugfix release of CircuitPython, and is a new stable release.

WARNING for nRF52 boards only: If your board has an nRF52 UF2 bootloader whose version is before 0.6.1, you will not be able to load CircuitPython 8.2.0 and later, due to increased size of the firmware. See these instructions for updating your bootloader.

For notable changes to 9.0.0 since 8.x.x, see the 9.0.0 release notes.

Download from circuitpython.org

Firmware downloads are available from the downloads page on circuitpython.org. The site makes it easy to select the correct file and language for your board.

Installation

To install follow the instructions in the Welcome to CircuitPython! guide. To install the latest libraries, see this page in that guide.

Try the latest version of the Mu editor for creating and editing your CircuitPython programs and for easy access to the CircuitPython serial connection (the REPL).

Documentation

Documentation is available in readthedocs.io.

Port status

CircuitPython has a number of "ports" that are the core implementations for different microcontroller families. Stability varies on a per-port basis. As of this release, these ports are consider stable (but see Known Issues below):

  • atmel-samd: Microchip SAMD21, SAMx5x
  • cxd56: Sony Spresense
  • espressif: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C3, ESP32-C6
  • nrf: Nordic nRF52840, nRF52833
  • raspberrypi: Raspberry Pi RP2040
  • stm: ST STM32F4 chip family

These ports are considered alpha and will have bugs and missing functionality:

  • broadcom: Raspberry Pi boards such as RPi 4, RPi Zero 2W
  • litex: fomu
  • mimxrt10xx: NXP i.MX RT10xxx
  • silabs: Silicon Labs MG24 family
  • stm: ST non-STM32F4 chip families

Changes since 9.0.4

Fixes and enhancements

  • Fix exception chaining for non-built-in exceptions. #9266. Thanks @jepler.

Port and board-specific changes

Broadcom

Espressif

i.MX

nRF

RP2040

SAMx

SiLabs

Spresense

STM

Individual boards

Documentation changes

Build and infrastructure changes

  • Fix local and ReadTheDocs documentation builds. #9185. Thanks @dhalbert.

Translation additions and improvements

New boards since 9.0.4

Known issues

Thanks

Thank you to all who used, tested, and contributed since 9.0.4, including the contributors above, and many others on GitHub and Discord. Join us on the Discord chat to collaborate.

CircuitPython 9.1.0-beta.2

15 May 20:08
7e57fa8
Compare
Choose a tag to compare
Pre-release

This is CircuitPython 9.1.0-beta.2, a beta for CircuitPython 9.1.0, and is a new unstable release. This release has known bugs that will be addressed before 9.1.0 final.

WARNING for nRF52 boards only: If your board has an nRF52 UF2 bootloader whose version is before 0.6.1, you will not be able to load CircuitPython 8.2.0 and later, due to increased size of the firmware. See these instructions for updating your bootloader.

Notable changes since 9.0.0

Incompatibility warnings

  • API changes to floppyio.
  • String values in settings.toml must be quoted.

Audio

  • RP2040 I2SOut supports BLCK and LRCLK in either order.
  • ESP32-S3 supports audiomp3.

Built-in modules

  • Enhance collections.deque functionality.
  • Add keypad_demux.DemuxKeyMatrix: use multiplexer for one side of a keypad matrix.
  • Add integration-based debouncing to keypad.
  • supervisor.Runtime.serial_bytes_available now returns a count instead of a bool.
  • Incompatible change: floppyio improvements, including API changes.

Graphics

  • fourwire.FourWire: chip_select pin is now optional.
  • picodvi now supports 640x240 and 800x240 resolutions.

Internal

  • Espressif: update to ESP-IDF v5.2.1.
  • Espressif: Change task-switching quantum to 1 millisecond from 10 milliseconds.

Networking

  • Implement ssl module for anything that provides socket.

Ports

  • New port for renode hardware simulator.

Supervisor

  • String values in settings.toml must be quoted.

USB

  • max3421e USB host support.
  • Allow user-specified names for usb_midi interfaces and jacks.

Download from circuitpython.org

Firmware downloads are available from the downloads page on circuitpython.org. The site makes it easy to select the correct file and language for your board.

Installation

To install follow the instructions in the Welcome to CircuitPython! guide. To install the latest libraries, see this page in that guide.

Try the latest version of the Mu editor for creating and editing your CircuitPython programs and for easy access to the CircuitPython serial connection (the REPL).

Documentation

Documentation is available in readthedocs.io.

Port status

CircuitPython has a number of "ports" that are the core implementations for different microcontroller families. Stability varies on a per-port basis. As of this release, these ports are consider stable (but see Known Issues below):

  • atmel-samd: Microchip SAMD21, SAMx5x
  • cxd56: Sony Spresense
  • espressif: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C3
  • nordic: Nordic nRF52840, nRF52833
  • raspberrypi: Raspberry Pi RP2040
  • stm: ST STM32F4 chip family

These ports are considered alpha and will have bugs and missing functionality:

  • broadcom: Raspberry Pi boards such as RPi 4, RPi Zero 2W
  • litex: fomu
  • mimxrt10xx: NXP i.MX RT10xxx
  • renode: hardware simulator
  • silabs: Silicon Labs MG24 family
  • stm: ST non-STM32F4 chip families

Changes since 9.1.0-beta.1

Fixes and enhancements

  • Update frozen libraries. #9250. Thanks @dhalbert.
  • Implement ssl module for anything that provides socket. #8954. Thanks @jepler.
  • Make sure the os.getcwd() is / after VM restart. #9224. Thanks @bill88t.

Port and board-specific changes

Broadcom

Espressif

  • Enable audiomp3 on ESP32-S3. #9218. Thanks @jepler.
  • Allow user-specified socket connect timeout. #9210. Thanks @dhalbert.
  • Use -Os for all 4MB builds, to save space. #9207. Thanks @tannewt.
  • Clear UART input buffer on creation, to avoid stray junk bytes. #9193. Thanks @dhalbert.

i.MX

nordic

renode

RP2040

SAMx

SiLabs

Spresense

STM

Individual boards

Documentation changes

Build and infrastructure changes

  • Add Adafruit_CircuitPython_Bitmap_Fonts to frozen libraries. #9202. Thanks @bradanlane.

Translation additions and improvements

New boards since 9.1.0-beta.1

Known issues

Thanks

Thank you to all who used, tested, and contributed since 9.1.0-beta.1, including the contributors above, and many others on GitHub and Discord. Join us on the Discord chat to collaborate.

CircuitPython 9.1.0-beta.1

19 Apr 01:16
ab69d6b
Compare
Choose a tag to compare
Pre-release

This is CircuitPython 9.1.0-beta.1, a beta for CircuitPython 9.1.0, and is a new unstable release. This release has known bugs that will be addressed before 9.1.0 final.

WARNING for nRF52 boards only: If your board has an nRF52 UF2 bootloader whose version is before 0.6.1, you will not be able to load CircuitPython 8.2.0 and later, due to increased size of the firmware. See these instructions for updating your bootloader.

Notable changes since 9.0.0

Incompatibility warnings

  • API changes to floppyio.
  • String values in settings.toml must be quoted.

Audio

  • RP2040 I2SOut supports BLCK and LRCLK in either order.

Built-in modules

  • Enhance collections.deque functionality.
  • Add keypad_demux.DemuxKeyMatrix: use multiplexer for one side of a keypad matrix.
  • Add integration-based debouncing to keypad.
  • supervisor.Runtime.serial_bytes_available now returns a count instead of a bool.
  • Incompatible change: floppyio improvements, including API changes.

Graphics

  • fourwire.FourWire: chip_select pin is now optional.
  • picodvi now supports 640x240 and 800x240 resolutions.

Internal

  • Espressif: update to ESP-IDF v5.2.1.
  • Espressif: Change task-switching quantum to 1 millisecond from 10 milliseconds.

Supervisor

  • String values in settings.toml must be quoted.

USB

  • max3421e USB host support.
  • Allow user-specified names for usb_midi interfaces and jacks.

Download from circuitpython.org

Firmware downloads are available from the downloads page on circuitpython.org. The site makes it easy to select the correct file and language for your board.

Installation

To install follow the instructions in the Welcome to CircuitPython! guide. To install the latest libraries, see this page in that guide.

Try the latest version of the Mu editor for creating and editing your CircuitPython programs and for easy access to the CircuitPython serial connection (the REPL).

Documentation

Documentation is available in readthedocs.io.

Port status

CircuitPython has a number of "ports" that are the core implementations for different microcontroller families. Stability varies on a per-port basis. As of this release, these ports are consider stable (but see Known Issues below):

  • atmel-samd: Microchip SAMD21, SAMx5x
  • cxd56: Sony Spresense
  • espressif: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C3
  • nordic: Nordic nRF52840, nRF52833
  • raspberrypi: Raspberry Pi RP2040
  • stm: ST STM32F4 chip family

These ports are considered alpha and will have bugs and missing functionality:

  • broadcom: Raspberry Pi boards such as RPi 4, RPi Zero 2W
  • litex: fomu
  • mimxrt10xx: NXP i.MX RT10xxx
  • silabs: Silicon Labs MG24 family
  • stm: ST non-STM32F4 chip families

Changes since 9.1.0-beta.0

Fixes and enhancements

  • Update frozen libraries. #9188. Thanks @dhalbert.
  • External flash cache allocation crashed into safe mode when heap was too small. #9187, #9169. Thanks @dhalbert.
  • Avoid putting terminal escape sequences in boot_out.txt. #9181. Thanks @bill88t.
  • MAX3421E USB host support. #9164. Thanks @tannewt.
  • Enable bitmapfilter on boards where it will fit. #9156. Thanks @dhalbert.
  • Allow user-specified names for usb_midi interfaces and jacks. #9146. Thanks @brushmate.
  • supervisor.Runtime.serial_bytes_available now returns a count instead of a bool. #9141. Thanks @dhalbert
  • Correct EPaperDisplay.time_to_refresh. #9140. Thanks @elpekenin.
  • floppyio improvements, including API changes. #9135. Thanks @jepler.
  • Require strings to be quoted in settings.toml #9117. Thanks @jepler.
  • fourwire.FourWire: chip_select pin is now optional. #9106. Thanks @wee-noise-makers.

Port and board-specific changes

Broadcom

Espressif

  • Document Espressif AnalogIn limitations. #9137. Thanks @dhalbert.
  • Change task-switching quantum to 1 millisecond from 10 milliseconds. #9134. Thanks @dhalbert.
  • Handle new ESP-IDF v5.2.1 failure codes for WiFi connections. #9126. Thanks @dhalbert.

i.MX

nordic

RP2040

  • Disable picodvi and usb_host on boards that cannot use them. #9116. Thanks @bablokb.
  • picodvi now supports 640x240 and 800x240 resolutions. #9102. Thanks @jepler.

SAMx

SiLabs

Spresense

STM

Individual boards

Documentation changes

Build and infrastructure changes

Translation additions and improvements

  • Thanks for translations:

New boards since 9.1.0-beta.0

Known issues

Thanks

Thank you to all who used, tested, and contributed since 9.1.0-beta.0, including the contributors above, and many others on GitHub and Discord. Join us on the Discord chat to collaborate.

CircuitPython 9.0.4

16 Apr 17:31
29eeef9
Compare
Choose a tag to compare

This is CircuitPython 9.0.4, the latest bugfix release of CircuitPython, and is a new stable release.

WARNING for nRF52 boards only: If your board has an nRF52 UF2 bootloader whose version is before 0.6.1, you will not be able to load CircuitPython 8.2.0 and later, due to increased size of the firmware. See these instructions for updating your bootloader.

For notable changes to 9.0.0 since 8.x.x, see the 9.0.0 release notes.

Download from circuitpython.org

Firmware downloads are available from the downloads page on circuitpython.org. The site makes it easy to select the correct file and language for your board.

Installation

To install follow the instructions in the Welcome to CircuitPython! guide. To install the latest libraries, see this page in that guide.

Try the latest version of the Mu editor for creating and editing your CircuitPython programs and for easy access to the CircuitPython serial connection (the REPL).

Documentation

Documentation is available in readthedocs.io.

Port status

CircuitPython has a number of "ports" that are the core implementations for different microcontroller families. Stability varies on a per-port basis. As of this release, these ports are consider stable (but see Known Issues below):

  • atmel-samd: Microchip SAMD21, SAMx5x
  • cxd56: Sony Spresense
  • espressif: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C3
  • nrf: Nordic nRF52840, nRF52833
  • raspberrypi: Raspberry Pi RP2040
  • stm: ST STM32F4 chip family

These ports are considered alpha and will have bugs and missing functionality:

  • broadcom: Raspberry Pi boards such as RPi 4, RPi Zero 2W
  • litex: fomu
  • mimxrt10xx: NXP i.MX RT10xxx
  • silabs: Silicon Labs MG24 family
  • stm: ST non-STM32F4 chip families

Changes since 9.0.3

Fixes and enhancements

  • External flash cache allocation crashed into safe mode when heap was too small. #9169. Thanks @dhalbert.

Port and board-specific changes

Broadcom

Espressif

i.MX

nRF

  • Move state word that survives reset to avoid its being overwritten by bootloader. #9168, #9160. Thanks @tannewt.
  • Fix regression from 9.0.3 treating small internal-only negative ADC values as large positive values. #9161. Thanks @dhalbert.
  • Allow reuse of AnalogIn pins as other types of pins. #9161. Thanks @dhalbert.

RP2040

SAMx

SiLabs

Spresense

STM

Individual boards

Documentation changes

Build and infrastructure changes

Translation additions and improvements

New boards since 9.0.3

Known issues

Thanks

Thank you to all who used, tested, and contributed since 9.0.3, including the contributors above, and many others on GitHub and Discord. Join us on the Discord chat to collaborate.

CircuitPython 9.0.3

04 Apr 13:47
0ef433b
Compare
Choose a tag to compare

This is CircuitPython 9.0.3, the latest bugfix release of CircuitPython, and is a new stable release.

The only changes to 9.0.3 from 9.0.2 are a fix for AnalogIn on Nordic nRF boards, and the addition of the Waveshare RP2040-GEEK board.

WARNING for nRF52 boards only: If your board has an nRF52 UF2 bootloader whose version is before 0.6.1, you will not be able to load CircuitPython 8.2.0 and later, due to increased size of the firmware. See these instructions for updating your bootloader.

For notable changes to 9.0.0 since 8.x.x, see the 9.0.0 release notes.

Download from circuitpython.org

Firmware downloads are available from the downloads page on circuitpython.org. The site makes it easy to select the correct file and language for your board.

Installation

To install follow the instructions in the Welcome to CircuitPython! guide. To install the latest libraries, see this page in that guide.

Try the latest version of the Mu editor for creating and editing your CircuitPython programs and for easy access to the CircuitPython serial connection (the REPL).

Documentation

Documentation is available in readthedocs.io.

Port status

CircuitPython has a number of "ports" that are the core implementations for different microcontroller families. Stability varies on a per-port basis. As of this release, these ports are consider stable (but see Known Issues below):

  • atmel-samd: Microchip SAMD21, SAMx5x
  • cxd56: Sony Spresense
  • espressif: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C3
  • nrf: Nordic nRF52840, nRF52833
  • raspberrypi: Raspberry Pi RP2040
  • stm: ST STM32F4 chip family

These ports are considered alpha and will have bugs and missing functionality:

  • broadcom: Raspberry Pi boards such as RPi 4, RPi Zero 2W
  • litex: fomu
  • mimxrt10xx: NXP i.MX RT10xxx
  • silabs: Silicon Labs MG24 family
  • stm: ST non-STM32F4 chip families

Changes since 9.0.2

Fixes and enhancements

Port and board-specific changes

Broadcom

Espressif

i.MX

nRF

RP2040

SAMx

SiLabs

Spresense

STM

Individual boards

Documentation changes

Build and infrastructure changes

Translation additions and improvements

New boards since 9.0.2

Known issues

Thanks

Thank you to all who used, tested, and contributed since 9.0.2, including the contributors above, and many others on GitHub and Discord. Join us on the Discord chat to collaborate.

CircuitPython 9.1.0-beta.0

28 Mar 18:06
14eb3b1
Compare
Choose a tag to compare
Pre-release

This is CircuitPython 9.1.0-beta.0, a beta for CircuitPython 9.1.0, and is a new unstable release. This release has known bugs that will be addressed before 9.1.0 final.

WARNING for nRF52 boards only: If your board has an nRF52 UF2 bootloader whose version is before 0.6.1, you will not be able to load CircuitPython 8.2.0 and later, due to increased size of the firmware. See these instructions for updating your bootloader.

Notable changes since 9.0.0

Audio

  • RP2040 I2SOut supports BLCK and LRCLK in either order.

Built-in modules

  • Enhance collections.deque functionality.
  • Add keypad_demux.DemuxKeyMatrix: use multiplexer for one side of a keypad matrix.
  • Add integration-based debouncing to keypad.

Internal

  • Espressif: update to ESP-IDF v5.2.1.

Download from circuitpython.org

Firmware downloads are available from the downloads page on circuitpython.org. The site makes it easy to select the correct file and language for your board.

Installation

To install follow the instructions in the Welcome to CircuitPython! guide. To install the latest libraries, see this page in that guide.

Try the latest version of the Mu editor for creating and editing your CircuitPython programs and for easy access to the CircuitPython serial connection (the REPL).

Documentation

Documentation is available in readthedocs.io.

Port status

CircuitPython has a number of "ports" that are the core implementations for different microcontroller families. Stability varies on a per-port basis. As of this release, these ports are consider stable (but see Known Issues below):

  • atmel-samd: Microchip SAMD21, SAMx5x
  • cxd56: Sony Spresense
  • espressif: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C3
  • nrf: Nordic nRF52840, nRF52833
  • raspberrypi: Raspberry Pi RP2040
  • stm: ST STM32F4 chip family

These ports are considered alpha and will have bugs and missing functionality:

  • broadcom: Raspberry Pi boards such as RPi 4, RPi Zero 2W
  • litex: fomu
  • mimxrt10xx: NXP i.MX RT10xxx
  • silabs: Silicon Labs MG24 family
  • stm: ST non-STM32F4 chip families

Changes since 9.0.0

Fixes and enhancements

  • Turn off displayio warnings noting name changes since 8.x.x. #9100, #9096. Thanks @dhalbert.
  • Fix bitbangio.SPI idle polarity for polarity=1. #9075. Thanks @kbsriram.
  • Enhance collections.deque functionality. #9065. Thanks @SAK917.
  • Add keypad_demux.DemuxKeyMatrix: use multiplexer for one side of a keypad matrix. #9035. Thanks @CDarius.
  • Add integration-based debouncing to keypad. #8855. Thanks @xs5871.

Port and board-specific changes

Broadcom

Espressif

i.MX

nRF

RP2040

SAMx

SiLabs

Spresense

STM

Individual boards

Documentation changes

Build and infrastructure changes

  • Do not include PICODVI-related sources if CIRCUITPY_PICODVI = 0. #9099. Thanks @bablokb.
  • Fix compile error when CIRCUITPY_USB_HOST = 0. #9091. Thanks @bablokb.
  • Update GitHub codespaces devcontainers. #9068. Thanks @bablokb.
  • Rename ports/nrf to ports/nordic to avoid overlap with MicroPython. #9062. Thanks @dhalbert.

Translation additions and improvements

  • Thanks for translations:

New boards since 9.0.0

Known issues

Thanks

Thank you to all who used, tested, and contributed since 9.0.0, including the contributors above, and many others on GitHub and Discord. Join us on the Discord chat to collaborate.