0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

既然ODR能控制管脚高低电平,为什么还需要BSRR寄存器呢?

工程师邓生 来源:未知 作者:刘芹 2023-10-24 11:49 次阅读

既然ODR能控制管脚高低电平,为什么还需要BSRR寄存器呢?

为什么需要BSRR寄存器

单片机中,为了控制端口的输出状态,我们需要使用特定的寄存器。其中,ODR寄存器负责直接控制端口输出电平,但是在某些情况下,我们需要更高效、更精准的控制电平状态,这时就需要使用BSRR寄存器了。

BSRR寄存器全称Bit Set/Reset Register,中文名称为位设置/重置寄存器,其作用是能够快速切换输入输出引脚的电平状态。通过BSRR寄存器的配置,我们可以简单、高效地设置或者重置对应的引脚电平,而无需进行其他操作。

BSRR寄存器的结构

BSRR寄存器总共32位,其中前16位是用于设置对应引脚的高电平,后16位是用于设置对应引脚的低电平。

在BSRR寄存器的低16位中,每4位对应一个引脚,以16进制的形式表示。例如:低16位的0号位(LSB)至3号位分别对应的引脚号为0~3,以此类推。对于高16位,它们与低16位的区别在于,它们控制对应引脚的低电平状态,即为清零操作。

例如,如果要使引脚1变为高电平,那么我们可以给BSRR寄存器的第17位(低16位的1号位)写入1,这将会把引脚1设置为高电平。如果想要将引脚1的电平设置为低电平,我们只需要给BSRR寄存器的第33位(高16位的1号位)写入1,即可实现。

BSRR寄存器与ODR寄存器的区别

虽然ODR和BSRR都可以控制引脚的电平状态,但是它们在实现上还是有一些区别的。

首先,ODR寄存器的写入操作是瞬时的,即写入后立即生效。而BSRR寄存器的写入操作是有延迟的,需要在CPU时钟上升沿时才能够生效,因此,如果需要精准地控制电平状态,我们需要根据CPU主频等因素,精确地计算出延迟时间。

其次,在使用BSRR寄存器时,我们可以直接通过对应电平位的写入操作,来实现针对某一位的设置或重置操作。这样,在高频率操作时,会比使用ODR寄存器更具有优势,不仅可以提高效率,还能保证电平状态的准确性。

还有一个重要区别是,在使用BSRR寄存器时,如果想要对某个引脚进行设置或重置,我们只需要对对应的位进行操作即可,而使用ODR寄存器时,我们需要同时对所有引脚进行设置或重置,这样会导致效率降低。

综上所述,BSRR寄存器与ODR寄存器相比,更加灵活高效,能够更好地满足实际需求,特别是在高频率控制电平情况下更为显著。

结语

在单片机的开发中,对端口的输入输出状态控制是一项非常基础的操作,因此理解和掌握相关的寄存器是非常重要的。在实际应用中,根据不同的场景需求,选择合适的寄存器会使我们的开发更加方便、高效。

BSRR寄存器虽然只是一个小小的寄存器,但是在高频率作业中,能够发挥出强大的功能和优势。因此,对于端口输出状态的控制需求得到了更好的满足。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 寄存器
    +关注

    关注

    31

    文章

    5357

    浏览量

    120701
  • odr
    odr
    +关注

    关注

    0

    文章

    5

    浏览量

    3568
  • bsrr
    +关注

    关注

    0

    文章

    2

    浏览量

    1268
收藏 人收藏

    评论

    相关推荐

    DAC5681z从FPGA读数据,为什么还需要一个DCLKP/N

    以DAC5681z为例,DAC芯片从FPGA读数据,然后按照自己的采样速率CLKIN/CLKINC 每隔16bit转换成1个电平值,为什么还需要一个DCLKP/N
    发表于 12-11 07:52

    ADS8678是否可以把CS直接拉低或者拉高,SDI保持低电平,使得ADC一直保持在STDBY模式?

    请问在使用ADS8678这款ADC的时候,向寄存器中写入8200h之后ADC进入STDBY模式,后续情况下SDI保持低电平就可以保持在STDBY模式,在保持低电平的时候,CS信号是否还需要
    发表于 11-29 08:30

    ADS62P49降低采样率,使用50M采样,除了“enable low speed mode”的寄存器还需要更改其他的设置吗?

    配置,输出时钟的频率是50MHz。 也改了ads62p49的“enable low speed mode”的寄存器,但是各种测试模式、正弦波出现的波形一直不对。 想问下还需更改哪些ads62p49的配置。除了“enable low speed mode”的
    发表于 11-18 07:04

    接口的控制与状态寄存器什么作用

    的行为并获取硬件的状态信息。 接口的控制与状态寄存器的作用 在现代计算机系统中,硬件设备与软件之间的交互是通过一系列的接口来实现的。这些接口不仅需要能够传输数据,还需要能够
    的头像 发表于 10-17 10:42 516次阅读

    请问tlv320dac3100设成喇叭输出时,应该怎样配置寄存器

    请问tlv320dac3100设成喇叭输出时,应该怎样配置寄存器? 我们按照datasheet中的example配置,spk有方波输出,但是没有音频数据,只有pop声。请问还需要修改哪些参数
    发表于 10-15 08:04

    寄存器是什么意思?寄存器是如何构成的?

    在计算机科学中,寄存器(Register)是一个高速存储单元,它位于中央处理(CPU)内部,用于存储计算机程序执行过程中所需要的数据、指令地址或状态信息。寄存器是计算机体系结构中至关
    的头像 发表于 08-02 18:23 4499次阅读
    <b class='flag-5'>寄存器</b>是什么意思?<b class='flag-5'>寄存器</b>是如何构成的?

    寄存器分为基本寄存器和什么两种

    寄存器是计算机中用于存储数据的高速存储单元,它们是CPU内部的重要组成部分。寄存器可以分为基本寄存器和扩展寄存器两种类型。 一、基本寄存器
    的头像 发表于 07-12 10:31 1496次阅读

    ESP32可以直接写入RX的高低电平,和直接读取TX的高低电平吗?

    如果串口的rx和tx的高低电平都是通过代码得到的状态,想把这个高低电平的变化解析成串口数据流,在不占用IO的情况下能否解析出数据? 也就是在includesocuart_struct.h这个寄存器
    发表于 06-07 08:20

    请求修正电路,当输入高低电平转换时,输出一秒低电平

    本帖最后由 du26548 于 2024-5-27 14:08 编辑 需求: INPUT高低电平转换时,OUT输出一秒低电平,其余时间为高阻态。 问题:D触发正常,555正常,高低电平
    发表于 05-27 13:11

    stm32的高低电平是怎么算的?

    请问下关于stm32的输入高低电平。 1.32输入多少算高,多少算低?是不是2v以上算高,0.8v一下算低;51是不是3.6和1.7为分界。 谢谢大家的回复
    发表于 05-16 06:27

    干货满满:ARM的内核寄存器讲解

    内核寄存器与外设寄存器: 内核寄存器与外设寄存器是完全不同的概念。内核寄存器是指 CPU 内部的寄存器
    发表于 04-17 11:47 3962次阅读
    干货满满:ARM的内核<b class='flag-5'>寄存器</b>讲解

    STM32的IO口初始化为输入浮空,那管脚是高电平还是低电平

    STM32的IO口初始化为输入浮空,那管脚是高电平还是低电平
    发表于 04-07 07:12

    AD7321的数据转换输出一直是高电平,不工作是为什么?

    AD7321的数据转换输出一直是高电平,前四位正常输出(通道0和通道1转换能在前四位体现出来),后12位数据位全是高电平,让AD7321工作只需要先写范围
    发表于 02-26 06:34

    CPU的6个主要寄存器

    CPU寄存器是中央处理内的组成部分,是有限存贮容量的高速存贮部件。寄存器是CPU内部的元件,包括通用寄存器、专用寄存器
    的头像 发表于 02-03 15:15 4539次阅读

    AD5522在写入寄存器的时候,busy信号一直为高电平,没有低电平的跳变是为什么?

    之前问了一个问题,没有得到解答。现在,我再描述一下我的问题。 1.我写入AD5522寄存器内的数据,都可以正确的读出来。 2.在写入寄存器的时候,busy信号一直为高电平,没有低电平
    发表于 01-12 07:24