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

相关文章

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

C#图表开发之Chart详解

《C#图表开发之Chart详解》C#中的Chart控件用于开发图表功能,具有Series和ChartArea两个重要属性,Series属性是SeriesCollection类型,包含多个Series对... 目录OverviChina编程ewSeries类总结OverviewC#中,开发图表功能的控件是Char

鸿蒙开发搭建flutter适配的开发环境

《鸿蒙开发搭建flutter适配的开发环境》文章详细介绍了在Windows系统上如何创建和运行鸿蒙Flutter项目,包括使用flutterdoctor检测环境、创建项目、编译HAP包以及在真机上运... 目录环境搭建创建运行项目打包项目总结环境搭建1.安装 DevEco Studio NEXT IDE

Python开发围棋游戏的实例代码(实现全部功能)

《Python开发围棋游戏的实例代码(实现全部功能)》围棋是一种古老而复杂的策略棋类游戏,起源于中国,已有超过2500年的历史,本文介绍了如何用Python开发一个简单的围棋游戏,实例代码涵盖了游戏的... 目录1. 围棋游戏概述1.1 游戏规则1.2 游戏设计思路2. 环境准备3. 创建棋盘3.1 棋盘类

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来