小记-STM8S003F3端口复用和端口开漏

1.软件方面:
STM8S003F3端口可以设置重映射,如pin12的PC5管脚,默认是SPI_SCK功能,可以重映射为TIM2_CH1,也就是timer2的1通道。映射方式并不像STM32那样有个AFR寄存器来配置,而是配置Option bytes字节,如下图(芯片手册的45页):
STM8S003 OPTION配置
也就是OPT2寄存器,注意是STM8S003F3系列的,其它的芯片配置字节是不一样的。
比如要使用PC5的TIM2_CH2来做PWM输出或PWM信号捕获,按上图中的AFR0那一栏所示,
AFR0 Alternate function remapping option 0
0: AFR0 remapping option inactive: Default alternate functions
1: Port C5 alternate function = TIM2_CH1; port C6 alternate function =
TIM1_CH1; port C7 alternate function = TIM1_CH2.
将AFR0设置为1时PC5将复用为TIM_CH1。
配置方法:
OPT2是个8位的寄存器,配置的方式比较特别,类似FLASH操作,有两种方法配置,一种是通过STVP进行配置,也就是通过ST的烧录软件界面那里配置;另一种是通过软件配置方式,说明下软件配置,共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进行复位刷默认配置即可。
以上是纯软件方式操作配置字节寄存器,另一种是通过STVP配置,如下图:
stvp_修改配置字节
通过修改红色框中的参数进行刷写修改。

2.硬件方面可能很容易疏忽的问题就是STM8S003F3的PB4和PB5端口,这两个端口分别是I2C通信的SCL和SDA端口,手册明确说明为:true open-drain I/O,也就是真正的开漏输出(手册里端口说明中带‘T’),P-BUFFER和那个保护二极管是没有使用的。这种情况下,如果没接上拉电阻的话,是不能输出高电平的。

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Windows下,可以使用bat批处理脚本来批量检测远程端口。Telnet是一种远程终端连接服务,可以通过它来连接到远程主机的特定端口。以下是一个使用Telnet命令在批处理脚本中批量检测远程端口的例子: @echo off setlocal set ip_list=file_path\ip_list.txt set port=80 for /f %%i in (%ip_list%) do ( telnet %%i %port% | find "Connected" > nul if errorlevel 1 ( echo %%i:%port% is closed ) else ( echo %%i:%port% is open ) ) pause 在以上示例中,首先我们定义了要检测的IP列表文件的路径,即ip_list.txt文件,然后我们设定了要检测的端口号,此处设定为80端口。接着使用for循环读取ip_list.txt文件中的每个IP地址。 在每次循环中,我们使用telnet命令连接到远程主机的指定端口。如果端口成功连接,则表示端口是开放的,telnet命令的输出会包含"Connected"关键字。我们使用find命令查找telnet命令的输出中是否包含"Connected"关键字。 如果find命令找到了"Connected"关键字,则说明端口是开放的,我们将显示"IP地址:端口号 is open"的消息。否则,即端口未连接,我们将显示"IP地址:端口号 is closed"的消息。 最后,我们使用pause命令来暂停脚本的运行,以便我们可以查看检测结果。 需要注意的是,Telnet命令在默认情况下可能未启用,需要手动在Windows设置中启用Telnet客户端功能。此外,Telnet命令在Windows 10及更高版本中可能已被淘汰,可以考虑使用其他工具如ncat或PowerShell来代替Telnet命令进行远程端口检测。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值