Arduino和MPLAB X 开发STM32F103和PIC16F15376

2024-01-26 23:36

本文主要是介绍Arduino和MPLAB X 开发STM32F103和PIC16F15376,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

要点:

  1. 使用Arduino开发STM32F103(Blue Pill),MPLAB X 开发PIC16F15376(Curiosity Nano)
  2. C/C++嵌入式开发
  3. ESP32(Arduino、ESP-IDF)和STM32实时操作系统FreeRTOS

STM32使用FreeRTOS示例

在使用 FreeRTOS 时,您应该记住一些术语差异。 FreeRTOS 中的“任务”是一个程序的一部分,可以与同一程序中的其他部分同时运行。 如果您做过其他并发编程,它类似于“线程”。 但是,请注意,CMSIS-RTOS(我们的 RTOS 的抽象层)将这些并发部分称为“线程”。 因此,您可能会看到它们在整个程序中互换使用,即使它们的含义并不完全相同。

/* Includes ------------------------------------------------------------------*/
#include "main.h"
#include "cmsis_os.h"/* Private variables ---------------------------------------------------------*/
UART_HandleTypeDef huart2;
osThreadId_t blink01Handle;
osThreadId_t blink02Handle;/* Private function prototypes -----------------------------------------------*/
void SystemClock_Config(void);
static void MX_GPIO_Init(void);
static void MX_USART2_UART_Init(void);
void StartBlink01(void *argument);
void StartBlink02(void *argument);int main(void)
{HAL_Init();SystemClock_Config();MX_GPIO_Init();MX_USART2_UART_Init();osKernelInitialize();const osThreadAttr_t blink01_attributes = {.name = "blink01",.priority = (osPriority_t) osPriorityNormal,.stack_size = 128};blink01Handle = osThreadNew(StartBlink01, NULL, &blink01_attributes);/* definition and creation of blink02 */const osThreadAttr_t blink02_attributes = {.name = "blink02",.priority = (osPriority_t) osPriorityBelowNormal,.stack_size = 128};blink02Handle = osThreadNew(StartBlink02, NULL, &blink02_attributes);osKernelStart();while (1){}}void SystemClock_Config(void)
{RCC_OscInitTypeDef RCC_OscInitStruct = {0};RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};/** Initializes the CPU, AHB and APB busses clocks */RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;RCC_OscInitStruct.HSIState = RCC_HSI_ON;RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSI;RCC_OscInitStruct.PLL.PLLM = 1;RCC_OscInitStruct.PLL.PLLN = 10;RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV7;RCC_OscInitStruct.PLL.PLLQ = RCC_PLLQ_DIV2;RCC_OscInitStruct.PLL.PLLR = RCC_PLLR_DIV2;if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK){Error_Handler();}RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK|RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_4) != HAL_OK){Error_Handler();}PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_USART2;PeriphClkInit.Usart2ClockSelection = RCC_USART2CLKSOURCE_PCLK1;if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK){Error_Handler();}if (HAL_PWREx_ControlVoltageScaling(PWR_REGULATOR_VOLTAGE_SCALE1) != HAL_OK){Error_Handler();}
}static void MX_USART2_UART_Init(void)
{huart2.Instance = USART2;huart2.Init.BaudRate = 115200;huart2.Init.WordLength = UART_WORDLENGTH_8B;huart2.Init.StopBits = UART_STOPBITS_1;huart2.Init.Parity = UART_PARITY_NONE;huart2.Init.Mode = UART_MODE_TX_RX;huart2.Init.HwFlowCtl = UART_HWCONTROL_NONE;huart2.Init.OverSampling = UART_OVERSAMPLING_16;huart2.Init.OneBitSampling = UART_ONE_BIT_SAMPLE_DISABLE;huart2.AdvancedInit.AdvFeatureInit = UART_ADVFEATURE_NO_INIT;if (HAL_UART_Init(&huart2) != HAL_OK){Error_Handler();}}static void MX_GPIO_Init(void)
{GPIO_InitTypeDef GPIO_InitStruct = {0};/* GPIO Ports Clock Enable */__HAL_RCC_GPIOC_CLK_ENABLE();__HAL_RCC_GPIOH_CLK_ENABLE();__HAL_RCC_GPIOA_CLK_ENABLE();__HAL_RCC_GPIOB_CLK_ENABLE();/*Configure GPIO pin Output Level */HAL_GPIO_WritePin(LD2_GPIO_Port, LD2_Pin, GPIO_PIN_RESET);/*Configure GPIO pin : B1_Pin */GPIO_InitStruct.Pin = B1_Pin;GPIO_InitStruct.Mode = GPIO_MODE_IT_FALLING;GPIO_InitStruct.Pull = GPIO_NOPULL;HAL_GPIO_Init(B1_GPIO_Port, &GPIO_InitStruct);/*Configure GPIO pin : LD2_Pin */GPIO_InitStruct.Pin = LD2_Pin;GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;GPIO_InitStruct.Pull = GPIO_NOPULL;GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;HAL_GPIO_Init(LD2_GPIO_Port, &GPIO_InitStruct);}/* USER CODE END Header_StartBlink01 */
void StartBlink01(void *argument)
{/* USER CODE BEGIN 5 *//* Infinite loop */for(;;){HAL_GPIO_TogglePin(GPIOA, GPIO_PIN_5);osDelay(500);}// In case we accidentally exit from task looposThreadTerminate(NULL);/* USER CODE END 5 */ 
}/* USER CODE END Header_StartBlink02 */
void StartBlink02(void *argument)
{for(;;){HAL_GPIO_TogglePin(GPIOA, GPIO_PIN_5);osDelay(600);}// In case we accidentally exit from task looposThreadTerminate(NULL);/* USER CODE END StartBlink02 */
}void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{/* USER CODE BEGIN Callback 0 *//* USER CODE END Callback 0 */if (htim->Instance == TIM6) {HAL_IncTick();}/* USER CODE BEGIN Callback 1 *//* USER CODE END Callback 1 */
}void Error_Handler(void)
{}#ifdef  USE_FULL_ASSERTvoid assert_failed(char *file, uint32_t line)
{ }
#endif /* USE_FULL_ASSERT */

