Перейти к содержанию

Настройка тактирования STM32F4 при помощи CMSIS


Гость Иван

Рекомендуемые сообщения

При смены множителя N в PLL, частота мерцания светодиодов остается неизменной. Даже если закомментировать регистры связанные с PLL и тактировать от HSE, то частота мигания светодиодов остается прежней.

Используется плата: stm32f4 discovery.

В чем может быть дело? Что не так?

Полный листинг программы:

#include "stm32f4xx.h"                 // Device header

int main (void)
	
{
		RCC->CR |= (RCC_CR_HSEON); 							//Enable HSE

	while( !(RCC->CR & RCC_CR_HSERDY) ) {} //ready to start HSE

	//FLASH
	FLASH->ACR |= FLASH_ACR_LATENCY | FLASH_ACR_PRFTEN| FLASH_ACR_ICEN| FLASH_ACR_DCEN;
	//PLL - HSE
	RCC->PLLCFGR |= RCC_PLLCFGR_PLLSRC_HSE; //set HSE as PLL source
	RCC->CR &= ~(RCC_CR_PLLON); 						//disable PLL before changes
	//PLL M
	RCC->PLLCFGR &= ~(RCC_PLLCFGR_PLLM); 		//clear all PLLM bits
	RCC->PLLCFGR |= RCC_PLLCFGR_PLLM_2; 		//set PLLM = 4 (100)
	//PLL P
	RCC->PLLCFGR &= ~(RCC_PLLCFGR_PLLP); 		//main PLL division PLLP = 2: 00
	//PLL N
	RCC->PLLCFGR &= ~(RCC_PLLCFGR_PLLN); 		//clear all PLLN bits with mask
	RCC->PLLCFGR |= RCC_PLLCFGR_PLLN_3; 		//set PLLN = 168 (1010 1000)
	RCC->PLLCFGR |= RCC_PLLCFGR_PLLN_5; 		//for 8 or 16 MHz HSE
	RCC->PLLCFGR |= RCC_PLLCFGR_PLLN_7; 		//
	//PLL Q 7 (0111)
	RCC->PLLCFGR &= ~(RCC_PLLCFGR_PLLQ);
	RCC->PLLCFGR |= (RCC_PLLCFGR_PLLQ_0	| RCC_PLLCFGR_PLLQ_2	| RCC_PLLCFGR_PLLQ_2);
	//AHB Prescaler
	RCC->CFGR &= ~(RCC_CFGR_HPRE); 					//Prescaler 1
	RCC->CFGR |= RCC_CFGR_HPRE_DIV1; 				//AHB = SYSCLK/1
	//APB1 Prescaler 8
	RCC->CFGR &= ~(RCC_CFGR_PPRE1);
	RCC->CFGR |= RCC_CFGR_PPRE1_DIV8;
	//APB2 Prescaler 2
	RCC->CFGR &= ~(RCC_CFGR_PPRE2);
	RCC->CFGR |= RCC_CFGR_PPRE2_DIV2;
	//PLL enable
	RCC->CR |= RCC_CR_PLLON; 								//enalbe PLL
	while((RCC->CR & RCC_CR_PLLRDY) == 0) {} 	//wait for PLL is ready
	//PLL System
	RCC->CFGR &= ~RCC_CFGR_SW;
	RCC->CFGR |= RCC_CFGR_SW_HSE; 					//PLL selected as system clock
	while((RCC->CFGR & RCC_CFGR_SWS) != RCC_CFGR_SWS_HSE) {} 	//wait for PLL is used

	
	RCC->AHB1ENR |=RCC_AHB1ENR_GPIODEN;	//start clock PORTD
	
	GPIOD->MODER |= GPIO_MODER_MODER15_0 | GPIO_MODER_MODER14_0 | GPIO_MODER_MODER13_0 | GPIO_MODER_MODER12_0; // Pin 15, 14, 13, 12 - out
	GPIOD->OTYPER &= ~0xF000; // Pin 15, 14, 13, 12 - Output push-pull
	GPIOD->OSPEEDR &= ~0xFF000000; // Pin 15, 14, 13, 12 - Low speed
	
	
while(1)
{
	// ON LED
	GPIOD->ODR |= GPIO_ODR_ODR_15 | GPIO_ODR_ODR_14 | GPIO_ODR_ODR_13 | GPIO_ODR_ODR_12;
	for (int i=0; i<24000000; i++){}
	// OFF LED
	GPIOD->ODR &= ~(GPIO_ODR_ODR_15 | GPIO_ODR_ODR_14 | GPIO_ODR_ODR_13 | GPIO_ODR_ODR_12);
	for (int i=0; i<24000000; i++){}
	
}
}

 

Ссылка на комментарий
Поделиться на другие сайты

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

RCC->CFGR |= RCC_CFGR_SW_HSE; 					//PLL selected as system clock
while((RCC->CFGR & RCC_CFGR_SWS) != RCC_CFGR_SWS_HSE) {} 	//wait for PLL is used

Источником тактирования выбран внешний кварц, а нужно выбирать PLL.

Должно быть как-то так:

RCC->CFGR |= RCC_CFGR_SW_PLL; 					//PLL selected as system clock
while((RCC->CFGR & RCC_CFGR_SWS) != RCC_CFGR_SWS_PLL) {} 	//wait for PLL is used

 

Ссылка на комментарий
Поделиться на другие сайты

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

4 часа назад, Вуйко сказал:

Источником тактирования выбран внешний кварц, а нужно выбирать PLL.

Должно быть как-то так:


RCC->CFGR |= RCC_CFGR_SW_PLL; 					//PLL selected as system clock
while((RCC->CFGR & RCC_CFGR_SWS) != RCC_CFGR_SWS_PLL) {} 	//wait for PLL is used

 

У меня так было изначально. Частота не меняется при смене N.

Это я потом пробовал с HSE

Ссылка на комментарий
Поделиться на другие сайты

  • 1 год спустя...

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
×
×
  • Создать...