Jump to content
Mars36

stm32f407vg отправка по UART

Recommended Posts

Доброго времени суток, второй день пытаюсь настроить отправку данных по UART для камня 407vg на плате discovery. Использую USART1 с ножками PB6(TX) и PB7(RX). Тактирование от внешнего кварца. Частота APB2 - 84MHz, соответственно BRR->0x222E.  При заливке прошивки в камень на ПК прилетает один мусорный байт и большей ничего не происходит, при ресете МК соответственно опять прилетает один мусорный байт. Пробовал подключать через USART2, там дела обстоят чуть лучше. Байты отправляются, но в виде мусора. Притом, отправлял разные символы(почти все цифры и буква алфавита) но код на терминали был либо 0xDF либо 0xFF.


/******************************************************************************/
/*                                 LYBRARY                                    */
/******************************************************************************/

#include "stm32f4xx.h"

/******************************************************************************/
/*                                 USE FUNCTION                               */
/******************************************************************************/

void InitGPIO (void);
void InitRCC(void);
void InitUSART2(void);
void delay (uint32_t time);

/******************************************************************************/
/*                                    MAIN                                    */
/******************************************************************************/

int main (void){
	
InitGPIO ();
InitRCC();
InitUSART2();
	while (1){
		
		GPIOD->BSRR |= GPIO_BSRR_BS15;
		while(!(USART1->SR & USART_SR_TC));
		USART1->DR = 'h';
		delay(200000000);
		GPIOD->BSRR |= GPIO_BSRR_BR15;
		delay(200000000);
		
	}
}

/******************************************************************************/
/*                                  InitGPIO                                  */
/******************************************************************************/
void InitUSART2(void){
	 RCC->APB2ENR |= RCC_APB2ENR_USART1EN;           
   RCC->AHB1ENR |= RCC_AHB1ENR_GPIOBEN;           

 
   GPIOB->MODER &= ~GPIO_MODER_MODER6_0;           
   GPIOB->MODER |= GPIO_MODER_MODER6_1;          
   GPIOB->PUPDR &= ~GPIO_PUPDR_PUPDR6;            
   GPIOB->OTYPER &= ~GPIO_OTYPER_OT_6;             
   GPIOB->OSPEEDR |= GPIO_OSPEEDER_OSPEEDR6;      
   GPIOB->AFR[0] |= 0x00000700;                       


   GPIOB->MODER &= ~GPIO_MODER_MODER7;              
   GPIOB->PUPDR &= ~GPIO_PUPDR_PUPDR7;               
   GPIOB->OSPEEDR |= GPIO_OSPEEDER_OSPEEDR7;   

   USART1->BRR = 0x0000222E;                             
   USART1->CR1 |= USART_CR1_UE;                       
   USART1->CR1 |= USART_CR1_TE;                      
   USART1->CR1 |= USART_CR1_RE;                       

   USART1->CR1 |= USART_CR1_RXNEIE;                  
   NVIC_EnableIRQ(USART1_IRQn);
}

void InitRCC(void){
	 RCC->CR |= ((uint32_t)RCC_CR_HSEON);                                    
   while (!(RCC->CR & RCC_CR_HSERDY));                                    

   FLASH->ACR = (FLASH_ACR_PRFTEN | FLASH_ACR_LATENCY|
                      FLASH_ACR_ICEN | FLASH_ACR_DCEN);                    

   RCC->CFGR |= RCC_CFGR_HPRE_DIV1;                                        
   RCC->CFGR |= RCC_CFGR_PPRE1_DIV4;                                       
   RCC->CFGR |= RCC_CFGR_PPRE2_DIV2;                                     

   RCC->CFGR &= ~RCC_PLLCFGR_PLLSRC;                                      
   RCC->CFGR &= ~RCC_PLLCFGR_PLLM;                                  
   RCC->CFGR &= ~RCC_PLLCFGR_PLLN;                                          
   RCC->CFGR &= ~RCC_PLLCFGR_PLLP;                                           

   RCC->CFGR |= RCC_PLLCFGR_PLLSRC_HSE;                                   
   RCC->CFGR |= RCC_PLLCFGR_PLLM_4;                                         
   RCC->CFGR |= (RCC_PLLCFGR_PLLN_7 | RCC_PLLCFGR_PLLN_5
                                                    | RCC_PLLCFGR_PLLN_3);      
                                          

   RCC->CR |= RCC_CR_PLLON;                                         
   while((RCC->CR & RCC_CR_PLLRDY) == 0) {}                           

   RCC->CFGR &= ~RCC_CFGR_SW;                                           
   RCC->CFGR |= RCC_CFGR_SW_PLL;                                     
   while((RCC->CFGR & RCC_CFGR_SWS) != RCC_CFGR_SWS_1) {} 
}

