1、C8051F 单片机的 IO 口设置c8051f020 I/O 配置小结 2007-04-06 23:05020 的每个 I/O 口引脚都可以被配置为推挽或漏极开路输出。同时引入了数字交叉开关,允许将内部数字系统资源映射到 P0、P1、P2 和 P3 的端口引脚。通过设置交叉开关寄存器可将片内的计数器/定时器、串行总线、硬件中断、ADC 转换启动输入、比较器输出以及微控制器内部的其他数字信号配置为出现在端口 I/O 引脚。必须在访问这些外设的 I/O 之前配置和允许交叉开关。注意的问题:1.低端口既能按位寻址,也可以按字节寻址;高端口只能按字节寻址。2.没有被分配到的引脚作为一般的数字通用 I
2、/O 口。3.P1 口还可以用作 ADC1 的模拟输入。4.P0MDOUTP3MDOUT 用于控制 I/O 端口每一位的输出状态。5.EMIF(外部存储器接口)是用于 CPU 与片外 XRAM 之间的数据传输通道,通过寄存器 EMI0CF 和 EMI0CN 选择和管理端口实现数据的传输。6.为了能访问片外存储器空间,必须设置 EMI0CN 寄存器的内容为片外存储器的空间页地址。7.如果把外部存储器接口(EMIF)设置在高端口则首先要把 EMI0CF 的 PRTSEL位设置为 1,选择高端口,同时选择地址的复用或非复用方式,在把 XBR 的外部寄存器的 EMIFLE 位设置为 0。8.复用方式配
3、置:在复用方式下,数据总线和地址总线的第 8 位共用相同的引脚(AD0AD7)。在该方式下,要用一个外部锁存器(如 74HC373 或相同功能的锁存器)保持 RAM 地址的低 8 位。外部锁存器由 ALE(地址锁存使能)信号控制,ALE 信号由外部存储器接口逻辑驱动。9.在总线复用时,需要把地址数据复用端口配置为漏极开路。10.ALE 高/低脉宽占 1 个 SYSCLK 周期,地址建立/保持时间占 0 个 SYSCLK 周期,/WR 和/RD 占 12 个 SYSCLK 周期,EMIF 工作在地址/数据复用方式,即:EMI0CF |= 0x2c;EMI0TC |= 0x2c;配置 EMIF 的
4、步骤是:先将 EMIF 选到低端口或高端口;然后选择复用方式或非复用方式;再选择存储器的模式(只用片内存储器、不带块选择的分片方式、带块选择的分片方式或只用片外存储器);然后设置EMI0TC;最后通过寄存器 PnMDOUT 和 P74OUT 选择所期望的相关端口的输出方式。如:void PORT_Init (void)XBR2 = 0x40; P74OUT |= 0xff; EMI0CF |= 0x2c; EMI0TC |= 0x6c; P3MDOUT |= 0xdf; 11.避免高端口处于“浮空”状态,以避免因输入浮空为无效逻辑电平而导致不必要的功率消耗,为此应采取如下措施的任何一种:a.将
5、 XBR2.7 位设置为逻辑0 选择弱上拉状态R/W R/W R/W R/W R/W R/W R/WR/W 复位值WEAKPUD XBARE -T4EXE T4E UART1E EMIFLE CNVSTE 00000000位 7 位 6 位 5 位 4 位 3 位 2位 1 位 0 SFR 地址位 7 WEAKPUD 弱上拉禁止位0 弱上拉全局允许1 弱上拉全局禁止位 6 XBARE 交叉开关允许位0 交叉开关禁止端口 0 1 2 和 3 的所有引脚被强制为输入方式1 交叉开关允许位 5 未用读 0 写=忽略位 4 T4EXE T4EX 输入允许位0 T4EX 不连到端口引脚1 T4EX 连到
6、端口引脚位 3 T4E T4 输入允许位0 T4 不连到端口引脚1 T4 连到端口引脚位 2 UART1E UART1 I/O 允许位0 UART1 I/O 不连到端口引脚1 UART1 TX 和 RX 连到两个端口引脚位 1 EMIFLE 外部存储器接口低端口允许位0 P0.7 P0.6 和 P0.5 的功能由交叉开关或端口锁存器决定1 如果 EMI0CF.4 = 0 外部存储器接口为复用方式则 P0.7 (/WR) P0.6 (/RD)和 P0.5 (/ALE)被交叉开关跳过它们的输出状态由端口锁存器和外部存储器接口决定1 如果 EMI0CF.4 = 1 外部存储器接口为非复用方式则 P0
7、.7 (/WR)和 P0.6 (/RD)被交叉开关跳过它们的输出状态由端口锁存器和外部存储器接口决定位 0 CNVSTE 外部转换启动输入允许位0 CNVSTR 不连到端口引脚1 CNVSTR 连到端口引脚;b.令 P74OUT=0xFF,将高端口输出方式配置为推拉方式(P74OUT 为高端口输出方式寄存器);c.向高端口数据寄存器 P4、P5、P6 和 P7 写 0。12.配置端口引脚的输出方式每个端口引脚的输出方式都可被配置为漏极开路或推挽方式。在推挽方式下向端口数据寄存器中的相应位写逻辑 0 将使端口引脚被驱动到 GND 写逻辑 1 将使端口引脚被驱动到 VDD ,在漏极开路方式下向端口
8、数据寄存器中的相应位写逻辑0 将使端口引脚被驱动到 GND,写逻辑 1,将使端口引脚处于高阻状态,当系统中不同器件的端口引脚有共享连接,即多个输出连接到同一个物理线时(例如SMBus 连接中的 SDA 信号),使用漏极开路方式以防止不同器件之间的冲突。(推挽方式在有些书中称为推拉方式)关于开漏、推挽方式,漏级开路即高阻状态,适用于输入/输出,其可独立输入/输出低电平和高阻状态,若需要产生高电平,则需使用外部上拉电阻或使用如 LCX245 等电平转换芯片。有些朋友,尤其是未学过此方面知识的朋友,在实际工作中将 I/O 口设置为漏开,并想输出高电平,但向口线上写 1 后对方并未认出高电平,但用万用
9、表测量引脚确有电压,这种认为是不对的,对于高阻状态来说,测量电压是无意义的,正确的方法应是外加上拉电阻,上拉电阻的阻值=上拉电压/芯片引脚最大灌(拉)电流。推挽方式可完全独立产生高低电平,推挽方式为低阻,这样,才能保证口线上不分走电压或分走极小的电压(可忽略),保证输出与电源相同的高电平,推挽适用于输出而不适用于输入,因为若对推挽(低阻)加高电平后,I=U/R,I 会很大,将造成口的烧毁。对于 C8051F 的很多型号片子,将 I/O 口设置为推挽方式的做法为:PnMDOUT=0xff,Pn=0x00,这样设置 I/O 口为推挽,并输出低电平(可降低功耗)将 I/O 口设置为漏开方式的做法为:
10、PnMDOUT=0x00,Pn=0x11,这样设置 I/O口为漏开。如果学过三极管放大电路一定知道,前置单管放大器和功放末级放大电路的区别。单片机内部的逻辑经过内部的逻辑运算后需要输出到外面,外面的器件可能需要较大的电流才能推动,因此在单片机的输出端口必须有一个驱动电路。这种驱动电路有两种形式:其中的一种是采用一只 N 型三极管(npn 或 n 沟道),以 npn 三极管为例,就是 e 接地,b 接内部的逻辑运算,c 引出,b 受内部驱动可以控制三极管是否导通但如果三极管的 c 极一直悬空,尽管 b 极上发生高低变化,c 极上也不会有高低变化,因此在这种条件下必须在外部提供一个电阻,电阻的一端
11、接 c(引出脚)另一端接电源,这样当三极管的 b 有高电压是三极管导通,c 电压为低,当 b 为低电压时三极管不通,c 极在电阻的拉动下为高电压,这种驱动电路有个特点:低电压是三极管驱动的,高电压是电阻驱动的(上下不对称),三极管导通时的 ec 内阻很小,因此可以提供很大的电流,可以直接驱动 led 甚至继电器,但电阻的驱动是有限的,最大高电平输出电流=(vcc-Vh)/r;另一种是互补推挽输出,采用 2 只晶体管,一只在上一只在下,上面的一只是 n 型,下面为 p 型(以三极管为例),两只管子的连接为:npn(上)的 c连 vcc,pnp(下)的 c 接地,两只管子的 ee,bb 相连,其中
12、 ee 作为输出(引出脚),bb 接内部逻辑,这个电路通常用于功率放大点路的末级(音响),当bb 接高电压时 npn 管导通输出高电压,由于三极管的 ec 电阻很小,因此输出的高电压有很强的驱动能力,当 bb 接低电压时 npn 截至,pnp 导通,由于三极管的 ec 电阻很小因此输出的低电压有很强的驱动能力,简单的例子,9013 导通时 ec 电阻不到 10 欧,以 Vh=2.5v,vcc=5v 计算,高电平输出电流最大=250MA,短路电流 500ma,这个计算同时告诉我们采用推挽输出时一定要小心千万不要出现外部电路短路的可能,否则肯定烧毁芯片,特别是外部驱动三极管时别忘了在三极管的基极加
13、限流电阻。推挽输出电路的形式很多,有些单片机上下都采用 n 型管,但内部逻辑提供互补输出,以上的说明仅仅为了说明推挽的原理,为了更深的理解可以参考功率放大电路。振荡器问:内部时钟振荡器是否稳定?是否可以用于产生波特率的时基?答:不同器件的内部时钟振荡器的精度是不同的(20%)。随电源电压变化,它也将发生变化(6.5%/V)。但基本不随温度变化(14、切换到外部振荡器。注意:振荡器频率的选择,即 OSCXCN 寄存器的配置(外部振荡器频率控制位的设置)。关于更多的信息以及源代码可以参看应用笔记 AN002配置内部和外部振荡器。应用笔记可以从我公司网站下载:问:C8051F MCU 的指令执行速度
14、为多少?答:C8051F MCU 的 CIP-51 内核采用流水线结构,与标准的 8051 结构相比,指令执行速度有很大的提高。标准的 8051 单片机执行一个单周期指令需要 12 个系统时钟周期,而 C8051F MCU 执行一个单周期指令只需要一个系统时钟周期。如果系统时钟频率为 25MHz,执行一个单周期指令所需时间为 40ns。问:切换外部晶振时应注意哪些问题?答:首先要允许外部振荡器,但此时的系统时钟源仍应是内部时钟,直到外部振荡器稳定后,才可将系统时钟源切换到外部振荡器上,否则会出现切换不过去,系统死机的情况。问:使用外部晶振应注意哪些问题?答:1、所有的模拟和数字电源引脚都应接电
15、源(2.73.6V);2、C8051F3xx 系列器件的晶振引脚间应跨接一个 10M 电阻(在新华龙网站的“主页”“原理图/PCB 库”中有 C8051F 系列单片机的典型接线图);3、晶振、电容等相关器件尽量靠近单片机的晶振引脚。问:系统时钟切换到外部时钟后,内部的时钟是否应关闭?答:可以选择关闭或不关闭,但是从降低功耗的角度来说,应该关闭。问:系统时钟可不可以在程序中随时切换?答:可以,但是由内部再一次切换到外部时应按照技术问答 2 所介绍的步骤进行切换。问:使用外部晶振时如何配置芯片的引脚?答答:对于芯片上有固定晶振引脚的设备(例如 C8051F02X);相应时钟输入引脚按选择的晶振模式
16、自动分配引脚;对于晶振引脚与 GPIO 共用的芯片(例如 C8051F30X);晶振引脚要按下述方式进行设置:(1).外接晶体体时;XTAL1 与 XTAL2 都要配置为模拟输入(2).外接振荡电路为“RC”或“C”方式时,XTAL2 引脚要配置为模拟输入(3).外接 CMOS 时钟电路时,XTAL2 引脚要配置为数字输入(4).以上几种方式在引脚的配置中都要使用跳过功能将此引脚跳过问:外接晶振的最高频率是多少?答:外接晶振的最高频率是 30MHz;模数转换问:从上电(或退出掉电模式)到 ADC 稳定开始转换需要多长时间?答:模拟建立时间也就是等待参考电平稳定的时间。它取决于接在 VREF 引
17、脚的电容容量。此电容越大 VREF 的噪音就越小,ADC 转换结果的噪音也就越小。如果用 4.7F 电容,则稳定时间大约为 2ms,如果无旁路电容(不推荐),稳定时间大约为 10S。注意:在开始转化之前,需要一个 1.5S 的跟踪时间,这也就决定了 ADC 多路转换开关(MUX)的切换速度。问:ADC 的最大输入电压及输入阻抗?答:ADC 的最大输入电压为 VREF,它的输入电压范围是 0V-AV+/VDD。输入电容为 10pF;输入阻抗等价于一个 5k 电阻和一个 10pF 电容的串联。请参考应用笔记 AN019“计算开关电容 ADC 的建立时间”。问:ADC 可编程窗口检测器有什么用途?答
18、:ADC 可编程窗口检测器在很多应用中非常有用。它不停地将 ADC 输出与用户编程的限制量进行比较,并在检查到越限条件时通知系统控制器,这在中断驱动的系统中尤其有效,既可以节省代码空间和 CPU 带宽又能提供快速响应的时间。问:为了使 ADC 或 DAC 具有更好的性能,是否应在 VREF 引脚接电容?答:推荐在 VREF 引脚接一个 0.1F 的陶瓷电容器与一个大的电容(典型为4.7F 钽电容)。在 VREF 引脚加电容是为了降低 VREF 的噪声。因为 VREF 的噪声越小,ADC 或 DAC 转换结果的噪声也就越小。且这两个电容在 PCB 板上应尽可能离 VREF 引脚近。问:内部参考电
19、平是否可以用于外部电路的参考?答:可以,你可以用 VREF 信号作为输出驱动其它电路(像放大器的偏置电压等)。注意,VREF 引脚只能提供源电流,也就是说,要有负载接地使电流流出C8051 器件。例如,如果你将 VREF 连到 OP 运放的(+)节点,你要加一个下拉电阻对地(24K 左右)将电流限制在 100A。问:如果测试的模拟输入电压范围是 0-5V 怎么办?答:因为模拟输入(AINx)引脚不能承受 5V 电压,任何引脚在任何情况下(不管 ADC 或 PGA 的设置如何)必须使其输入 电压保持在 AGND 和 AV之间,这是为了避免沉(或源)电流通过 ESD 保护装置。为了测试 0-5V
20、范围的信号,必须使信号衰减(衰减到 AV以下)才能进入到 ADC 输入。当使用外部 VREF 时,要求 VREF 的最大值比 AV+小 300mV。问:F02x 器件内部有 PGA(可编程增益放大器)可以对输入模拟信号进行放大。其中的一个放大倍数为 0.5 倍。是否意味着我可以外接+6V 的模拟输入电压,经过 0.5 倍的放大变成 3V 输入到 AINx 呢?答:请注意:任何模拟引脚(数据 IO 口和 VDD 引脚除外)的最大输入电压为-0.3V 到 VDD+0.3V。如果超出此范围可能造成器件永久损坏。在单端输入方式,有两个限制因素如下:1、AIN 输入电压必须在 AGND 和 AV+之间以
21、避免吸/源电流流过 ESD 保护器件。2、AIN 电压必须在 AGND 和(VREF / GAIN) 之间。假设一个 12 位的 ADC,AINx 引脚的输入电压小于 AGND,结果将是 0x000;如果输入电压大于(VREF / GAIN) ,结果将是 0xFFF。例如,使用外部 1.25V 参考,PGA 增益为 0.5,允许的电压输入范围是 0V 到 (1.25V / 0.5 = 2.5V)。问:如何提高系统的 ADC 的性能?答:第一、将模拟电源和数字电源分开,可以使用比较简单的方法,如在模拟电源和数字电源之间加简单的滤波。第二、将模拟地和数字地分开,并在电源附近通过磁珠连接。第三、制板
22、时,大面积覆铜。第四、未使用到的模拟引脚要接地。第五、为了确保参考电压的稳定,参考电压引脚一定要接去耦电容。第六、模拟信号的输入电压范围是 0-VDD,如果模拟输入的外围有可能侵入高电压(超过芯片的极限允许范围),就要采取保护措施(如加两个肖特级二极管)。如果模拟输入会有瞬间过电流,也要加限流保护。问:如果使用内部参考源,C8051F020/F021 的参考电压引脚如何连接?答:C8051F020/F022 共有 4 个参考电压引脚,VREF,VREF0,VRFE1 和 VREFD。允许 ADC 和 DAC 使用一个外部电压基准或片内电压基准。通过配置 VREF0CF 基准电压控制寄存器,AD
23、C0 还可以使用 DAC0 的输出作为内部基准,ADC1 也可以使用模拟电源作为电压基准。内部基准电压必须通过 VREF 引脚连接到芯片内部。所以当您的系统中使用到内部基准电压时,必须确保 VREF 与VREF0,VREF1,VREFD(全部或部分)引脚的连接。C8051F021/F023 共有两个参考电压引脚,VREFA 和 VREF。如果 ADC0 和 ADC1 使用内部参考源,必须将 VREFA 与 VREF 引脚连接。注意:如果使用 ADC 或 DAC,则不管电压基准取自片内还是片外,REF0CN 寄存器中的 BIASE 位必须被置为逻辑 1。问:为什么在进行 A/D 转换时测得的数据
24、跳变很大?答:当输入信号有干扰脉冲、ADC 的转换时间太短、在通道切换后通道还没有稳定就开始转换等原因都会导致转换后的数据跳变大,请仔细检查以上三点并做相应的处理就可以解决此类问题。问:在进行 A/D 转换时所测得的数据与计算所得的数据相差很大,但跳变不大,为什么?答:1、计算时所用的基准电压是多少,如果用的是内部基准,把内部基准电压通过交叉开关分配到芯片引脚上,再进行测量;2、换别的通道转换看是否正常。问:ADC 的单端输入与差分输入的区别?答答:在单端方式工作时;ADC 转换的是单输入引脚对地的电压值;在增益为1 时,测量的值就是输入的电压值;范围是 0V 到 VREF;当增益增加时,输入
25、的范围要相应的减小;在差分方式工作时;ADC 转换的是 AIN+与 AIN-两个引脚的差值;在增益为 1 时,测量的值等于(AIN+)-(AIN-),范围是-VREF 到+VREF;当增益增加时,输入的范围要相应的减小。注意:在差分方式时所提的负压是指 AIN-引脚的电压大于 AIN+引脚的电压,实际输入到两个引脚的电压对地都必需是正的;例如:如果 AIN+引脚输入的电压为 0V,AIN-引脚的输入电压为 1/2VREF 时,差分的输入电压为(0V-1/2VREF) = -1/2VREF。 端口问:器件 IO 口的吸收(sink)电流和源(source)电流是多少?答:IO 口的沉电流和拉电流
26、的极限参数为 100mA(但是此时已经不能保证端口的正常逻辑关系了)。具体的参数请参考 datasheet 的端口 IO 部分的“端口I/O 直流电气特性”。问:端口是否要加保护?答:在端口电流瞬间跳变的情况下,建议加限流电阻进行保护。另外如果端口可能有超过极限电压范围的瞬变电平侵入,也要加瞬态保护。(瞬态保护的通常方式为接入 TVS 器件)问:C8051F 系列单片机的 IO 口与传统 8051 单片机相比有什么区别?答:C8051F 系列单片机的 IO 口全部为三态双向口(而传统 8051 单片机P1、P2、P3 口为准双向口),内部有弱上拉可禁止(传统 8051 单片机固有),可配置为开
27、漏输出和推挽输出(传统 8051 单片机只有开漏输出)。片内数字资源要通过数据交叉开关(crossbar)按一定的优先级配置到 IO 引脚(C8051F2xx 系列除外,而传统 8051 单片机不具备这一功能)。IO 口的配置更加灵活。问:C8051F 系列单片机电源电压全部为 2.7-3.6V,那么是否有与 5V 系统接口的比较简单的解决方案?答:所有 IO 口允许 5V(极限值为 5.8V)输入,但是输出高电平为 VDD。如果与 5V 系统接口,最简单的方法是开漏输出并在输出端加接 5V 上拉,关键是上拉电阻的选择。具体参考应用笔记 AN011“在 5V 系统中使用 C8051Fxxx”。
28、建议:如果可能,请尽量选用供电电压兼容的芯片,这是一种最理想的选择。问:模拟引脚能否简单地用于数字 IO?答:如果模拟引脚是独立的是不可以的。但是如果模拟引脚和数字 IO 是复用的,是可以通过 SFR 的设置来完成配置。问:C8051F020/022 的 p4-p7 口和 p0-p3 口有什么不同?答:P0-P3 口复位时为通用口,可通过 Crossbar(数据交叉开关)寄存器按优先级设置成第二功能。而 P4-P7 口是通用口,另外 P4-P7 寄存器不能位寻址。问:如果通过 Crossbar 寄存器使能并分配为 P0.0 和 P0.1 引脚,那么,我还可以用这两个引脚为通用 I/O 吗?答:
29、如果你通过 Crossbar 使能一个外设,如 UART,那么这个外设将控制这些引脚的输出状态(逻辑高/逻辑低)。你可以在任何时刻读引脚的状态,与 Crossbar 控制与否无关。当被禁止时,大部分外设的输出引脚被置为高阻态(UART 口是一个很好的例子)。因为 UART 收发器无明确的禁止态,你可将相应的引脚置成开漏输出模式,也可以达到相同的结果,因为 UART 收发器在空闲时引脚为逻辑 1。总的来说,Crossbar 置配后在末使用时的外设引脚可以用于数据输入,但不能作为数据输出。其它器件,如 F3xx 系列,口引脚可通过 Crossbar“重新声明”且用于 GPIO 引脚对器件管脚无影响
30、,因为这些器件具有“引脚跳过”(PIN SKIP)特性。问:IO 口的开漏和推挽输出如何使用?答:将端口引脚置成推挽输出方式,这将使能端口引脚驱动器。总体上来讲,数据输入端口引脚置成开漏方式、数据输出端口引脚置成推挽方式。当引脚用于输出连接上拉电阻(也就是说当与 5V 系统接口时)时配置成开漏输出。问:引脚 P1.4P1.7 中断如何使用?答:如果外部中断(EX4EX7)使能且相应的引脚 P1.4P1.7 变低(可以是外部输入信号、写输出端口锁存或是 Crossbar 定义的外设启动的事件)。那么中断标志(PRT1IF.n)将置位,如果全局中断使能,将产生一个中断。中断逻辑检测本身的逻辑状态,与产生逻辑状态变化的原因无关。问:是不是所有的 C8051F 系列单片机的 I/O 口都是 5V 兼容?答:不是,例如 C8051F060 只有 P0 口是 5V 兼容,具体的要参照相关型号的数据手册。问:P4 口的某些引脚已用为外部存储器的控制信号,剩下的口线能否作为普通I/O 使用?答:可以,但不能直接给此端口送数,应通过“与”或者“或”的方式来对此端口进行操作。问:为什么端口的数据寄存器置为 0 时,其引脚上的电平还是为高电平?答:交叉开关使能位没有置位。问:端口在停机(STOP)模式下是什么状态?答:端口在停机模式下将保持进入停机模式前的状态。