Releases: adafruit/circuitpython
CircuitPython 9.0.4
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, SAMx5xcxd56
: Sony Spresenseespressif
: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C3nrf
: Nordic nRF52840, nRF52833raspberrypi
: Raspberry Pi RP2040stm
: 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 2Wlitex
: fomumimxrt10xx
: NXP i.MX RT10xxxsilabs
: Silicon Labs MG24 familystm
: 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
- See https://github.com/adafruit/circuitpython/issues for other issues, including issues still to be addressed for:
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
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, SAMx5xcxd56
: Sony Spresenseespressif
: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C3nrf
: Nordic nRF52840, nRF52833raspberrypi
: Raspberry Pi RP2040stm
: 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 2Wlitex
: fomumimxrt10xx
: NXP i.MX RT10xxxsilabs
: Silicon Labs MG24 familystm
: 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
- Waveshare RP2040-GEEK. #9090. Thanks @RetiredWizard.
Known issues
- See https://github.com/adafruit/circuitpython/issues for other issues, including issues still to be addressed for:
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
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
supportsBLCK
andLRCLK
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, SAMx5xcxd56
: Sony Spresenseespressif
: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C3nrf
: Nordic nRF52840, nRF52833raspberrypi
: Raspberry Pi RP2040stm
: 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 2Wlitex
: fomumimxrt10xx
: NXP i.MX RT10xxxsilabs
: Silicon Labs MG24 familystm
: 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 forpolarity=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
- Implement
Socket.setsockopt(SOL_SOCKET, SO_REUSEADDR)
for Pico W. #9100, #9084. Thanks @jepler. I2SOut
: supportBLCK
andLRCLK
in either order. #9097. Thanks @Fabien-Chouteau (@wee-noise-makers).
SAMx
SiLabs
Spresense
STM
Individual boards
- Adafruit ItsyBitsy ESP32: fix
board.NEOPIXEL
andboard.NEOPIXEL_POWER
pin assignments. #9100, #9087. Thanks @RetiredWizard. - Adafruit Trinkey SHT4x: fix
board.I2C()
pins. #9108, #9107. Thanks @dhalbert and @BlitzCityDIY.
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
toports/nordic
to avoid overlap with MicroPython. #9062. Thanks @dhalbert.
Translation additions and improvements
- Thanks for translations:
- @wtuemura (Portuguese - Brazil)
New boards since 9.0.0
- M5Stack CoreS3. #9093. Thanks @CDarius.
- RF.Guru MicroPico. #9095. Thanks @ure (@Guru-RF).
- Sunton ESP32-2432S028. #9092. Thanks @SeanTheITGuy.
- Waveshare ESP32-S3 GEEK. #9076. Thanks @kylefmohr.
Known issues
- See https://github.com/adafruit/circuitpython/issues for other issues, including issues still to be addressed for:
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.
CircuitPython 9.0.2
This is CircuitPython 9.0.2, the latest bugfix release of CircuitPython, and is a new stable release.
The only change to 9.0.2 from 9.0.1 is a fix for a pin error for the Adafruit SHT4x Trinkey board. You do not need to upgrade from 9.0.1 unless you are using this 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, SAMx5xcxd56
: Sony Spresenseespressif
: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C3nrf
: Nordic nRF52840, nRF52833raspberrypi
: Raspberry Pi RP2040stm
: 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 2Wlitex
: fomumimxrt10xx
: NXP i.MX RT10xxxsilabs
: Silicon Labs MG24 familystm
: ST non-STM32F4 chip families
Changes since 9.0.0
Fixes and enhancements
Port and board-specific changes
Broadcom
Espressif
i.MX
nRF
RP2040
SAMx
SiLabs
Spresense
STM
Individual boards
- Adafruit Trinkey SHT4x: fix
board.I2C()
pins. #9107. Thanks @dhalbert and @BlitzCityDIY.
Documentation changes
Build and infrastructure changes
Translation additions and improvements
New boards since 9.0.0
Known issues
- See https://github.com/adafruit/circuitpython/issues for other issues, including issues still to be addressed for:
Thanks
Thank you to all who used, tested, and contributed since 9.0.1, including the contributors above, and many others on GitHub and Discord. Join us on the Discord chat to collaborate.
CircuitPython 9.0.1
This is CircuitPython 9.0.1, 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, SAMx5xcxd56
: Sony Spresenseespressif
: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C3nrf
: Nordic nRF52840, nRF52833raspberrypi
: Raspberry Pi RP2040stm
: 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 2Wlitex
: fomumimxrt10xx
: NXP i.MX RT10xxxsilabs
: Silicon Labs MG24 familystm
: ST non-STM32F4 chip families
Changes since 9.0.0
Fixes and enhancements
Port and board-specific changes
Broadcom
Espressif
i.MX
nRF
RP2040
SAMx
SiLabs
Spresense
STM
Individual boards
- Adafruit ItsyBitsy ESP32: fix
board.NEOPIXEL
andboard.NEOPIXEL_POWER
pin assignments. #9087. Thanks @RetiredWizard.
Documentation changes
Build and infrastructure changes
Translation additions and improvements
New boards since 9.0.0
Known issues
- See https://github.com/adafruit/circuitpython/issues for other issues, including issues still to be addressed for:
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.
CircuitPython 9.0.0
This is CircuitPython 9.0.0, the latest major 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 to 9.0.0 since 8.x.x
Incompatibility warnings
- New storage management. See Internal below about possible new memory errors with existing programs.
- Filesystems such as SD cards must now be mounted on an existing directory as a mount point. See Storage below.
- Incompatible change in
socket
behavior: Sockets must be explictly made reusable. See Networking below. displayio.*Display.show()
has been removed. Use*Display.root_group =
instead.I2CPeripheral
is nowI2CTarget
.
Audio
- Add
synthio.Note
.loop_start
and.loop_end
properties. - Add
synthio.Synthesizer.note_state
. - Add I2S MCLK support on Espressif.
- Allow signed amplitude in
synthio
.
Built-in modules
- Add
OrderedDict.move_to_end()
. - Add
warnings
module, similar to what is in CPython. - Add
locale.getlocale()
. - Add
codeop.compile_command()
. - Remove 8.x.x deprecations:
displayio.*.show()
,I2CPeripheral
renamed toI2CTarget
.
Graphics
- Reorganize and split
displayio
. 8.x.x naming structure is available in 9.x.x, but will be removed in 10.0.0.displayio.Display
is nowbusdisplay.BusDisplay
.displayio.FourWire
is nowfourwire.FourWire
.displayio.EPaperDisplay
is nowepaperdisplay.EPaperDisplay
.displayio.I2CDisplay
is nowi2cdisplaybus.I2CDisplayBus
.
- Add
jpegio
JPEG decoder support. - Add
bitmapfilter
image manipulation.
Internal
- New split-heap internal dynamic storage mechanism. Some CircuitPython programs may fail with
MemoryError
. If you encounter programs that work in 8.x.x but getMemoryError
exceptions, consider filing an issue with details. - Merge updates from MicroPython v1.19.1, v1.20.0, and v1.21.0.
- Espressif: update to ESP-IDF v5.1.3.
Networking
- Allow specifying protocol for raw sockets.
- Add mDNS TXT record support.
- Make SD cards available over web workflow.
- Allow fetching of associated stations in access-point mode.
- Incompatible change: Require explicit socket port reuse. Use
socket.setsockopt(pool.SOL_SOCKET, pool.SO_REUSEADDR, 1)
, as in CPython.
Python interpreter
- Use terser error messages on small builds.
Storage
- CIRCUITPY drives now mount on Android.
- Increased file capacity on CIRCUITPY drives <= 128kB.
- Incompatible change: Require filesystem mounts to be on existing directories. Create
/sd
in fresh filesystems to provide a mount point.
Supervisor
- Add
repl.py
, which runs just before the REPL starts up.
USB
- Video device ("Webcam", UVC) support.
- HID can wake up sleeping host computer.
- Further USB host support, on i.MX and RP2040.
- Allow setting USB HID interface name.
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, SAMx5xcxd56
: Sony Spresenseespressif
: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C3nrf
: Nordic nRF52840, nRF52833raspberrypi
: Raspberry Pi RP2040stm
: 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 2Wlitex
: fomumimxrt10xx
: NXP i.MX RT10xxxsilabs
: Silicon Labs MG24 familystm
: ST non-STM32F4 chip families
Changes since 9.0.0-rc.1
Fixes and enhancements
Port and board-specific changes
Broadcom
Espressif
i.MX
nRF
RP2040
SAMx
SiLabs
Spresense
STM
Individual boards
- M5Stack Cardputer: fix
board.I2S_DATA
pin name typo. #9020. Thanks @RetiredWizard.
Documentation changes
Build and infrastructure changes
Translation additions and improvements
New boards since 9.0.0-rc.1
Known issues
- See https://github.com/adafruit/circuitpython/issues for other issues, including issues still to be addressed for:
Thanks
Thank you to all who used, tested, and contributed since 9.0.0-rc.1, including the contributors above, and many others on GitHub and Discord. Join us on the Discord chat to collaborate.
CircuitPython 9.0.0 Release Candidate 1
This is CircuitPython 9.0.0-rc.1, a release candidate for 9.0.0 final. This release is believed to be stable, and is meant for testing before the final release of 9.0.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 to 9.0.0 since 8.x.x
Incompatibility warnings
- New storage management. See Internal below about possible new memory errors with existing programs.
- Filesystems such as SD cards must now be mounted on an existing directory as a mount point. See Storage below.
- Incompatible change in
socket
behavior: Sockets must be explictly made reusable. See Networking below. displayio.*Display.show()
has been removed. Use*Display.root_group =
instead.I2CPeripheral
is nowI2CTarget
.
Audio
- Add
synthio.Note
.loop_start
and.loop_end
properties. - Add
synthio.Synthesizer.note_state
. - Add I2S MCLK support on Espressif.
- Allow signed amplitude in
synthio
.
Built-in modules
- Add
OrderedDict.move_to_end()
. - Add
warnings
module, similar to what is in CPython. - Add
locale.getlocale()
. - Add
codeop.compile_command()
. - Remove 8.x.x deprecations:
displayio.*.show()
,I2CPeripheral
renamed toI2CTarget
.
Graphics
- Reorganize and split
displayio
. 8.x.x naming structure is available in 9.x.x, but will be removed in 10.0.0. - Add
jpegio
JPEG decoder support. - Add
bitmapfilter
image manipulation.
Internal
- New split-heap internal dynamic storage mechanism. Some CircuitPython programs may fail with
MemoryError
. If you encounter programs that work in 8.x.x but getMemoryError
exceptions, consider filing an issue with details. - Merge updates from MicroPython v1.19.1, v1.20.0, and v1.21.0.
- Espressif: update to ESP-IDF v5.1.3.
Networking
- Allow specifying protocol for raw sockets.
- Add mDNS TXT record support.
- Make SD cards available over web workflow.
- Allow fetching of associated stations in access-point mode.
- Incompatible change: Require explicit socket port reuse. Use
socket.setsockopt(pool.SOL_SOCKET, pool.SO_REUSEADDR, 1)
, as in CPython.
Python interpreter
- Use terser error messages on small builds.
Storage
- CIRCUITPY drives now mount on Android.
- Increased file capacity on CIRCUITPY drives <= 128kB.
- Incompatible change: Require filesystem mounts to be on existing directories. Create
/sd
in fresh filesystems to provide a mount point.
Supervisor
- Add
repl.py
, which runs just before the REPL starts up.
USB
- Video device ("Webcam", UVC) support.
- HID can wake up sleeping host computer.
- Further USB host support, on i.MX and RP2040.
- Allow setting USB HID interface name.
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, SAMx5xcxd56
: Sony Spresenseespressif
: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C3nrf
: Nordic nRF52840, nRF52833raspberrypi
: Raspberry Pi RP2040stm
: 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 2Wlitex
: fomumimxrt10xx
: NXP i.MX RT10xxxsilabs
: Silicon Labs MG24 familystm
: ST non-STM32F4 chip families
Changes since 9.0.0-rc.0
Fixes and enhancements
- Update frozen libraries. #9046. Thanks @dhalbert.
- Fix tlsf allocation logic. #9039. Thanks @tannewt.
Port and board-specific changes
Broadcom
Espressif
- Fix RMT clock speed on ESP32-H2. #9051. Thanks @tannewt.
- Fix
_bleio.Adapter
name setting. #9041. Thanks @dhalbert. - Fix
tlsf
allocation logic. #9039. Thanks @tannewt. - Fix error reporting for certain connection errors. #8888. Thanks @bill88t.
i.MX
nRF
RP2040
- Handle multiple USB setup packets: TinyUSB fix. #9042. Thanks @hathach.
- Don't claim
PWMOut
pin before validation. #9024. Thanks @dhalbert. - Update
cyw43-driver
to upstream version v1.0.3. #9022. Thanks @eightycc.
SAMx
SiLabs
Spresense
STM
Individual boards
- Adafruit MatrixPortal S3: disable
espcamera
properly. #9043. Thanks @jerryneedell and @dhalbert.
Documentation changes
- Fix
supervisor.Runtime.serial_bytes_available
documentation. #9032. Thanks @RetiredWizard.
Build and infrastructure changes
Translation additions and improvements
- Thanks for translations:
- @Sokromatrix (German)
- @wtuemura (Portuguese - Brazil)
- @Xfox20 (German)
New boards since 9.0.0-rc.0
- Adafruit Feather ESP32-C6 4MB Flash No PSRAM. #9018. Thanks @dhalbert.
- Waveshare RP2040-Tiny. #8796. Thanks @bill88t.
Known issues
- See https://github.com/adafruit/circuitpython/issues for other issues, including issues still to be addressed for:
Thanks
Thank you to all who used, tested, and contributed since 9.0.0-rc.0, including the contributors above, and many others on GitHub and Discord. Join us on the Discord chat to collaborate.
CircuitPython 9.0.0 Release Candidate 0
This is CircuitPython 9.0.0-rc.0, a release candidate for 9.0.0 final. This release is believed to be stable, and is meant for testing before the final release of 9.0.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 to 9.0.0 since 8.x.x
Incompatibility warnings
- New storage management. See Internal below about possible new memory errors with existing programs.
- Filesystems such as SD cards must now be mounted on an existing directory as a mount point. See Storage below.
- Incompatible change in
socket
behavior: Sockets must be explictly made reusable. See Networking below. displayio.*Display.show()
has been removed. Use*Display.root_group =
instead.I2CPeripheral
is nowI2CTarget
.
Audio
- Add
synthio.Note
.loop_start
and.loop_end
properties. - Add
synthio.Synthesizer.note_state
. - Add I2S MCLK support on Espressif.
- Allow signed amplitude in
synthio
.
Built-in modules
- Add
OrderedDict.move_to_end()
. - Add
warnings
module, similar to what is in CPython. - Add
locale.getlocale()
. - Add
codeop.compile_command()
. - Remove 8.x.x deprecations:
displayio.*.show()
,I2CPeripheral
renamed toI2CTarget
.
Graphics
- Reorganize and split
displayio
. 8.x.x naming structure is available in 9.x.x, but will be removed in 10.0.0. - Add
jpegio
JPEG decoder support. - Add
bitmapfilter
image manipulation.
Internal
- New split-heap internal dynamic storage mechanism. Some CircuitPython programs may fail with
MemoryError
. If you encounter programs that work in 8.x.x but getMemoryError
exceptions, consider filing an issue with details. - Merge updates from MicroPython v1.19.1, v1.20.0, and v1.21.0.
- Espressif: update to ESP-IDF v5.1.3.
Networking
- Allow specifying protocol for raw sockets.
- Add mDNS TXT record support.
- Make SD cards available over web workflow.
- Allow fetching of associated stations in access-point mode.
- Incompatible change: Require explicit socket port reuse. Use
socket.setsockopt(pool.SOL_SOCKET, pool.SO_REUSEADDR, 1)
, as in CPython.
Python interpreter
- Use terser error messages on small builds.
Storage
- CIRCUITPY drives now mount on Android.
- Increased file capacity on CIRCUITPY drives <= 128kB.
- Incompatible change: Require filesystem mounts to be on existing directories. Create
/sd
in fresh filesystems to provide a mount point.
Supervisor
- Add
repl.py
, which runs just before the REPL starts up.
USB
- Video device ("Webcam", UVC) support.
- HID can wake up sleeping host computer.
- Further USB host support, on i.MX and RP2040.
- Allow setting USB HID interface name.
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, SAMx5xcxd56
: Sony Spresenseespressif
: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C3nrf
: Nordic nRF52840, nRF52833raspberrypi
: Raspberry Pi RP2040stm
: 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 2Wlitex
: fomumimxrt10xx
: NXP i.MX RT10xxxsilabs
: Silicon Labs MG24 familystm
: ST non-STM32F4 chip families
Changes since 9.0.0-beta.2
Fixes and enhancements
- Update frozen libraries. #9019. Thanks @dhalbert.
- Fix corrupted BLE ScanEntry objects. #9014. Thanks @dhalbert.
- Setting the
WatchdogTimer
timeout will reset the watchdog interval. #9012. Thanks @tannewt. - Improve
RGBMatrix
reliability. #9008. Thanks @tannewt. - Fix
ETIMEDOUT
exceptions inssl
. #9006. Thanks @jepler. - Postpone web workflow request if SPI bus is locked. #9005. Thanks @jepler.
- Fix USB Host HID. #8999. Thanks @hathach.
- Allow web workflow to write to CIRCUITPY when connected to USB. #8994. Thanks @tannewt.
- Disable
warnings
during REPL autocomplete. #8993. Thanks @tannewt. - Allow setting USB HID interface name. #8989. Thanks @MariuszCwikla.
- Include language code in USB Host string descriptors. #8976. Thanks @tannewt.
- Use finalizer to properly clean up
PWMOut
objects, including those used by other objects. #8966. Thanks @tannewt. - Freeze new
adafruit_connection_manager
library on appropriate boards. #8963. Thanks @justmobilize. - Fix
ssl.SSLSocket.bind()
error checking. #8962. Thanks @tannewt. - Allow fetching of associated stations in access-point mode. #8820. Thanks @romkey.
Port and board-specific changes
Broadcom
Espressif
- Update ESP-IDF to v5.1.3. #9008. Thanks @tannewt.
- Fix
WatchdogTimer
units. #9012. Thanks @tannewt. - Use a finalizer to clean up
espcamera
objects. #8990. Thanks @dhalbert.
i.MX
nRF
RP2040
SAMx
SiLabs
Spresense
STM
Individual boards
- Adafruit QT Py M0 Haxpress: allow W25Q32FV flash chip. #9011. Thanks @guutz.
- M5Stack Atom S3: fix display colors. #8998. Thanks @jins-tkomoda.
- PewPew LCD: update board to v4.1. #8959. Thanks @deshipu.
Documentation changes
Build and infrastructure changes
- Update
tlsf
library to allow allocating just-freed region. #9004. Thanks @tannewt. - Update
tools/convert_release_notes.py
to usemistune
v3. #8955. Thanks @dhalbert.
Translation additions and improvements
New boards since 9.0.0-beta.2
- Adafruit ItsyBitsy ESP32. #8953. Thanks @BlitzCityDIY.
- Adafruit SHT4x Trinkey M0. #9007. Thanks @ladyada.
- M5Stack Cardputer. #8816. Thanks @jamesjnadeau and @FoamyGuy.
- senseBox MCU-S2 ESP32S2. #8997, #8965. Thanks @mariopesch.
Known issues
- See https://github.com/adafruit/circuitpython/issues for other issues, including issues still to be addressed for:
Thanks
Thank you to all who used, tested, and contributed since 9.0.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.0 Beta 2
This is CircuitPython 9.0.0-beta.2, a beta release for 9.0.0, and is a new unstable release. This release has known bugs that will be addressed before 9.0.0 final.
Note for MEMENTO Camera Board users: This release contains an important fix for MEMENTO. If you originally installed a version of CircuitPython older than 9.0.0-beta.2 on your board, your CIRCUITPY drive thinks it is larger than it really is. This can cause crashes. To fix this, back up what is on your drive, install CircuitPython 9.0.0-beta.2 or later, and then erase and reformat CIRCUITPY by running this code from the terminal or in a program
import storage
storage.erase_filesystem()
Or, use the factory reset procedure described in the MEMENTO Learn Guide. But the simple code above will work just as well.
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 to 9.0.0 since 8.x.x
Incompatibility warnings
- New storage management. See Internal below about possible new memory errors with existing programs.
- Filesystems such as SD cards must now be mounted on an existing directory as a mount point. See Storage below.
- Incompatible change in
socket
behavior: Sockets must be explictly made reusable. See Networking below.
Audio
- Add
synthio.Note
.loop_start
and.loop_end
properties. - Add
synthio.Synthesizer.note_state
. - Add I2S MCLK support on Espressif.
- Allow signed amplitude in
synthio
.
Built-in modules
- Add
OrderedDict.move_to_end()
. - Add
warnings
module, similar to what is in CPython. - Add
locale.getlocale()
. - Add
codeop.compile_command()
. - Remove 8.x.x deprecations:
displayio.*.show()
,I2CPeripheral
renamed toI2CTarget
.
Graphics
- Reorganize and split
displayio
. 8.x.x naming structure is available in 9.x.x, but will be removed in 10.0.0. - Add
jpegio
JPEG decoder support. - Add
bitmapfilter
image manipulation.
Internal
- New split-heap internal dynamic storage mechanism. Some CircuitPython programs may fail with
MemoryError
. If you encounter programs that work in 8.x.x but getMemoryError
exceptions, consider filing an issue with details. - Merge updates from MicroPython v1.19.1, v1.20.0, and v1.21.0.
- Espressif: update to ESP-IDF v5.1.2.
Networking
- Allow specifying protocol for raw sockets.
- Add mDNS TXT record support.
- Make SD cards available over web workflow.
- Incompatible change: Require explicit socket port reuse. Use
socket.setsockopt(pool.SOL_SOCKET, pool.SO_REUSEADDR, 1)
, as in CPython.
Python interpreter
- Use terser error messages on small builds.
Storage
- CIRCUITPY drives now mount on Android.
- Increased file capacity on CIRCUITPY drives <= 128kB.
- Incompatible change: Require filesystem mounts to be on existing directories. Create
/sd
in fresh filesystems to provide a mount point.
Supervisor
- Add
repl.py
, which runs just before the REPL starts up.
USB
- Video device ("Webcam", UVC) support.
- HID can wake up sleeping host computer.
- Further USB host support, on i.MX and RP2040.
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, SAMx5xcxd56
: Sony Spresenseespressif
: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C3nrf
: Nordic nRF52840, nRF52833raspberrypi
: Raspberry Pi RP2040stm
: 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 2Wlitex
: fomumimxrt10xx
: NXP i.MX RT10xxxsilabs
: Silicon Labs MG24 familystm
: ST non-STM32F4 chip families
Changes since 9.0.0-beta.1
Fixes and enhancements
Port and board-specific changes
Broadcom
Espressif
i.MX
nRF
RP2040
SAMx
SiLabs
Spresense
STM
Individual boards
- Adafruit MEMENTO: Fix CIRCUITPY size. Requires
storage.erase_filesystem()
. #8952. Thanks @dhalbert @jepler. - Cytron Maker Uno RP2040: Change name; remove RGB status LED. #8950. Thanks @noqman.
Documentation changes
Build and infrastructure changes
- Add tests for
bit_length()
. Thanks @kbsriram.
Translation additions and improvements
- Thanks for translations:
- @hexthat (Chinese - Pinyin)
New boards since 9.0.0-beta.1
Known issues
- See https://github.com/adafruit/circuitpython/issues for other issues, including issues still to be addressed for:
Thanks
Thank you to all who used, tested, and contributed since 9.0.0-beta.1, including the contributors above, and many others on GitHub and Discord. Join us on the Discord chat to collaborate.
CircuitPython 9.0.0 Beta 1
This is CircuitPython 9.0.0-beta.1, a beta release for 9.0.0, and is a new unstable release. This release has known bugs that will be addressed before 9.0.0 final.
NOTE: CircuitPython 9.0.0-alpha.4 and later use a new internal dynamic storage mechanism ("split heap"), which is being tuned. You may find that some CircuitPython programs fail with MemoryError
. If you encounter programs that work in 8.x.x but get MemoryError
exceptions, consider filing an issue with details.
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 to 9.0.0 since 8.x.x
Audio
- Add
synthio.Note
.loop_start
and.loop_end
properties. - Add
synthio.Synthesizer.note_state
. - Add I2S MCLK support on Espressif.
- Allow signed amplitude in
synthio
.
Built-in modules
- Add
OrderedDict.move_to_end()
. - Add
warnings
module, similar to what is in CPython. - Add
locale.getlocale()
. - Add
codeop.compile_command()
. - Remove 8.x.x deprecations:
displayio.*.show()
,I2CPeripheral
renamed toI2CTarget
.
Graphics
- Reorganize and split
displayio
. 8.x.x naming structure is available in 9.x.x, but will be removed in 10.0.0. - Add
jpegio
JPEG decoder support. - Add
bitmapfilter
image manipulation.
Internal
- New split-heap internal dynamic storage mechanism.
- Merge updates from MicroPython v1.19.1, v1.20.0, and v1.21.0.
- Espressif: update to ESP-IDF v5.1.2.
Networking
- Allow specifying protocol for raw sockets.
- Add mDNS TXT record support.
- Make SD cards available over web workflow.
- API change: Require explicit socket port reuse. Use
socket.setsockopt(pool.SOL_SOCKET, pool.SO_REUSEADDR, 1)
, as in CPython.
Python interpreter
- Use terser error messages on small builds.
Storage
- CIRCUITPY drives now mount on Android.
- Increased file capacity on CIRCUITPY drives <= 128kB.
- Require filesystem mounts to be on existing directories. Create
/sd
in fresh filesystems to provide a mount point.
Supervisor
- Add
repl.py
, which runs just before the REPL starts up.
USB
- Video device ("Webcam", UVC) support.
- HID can wake up sleeping host computer.
- Further USB host support, on i.MX and RP2040.
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, SAMx5xcxd56
: Sony Spresenseespressif
: Espressif ESP32, ESP32-S2, ESP32-S3, ESP32-C3nrf
: Nordic nRF52840, nRF52833raspberrypi
: Raspberry Pi RP2040stm
: 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 2Wlitex
: fomumimxrt10xx
: NXP i.MX RT10xxxsilabs
: Silicon Labs MG24 familystm
: ST non-STM32F4 chip families
Changes since 9.0.0-beta.0
Fixes and enhancements
- Require explicit socket port reuse (
SO_REUSEADDR
). #8940. Thanks @tannewt. - Update frozen submodules. #8938. Thanks @dhalbert.
- Update root certificates to include ssl.com RSA root. #8935. Thanks @dhalbert.
- Prevent out-of-range USB MSC reads. Fixes problem with Samsung Disk Magician. #8933. Thanks @drath42 and @jepler.
- Set socket type on accepted socket. #8932. Thanks @jepler.
- Increase CDC RX buffer size to allow better ctrl-C handling. #8929. Thanks @tannewt.
- Fix crash when appending to read-only
displayio.Group
, such asCIRCUITPYTHON_TERMINAL
. #8923. Thanks @jepler. - Fix
JpegDecoder
arguments. #8905. Thanks @FoamyGuy. - Restore
<module>.file
attribute. #8881. Thanks @jepler. - Allow
RGBMatrix
framebuffer size to be more than 65535 bytes. #8864, #8847. Thanks @jepler. - Allow zero-size
blit
inbitmaptools
. #8880. Thanks @FoamyGuy. - Allow creating a mount point on an existing directory, in preparation 9.0.0 for capability. #8864, #8863. Thanks @jepler.
- Create
/sd/placeholder.txt
to document and provide a mount point for SD cards. #8860. Thanks @jepler. - Add
bitmapfilter.blend()
. #8859. Thanks @jepler. - Fix
.keys()
for dict subclasses. #8851. Thanks @dhalbert. - USB video device (UVC) support. #8831. Thanks @jepler.
- Correct
sys.version
to say "CircuitPython. #8808. Thanks @bill88t. - USB host keyboard: add function keys and other keys. #8807. Thanks @iyalosovetsky.
Port and board-specific changes
Broadcom
Espressif
- Fix and speed up TLS access to sites using elliptic-curve certificates. #8924. Thanks @dhalbert.
- Turn off
_bleio
on 4MB ESP32-S3 boards and refactor_bleio
setting for other boards. #82924. Thanks @dhalbert. - Reduce NeoPixel animation glitching. #8920. Thanks @tannewt.
- Fix socket failures by disabling variable length SSL buffers. #8913. Thanks @tannewt.
- Use new ESP-IDF PCNT, RMT, and timer group drivers. #8909. Thanks @tannewt.
- Correct flash and PSRAM speeds. #8870. Thanks @tannewt.
- Disable non-working
i2ctarget
. #8869. Thanks @tannewt. - Allocate SPIRAM only via
caps_alloc()
. #8868. Thanks @tannewt. - Re-enable
ParallelDisplayBus
. #8862. Thanks @tannewt.
i.MX
nRF
RP2040
- Swap PIO allocation for USB host for better operation on Pico W. #8922. Thanks @jepler.
- Update CYW43 driver to Adafruit fork. #8861. Thanks @eightycc.
SAMx
SiLabs
Spresense
STM
Individual boards
- Adafruit Feather RP240 USB Host: allow control of
board.USB_HOST_5V_POWER
pin. #8471. Thanks @jepler. - Espressif ESP32-S3 Eye: add OV2640 support. #8901. Thanks @jerryneedell.
- Pimoroni Pico DV Base W: fix I2S audio pin assignments. #8915. Thanks @RetiredWizard.
- UnexpectedMaker Bling: Pin changes. #8853. Thanks @UnexpectedMaker.
Documentation changes
- Fix some type annotations in
synthio
. #8895. Thanks @jepler. - Add board-specific stub file generation. #8882. Thanks @FoamyGuy.
- Use terser error messages on smaller builds. #8844. Thanks @dhalbert.
Build and infrastructure changes
- Update to
pre-commit/action@v3.0.1
to get Node.js 20 support. #8936. Thanks @dhalbert. - Report errors as failures in
build-board-info.py
. #8934. Thanks @jepler. - Include branch and PR number in PR merge firmware filenames. #8930. Thanks @dhalbert.
- Refactor
mbedtls
use toshared-module/
. #8926. Thanks @jepler. - Fix problems found while developing
ports/posix
. #8900. Thanks @jepler. - Fix
tools/test-stubs.sh
. #8898. Thanks @justmobilize. - Fix
circuitpython_setboard
OS path separator. #8894. Thanks @justmobilize. - Document how to use
MP_REGISTER_MODULE
. #8849. Thanks @jepler.
Translation additions and improvements
New boards since 9.0.0-beta.0
- Adafruit Floppsy RP2040. #8834. Thanks @jepler.
- M5Stack Dial. #8931. Thanks @CDarius.
- Pimoroni Inky Frame 7.3in. #8896. Thanks @kattni.
Known issues
- See https://github.com/adafruit/circuitpython/issues for other issues, including issues still to be addressed for:
Thanks
Thank you to all who used, tested, and contributed to 9.0.0-beta.1, including the contributors above, and many others on GitHub and Discord. Join us on the Discord chat to collaborate.