在 main() 的开头,您应该看到由 CubeMX 设置的为我们定义的线程。 请注意,我们将入口函数名称传递给 osThreadNew() 函数,一旦我们调用 osKernelStart(),该函数就会调用这些函数。 一旦 osKernelStart() 被调用,我们不希望在 main() 中的后面有任何代码,因为理想情况下,程序应该永远不会从 osKernelStart() 返回。

此时,我们的线程应该同时运行,具有自己的设置代码和永远的 while 循环。还有一个正在运行的后台调度程序任务,它负责在线程之间切换上下文。

StartBlink01() 和 StartBlink02() 是我们的线程。 每个都有自己的永远循环,并且它们应该同时运行。 虽然它们在我们的单核处理器中无法占用相同的空间和时间,但调度程序会切换它们,让我们看起来像是同时运行 2 个线程。

请注意,我们需要使用 osDelay(),而不是 HAL_Delay()。 高优先级任务中的 HAL_Delay() 可能会占用处理器,从而阻止上下文切换。 它还可以防止调度程序空闲,从而节省电量。 因此,我们使用 osDelay() 告诉调度程序在等待期间可以切换到不同的任务。

我们对blink01 和blink02 使用不同的延迟时间,以便这两个任务争夺LED 的切换。

开发环境

本文中描述的两个微控制器板(Blue Pill 和 Curiosity Nano)可以使用不同的 IDE 进行编程。 IDE是一种编程和调试软件工具,包括代码编辑器、编译环境、调试选项等。 许多 IDE 还用于通过 USB 端口连接将编译后的程序上传到微控制器板。

  • Arduino IDE:这个免费的 IDE 最初是为了对 Arduino 微控制器板进行编程而创建的,但如果您为其安装了库,您也可以使用它来对 Blue Pill 微控制器板进行编程。
  • MPLAB X IDE:由 Curiosity Nano 制造商 Microchip 制造。 这是对 Curiosity Nano 进行编程所需的免费 IDE。

Arduino和MPLAB X案例

  • 按钮开关LED
  • 用光敏电阻测量光量
  • 温湿度测量
  • 使用 LED 显示的莫尔斯电码 SOS 视觉警报
  • 创建拍手开关
  • 气体检测器
  • 互联网温度记录仪
  • 物联网花盆湿度传感器
  • 物联网太阳能(电压)测量
  • 数字体温测量(温度计)
  • 社交距离警报
  • 20 秒洗手计时器

ESP32和STM32实时操作系统FreeRTOS

ESP32(Arduino)多任务FreeRTOS

  • 队列管理
  • 更改任务的优先级
  • 如何使用FreeRTOS结构队列接收多个任务的数据
  • 如何使用 vTaskDelete() API 删除任务
  • 使用队列集
  • 创建带队列的邮箱
  • 创建一次性和自动重新加载定时器
  • 二进制信号量 – 使用 Arduino 进行任务中断同步的示例
  • 使用 Arduino 计数信号量示例
  • 斥教程 – 避免优先级反转
  • 递归互斥以避免死锁
  • 使用 Arduino 的 FreeRTOS 中断管理示例

ESP-IDF示例FreeRTOS

STM32开发调试FreeRTOS

参阅一: 亚图跨际
参阅二:亚图跨际

这篇关于Arduino和MPLAB X 开发STM32F103和PIC16F15376的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/648395

相关文章

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

基于Python开发一个有趣的工作时长计算器

《基于Python开发一个有趣的工作时长计算器》随着远程办公和弹性工作制的兴起,个人及团队对于工作时长的准确统计需求日益增长,本文将使用Python和PyQt5打造一个工作时长计算器,感兴趣的小伙伴可... 目录概述功能介绍界面展示php软件使用步骤说明代码详解1.窗口初始化与布局2.工作时长计算核心逻辑3

python web 开发之Flask中间件与请求处理钩子的最佳实践

《pythonweb开发之Flask中间件与请求处理钩子的最佳实践》Flask作为轻量级Web框架,提供了灵活的请求处理机制,中间件和请求钩子允许开发者在请求处理的不同阶段插入自定义逻辑,实现诸如... 目录Flask中间件与请求处理钩子完全指南1. 引言2. 请求处理生命周期概述3. 请求钩子详解3.1

如何基于Python开发一个微信自动化工具

《如何基于Python开发一个微信自动化工具》在当今数字化办公场景中,自动化工具已成为提升工作效率的利器,本文将深入剖析一个基于Python的微信自动化工具开发全过程,有需要的小伙伴可以了解下... 目录概述功能全景1. 核心功能模块2. 特色功能效果展示1. 主界面概览2. 定时任务配置3. 操作日志演示

JavaScript实战:智能密码生成器开发指南

本文通过JavaScript实战开发智能密码生成器,详解如何运用crypto.getRandomValues实现加密级随机密码生成,包含多字符组合、安全强度可视化、易混淆字符排除等企业级功能。学习密码强度检测算法与信息熵计算原理,获取可直接嵌入项目的完整代码,提升Web应用的安全开发能力 目录