opendrain

时间:2024-03-30 09:47:39编辑:优化君

什么是open drain

OPEN DRAIN输出只能做输出口,当外部无上拉电阻时,该口为高阻状态。只有外部有上拉电阻时,才有可能输出高或低的电平。当外部无上拉电阻时,该口不能输出高电平,应该可以输出低电平。如果接上拉电阻,则可以实现高低电平输出 。漏极开路输出,用法同等OC射极输出。如果作为图腾输出必须接上拉电阻。接容性负载时下降延是芯片内的晶体管是有源驱动速度较快,上升延是无源的外接电阻速度慢,如果要求速度高电阻选择要小,功耗会大。所以负载电阻的选择要兼顾功耗和速度。芯片的 Open drain 输出是设计用于"线或" (wire OR) 逻辑的. 也可以用于如继电器之类只吸入电流的负载, 或驱动比你的芯片电源电压高的负载,但要注意阅读手册上给出的耐压和最大驱动电流, 当然耐压一般比电源电压高。


GPIO 输入模式是什么意思

*Input floating: 引脚悬空,就是没有上拉也没有下拉电阻的意思,针对外部有上拉器件使用,节省能耗,做AD输入时也可以这样设置。

*Input pull-up: 芯片输入有内部有上拉电阻(电阻接VCC)

*Input pull-down: 芯片输入有内部下拉电阻(电阻接)

*Analog input: 模拟输入,用于AD,比较器输入(我理解是跟floating一样,实际我没有用到这个方式)

*Output open-drain: 开漏输出,类似三极管集电极引出,就是输出没有上拉电阻,要外部供电,否则输出永远是“0”

*Output push-pull: 推挽输出,输出引脚对VCC和对地各有一个MOS管,输出电流较大

*Alternate function push-pull: 复用推挽输出

*Alternate function open-drain: 复用开漏输出
最后这两个功能请参考端口映射说明。


单片机中的一些缩写的意思

SCM(Single Chip Micyoco缩写),是单片微型计算机的简称,从广义上讲单片机是微型计算机的一种,是集成在一个芯片上的,专门用于检测控制领域上的微型计算机。单片机又称单片微控制器,它不是完成某一个逻辑功能的芯片,而是把一个计算机系统集成到一个芯片上。相当于一个微型的计算机,和计算机相比,单片机只缺少了I/O设备。概括的讲:一块芯片就成了一台计算机。它的体积小、质量轻、价格便宜、为学习、应用和开发提供了便利条件。同时,学习使用单片机是了解计算机原理与结构的最佳选择。扩展资料单片机用到的一些缩写、单词:1、RISC: Reduced Instruction Set Computer 精简指令集计算机2、RTOS:Real Time Operating System 实时操作系统3、DMA:Direct Memory Access 存储器直接访问4、EXTI: External Interrupts 外部中断5、FSMC: Flexible static memory controller 可变静态存储控制器6、FPB:flash patch and breakpoint FLASH 转换及断电单元参考资料来源:百度百科-单片机

单片机IO口设置为open drain有什么好处?

open drain相当于双极器件中的open collector(集电极开路电路),它的一个重要的优点是可以“线与”,就是说当多个漏极开路器件的输出连在一起的时候,只要是其中一个导通,输出就为‘0’。这个特性被广泛用于串行总线电路。至于说上拉电阻对外部电路的影响应该算不上是优点吧。
楼上的“上拉电阻的选择权在用户”意思是,在不用片内上拉电阻的时候,使用者要在外部加一个上拉电阻。
片内上拉电阻的阻值一般手册里边都有标明,大概是几K 吧。


单片机I2C总线通信问题,高手进

IIC总线工作原理 I2C总线进行数据传送时,时钟信号为高电平期间,数据线上的数据必须保持稳定,只有在时钟线上的信号为低电平期间,数据线上的高电平或低电平状态才允许变化。 起始和终止信号 :SCL线为高电平期间,SDA线由高电平向低电平的变化表示起始信号;SCL线为高电平期间,SDA线由低电平向高电平的变化表示终止信号。数据传送格式(1)字节传送与应答每一个字节必须保证是8位长度。数据传送时,先传送最高位(MSB),每一个被传送的字节后面都必须跟随一位应答位(即一帧共有9位)。如果一段时间内没有收到从机的应答信号,则自动认为从机已正确接收到数据。 AT24C02的芯片地址如下图,1010为固定,A0,A1,A2正好与芯片的1,2,3引角对应,为当前电路中的地址选择线,三根线可选择8个芯片同时连接在电路中,当要与哪个芯片通信时传送相应的地址即可与该芯片建立连接,TX-1B实验板上三根地址线都为0。最后一位R/W为告诉从机下一字节数据是要读还是写,0为写入,1为读出。 AT24C02的芯片地址(0xa0为写,0xa1为读)任一地址写入数据格式 Void write_add(uchar address,uchar info)//指定地址写一个字节数据{ start(); writebyte(0xa0); respons(); writebyte(address); respons(); writebyte(info); respons(); stop();}
任一地址读取数据格式void init() //初始化{ SCL=1; delay(); SDA=1; delay();}void start() //启动信号{ SDA=1; delay(); SCL=1; delay(); SDA=0; delay();}void stop() //停止信号{ SDA=0; delay(); SCL=1; delay(); SDA=1; delay();}void respons() //回应信号{ uchar i=0;SCL=1;delay();while((SDA==1)&&(i<255))i++; SCL=0;delay();}void writebyte(uchar date)// 写一个字节{ uchar i,temp; temp=date; for(i=0;i<8;i++) { temp=temp<<1; SCL=0; delay(); SDA=CY; delay(); SCL=1; delay(); } SCL=0; delay(); SDA=1; delay();}uchar readbyte()//读一个字节{ uchar i,j,k; SCL=0; delay(); SDA=1; for(i=0;i<8;i++) { SCL=1; delay(); if(SDA==1) j=1; else j=0; k=(k<<1)|j; SCL=0; delay(); } delay(); return k;}uchar read_add(uchar address)//指定地址读一个字节数据{ uchar dd; start(); writebyte(0xa0); respons(); writebyte(address); respons(); start(); writebyte(0xa1); respons(); dd=readbyte(); stop(); return dd;}


上一篇:shang

下一篇:borntobewild