void InitGPIO (void) {

	RCC->AHB1ENR |= RCC_AHB1ENR_GPIODEN;                  			

	GPIOD->MODER |= GPIO_MODER_MODE15_0;                  		
	GPIOD->OTYPER &=~ GPIO_OTYPER_OT15;                  				
	GPIOD->OSPEEDR |= GPIO_OSPEEDR_OSPEED15_0;           			
	
	GPIOD->MODER |= GPIO_MODER_MODE14_0;                  		
	GPIOD->OTYPER &=~ GPIO_OTYPER_OT14;                  			
	GPIOD->OSPEEDR |= GPIO_OSPEEDR_OSPEED14_0;   
	
	GPIOD->MODER |= GPIO_MODER_MODE13_0;                 			 
	GPIOD->OTYPER &=~ GPIO_OTYPER_OT13;                  			 
	GPIOD->OSPEEDR |= GPIO_OSPEEDR_OSPEED13_0;          		   
	
	GPIOD->MODER |= GPIO_MODER_MODE12_0;
	GPIOD->OTYPER &=~ GPIO_OTYPER_OT12;
	GPIOD->OSPEEDR |= GPIO_OSPEEDER_OSPEEDR15_0;
}

void delay(uint32_t time){
	uint32_t i;
	for (i=0; i<time;i++);
}

 

2019-02-21_00-12-22.png

Share this post


Link to post
Share on other sites

тут GPIOB->AFR[0] |= 0x00000700; проблема 

как убедились что тактовая правильная? 

может еще что-то есть, завтра мож посмотрю.

Edited by MasterElectric

Share this post


Link to post
Share on other sites

Изготовление 2-х слойных плат от 2$, а 4-х слойных от 5$!

Быстрое изготовление прототипа платы всего за 24 часа! Прямая доставка с нашей фабрики!

Смотрите видео о фабрике JLCPCB: https://youtu.be/_XCznQFV-Mw

Посетите первую электронную выставку JLCPCB https://jlcpcb.com/E-exhibition чтобы получить купоны и выиграть iPhone 12, 3D-принтер и так далее...

@MasterElectric в кубе пожмакал делители, после прописал нужные руками. Получилось. Что на апб2 - 84mhz, что в притык по даташиту. (8400000+4800)/9600=0х222Е.

А что не так с регистром afr? Должен быть выбран младший, т.к. пины 6 и 7 и af7 из таблицы по референс мануалу, если нужно перенастроить с pa9 и pa10.

Share this post


Link to post
Share on other sites

Вебинар "Новый BlueNRG-LP с Bluetooth 5.2 и Long Range — волшебная палочка разработчика IoT" (04/02/2021)

Приглашаем 4 февраля на бесплатный вебинар о BlueNRG-LP - новой системе-на-кристалле (SoC) STMicroelectronics. На вебинаре будут детально рассмотрены функциональные блоки, особенности подключения, аппаратные и программные средства для разработки, настройка сценариев с помощью BlueNRG-GUI, практические примеры работы с микросхемой, а также примеры применения BlueNRG-LP в устройствах интернета вещей.

Подробнее

Новые компактные конденсаторы Panasonic серии TPS. Закаленный характер.

Panasonic представил новую серию TPS твердотельных танталовых конденсаторов с проводящим полимером для поверхностного монтажа. Конденсаторы серии TPS обладают уникальными особенностями, что делает их отличным выбором для использования в приложениях с высокими требованиями.

