stm8 io口重映射

2020-02-15来源: eefocus关键字:stm8  io口  重映射

STM8S003F3端口可以设置重映射,如pin16的PC6管脚,默认复用功能是SPI_MOSI功能,可以重映射为TIM1_CH1,也就是timer1的1通道。映射方式并不像STM32那样有个AFR寄存器来配置,而是配置Option bytes字节,如下图

也就是OPT2寄存器,注意是STM8S003F3系列的,其它的芯片配置字节是不一样的。


比如要配置PC6引脚为定时器1PWM输出比较通道TIM_CH1,   配置方法如下: 


OPT2是个8位的寄存器,配置的方式比较特别,类似FLASH操作,有两种方法配置,一种是通过STVP进行配置,也就是通过ST的烧录软件界面那里配置(或者IAR软件里选项字节配置);

另一种是通过软件配置方式,说明下软件配置,共4步:


#define FLASH_EOP 0X04  //标志位

 #define FLASH_DUL 0X08  //标志位

void FLASH_Init(void)  //端口重映射初始化函数,在此将PC5映射为TIM2_CH1

{  

    unsigned char *flash_OPT2;

    unsigned char *flash_NOPT2;

    flash_OPT2=(unsigned char*)0x4803;   //OPT2寄存器的ADDR

    flash_NOPT2=(unsigned char*)0x4804;  //NOPT2寄存器的ADDR,此寄存器的值是OPT2的取反值

    //------------------------------------------------------------- 

    //第一步  初始化FLASH  

    while( (FLASH_IAPSR & FLASH_DUL) == 0X00 )      

    {  

        FLASH_DUKR = 0XAE;       

        FLASH_DUKR = 0X56;    

    } //一旦配置失败,此处将陷入死循环。实际使用请加入超时机制,在此省略 

    //-------------------------------------------------------------           

    //第二步  对OPT进行编程,首先需要如下操作:开启opt编程  

    FLASH_CR2 |= 0X80;     //OPT  = 1  

    FLASH_NCR2 &= 0X7F;    //NOPT = 0   

    //-------------------------------------------------------------       

    //第三步  修改内存  

    1.修改参数,启用复用功能 

    2.OPT2 和 NOPT2要相反  

    //修改OPT2  

    *flash_OPT2 = 0X01;      // 0000 0001  AFR0=1,PC5复用为TIM2_CH1其它默认清0   

    while( (FLASH_IAPSR & FLASH_EOP) == 0 );  //等待操作完成   

    //修改NOPT2  

    *flash_NOPT2 = ~*flash_OPT2;     

    while( (FLASH_IAPSR & FLASH_EOP) == 0 );  //等待操作完成  

    //一旦配置失败,此处将陷入死循环。实际使用请加入超时机制,在此省略

    //-------------------------------------------------------------   

    //第四步  对OPT进行编程,最后需要如下操作:禁用opt编程  

    FLASH_CR2 &= ~0X80;    //OPT  = 1  

    FLASH_NCR2 |= 0X80;    //NOPT = 0  

}


  以上是配置函数,经过验证过可用,但使用过程中建议不要每次都进行配置,因为是对选项字节的操作,如果单片机上电不稳定会造成配置操作出现中断而导致单片机锁住问题。解决方法是第一次运行时,配置完毕后将配置状态写入FLASH某个地址,下次每次启动时读取该FLASH地址状态值,如果是已经配置过,则不需要再次配置。被锁住后通过烧录工具STVP进行复位刷默认配置即可。 

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

上一篇:STM8S外设的端口映射问题
下一篇:Stm8 串口重定向及问题解决

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

推荐阅读

STM8S库文件判断指定IO输入引脚电平GPIO_ReadInputPin有问题
/**  * @brief  Reads the specified GPIO input data pin.  * @param  GPIOx : Select the GPIO peripheral number (x = A to I).  * @param  GPIO_Pin : Specifies the pin number.  * @retval BitStatus : GPIO input pin status.  */BitStatus GPIO_ReadInputPin(GPIO_TypeDef* GPIOx, GPIO_Pin_Ty
发表于 2020-02-08
STM8 GPIO输入输出模式
悬浮输入悬浮输入,也叫浮空输入,顾名思义,即引脚悬空。这种方式的输入阻抗很高。当悬浮输入的引脚上加上信号时,单片机所得到的信号并不确定是高电平或是低电平,是一个不确定的信号。悬浮输入的典型应用就是模数转换,外部的任何一个小信号都要经过A/D采样转换为数字信号。上拉输入上拉就是把电位拉高,比如拉到Vcc。上拉就是将不确定的信号通过一个电阻嵌位在高电平!电阻同时起限流作用!强弱只是上拉电阻的阻值不同。上拉输入最典型的应用就是外部按键,当按键未按下时,我们要保证它是高电平,当按键按下时才被拉低。推挽输出推挽输出(Push-pull output),也称为互补输出,推拉式输出。推挽输出模式导通损耗小,效率高。在此模式下,N-MOS、P-MO
发表于 2020-02-08
STM8 GPIO输入输出模式
STM8L的USART1串口通信详解 含例程
。/****************************************************************************************开发环境:IAR for stm8 v1.40.1*硬件平台:STM8L-DISCOVERY*功能说明:每隔500ms通过PC3引脚向上位机发送一组数据。串口配置为:波特为9600,8个数据位,1个停止位,无奇偶校验。*作    者:茗风****************************************************************************************/#include"
发表于 2020-02-08
使用STM8S105K4T6C 模数转换器的12通道
分享今天遇到的一个stm8s模数转换的小问题~~~这款单片机一共提供了7个模数转换通道,他们分别是AIN0-AIN5和AIN12。stm8s105k4t6c的管脚图其中AIN0-AIN5的配置和使用方法如下,配置为连续转换、扫描模式(代码写的不好,大神请见谅~):[mw_shl_code=c,true]/*---------------------------------包含头文件---------------------------------*/#include "adc.h" #define        ADC     
发表于 2020-02-08
stm8——LED流水灯实现
最近接触并学习了一款STM8系列的芯片。以前学习了的ARM9+Linux后,再来学习单片机就感到上手很快了。 芯片基本信息:Type:STM8L151G68-bit ultralow power MCU, up to 32 KB Flash, 1 KB Data EEPROM RTC, LCD, timers, USART, I2C, SPI, ADC, DAC, comparators具体可以查看datasheet:http://pdf-file.ic37.com/pdf4/STMICROELECTRONICS
发表于 2020-02-08
MCU程序设计之STM8S的optionbytes
今天使用STM8S在程序中修改optionbyte遇到问题一直读取为0,不能进入设置流程,之前的程序今天重新修改东西,使用新的片子,原来程序如下:  AFR_TEMP = (uint16_t)((uint16_t)0x01 << 8);  AFR_TEMP = AFR_TEMP | (uint16_t)0xFE;  AFR_TEMP = (AFR_TEMP >> 8);之所以直接赋值而不调用函数,是因为程序代码空间有限,使用函数调用方法修改没有问题,如下:  AFR_TEMP = FLASH_ReadOptionByte(0X4803);  AFR_TEMP
发表于 2020-02-08
小广播
何立民专栏 单片机及嵌入式宝典

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

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2020 EEWORLD.com.cn, Inc. All rights reserved