:mod:`microcontroller` ====================== .. py:module:: microcontroller .. autoapi-nested-parse:: Pin references and cpu functionality The `microcontroller` module defines the pins from the perspective of the microcontroller. See :py:mod:`board` for board-specific pin mappings. .. raw:: html

Available on these boards

.. py:data:: cpu :annotation: :Processor CPU information and control, such as ``cpu.temperature`` and ``cpu.frequency`` (clock frequency). This object is an instance of `microcontroller.Processor`. .. py:data:: cpus :annotation: :Processor CPU information and control, such as ``cpus[0].temperature`` and ``cpus[1].frequency`` (clock frequency) on chips with more than 1 cpu. The index selects which cpu. This object is an instance of `microcontroller.Processor`. .. py:function:: delay_us(delay: int) -> None Dedicated delay method used for very short delays. **Do not** do long delays because this stops all other functions from completing. Think of this as an empty ``while`` loop that runs for the specified ``(delay)`` time. If you have other code or peripherals (e.g audio recording) that require specific timing or processing while you are waiting, explore a different avenue such as using `time.sleep()`. .. py:function:: disable_interrupts() -> None Disable all interrupts. Be very careful, this can stall everything. .. py:function:: enable_interrupts() -> None Enable the interrupts that were enabled at the last disable. .. py:function:: on_next_reset(run_mode: RunMode) -> None Configure the run mode used the next time the microcontroller is reset but not powered down. :param ~microcontroller.RunMode run_mode: The next run mode .. py:function:: reset() -> None Reset the microcontroller. After reset, the microcontroller will enter the run mode last set by `on_next_reset`. .. warning:: This may result in file system corruption when connected to a host computer. Be very careful when calling this! Make sure the device "Safely removed" on Windows or "ejected" on Mac OSX and Linux. .. py:data:: nvm :annotation: :Optional[nvm.ByteArray] Available non-volatile memory. This object is the sole instance of `nvm.ByteArray` when available or ``None`` otherwise. :type: nvm.ByteArray or None .. py:data:: watchdog :annotation: :Optional[watchdog.WatchDogTimer] Available watchdog timer. This object is the sole instance of `watchdog.WatchDogTimer` when available or ``None`` otherwise. .. py:class:: Pin Identifies an IO pin on the microcontroller. Identifies an IO pin on the microcontroller. They are fixed by the hardware so they cannot be constructed on demand. Instead, use :mod:`board` or :mod:`microcontroller.pin` to reference the desired pin. .. py:class:: Processor Microcontroller CPU information and control Usage:: import microcontroller print(microcontroller.cpu.frequency) print(microcontroller.cpu.temperature) Note that on chips with more than one cpu (such as the RP2040) microcontroller.cpu will return the value for CPU 0. To get values from other CPUs use microcontroller.cpus indexed by the number of the desired cpu. i.e. print(microcontroller.cpus[0].temperature) print(microcontroller.cpus[1].frequency) You cannot create an instance of `microcontroller.Processor`. Use `microcontroller.cpu` to access the sole instance available. .. py:attribute:: frequency :annotation: :int The CPU operating frequency in Hertz. (read-only) .. py:attribute:: reset_reason :annotation: :ResetReason The reason the microcontroller started up from reset state. .. py:attribute:: temperature :annotation: :Optional[float] The on-chip temperature, in Celsius, as a float. (read-only) Is `None` if the temperature is not available. .. py:attribute:: uid :annotation: :bytearray The unique id (aka serial number) of the chip as a `bytearray`. (read-only) .. py:attribute:: voltage :annotation: :Optional[float] The input voltage to the microcontroller, as a float. (read-only) Is `None` if the voltage is not available. .. py:class:: ResetReason The reason the microntroller was last reset .. py:attribute:: POWER_ON :annotation: :object The microntroller was started from power off. .. py:attribute:: BROWNOUT :annotation: :object The microntroller was reset due to too low a voltage. .. py:attribute:: SOFTWARE :annotation: :object The microntroller was reset from software. .. py:attribute:: DEEP_SLEEP_ALARM :annotation: :object The microntroller was reset for deep sleep and restarted by an alarm. .. py:attribute:: RESET_PIN :annotation: :object The microntroller was reset by a signal on its reset pin. The pin might be connected to a reset button. .. py:attribute:: WATCHDOG :annotation: :object The microcontroller was reset by its watchdog timer. .. py:attribute:: UNKNOWN :annotation: :object The microntroller restarted for an unknown reason. .. py:attribute:: RESCUE_DEBUG :annotation: :object The microntroller was reset by the rescue debug port. .. py:class:: RunMode run state of the microcontroller Enum-like class to define the run mode of the microcontroller and CircuitPython. .. py:attribute:: NORMAL :annotation: :RunMode Run CircuitPython as normal. :type microcontroller.RunMode: .. py:attribute:: SAFE_MODE :annotation: :RunMode Run CircuitPython in safe mode. User code will not run and the file system will be writeable over USB. :type microcontroller.RunMode: .. py:attribute:: UF2 :annotation: :RunMode Run the uf2 bootloader. :type microcontroller.RunMode: .. py:attribute:: BOOTLOADER :annotation: :RunMode Run the default bootloader. :type microcontroller.RunMode: