正点原子阿尔法ARM开发板-IMX6ULL(八)——串口通信(寄存器解释)(补:有源蜂鸣器)

文章目录

一、蜂鸣器(待,理解)

1.1 第一行

对于第一行,首先先到fsl_iomuxc文件里面寻找IOMUXC_SetPinMux这个函数

其次确定了SNV_TAMPER1并且复用为GPIO模式

之后查看,IM6ULL的参考手册,看到第32章节、找到SNV_TAMPER1

此时锁定复用方式为GPIO5_IO01

之后再到fsl_iomuxc,h上面找到这个SNV复用的宏定义,并且作为第一个输入参数

根据手册,第二个参数为输入,为0(查了下功能,0的意思是不需要使能软件输入功能?)

1.2 第二行

还是再fsl_iomuxc.h最下面找到IOMUXC_SetPinConfig,也就是电气属性

第一个参数还是和前面一样,最后还是和LDE一样设置为0X10B0,理由和LED的注释一样

1.3 第三行

刚刚我特地去看了下
正点原子阿尔法ARM开发板-IMX6ULL(四)------汇编LED驱动实验-下

首先为什么是(1<<1),因为IO01是在1这个位置,也就是2的一次方,所以左移一位,也就是2

关于或等于|=,也就是GDIR原本是什么不变,但是按位相或,有1则1.

第四行和第三行解释一样

首先是低电平打开,所以&=,有0则都0,所以取反

二、串口原理

2.1 通信格式

比特率:9600、19200、115200

TTL和232的区别

RS-232电平实在VGA口的com3的那

2.2 UART寄存器

在第55章,有IMX6ULL的UART_URXD保存着接受数据的寄存器

UART_UTXD寄存器为发送数据寄存器,如果需要通过串口发送数据,只需要将数据写入到UART_UTXD寄存器里面。

UART_UCR1-UCR4都是串口的控制寄存器。UART_UCR1的bit0是UART的使能位,为1的时候使能UART。Bit14为自动检测波特率使能位,为1的时候使能波特率自动检测。

UART_UCR2的bit0为软件复位位。为0的时候复位UART。Bit1使能UART的接收,我们要配置为1。Bit2为发送使能,要设置为1。Bit5设置数据位,0的话表示7位数据位,1的话表示8位数据位。Bit6设置停止位,0的话表示1位停位,1的话表示2位。Bit7奇偶校验位,为0的时候是偶校验,为1的时候是计校验。Bit8校验使能位,为0的时候关闭校验。

UART_UCR3的bit2必须为1!!

UART_UFCR寄存器的bit9~7设置分频值,UART的时钟源=PLL3/6=480/6=80MHz。CSCDR1寄存器的UART_CLK_SEL位设置UART的时钟源,为O的时候UART时钟源为8OMHz:,为1的时候UART时钟源为24M晶振。CSCDR1寄存器的UART_CLK_PODF位控制分频,一般设置为1分频,因此UART_CLK_ROOT:=80MHZ

UART_UFCR、UART_UBIR和UART_UBMR这三个寄存器决定了串口波特率。·

UART_USR2寄存器的bit0为1的时候表示有数据可以读取。Bit3为1的时候表示数据发送完成。

相关推荐
韦德斯1 天前
嵌入式Linux的RTC读写操作应用
linux·运维·c语言·arm开发·实时音视频
byte轻骑兵1 天前
嵌入式 ARM Linux 系统构成全解:从硬件到应用层层剖析
linux·arm开发·arm·嵌入式开发
思尔芯S2C1 天前
面向未来的智能视觉参考设计与汽车架构,思尔芯提供基于Arm技术的创新方案
arm开发·架构·汽车·iot·fpga原型验证·prototyping·智慧视觉
Eternal-Student2 天前
【docker了解】如何将x86镜像转换为适用于Jetson的ARM镜像
arm开发·docker·容器
不怕犯错,就怕不做2 天前
修复kernel编译栈帧大小异常问题error: the frame size of 1928 bytes is larger than 1024 bytes
linux·arm开发·驱动开发
憧憬一下3 天前
UART硬件介绍
arm开发·嵌入式硬件·串口·嵌入式·linux驱动开发
Petal9909124 天前
UEFI学习笔记(十八):ARM电源管理之PSCI和SCMI概述
arm开发·笔记·学习·uefi
古月居GYH4 天前
一文了解ARM内部架构
arm开发·架构
白书宇4 天前
13.100ASK_T113-PRO RTC实验
linux·arm开发·驱动开发·嵌入式硬件·物联网·硬件工程
简简单单一天吃六顿5 天前
rootfs根文件系统在Linux下制作动态库
linux·服务器·arm开发·iot