boards/makerbase/mks_canable_v20/doc/index.rst
.. zephyr:board:: mks_canable_v20
Overview
The Makerbase MKS CANable V2.0 board features an ARM Cortex-M4 based STM32G431C8 MCU with a CAN, USB and debugger connections. Here are some highlights of the MKS CANable V2.0 board:
The LED red/power_led (D1) is connected directly to on-board 3.3 V and not controllable by the MCU.
More information about the board can be found at the MKS CANable V2.0 website.
It is very advisable to take a look in on user manual MKS CANable V2.0 User Manual and
schematic MKS CANable V2.0 schematic_ before start.
More information about STM32G431KB can be found here:
STM32G431C8 on www.st.com_STM32G4 reference manual_.. zephyr:board-supported-hw::
.. rst-class:: rst-columns
For more details please refer to MKS CANable V2.0 schematic_.
The MKS CANable V2.0 system clock is driven by internal high speed oscillator. By default system clock is driven by PLL clock at 160 MHz, the PLL is driven by the 16 MHz high speed internal oscillator.
The FDCAN1 peripheral is driven by PLLQ, which has 80 MHz frequency.
Programming and Debugging
.. zephyr:board-supported-runners::
MKS CANable V2.0 board includes an SWDIO debug connector header J4.
.. note::
The debugger is not the part of the board!
Applications for the mks_canable_v20 board target can be built and
flashed in the usual way (see :ref:build_an_application and
:ref:application_run for more details).
The board could be flashed using west.
The debugger shall be wired to MKS CANable V2.0 board's J4 connector
according MKS CANable V2.0 schematic_.
Build and flash an application. Here is an example for
:zephyr:code-sample:hello_world.
.. zephyr-app-commands:: :zephyr-app: samples/hello_world :board: mks_canable_v20 :goals: build flash :west-args: -S rtt-console :compact:
The argument -S rtt-console is needed for debug purposes with SEGGER RTT protocol.
This option is optional and may be omitted. Omitting it frees up RAM space but prevents RTT usage.
If option -S rtt-console is selected, the connection to the target can be established as follows:
.. code-block:: console
$ telnet localhost 9090
You should see the following message on the console:
.. code-block:: console
$ Hello World! mks_canable_v20/stm32g431xx
.. note::
Current OpenOCD config will skip Segger RTT for OpenOCD under 0.12.0.
You can debug an application in the usual way. Here is an example for the
:zephyr:code-sample:hello_world application.
.. zephyr-app-commands:: :zephyr-app: samples/hello_world :board: mks_canable_v20 :maybe-skip-config: :goals: debug
References
.. target-notes::
.. _MKS CANable V2.0 website: https://github.com/makerbase-mks/CANable-MKS
.. _MKS CANable V2.0 User Manual: https://github.com/makerbase-mks/CANable-MKS/blob/main/User%20Manual/CANable%20V2.0/Makerbase%20CANable%20V2.0%20Use%20Manual.pdf
.. _MKS CANable V2.0 schematic: https://github.com/makerbase-mks/CANable-MKS/blob/main/Hardware/MKS%20CANable%20V2.0/MKS%20CANable%20V2.0_001%20schematic.pdf
.. _STM32G431C8 on www.st.com: https://www.st.com/en/microcontrollers-microprocessors/stm32g431c8.html
.. _STM32G4 reference manual: https://www.st.com/resource/en/reference_manual/rm0440-stm32g4-series-advanced-armbased-32bit-mcus-stmicroelectronics.pdf
.. _STM32CubeProgrammer: https://www.st.com/en/development-tools/stm32cubeprog.html