STM8 IO口的位操作

2020-03-01来源: eefocus关键字:STM8  IO口  位操作

很多新手在不用STM库函数的情况下,不知道如何多STM8的I/O口进行按位操作,下面把我刚开始用STM8的经验跟大家分享一下!


/*----------------------------------------------------------------------------*/

//IO bits define


/* Port A data output bits*/

volatile _Bool PA_ODR_0  @PA_ODR:0;

volatile _Bool PA_ODR_1  @PA_ODR:1;

volatile _Bool PA_ODR_2  @PA_ODR:2;

volatile _Bool PA_ODR_3  @PA_ODR:3;

volatile _Bool PA_ODR_4  @PA_ODR:4;

volatile _Bool PA_ODR_5  @PA_ODR:5;

volatile _Bool PA_ODR_6  @PA_ODR:6;

volatile _Bool PA_ODR_7  @PA_ODR:7;



/* Port A data input bits*/

volatile _Bool PA_IDR_0  @PA_IDR:0;

volatile _Bool PA_IDR_1  @PA_IDR:1;

volatile _Bool PA_IDR_2  @PA_IDR:2;

volatile _Bool PA_IDR_3  @PA_IDR:3;

volatile _Bool PA_IDR_4  @PA_IDR:4;

volatile _Bool PA_IDR_5  @PA_IDR:5;

volatile _Bool PA_IDR_6  @PA_IDR:6;

volatile _Bool PA_IDR_7  @PA_IDR:7;


/* Port B data output bits*/

volatile _Bool PB_ODR_0  @PB_ODR:0;

volatile _Bool PB_ODR_1  @PB_ODR:1;

volatile _Bool PB_ODR_2  @PB_ODR:2;

volatile _Bool PB_ODR_3  @PB_ODR:3;

volatile _Bool PB_ODR_4  @PB_ODR:4;

volatile _Bool PB_ODR_5  @PB_ODR:5;

volatile _Bool PB_ODR_6  @PB_ODR:6;

volatile _Bool PB_ODR_7  @PB_ODR:7;



/* Port B data input bits*/

volatile _Bool PB_IDR_0  @PB_IDR:0;

volatile _Bool PB_IDR_1  @PB_IDR:1;

volatile _Bool PB_IDR_2  @PB_IDR:2;

volatile _Bool PB_IDR_3  @PB_IDR:3;

volatile _Bool PB_IDR_4  @PB_IDR:4;

volatile _Bool PB_IDR_5  @PB_IDR:5;

volatile _Bool PB_IDR_6  @PB_IDR:6;

volatile _Bool PB_IDR_7  @PB_IDR:7;



/* Port C data output bits*/

volatile _Bool PC_ODR_0  @PC_ODR:0;

volatile _Bool PC_ODR_1  @PC_ODR:1;

volatile _Bool PC_ODR_2  @PC_ODR:2;

volatile _Bool PC_ODR_3  @PC_ODR:3;

volatile _Bool PC_ODR_4  @PC_ODR:4;

volatile _Bool PC_ODR_5  @PC_ODR:5;

volatile _Bool PC_ODR_6  @PC_ODR:6;

volatile _Bool PC_ODR_7  @PC_ODR:7;

/* Port C data input bits*/

volatile _Bool PC_IDR_0  @PC_IDR:0;

volatile _Bool PC_IDR_1  @PC_IDR:1;

volatile _Bool PC_IDR_2  @PC_IDR:2;

volatile _Bool PC_IDR_3  @PC_IDR:3;

volatile _Bool PC_IDR_4  @PC_IDR:4;

volatile _Bool PC_IDR_5  @PC_IDR:5;

volatile _Bool PC_IDR_6  @PC_IDR:6;

volatile _Bool PC_IDR_7  @PC_IDR:7;



/* Port D data output bits*/

volatile _Bool PD_ODR_0  @PD_ODR:0;

volatile _Bool PD_ODR_1  @PD_ODR:1;

volatile _Bool PD_ODR_2  @PD_ODR:2;

volatile _Bool PD_ODR_3  @PD_ODR:3;

volatile _Bool PD_ODR_4  @PD_ODR:4;

volatile _Bool PD_ODR_5  @PD_ODR:5;

volatile _Bool PD_ODR_6  @PD_ODR:6;

volatile _Bool PD_ODR_7  @PD_ODR:7;



/* Port D data input bits*/

volatile _Bool PD_IDR_0  @PD_IDR:0;

volatile _Bool PD_IDR_1  @PD_IDR:1;

volatile _Bool PD_IDR_2  @PD_IDR:2;

volatile _Bool PD_IDR_3  @PD_IDR:3;

