From eeaf94a7d57e2ab21c4b13ddc9e2e239cd01ddf8 Mon Sep 17 00:00:00 2001 From: Jerzy Kasenberg Date: Fri, 20 Dec 2024 14:04:01 +0100 Subject: [PATCH] hw/mcu/stm32f4: Add shell command to show clocks This adds package that can display all enabled clocks. Similar to what was already done for stm32f1 Signed-off-by: Jerzy Kasenberg --- hw/mcu/stm/stm32f4xx/mcu_cli/pkg.yml | 35 ++ hw/mcu/stm/stm32f4xx/mcu_cli/src/mcu_cli.c | 436 +++++++++++++++++++++ hw/mcu/stm/stm32f4xx/mcu_cli/syscfg.yml | 24 ++ 3 files changed, 495 insertions(+) create mode 100644 hw/mcu/stm/stm32f4xx/mcu_cli/pkg.yml create mode 100644 hw/mcu/stm/stm32f4xx/mcu_cli/src/mcu_cli.c create mode 100644 hw/mcu/stm/stm32f4xx/mcu_cli/syscfg.yml diff --git a/hw/mcu/stm/stm32f4xx/mcu_cli/pkg.yml b/hw/mcu/stm/stm32f4xx/mcu_cli/pkg.yml new file mode 100644 index 0000000000..cff88acead --- /dev/null +++ b/hw/mcu/stm/stm32f4xx/mcu_cli/pkg.yml @@ -0,0 +1,35 @@ +# +# Licensed to the Apache Software Foundation (ASF) under one +# or more contributor license agreements. See the NOTICE file +# distributed with this work for additional information +# regarding copyright ownership. The ASF licenses this file +# to you under the Apache License, Version 2.0 (the +# "License"); you may not use this file except in compliance +# with the License. You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, +# software distributed under the License is distributed on an +# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +# KIND, either express or implied. See the License for the +# specific language governing permissions and limitations +# under the License. +# + +pkg.name: hw/mcu/stm/stm32f4xx/mcu_cli +pkg.description: MCU cli for STM32F4 chips. +pkg.author: "Apache Mynewt " +pkg.keywords: + - stm32 + - stm32f4 + +pkg.deps: + - "@apache-mynewt-core/hw/mcu/stm/stm32f4xx" + - "@apache-mynewt-core/kernel/os" + +pkg.req_apis: + - console + +pkg.init: + mcu_cli_init: 'MYNEWT_VAL(MCU_CLI_SYSINIT_STAGE)' diff --git a/hw/mcu/stm/stm32f4xx/mcu_cli/src/mcu_cli.c b/hw/mcu/stm/stm32f4xx/mcu_cli/src/mcu_cli.c new file mode 100644 index 0000000000..349fe01b04 --- /dev/null +++ b/hw/mcu/stm/stm32f4xx/mcu_cli/src/mcu_cli.c @@ -0,0 +1,436 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +#include "os/mynewt.h" + +#include +#include +#include +#include +#include + +extern uint32_t SystemCoreClock; + +static const char *system_clock_source[4] = { "HSI", "HSE", "PLL", "" }; + +static const char * +on_off_state(uint32_t on) +{ + return on ? "on" : "off"; +} + +static void +print_ahb_peripherals(struct streamer *streamer, bool all) +{ + streamer_printf(streamer, " AHB HCLK: %u\n", (unsigned int)HAL_RCC_GetHCLKFreq()); + + if (all || RCC->AHB1ENR & RCC_AHB1ENR_GPIOAEN) { + streamer_printf(streamer, " GPIOA %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_GPIOAEN)); + } + if (all || RCC->AHB1ENR & RCC_AHB1ENR_GPIOBEN) { + streamer_printf(streamer, " GPIOB %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_GPIOBEN)); + } + if (all || RCC->AHB1ENR & RCC_AHB1ENR_GPIOCEN) { + streamer_printf(streamer, " GPIOC %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_GPIOCEN)); + } + if (all || RCC->AHB1ENR & RCC_AHB1ENR_GPIODEN) { + streamer_printf(streamer, " GPIOD %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_GPIODEN)); + } +#ifdef GPIOE + if (all || RCC->AHB1ENR & RCC_AHB1ENR_GPIOEEN) { + streamer_printf(streamer, " GPIOE %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_GPIOEEN)); + } +#endif +#ifdef GPIOF + if (all || RCC->AHB1ENR & RCC_AHB1ENR_GPIOFEN) { + streamer_printf(streamer, " GPIOF %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_GPIOFEN)); + } +#endif +#ifdef GPIOG + if (all || RCC->AHB1ENR & RCC_AHB1ENR_GPIOGEN) { + streamer_printf(streamer, " GPIOG %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_GPIOGEN)); + } +#endif + if (all || RCC->AHB1ENR & RCC_AHB1ENR_GPIOHEN) { + streamer_printf(streamer, " GPIOH %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_GPIOHEN)); + } +#ifdef RCC_AHB1ENR_GPIOIEN + if (all || RCC->AHB1ENR & RCC_AHB1ENR_GPIOIEN) { + streamer_printf(streamer, " GPIOI %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_GPIOIEN)); + } +#endif +#ifdef RCC_AHB1ENR_GPIOJEN + if (all || RCC->AHB1ENR & RCC_AHB1ENR_GPIOJEN) { + streamer_printf(streamer, " GPIOI %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_GPIOJEN)); + } +#endif +#ifdef RCC_AHB1ENR_GPIOKEN + if (all || RCC->AHB1ENR & RCC_AHB1ENR_GPIOKEN) { + streamer_printf(streamer, " GPIOI %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_GPIOKEN)); + } +#endif + if (all || RCC->AHB1ENR & RCC_AHB1ENR_CRCEN) { + streamer_printf(streamer, " CRC %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_CRCEN)); + } +#ifdef RCC_AHB1ENR_BKPSRAMEN + if (all || RCC->AHB1ENR & RCC_AHB1ENR_BKPSRAMEN) { + streamer_printf(streamer, " BKPSRAM %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_BKPSRAMEN)); + } +#endif +#ifdef RCC_AHB1ENR_CCMDATARAMEN + if (all || RCC->AHB1ENR & RCC_AHB1ENR_CCMDATARAMEN) { + streamer_printf(streamer, " CCMDATARAM %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_CCMDATARAMEN)); + } +#endif + if (all || RCC->AHB1ENR & RCC_AHB1ENR_DMA1EN) { + streamer_printf(streamer, " DMA1 %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_DMA1EN)); + } + if (all || RCC->AHB1ENR & RCC_AHB1ENR_DMA2EN) { + streamer_printf(streamer, " DMA2 %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_DMA2EN)); + } +#ifdef RCC_AHB1ENR_ETHMACEN + if (all || RCC->AHB1ENR & RCC_AHB1ENR_ETHMACEN) { + streamer_printf(streamer, " ETHMAC %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_ETHMACEN)); + } +#endif +#ifdef RCC_AHB1ENR_ETHMACTXEN + if (all || RCC->AHB1ENR & RCC_AHB1ENR_ETHMACTXEN) { + streamer_printf(streamer, " ETHMACTX %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_ETHMACTXEN)); + } +#endif +#ifdef RCC_AHB1ENR_ETHMACRXEN + if (all || RCC->AHB1ENR & RCC_AHB1ENR_ETHMACRXEN) { + streamer_printf(streamer, " ETHMACRX %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_ETHMACRXEN)); + } +#endif +#ifdef RCC_AHB1ENR_ETHMACPTPEN + if (all || RCC->AHB1ENR & RCC_AHB1ENR_ETHMACPTPEN) { + streamer_printf(streamer, " ETHMACPTP %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_ETHMACPTPEN)); + } +#endif +#ifdef RCC_AHB1ENR_OTGHSEN + if (all || RCC->AHB1ENR & RCC_AHB1ENR_OTGHSEN) { + streamer_printf(streamer, " OTGHS %s\n", on_off_state(RCC->AHB1ENR & RCC_AHB1ENR_OTGHSEN)); + } +#endif +#ifdef RCC_AHB1ENR_OTGHSULPIEN + if (all || RCC->AHB1ENR & RCC_AHB1ENR_OTGHSULPIEN) { + streamer_printf(streamer, " OTGHSULPI %s\n", on_off_state(RCC->AHB2ENR & RCC_AHB1ENR_OTGHSULPIEN)); + } +#endif + +#if defined(RCC_AHB2ENR_DCMIEN) + if (all || RCC->AHB2ENR & RCC_AHB2ENR_DCMIEN) { + streamer_printf(streamer, " DCMI %s\n", on_off_state(RCC->AHB2ENR & RCC_AHB2ENR_DCMIEN)); + } +#endif +#if defined(RCC_AHB2ENR_AESEN) + if (all || RCC->AHB2ENR & RCC_AHB2ENR_AESEN) { + streamer_printf(streamer, " AES %s\n", on_off_state(RCC->AHB2ENR & RCC_AHB2ENR_AESEN)); + } +#endif +#if defined(RCC_AHB2ENR_CRYPEN) + if (all || RCC->AHB2ENR & RCC_AHB2ENR_CRYPEN) { + streamer_printf(streamer, " CRYP %s\n", on_off_state(RCC->AHB2ENR & RCC_AHB2ENR_CRYPEN)); + } +#endif +#if defined(RCC_AHB2ENR_HASHEN) + if (all || RCC->AHB2ENR & RCC_AHB2ENR_HASHEN) { + streamer_printf(streamer, " HASH %s\n", on_off_state(RCC->AHB2ENR & RCC_AHB2ENR_HASHEN)); + } +#endif +#if defined(RCC_AHB2ENR_RNGEN) + if (all || RCC->AHB2ENR & RCC_AHB2ENR_RNGEN) { + streamer_printf(streamer, " RNG %s\n", on_off_state(RCC->AHB2ENR & RCC_AHB2ENR_RNGEN)); + } +#endif +#if defined(RCC_AHB2ENR_OTGFSEN) + if (all || RCC->AHB2ENR & RCC_AHB2ENR_OTGFSEN) { + streamer_printf(streamer, " OTGFS %s\n", on_off_state(RCC->AHB2ENR & RCC_AHB2ENR_OTGFSEN)); + } +#endif +#if defined(RCC_AHB3ENR_FSMCEN) + if (all || RCC->AHB3ENR & RCC_AHB3ENR_FSMCEN) { + streamer_printf(streamer, " FSMC %s\n", on_off_state(RCC->AHB2ENR & RCC_AHB3ENR_FSMCEN)); + } +#endif +} + +static void +print_apb1_peripherals(struct streamer *streamer, bool all) +{ + uint32_t pckl1 = HAL_RCC_GetPCLK1Freq(); + uint32_t timmul = RCC->CFGR & RCC_CFGR_PPRE2_2 ? 2 : 1; + + streamer_printf(streamer, " APB1 PCLK1: %u\n", (unsigned int)pckl1); + if (all || RCC->APB1ENR & RCC_APB1ENR_TIM2EN) { + streamer_printf(streamer, " TIM2 %s %u (ARR %u)\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_TIM2EN), + pckl1 * timmul / (TIM2->PSC + 1), (TIM2->ARR)); + } + if (all || RCC->APB1ENR & RCC_APB1ENR_TIM3EN) { + streamer_printf(streamer, " TIM3 %s %u (ARR %u)\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_TIM3EN), + pckl1 * timmul / (TIM3->PSC + 1), (TIM3->ARR + 1)); + } + if (all || RCC->APB1ENR & RCC_APB1ENR_TIM4EN) { + streamer_printf(streamer, " TIM4 %s %u\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_TIM4EN), + pckl1 * timmul / (TIM4->PSC + 1)); + } +#ifdef RCC_APB1ENR_TIM5EN + if (all || RCC->APB1ENR & RCC_APB1ENR_TIM5EN) { + streamer_printf(streamer, " TIM5 %s %u\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_TIM5EN), + pckl1 * timmul / (TIM5->PSC + 1)); + } +#endif +#ifdef RCC_APB1ENR_TIM6EN + if (all || RCC->APB1ENR & RCC_APB1ENR_TIM6EN) { + streamer_printf(streamer, " TIM6 %s %u\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_TIM6EN), + pckl1 * timmul / (TIM6->PSC + 1)); + } +#endif +#ifdef RCC_APB1ENR_TIM7EN + if (all || RCC->APB1ENR & RCC_APB1ENR_TIM7EN) { + streamer_printf(streamer, " TIM7 %s %u\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_TIM7EN), + pckl1 * timmul / (TIM7->PSC + 1)); + } +#endif +#ifdef RCC_APB1ENR_TIM12EN + if (all || RCC->APB1ENR & RCC_APB1ENR_TIM12EN) { + streamer_printf(streamer, " TIM12 %s %u\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_TIM12EN), + pckl1 * timmul / (TIM12->PSC + 1)); + } +#endif +#ifdef RCC_APB1ENR_TIM13EN + if (all || RCC->APB1ENR & RCC_APB1ENR_TIM13EN) { + streamer_printf(streamer, " TIM13 %s %u\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_TIM13EN), + pckl1 * timmul / (TIM3->PSC + 1)); + } +#endif +#ifdef RCC_APB1ENR_TIM14EN + if (all || RCC->APB1ENR & RCC_APB1ENR_TIM14EN) { + streamer_printf(streamer, " TIM14 %s %u\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_TIM14EN), + pckl1 * timmul / (TIM14->PSC + 1)); + } +#endif + if (all || RCC->APB1ENR & RCC_APB1ENR_WWDGEN) { + streamer_printf(streamer, " WWD %s\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_WWDGEN)); + } + if (all || RCC->APB1ENR & RCC_APB1ENR_SPI2EN) { + streamer_printf(streamer, " SPI2 %s\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_SPI2EN), + pckl1 >> (1 + ((SPI2->CR1 & SPI_CR1_BR_Msk) >> SPI_CR1_BR_Pos))); + } +#ifdef RCC_APB1ENR_SPI3EN + if (all || RCC->APB1ENR & RCC_APB1ENR_SPI3EN) { + streamer_printf(streamer, " SPI3 %s %u\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_SPI3EN), + pckl1 >> (1 + ((SPI3->CR1 & SPI_CR1_BR_Msk) >> SPI_CR1_BR_Pos))); + } +#endif + if (all || RCC->APB1ENR & RCC_APB1ENR_USART2EN) { + streamer_printf(streamer, " USART2 %s\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_USART2EN)); + } +#ifdef RCC_APB1ENR_USART3EN + if (all || RCC->APB1ENR & RCC_APB1ENR_USART3EN) { + streamer_printf(streamer, " USART3 %s\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_USART3EN)); + } +#endif +#ifdef RCC_APB1ENR_UART4EN + if (all || RCC->APB1ENR & RCC_APB1ENR_UART4EN) { + streamer_printf(streamer, " UART4 %s\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_UART4EN)); + } +#endif +#ifdef RCC_APB1ENR_UART5EN + if (all || RCC->APB1ENR & RCC_APB1ENR_UART5EN) { + streamer_printf(streamer, " UART5 %s\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_UART5EN)); + } +#endif + if (all || RCC->APB1ENR & RCC_APB1ENR_I2C1EN) { + streamer_printf(streamer, " I2C1 %s\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_I2C1EN)); + } + if (all || RCC->APB1ENR & RCC_APB1ENR_I2C2EN) { + streamer_printf(streamer, " I2C2 %s\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_I2C2EN)); + } + if (all || RCC->APB1ENR & RCC_APB1ENR_I2C3EN) { + streamer_printf(streamer, " I2C3 %s\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_I2C3EN)); + } +#ifdef RCC_APB1ENR_CAN1EN + if (all || RCC->APB1ENR & RCC_APB1ENR_CAN1EN) { + streamer_printf(streamer, " CAN1 %s\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_CAN1EN)); + } +#endif +#ifdef RCC_APB1ENR_CAN2EN + if (all || RCC->APB1ENR & RCC_APB1ENR_CAN2EN) { + streamer_printf(streamer, " CAN2 %s\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_CAN2EN)); + } +#endif + if (all || RCC->APB1ENR & RCC_APB1ENR_PWREN) { + streamer_printf(streamer, " PWR %s\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_PWREN)); + } +#ifdef RCC_APB1ENR_DACEN + if (all || RCC->APB1ENR & RCC_APB1ENR_DACEN) { + streamer_printf(streamer, " DAC %s\n", on_off_state(RCC->APB1ENR & RCC_APB1ENR_DACEN)); + } +#endif +} + +static void +print_apb2_peripherals(struct streamer *streamer, bool all) +{ + uint32_t pckl2 = HAL_RCC_GetPCLK2Freq(); + uint32_t adcpre = (((ADC->CCR & ADC_CCR_ADCPRE_Msk) >> ADC_CCR_ADCPRE_Pos) + 1) * 2; + uint32_t timmul = RCC->CFGR & RCC_CFGR_PPRE2_2 ? 2 : 1; + + streamer_printf(streamer, " APB2 PCLK2: %u\n", (unsigned int)pckl2); + + if (all || RCC->APB2ENR & RCC_APB2ENR_USART1EN) { + streamer_printf(streamer, " USART1 %s\n", on_off_state(RCC->APB2ENR & RCC_APB2ENR_USART1EN)); + } + if (all || RCC->APB2ENR & RCC_APB2ENR_USART6EN) { + streamer_printf(streamer, " USART6 %s\n", on_off_state(RCC->APB2ENR & RCC_APB2ENR_USART6EN)); + } + + if (all || RCC->APB2ENR & RCC_APB2ENR_ADC1EN) { + streamer_printf(streamer, " ADC1 %s %u\n", on_off_state(RCC->APB2ENR & RCC_APB2ENR_ADC1EN), + pckl2 / adcpre); + } +#ifdef RCC_APB2ENR_ADC2EN + if (all || RCC->APB2ENR & RCC_APB2ENR_ADC2EN) { + streamer_printf(streamer, " ADC2 %s %u\n", on_off_state(RCC->APB2ENR & RCC_APB2ENR_ADC2EN), + pckl2 / adcpre); + } +#endif +#if defined(RCC_APB2ENR_ADC3EN) + if (all || RCC->APB2ENR & RCC_APB2ENR_ADC3EN) { + streamer_printf(streamer, " ADC3 %s %u\n", on_off_state(RCC->APB2ENR & RCC_APB2ENR_ADC3EN), + pckl2 / adcpre); + } +#endif +#if defined(RCC_APB2ENR_ADC3EN) + if (all || RCC->APB2ENR & RCC_APB2ENR_ADC3EN) { + streamer_printf(streamer, " SDIO %s\n", on_off_state(RCC->APB2ENR & RCC_APB2ENR_ADC3EN)); + } +#endif + if (all || RCC->APB2ENR & RCC_APB2ENR_SDIOEN) { + streamer_printf(streamer, " SDIO %s %u\n", on_off_state(RCC->APB2ENR & RCC_APB2ENR_SDIOEN), + pckl2 / (2 + (SDIO->CLKCR & SDIO_CLKCR_CLKDIV_Msk))); + } + if (all || RCC->APB2ENR & RCC_APB2ENR_SPI1EN) { + streamer_printf(streamer, " SPI1 %s %u\n", on_off_state(RCC->APB2ENR & RCC_APB2ENR_SPI1EN), + pckl2 >> (1 + ((SPI1->CR1 & SPI_CR1_BR_Msk) >> SPI_CR1_BR_Pos))); + } +#if defined(RCC_APB2ENR_SPI4EN) + if (all || RCC->APB2ENR & RCC_APB2ENR_SPI4EN) { + streamer_printf(streamer, " SPI4 %s %u%s\n", on_off_state(RCC->APB2ENR & RCC_APB2ENR_SPI4EN), + pckl2 >> (1 + ((SPI4->CR1 & SPI_CR1_BR_Msk) >> SPI_CR1_BR_Pos)), + (SPI4->I2SCFGR & SPI_I2SCFGR_I2SMOD) ? " (I2S)" : ""); + } +#endif +#if defined(RCC_APB2ENR_SPI5EN) + if (all || RCC->APB2ENR & RCC_APB2ENR_SPI5EN) { + streamer_printf(streamer, " SPI5 %s %u%s\n", on_off_state(RCC->APB2ENR & RCC_APB2ENR_SPI5EN), + pckl2 >> (1 + ((SPI5->CR1 & SPI_CR1_BR_Msk) >> SPI_CR1_BR_Pos)), + (SPI5->I2SCFGR & SPI_I2SCFGR_I2SMOD) ? " (I2S)" : ""); + } +#endif + if (all || RCC->APB2ENR & RCC_APB2ENR_SYSCFGEN) { + streamer_printf(streamer, " SYSCFG %s\n", on_off_state(RCC->APB2ENR & RCC_APB2ENR_SYSCFGEN)); + } + + if (all || RCC->APB2ENR & RCC_APB2ENR_TIM1EN) { + streamer_printf(streamer, " TIM1 %s %u\n", on_off_state(RCC->APB2ENR & RCC_APB2ENR_TIM1EN), + pckl2 * timmul / (TIM1->PSC + 1)); + } +#ifdef RCC_APB2ENR_TIM8EN + if (all || RCC->APB2ENR & RCC_APB2ENR_TIM8EN) { + streamer_printf(streamer, " TIM8 %s %u\n", on_off_state(RCC->APB2ENR & RCC_APB2ENR_TIM8EN), + pckl2 * timmul / (TIM8->PSC + 1)); + } +#endif +#ifdef RCC_APB2ENR_TIM9EN + if (all || RCC->APB2ENR & RCC_APB2ENR_TIM9EN) { + streamer_printf(streamer, " TIM9 %s\n", on_off_state(RCC->APB2ENR & RCC_APB2ENR_TIM9EN), + pckl2 * timmul / (TIM9->PSC + 1)); + } +#endif +#ifdef RCC_APB2ENR_TIM10EN + if (all || RCC->APB2ENR & RCC_APB2ENR_TIM10EN) { + streamer_printf(streamer, " TIM10 %s\n", on_off_state(RCC->APB2ENR & RCC_APB2ENR_TIM10EN), + pckl2 * timmul / (TIM10->PSC + 1)); + } +#endif +#ifdef RCC_APB2ENR_TIM11EN + if (all || RCC->APB2ENR & RCC_APB2ENR_TIM11EN) { + streamer_printf(streamer, " TIM11 %s\n", on_off_state(RCC->APB2ENR & RCC_APB2ENR_TIM11EN), + pckl2 * timmul / (TIM11->PSC + 1)); + } +#endif +} + +static int +mcu_cli_info_cmd(const struct shell_cmd *cmd, int argc, char **argv, + struct streamer *streamer) +{ + bool all; + int sw = ((RCC->CFGR & RCC_CFGR_SWS) >> RCC_CFGR_SWS_Pos); + + all = argc > 1 && strcmp(argv[1], "all") == 0; + + streamer_printf(streamer, "Clocks:\n"); + streamer_printf(streamer, " SYSCLK: %u\n", (unsigned int)SystemCoreClock); + streamer_printf(streamer, " source %s\n", system_clock_source[sw]); + streamer_printf(streamer, " HSI: %s\n", on_off_state(RCC->CR & RCC_CR_HSION)); + streamer_printf(streamer, " HSE: %s\n", on_off_state(RCC->CR & RCC_CR_HSEON)); + streamer_printf(streamer, " PLL: %s\n", on_off_state(RCC->CR & RCC_CR_PLLON)); + streamer_printf(streamer, " LSI: %s\n", on_off_state(RCC->CSR & RCC_CSR_LSION)); + streamer_printf(streamer, " LSE: %s\n", on_off_state(RCC->BDCR & RCC_BDCR_LSEON)); + streamer_printf(streamer, "Peripherals:\n"); + print_ahb_peripherals(streamer, all); + print_apb1_peripherals(streamer, all); + print_apb2_peripherals(streamer, all); + + return 0; +} + +#if MYNEWT_VAL(SHELL_CMD_HELP) +static const struct shell_param mcu_cli_info_params[] = { + {"all", "show also disabled peripherals."}, + {NULL, NULL} +}; + +static const struct shell_cmd_help mcu_cli_info_help = { + .summary = "show mcu info", + .usage = "\n" + "info\n" + " Shows clocks, and enabled peripherals.\n" + "info all\n" + " Shows clocks and all peripherals.\n", + .params = mcu_cli_info_params, +}; +#endif + +static const struct shell_cmd mcu_cli_commands[] = { + SHELL_CMD_EXT("info", mcu_cli_info_cmd, &mcu_cli_info_help), + { }, +}; + +int +mcu_cli_init(void) +{ + shell_register("mcu", mcu_cli_commands); + + return 0; +} diff --git a/hw/mcu/stm/stm32f4xx/mcu_cli/syscfg.yml b/hw/mcu/stm/stm32f4xx/mcu_cli/syscfg.yml new file mode 100644 index 0000000000..d45c500937 --- /dev/null +++ b/hw/mcu/stm/stm32f4xx/mcu_cli/syscfg.yml @@ -0,0 +1,24 @@ +# +# Licensed to the Apache Software Foundation (ASF) under one +# or more contributor license agreements. See the NOTICE file +# distributed with this work for additional information +# regarding copyright ownership. The ASF licenses this file +# to you under the Apache License, Version 2.0 (the +# "License"); you may not use this file except in compliance +# with the License. You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, +# software distributed under the License is distributed on an +# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +# KIND, either express or implied. See the License for the +# specific language governing permissions and limitations +# under the License. +# + +syscfg.defs: + MCU_CLI_SYSINIT_STAGE: + description: > + Sysinit stage for mcu cli. + value: 501