Подробнее

Если разрешаете прерывание по USART то надо и обработчик объявить, иначе работать на будет.

Share this post


Link to post
Share on other sites

SiC MOSFET на 1200 В для схем флайбэк до 500 Вт!

Компания Wolfspeed выпустила новые карбид-кремниевые транзисторы C3M0350120D/J на 1200 В, предназначенные для маломощных устройств мощностью до 500 Вт. Карбид-кремниевые транзисторы в сравнении с кремниевыми демонстрируют меньший на 75% уровень потерь на переключение и меньшее на 50% значение потерь проводимости в рабочем режиме при температуре кристалла 100…150°С.

Подробнее

@snn_krs Пока данные не принимаю. Сначала бы с отправкой разобраться. 

Изменил "GPIOB->AFR[0] |= 0x00000700;" на "GPIOB->AFR[0] |= GPIO_AFRL_AFRL7_0 | GPIO_AFRL_AFRL7_1 | GPIO_AFRL_AFRL7_2; " и сделал галушку для прерывания по приему на всякий случай, но все осталось точно так же. По идее делаю как написано в RM и даташите, хотя скорее всего я слепой.

2019-02-21_01-24-30.png

2019-02-21_01-24-04.png

Edited by Mars36

Share this post


Link to post
Share on other sites
11 hours ago, Mars36 said:

Изменил "GPIOB->AFR[0] |= 0x00000700;" на "GPIOB->AFR[0] |= GPIO_AFRL_AFRL7_0 | GPIO_AFRL_AFRL7_1 | GPIO_AFRL_AFRL7_2; "

Если только передачу отлаживаете то делайте для пина 6. А лучше для обеих "GPIOB->AFR[0] |= 0x77000000;"

Share this post


Link to post
Share on other sites
12 часа назад, Mars36 сказал:

Байты отправляются, но в виде мусора.

Глянул свой код для 205 проца. Настройка у него идентична 407. Для UART я задаю несколько больше настроек:

USART2->CR1 |= USART_CR1_RE | USART_CR1_TE | USART_CR1_UE | USART_CR1_M | USART_CR1_PCE | USART_CR1_PS;

 

Далее, вот тут GPIOB->AFR[0] |= 0x00000700; вы задаете настройки для PB2, а у вас PB6/PB7. У вас должно быть так: GPIOB->AFR[0] |= 0x77000000;

 

Ну и чисто для справки, delay удобно делать на системном таймере:

// SysTick INIT
SysTick_Config(120000000/1000);//1ms	

volatile unsigned int SysTickDelay;

void _delay_ms(uint32_t Val)
{
	   SysTickDelay = Val;
	   while (SysTickDelay != 0) {};
}

//------------------------------------------------------------------------
void SysTick_Handler(void)
{
   if (SysTickDelay != 0)
   {
      SysTickDelay--;
   }
}

 

Share this post


Link to post
Share on other sites

@BARS_Спасибо. Установил настройки UART как у вас и изменил значение AFR на " GPIOB->AFR[0] |= 0x77000000;". Ситуация улучшилась. Теперь байты передаются когда нужно, но так же какой то мусор. Как мне кажется дело либо в кодировке терминала либо с частотой МК. Функцию инициализации RCC перепроверил несколько раз, все должно быть в норме. Но терминал пишет ошибку связанную с битрейтом. Для удобства решил сразу отправлять код "0x31". 

Функцию для задержки написал, что бы случае чего не заспамило терминал, но за пример на таймере спасибо). До этого использовал FreeRTOS и задержку из перехода между задачами.

2019-02-21_13-53-08.png

Edited by Mars36

Share this post


Link to post
Share on other sites

USART_CR1_PCE | USART_CR1_PS уберите, это включается контроль четности. Забыл их удалить. А тактовую можно проверить при помощи моего delay. Настроить задержку на 1000мс, например, и помигать диодом. Если мигает раз в секунду, значит все гуд. Только в SysTick_Config(120000000/1000);//1ms свою частоту впишите.

Share this post