volatile _Bool PD_IDR_4  @PD_IDR:4;

volatile _Bool PD_IDR_5  @PD_IDR:5;

volatile _Bool PD_IDR_6  @PD_IDR:6;

volatile _Bool PD_IDR_7  @PD_IDR:7;


关键字:STM8  IO口  位操作 编辑:什么鱼 引用地址:http://news.pyfle.com/mcu/ic490061.html 本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:STM8 GPIO 寄存器的理解
下一篇:STM8L51X gpio中断

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

stm8l低功耗系列
最近干刚做了一个stm8的项目用的是L低功耗系列,其中遇到一个问题。外设寄存器的值怎么都写入不进去。用IAR仿真产看寄存器的值,不论写进去多少,都是初始值。后来把所有寄存器都写了一遍,发现有的能写进去,有的写不进去。比如GPIO的寄存器就能写进去。百思不得姐,偶然查看clock的库函数发现个函数是设置外设时钟的。这个系列,亦或者整个低功耗系列的每个外设是不是都需要在时钟寄存器中单独设置时钟。(以前所使用的芯片都是在外设寄存器中使能或者是禁使能)
发表于 2020-03-09
STM8L+BC26双低功耗,微安
现在在做一个项目需要用到STM8L和BC26。长时间断链后连接下服务器,并且发送一下当前状态,需要用到STM8L和BC26的低功耗。STM8L低功耗,这里用HALT模式,RTC规定时间唤醒。第一步需要关闭所有外设,把所有管脚为设置为输出,并且输出低,管脚根据具体环境设置,需要输出高电平的则输出高电平。在关闭外设的是后是需要先_DeInit,然后在关闭外设始终,有点需要特别主要,要把在进入halt模式的时候需要把所有的中断的标志位清空,否则使用RTC唤醒则会不起作用。第二步就设置低功耗的一些配置。第三步配置完成后进入低功耗。项目中需要用到外部高速始终和BC26通信,所以在进入和退出halt模式的时候需要重新初始化active模式下的
发表于 2020-03-09
stm8l151低功耗程序架构,调试心得
最近帮医院做了一款体温记录仪,整个硬件方案资源是:stm8L151 + NTC*2 + EEPROM + 锂电池充电保护电路 + 18mAh纽扣电池;软件逻辑是,每隔一分钟,采样两路温度并保存在EEP里;通过USB转TTL,上位机能够读取,展示温度曲线,最大最小平均值等简单的运算;整个方案很简单,但也走了不少弯路......单片机程序框架之伪代码:void main(void){    CLK_Config();    GPIO_Config();    ADC_Config();    USART_Config();   
发表于 2020-03-09
STM8s外部时钟晶振失效时钟安全系统CSS启动演示
使用的最小系统晶振是8m的。这里说下配置过程:时钟自动切换,开启切换中断在中断里面清除中断标志,使能CSS并开启CSS中断CSS中断发生,清除CSS中断标志,将HSI二分频,即16M/2=8M,与外部晶振相同,这样不会影响串口波特率窗口输出配置信息:用手触碰PA1、PA2引脚使外部晶振失效串口输出CSS中断
发表于 2020-03-09
STM8s外部时钟晶振失效时钟安全系统CSS启动演示
STM8S103之时钟设置
最大时钟(指的是system clock):外部晶振24MHz,内部高速RC16MHz三个时钟源:外部晶振、内部高速RC(上电默认) +内部低速RC几个时钟:master clock(即sytem clock),fcpu,外设时钟、AWU时钟调用库函数中CLK_ClockSwitchConfig,参考库函数clk_clockselection,但是分频还得进一步设置上电默认:内部高速RC,HSIDIV=/8,CPUDIV=/1,外部时钟全使能,查看相关寄存器的Reset value
发表于 2020-03-09
STM8S103之时钟设置
stm8 16M晶振下精确软件延时
void inerDelay_us(unsigned char n) {for(;n>0;n--) { asm("nop"); //在STM8里面,16M晶振,_nop_() 延时了 333nsasm("nop"); asm("nop"); asm("nop"); }}//---- 毫秒级延时程序----------------------- void Delayms(unsigned int time) { unsigned int i; 
发表于 2020-03-08
小广播
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2020 pyfle.com, Inc. All rights reserved
快乐赛车福利彩票 快乐飞艇怎么样倍投 山东11选5开奖 快乐赛车注册网址 快乐飞艇怎么赢钱 快乐赛车是属于彩票吗 奔驰彩票开奖 快乐飞艇怎么样买稳赢 北京赛车pk10玩法 快乐飞艇怎么样稳赚