.. currentmodule:: rk :mod:`rk` --- functionality specific to RV1106 MCUs =================================================== .. module:: rk :synopsis: functionality specific to RV1106 MCUs This module provides functionality specific to RV1106 microcontrollers, including direct access to peripheral registers. Memory access ------------- The module exposes three objects used for raw memory access. .. data:: mem8 Read/write 8 bits of memory. .. data:: mem16 Read/write 16 bits of memory. .. data:: mem32 Read/write 32 bits of memory. Use subscript notation ``[...]`` to index these objects with the address of interest. These memory objects can be used in combination with the peripheral register constants to read and write registers of the MCU hardware peripherals, as well as all other areas of address space. Peripheral register constants ----------------------------- The module defines constants for registers which are generated from CMSIS header files, and the constants available depend on the microcontroller series that is being compiled for. Examples of some constants include: .. data:: GPIOA Base address of the GPIOA peripheral. .. data:: GPIOB Base address of the GPIOB peripheral. .. data:: GPIO_BSRR Offset of the GPIO bit set/reset register. .. data:: GPIO_IDR Offset of the GPIO input data register. .. data:: GPIO_ODR Offset of the GPIO output data register. Constants that are named after a peripheral, like ``GPIOA``, are the absolute address of that peripheral. Constants that have a prefix which is the name of a peripheral, like ``GPIO_BSRR``, are relative offsets of the register. Accessing peripheral registers requires adding the absolute base address of the peripheral and the relative register offset. For example ``GPIOA + GPIO_BSRR`` is the full, absolute address of the ``GPIOA->BSRR`` register. Example use: .. code-block:: python3 # set PA2 high stm.mem32[stm.GPIOA + stm.GPIO_BSRR] = 1 << 2 # read PA3 value = (stm.mem32[stm.GPIOA + stm.GPIO_IDR] >> 3) & 1