Link to post
Share on other sites

@BARS_ Поправил настройку и использовал функцию задержки на таймере, тоже самое. Подключил РТОС и использовал его задержку и так же по нулям.Понизив частоту до 24 Mhz сообщение об ошибке не стало но мусор остался. Нашел тему на easyelectronics с частично похожей проблемой. Там ее решили. Решенный вариант я залил в свой камень, но вместо сообщения "Hello" приходит один и тот же код 0xF8, хотя на отправку идет пять символов. Код с той темы:

#include "stm32f4xx.h"                  // Device header
#include "FreeRTOS.h"
#include "task.h"
#include "queue.h"

void RCC_Init(void);
void GPIO_Init(void);
void UART_Init(void);

void USART2_send (char chr);

void vTaskLed1 (void *argument);

int main(void){
   RCC_Init();
   GPIO_Init();
   UART_Init();

   xTaskCreate(vTaskLed1,"LED1",32,NULL,1,NULL);

   vTaskStartScheduler();                        //planner

   while(1);
}

//**********************************************************************************

void vTaskLed1 (void *argument){
   while(1){
      GPIOD->ODR |= GPIO_ODR_ODR_12;         //turn on led green
      GPIOD->ODR &= ~GPIO_ODR_ODR_13;         //turn off led orange
      vTaskDelay(10000);
      GPIOD->ODR |= GPIO_ODR_ODR_13;         //turn on led orange
      GPIOD->ODR &= ~GPIO_ODR_ODR_12;         //turn off led green

      USART2_send('H');
      USART2_send('e');
      USART2_send('l');
      USART2_send('l');
      USART2_send('0');
      USART2_send('!');
      USART2_send('\n');
      vTaskDelay(10000);
   }
}


//**********************************************************************************


void RCC_Init(void){
   RCC->CR |= ((uint32_t)RCC_CR_HSEON);                                     // Enable HSE
   while (!(RCC->CR & RCC_CR_HSERDY));                                       // Ready start HSE

   FLASH->ACR = (FLASH_ACR_PRFTEN | FLASH_ACR_LATENCY|
                      FLASH_ACR_ICEN | FLASH_ACR_DCEN);                     // Cloclk Flash memory

   RCC->CFGR |= RCC_CFGR_HPRE_DIV1;                                          // AHB = SYSCLK/1 - 168/1
   RCC->CFGR |= RCC_CFGR_PPRE1_DIV4;                                          // APB1 = HCLK/4 - 168/4 = 42
   RCC->CFGR |= RCC_CFGR_PPRE2_DIV2;                                          // APB2 = HCLK/2 - 168/2 = 84

   RCC->CFGR &= ~RCC_PLLCFGR_PLLSRC;                                          // clearn PLLSRC bits
   RCC->CFGR &= ~RCC_PLLCFGR_PLLM;                                    // clearn PLLM bits
   RCC->CFGR &= ~RCC_PLLCFGR_PLLN;                                             // clearn PLLN bits
   RCC->CFGR &= ~RCC_PLLCFGR_PLLP;                                             // clearn PLLP bits

   RCC->CFGR |= RCC_PLLCFGR_PLLSRC_HSE;                                     // source HSE = 8MHz
   RCC->CFGR |= RCC_PLLCFGR_PLLM_4;                                           // source HSE/4 = 2 MHz
   RCC->CFGR |= (RCC_PLLCFGR_PLLN_7 | RCC_PLLCFGR_PLLN_5
                                                    | RCC_PLLCFGR_PLLN_3);       // is set N mul: PLLM x168: clock = 2 MHz * 168 = 336 MHz
   // already RCC_PLLCFGR_PLLP = 0;                                           // PLLN/2 = 336 MHz * 2 = 168 MHz

   RCC->CR |= RCC_CR_PLLON;                                           // enable PLL
   while((RCC->CR & RCC_CR_PLLRDY) == 0) {}                           // wait till PLL is ready

   RCC->CFGR &= ~RCC_CFGR_SW;                                            // clear SW bits
  RCC->CFGR |= RCC_CFGR_SW_PLL;                                      // select source SYSCLK = PLL
   while((RCC->CFGR & RCC_CFGR_SWS) != RCC_CFGR_SWS_1) {}          // wait till PLL is used
}

