-
Notifications
You must be signed in to change notification settings - Fork 6.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for WCH CH56x series SoC #64472
base: main
Are you sure you want to change the base?
Conversation
a10ccca
to
80ce4f7
Compare
80ce4f7
to
5781915
Compare
89abf9b
to
4056049
Compare
* Website: https://wch-ic.com/ Signed-off-by: Chen Xingyu <hi@xingrz.me>
cc6495c
to
e6ed4e0
Compare
NOTE: Duplicated with an existing PR. Leaving this commit here just as a placeholder. Will be rebased soon after that existing PR get merged. ========================================================================== In certain cases, platforms may have their own implemented interrupt controllers (e.g., the PFIC on WCH MCUs) that require the ability to implement the irq_enable/disable functions at the SoC level. Similar support already exists for ARM and ARM64. This commit adds support for RISC-V as well. Signed-off-by: Chen Xingyu <hi@xingrz.me> # Conflicts: # include/zephyr/arch/riscv/irq.h
e6ed4e0
to
e667dcc
Compare
QingKe V3 is an RV32IMAC core developed by WCH Signed-off-by: Chen Xingyu <hi@xingrz.me>
Based on QingKe V3A core, CH569/5 are members of the CH56x series. Signed-off-by: Chen Xingyu <hi@xingrz.me>
PFIC (Programmable Fast Interrupt Controller) is the interrupt controller implmentation in WCH QingKe series RISC-V MCUs. Signed-off-by: Chen Xingyu <hi@xingrz.me> # Conflicts: # drivers/interrupt_controller/CMakeLists.txt # drivers/interrupt_controller/Kconfig
This driver is shared across QingKe V3A series, including CH32V103, CH569/5 and CH573/1. Signed-off-by: Chen Xingyu <hi@xingrz.me>
This commit describes the system control block of the CH56x in DTS. This block will be utilized in future drivers for functions such as pin remapping, clock control, and interrupt management. Additionally, macros has been added to facilitate easy access to the block. Signed-off-by: Chen Xingyu <hi@xingrz.me>
The CH56x can be configured to run on a 30MHz external oscillator or a 480MHz PLL generated by the USB PHY. This commit introduces a clock controller that can automatically select one of the two available clock sources and determine the appropriate divisor based on the given frequency. The `CONFIG_SYS_CLOCK_HW_CYCLES_PER_SEC` value is also updated with the selected frequency. Signed-off-by: Chen Xingyu <hi@xingrz.me> # Conflicts: # drivers/clock_control/Kconfig # soc/riscv/riscv-privileged/wch_ch32v/Kconfig.defconfig.ch56x
This commit implements a GPIO driver for CH56x series. The 2 instances of GPIO share a same IRQ line on this chip. So the config `SHARED_IRQ` is selected as well. Signed-off-by: Chen Xingyu <hi@xingrz.me>
This commit introduces a pinctrl driver for the CH5xx series. The limitations of pin multiplexing of WCH CH5xx series are described in the binding configuration. Signed-off-by: Chen Xingyu <hi@xingrz.me>
This commit introduces UART driver for CH5xx series, supporting both polling and interrupt-driven mode. Signed-off-by: Chen Xingyu <hi@xingrz.me>
`WCHISPTool_CMD` is the commandline version of WCHISPTool, which is a USB flashing tool for WCH series MCUs. Signed-off-by: Chen Xingyu <hi@xingrz.me>
CH565W-EVT and CH569W-EVT are boards by WCH for the evaluation of CH565W and CH569W chips. Signed-off-by: Chen Xingyu <hi@xingrz.me>
* Add `WCH Platforms` section * Add `xingrz` to maintainers of `WCH Platform` Signed-off-by: Chen Xingyu <hi@xingrz.me>
e667dcc
to
7cd499e
Compare
I am very interested to follow this PR, how can I help @xingrz |
This pull request has been marked as stale because it has been open (more than) 60 days with no activity. Remove the stale label or add a comment saying that you would like to have the label removed otherwise this pull request will automatically be closed in 14 days. Note, that you can always re-open a closed pull request at any time. |
Any plans to merge it? |
QingKe is a series of RISC-V cores developed by WCH, consisting with V2A, V3A and V4B/C/F series of MCUs.
CH569/CH565 are 2 of the members of the QingKe V3A series. This PR brings initial support for these two SoCs to Zephyr.
In summary, this PR includes:
CH565W-EVT
andCH569W-EVT
evaluation boardsSupport for other series members will be submit in future PRs.
References:
TODOs