银杏科技有限公司旗下技术文档发布平台 | |||
技术支持电话 | 0379-69926675-801 | ||
技术支持邮件 | Gingko@vip.163.com | ||
版本 | 日期 | 作者 | 修改内容 |
---|---|---|---|
V1.0 | 2020-03-26 | gingko | 初次建立 |
1.在主界面选择File–>New Project 或者直接点击ACCEE TO MCU SELECTOR 2.出现芯片型号选择,搜索自己芯片的型号,双击型号,或者点击Start Project进入配置 在搜索栏的下面,提供的各 种查找方式,可以选择芯片内核,型号,等等,可以帮助你查找芯片。本实验选取的芯片型号为:STM32H750IBKx。 3.配置RCC,使用外部时钟源 4.时基源选择SysTick 5.将PA10,PB7,PB8设置为GPIO_Output 6.引脚模式配置 7.配置串口 在NVIC Settings一栏使能接收中断 引脚配置 8.时钟源设置,选择外部高速时钟源,配置为最大主频 9.工程文件的设置, 这里就是工程的各种配置 我们只用到有限几个,其他的默认即可 IDE我们使用的是 MDK V5.27 10.点击Code Generator,进行进一步配置
(1)接口的信号电平值较高,易损坏接口电路的芯片。RS232接口任何一条信号线的电压均为负逻辑关系。即:逻辑“1” 为-3—-15V;逻辑“0”:+3—+15V,噪声容限为2V。即要求接收器能识别高于+3V的信号作为逻辑“0”,低于-3V的信 号作为逻辑“1”,TTL电平为5V为逻辑正,0为逻辑负。与TTL电平不兼容故需使用电平转换电路方能与TTL电路连接。 (2)传输速率较低,在异步传输时,比特率为20Kbps;因此在51CPLD开发板中,综合程序波特率只能采用19200,也是 这个原因。 (3)接口使用一根信号线和一根信号返回线而构成共地的传输形式,这种共地传输容易产生共模干扰,所以抗噪声干扰 性弱。 (4)传输距离有限,最大传输距离标准值为50英尺,实际上也只能用在15米左右。
LED_ON\r\n | LED灯亮 |
LED_OFF\r\n | LED灯灭 |
int main(void) { int i; char buffer[20]; HAL_Init(); SystemClock_Config(); i2c.initialize(); axp152.initialize(); axp152.set_dcdc1(3500);//[ARM & FPGA BK1/2/6 &OTHER] axp152.set_dcdc2(1200);//[FPGA INT & PLL D] axp152.set_aldo1(2500);//[FPGA PLL A] axp152.set_dcdc4(3300);//[POWER_OUTPUT] axp152.set_dcdc3(3300);//[FPGA BK4][Adjustable] axp152.set_aldo2(3300);//[FPGA BK3][Adjustable] axp152.set_dldo1(3300);//[FPGA BK7][Adjustable] axp152.set_dldo2(3300);//[FPGA BK5][Adjustable] HAL_Delay(100); MX_GPIO_Init(); MX_USART1_UART_Init(); usart1.initialize(115200);//串口波特率设置 usart1.printf("Hello, I am iCore4T\r\n");//串口信息输出 LED_ON; while (1) { if(usart1.receive_ok_flag){ //接收完成 usart1.receive_ok_flag = 0; for(i = 0;i < 20;i++){ buffer[i] = tolower(usart1.receive_buffer[i]); }//比较接收信息 if(memcmp(buffer,"led_on",strlen("led_on")) == 0){ LED_ON; usart1.printf("ok!\r\n"); } if(memcmp(buffer,"led_off",strlen("led_off")) == 0){ LED_OFF; usart1.printf("ok!\r\n"); } } } }
UART_HandleTypeDef huart1;
typedef struct __UART_HandleTypeDef { USART_TypeDef *Instance; //UART寄存器基地址 UART_InitTypeDef Init; //UART通信参数 uint8_t * pTxBuffPtr; //指向UART Tx传输缓冲区的指针 uint16_t TxXferSize; //UART Tx传输大小 __IO uint16_t TxXferCount; //UART Tx传输计数器 uint8_t * pRxBuffPtr; //指向UART Rx传输缓冲区的指针 uint16_t RxXferSize; //UART Rx传输大小 __IO uint16_t RxXferCount; //UART Rx传输计数器 DMA_HandleTypeDef * hdmatx; //UART Tx DMA句柄参数 DMA_HandleTypeDef * hdmarx; //UART Rx DMA句柄参数 HAL_LockTypeDef Lock; //锁定对象 __IO HAL_UART_StateTypeDef gState; //与全局句柄管理有关的UART状态信息并且与Tx操作有关。 __IO HAL_UART_StateTypeDef RxState; //与Rx操作有关的UART状态信息 __IO uint32_t ErrorCode; //UART错误代码 } UART_HandleTypeDef;
HAL_UART_Transmit(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size, uint32_t Timeout)
HAL_UART_Receive_IT(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size)
HAL_UART_IRQHandler(UART_HandleTypeDef *huart); //串口中断处理函数 HAL_UART_TxCpltCallback(UART_HandleTypeDef *huart); //串口发送中断回调函数 HAL_UART_TxHalfCpltCallback(UART_HandleTypeDef *huart); //串口发送一半中断回调函数(用的较少) HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart); //串口接收中断回调函数 HAL_UART_RxHalfCpltCallback(UART_HandleTypeDef *huart); //串口接收一半回调函数(用的较少) HAL_UART_ErrorCallback(); //串口接收错误函数
HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart);
HAL_UART_GetState(); HAL_UART_IRQHandler(UART_HandleTypeDef *huart);
HAL_UART_GetState(); //判断UART的接收是否结束,或者发送数据是否忙碌