void GPIO_Init (void){
   RCC->AHB1ENR |= RCC_AHB1ENR_GPIODEN;   //Turn on clock on AHB1 to GPIOD

   GPIOD->MODER &= ~GPIO_MODER_MODER13;   //PD15 - clear - led orange
   GPIOD->MODER |= GPIO_MODER_MODER13_0;   //PD13 - PP - led orange
   GPIOD->MODER &= ~GPIO_MODER_MODER12;   //PD15 - clear - led green
   GPIOD->MODER |= GPIO_MODER_MODER12_0;   //PD12 - PP - led green
   GPIOD->OSPEEDR = 0;               //low speed for all gpiod
   GPIOD->OTYPER = 0;
}

void UART_Init(void){
   RCC->APB1ENR |= RCC_APB1ENR_USART2EN;            //Turn on clock on APB1 to UASRT1 ----------------------------тут
   RCC->AHB1ENR |= RCC_AHB1ENR_GPIOAEN;            //Turn on clock on AHB1 to GPIOA

   //PA2 - TX
   GPIOA->MODER &= ~GPIO_MODER_MODER2_0;            //MODER 10
   GPIOA->MODER |= GPIO_MODER_MODER2_1;            //MODER 10
   GPIOA->PUPDR &= ~GPIO_PUPDR_PUPDR2;               //PUPDR 00
   GPIOA->OTYPER &= ~GPIO_OTYPER_OT_2;               //OTYPER 0 => PA2 - AF PP
   GPIOA->OSPEEDR |= GPIO_OSPEEDER_OSPEEDR2;      //OSPEED 11 -  very high speed
   GPIOA->AFR[0] |= 0x00000700;                        //AF7

   //PA3 - RX
   GPIOA->MODER &= ~GPIO_MODER_MODER3;               //MODER 00
   GPIOA->PUPDR &= ~GPIO_PUPDR_PUPDR3;               //PUPDR 0 => PA3 - floating input
   GPIOA->OSPEEDR |= GPIO_OSPEEDER_OSPEEDR3;   //OSPEED 11 -  very high speed

   USART2->BRR = 0x00001117;                              // BRR = (f(APB1)+ 4800)/9600, f(APB1) == 42 MHz
   USART2->CR1 |= USART_CR1_UE;                        //Enable USART2
   USART2->CR1 |= USART_CR1_TE;                        //Transmitter USART2
   USART2->CR1 |= USART_CR1_RE;                        //Resiver USART2

   USART2->CR1 |= USART_CR1_RXNEIE;                  //RX Interrupt Enable
   NVIC_EnableIRQ(USART2_IRQn);
}

void USART2_send (char chr){
   while(!USART2->SR & USART_SR_TC);
   USART2->DR = chr;
}

 

У человека с той темы так же дискавери. Как по мне сажать UART на P2-P3 не очень хорошо, т.к. по схеме там висят железки, но у него как я понял все заработало. Подумал, что это из за юсб хаба к которому подключена отладка и USB->UART, но попробовав воткнуть сразу в порту на материнке, ноутбуке и другом компе, но ситуация не изменилась. Странно, что каждый раз приходит почти один и тот же код.

Edited by Mars36

Share this post


Link to post
Share on other sites

Join the conversation

You are posting as a guest. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Loading...

  • Сообщения


  • Футболка электронщика

  • Similar Content

    • By Стальной
      Доброго времени суток!
      Неделю не могу запустить DCMI на STM32F407VET6. 
      Работаю через HAL, инициализация кубом. К МК подключена камера OV7670. Камера дает картинку 640х480, и такое изображение мне негде хранить. Поэтому через фичу CROP хочу вырезать картинку 160х128 из центра под имеющийся экран.
      Ниже примерный код, без настройки камеры. Камера тактируется от 16 МГц MCO. Сигналы поступают на выводы МК, посмотрел осциллографом. У камеры есть некоторые настройки, которые тут в коде не показал, так как они влияют только на представление данных, но не на алгоритм захвата данных.
      /* USER CODE BEGIN PV */ uint16_t DCMI_data[20480] = {0}; //128*160=20480 words uint32_t ptr; /* USER CODE END PV */ //тут еще код куба, пропущу его int main(void) { /* USER CODE BEGIN 1 */ /* USER CODE END 1 */ /* MCU Configuration--------------------------------------------------------*/ /* Reset of all peripherals, Initializes the Flash interface and the Systick. */ HAL_Init(); /* USER CODE BEGIN Init */ /* USER CODE END Init */ /* Configure the system clock */ SystemClock_Config(); /* USER CODE BEGIN SysInit */ /* USER CODE END SysInit */ /* Initialize all configured peripherals */ MX_GPIO_Init(); MX_DMA_Init(); MX_DCMI_Init(); /* USER CODE BEGIN 2 */ HAL_GPIO_WritePin(GPIOA, GPIO_PIN_15, GPIO_PIN_SET); //снять ресет с матрицы ptr = (uint32_t)(&DCMI_data[0]); HAL_Delay( 500 ); //начать резать с 512 клока строки (256 пиксель), начать резать с 160 строки //захватить 256 клоков (128 пикселей), захватить 160 строк HAL_DCMI_ConfigCrop(&hdcmi, 512, 160, 256, 160); HAL_DCMI_EnableCrop(&hdcmi); /* USER CODE END 2 */ /* Infinite loop */ /* USER CODE BEGIN WHILE */ while (1) { /* USER CODE END WHILE */ /* USER CODE BEGIN 3 */ HAL_DCMI_Start_DMA(&hdcmi, DCMI_MODE_SNAPSHOT, ptr, 10240); //однократный захват, 10240 тетрад, 20480 слов, 160*128=40960 пикселей HAL_Delay(1500); } /* USER CODE END 3 */ } В результате в буфере ничего не появляется, DMA туда ничего не кладёт, проверил. Если не вызывать функцию EnableCrop, но какие-то данные появляются, но на экран их корректно отобразить не получается. Также пытался в камере обрезку включить, а не в МК - снова нет данных. Пробовал разные частоты тактирования матрицы давать - без разницы. Отладчиком увидел, что бит EN в регистре конфигурации потока  DMA не снимается, как будто DMA не получал запросов на транзакции. Помогите, пожалуйста, разобраться.
      Проект на яндексДиске
    • By Карен Григорян
      Здравствуйте, товарищи форумчане!
      У меня вот такая проблемка: есть такая схема:

      По сути тут stm32 на который подаётся некоторое постоянное напряжение, а именно на вход PA1. МК получает его, приводит в цифровую форму (разрядность АЦП равна восьми) и выводит их при помощи восьми GPIO выводов, а именно PB0-PB7. Эти выводы соединены со схемой ЦАП, которая преобразует значение, полученное от stm32 обратно в аналоговую форму и выводит в пробнике R2(1).
      Проблема в том результат выводится не верный. Точнее говоря не всегда верный. Когда я подаю 1В, то на выходе получаю 0,99В, что верно. Но когда, например, подаю 300мВ, то получаю 1.8В, что совсем не верно. Код прошивки предельно прост:
        while (1)
        {
              HAL_ADC_Start_IT(&hadc1);
              HAL_Delay(10);
      }
      Код колбека прерывания:
      void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef* hadc)
      {
          if(hadc->Instance == ADC1) //check if the interrupt comes from ACD1
          {
            int adc = HAL_ADC_GetValue(&hadc1);
                  HAL_GPIO_WritePin(GPIOB,GPIO_PIN_0,(adc>>0)&1);
                  HAL_GPIO_WritePin(GPIOB,GPIO_PIN_1,(adc>>1)&1);
                  HAL_GPIO_WritePin(GPIOB,GPIO_PIN_2,(adc>>2)&1);
                  HAL_GPIO_WritePin(GPIOB,GPIO_PIN_3,(adc>>3)&1);
                  HAL_GPIO_WritePin(GPIOB,GPIO_PIN_4,(adc>>4)&1);
                  HAL_GPIO_WritePin(GPIOB,GPIO_PIN_5,(adc>>5)&1);
                  HAL_GPIO_WritePin(GPIOB,GPIO_PIN_6,(adc>>6)&1);
                  HAL_GPIO_WritePin(GPIOB,GPIO_PIN_7,(adc>>7)&1);
          }
              }
      На всякий случай вот настройка АЦП в stm32:

      Вот пример неправильного вычисления:

    • By Vladimir Rubtsov
      Здраствуйте) Подскажите мне балбесу что я делаю не так. Хочу сделать чтобы при нажатии кнопки (PB13) срабатывал светодиод (PE1), но не работает, я как понял что я не правильно инициализирую режим работы порта кнопки, должен быть режим Input mode, но я не пойму как это сделать. У меня просто горит светодиод, но при нажатии кнопки ничего не происходит. Плата у меня stm32h743zi. Подскажите пожалуйста что я делаю не так, все сайты прочекал, но так ничего и не нашел. p.s. Пробовал через HAL писать тоже самое, там естественно все работает, но я хочу понять как работать с кнопкой без HAL.
      #include "stm32h7xx.h" void GPIO_Init(void); int main(void) { GPIO_Init(); if((GPIOC->IDR & GPIO_IDR_ID13) != 0) { GPIOE->BSRR |= GPIO_BSRR_BR1; }else{ GPIOE->BSRR |= GPIO_BSRR_BS1; } } void GPIO_Init () { RCC->AHB4ENR |= RCC_AHB4ENR_GPIOEEN; RCC->AHB4ENR |= RCC_AHB4ENR_GPIOCEN; GPIOE->MODER = GPIO_MODER_MODE1_0; GPIOC->MODER &= ~GPIO_MODER_MODE13; }


    • By Денисов Никита
      Здравствуйте. Решил я таки попробовать перебраться с Arduino AVR на STM32 и для начала решил полностью скопировать Arduino проект, но появилась проблема. Код который на AVR занимал 7кбайт и свободно вмещался на Atmega8, на STM32 занимает 26кбайт. В проекте используется 2 канала ацп + прерывания по DMA, дисплей 1602 по i2c и 4 GPIO. Конечно это занимает только 42% памяти STM32F103C8T, но для такого проекта она избыточна и я хотел использовать STM32F030F4P, но там только 16 кб памяти и прошивка не влезает. Что я не так делаю? Может нужно какую-то оптимизацию включить или что-то подобное(выбран уровень оптимизации for size)? Или у меня просто код никчёмный? Но там так мало написано, что сомневаюсь что я мог где-то накосячить 
    • By Любовь Бертулите
      Компания производитель вендинговых автоматов для розлива питьевой воды в поисках инженера-системотехника/инженера электронщика.
      График 5/2 с 9 до 18, здесь удаленный формат не рассматриваем.
      Место работы – г. Екатеринбург.
      Мы ищем специалиста, который будет делать прототипы нового для контроллера, курировать производство, проверять, дорабатывать, перепаивать, а также:
      Переписывать текущие программы на С++; Создавать программу для Android для конфигурации параметров контроллера через bluetooth. (т.е. предлагать новые, современные идеи и подходы для развития имеющихся контроллеров, которыми вы владеете); Предлагать новые программные продукты, среды разработки. Будет в тренде мира микроэлектроники, китайского контрактного производства. Может предложить совершенно новую реализацию наших текущих задач, чтобы это было лучше и эффективнее. В идеале, нам нужен специалист, который имеет:
      Опыт программирования микроконтроллеров Atmega, STM32, ESP32; Опыт работы в Altium Designer; Опыт работы в c++ (IAR, QT); Опыт работы с modbus, rs485/232, SPI. Готовы рассматривать специалистов с разным опытом, поэтому пишите, задавайте вопросы.
      Резюме можно отправить на почту lb@ktekt.ru (да, мы кадровое агентство), позвонить можно по следующему тел. 89068001212 - Любовь. 
       
×
×
  • Create New...