STM8S103的引脚封装图如下

是一个20管脚的51类型单片机,8Kflash 1kRAM。
STM8S207引脚封装如下

一个48引脚64KFLASH和6K的RAM,也是51单片机,但串口和定时器的功能多了。
从手册看,timer1是ADVANCED 定时器,timer 2 3是通用型定时器。
在移植过程中以为只要改动器件类型同时在stm8s.h内将
#ifndef __STM8S_H
#define __STM8S_H
#define STM8S207  //STM8S103 
103注释掉并开通207的宏定义。
定时器初始化如下
void TIM1_Init(void)
{
    TIM1_DeInit();                     //定时器1相关寄存器复位
   
    TIM1_TimeBaseInit(7, TIM1_COUNTERMODE_UP, 9999, 0);   //中断时间10ms 
    // TIM1_TimeBaseInit(8, TIM1_COUNTERMODE_UP, 1500, 0);   //中断时间ms 
    TIM1_ITConfig(TIM1_IT_UPDATE, ENABLE);         //使能中断 
    TIM1_Cmd(ENABLE); //使能TIM1
}
void TIM2_Init(void)
{
   TIM2_DeInit();
   TIM2_TimeBaseInit(TIM2_PRESCALER_1, 125*20);//20ms中断
   TIM2_ITConfig(TIM2_IT_UPDATE, ENABLE);     //使能中断
   ITC_SetSoftwarePriority(ITC_IRQ_TIM2_OVF, ITC_PRIORITYLEVEL_2);//设置d定时器中断优先级 2
   TIM2_Cmd(ENABLE);//使能定时器1
}
但是通过单步调试,确无法进入中断
#pragma vector=ITC_IRQ_TIM2_OVF + 2
__interrupt void TIM2_UPD_OVF_BRK_IRQHandler(void)
{  
 
  TIM2_ClearFlag(TIM2_FLAG_UPDATE);    //清定时器1更新中断标志
 
}
观察寄存器发现 TIMER2 的寄存器值TIMER2_IER无法开通中断也就是使能中断 ,手册和register都显示timer2 的寄存器很少。TIMER1和TIMER2的比较如下


后来在stm8s_timer2.h里发现了端倪
typedef struct TIM2_struct
{
 __IO uint8_t CR1; 
// __IO uint8_t RESERVE1;
// __IO uint8_t RESERVE2; //注释掉用于STM8S207 否则用于stm8s103
 __IO uint8_t IER; 
 __IO uint8_t SR1; 
 __IO uint8_t SR2; 
 __IO uint8_t EGR; 
 __IO uint8_t CCMR1;
 __IO uint8_t CCMR2;
 __IO uint8_t CCMR3;
 __IO uint8_t CCER1;
 __IO uint8_t CCER2;
 __IO uint8_t CNTRH;
 __IO uint8_t CNTRL;
 __IO uint8_t PSCR; 
 __IO uint8_t ARRH; 
 __IO uint8_t ARRL; 
 __IO uint8_t CCR1H;
 __IO uint8_t CCR1L;
 __IO uint8_t CCR2H;
 __IO uint8_t CCR2L;
 __IO uint8_t CCR3H;
 __IO uint8_t CCR3L;
}
TIM2_TypeDef;
也就是在给timer2 的寄存器赋值时由于多了两个没用的,将数值顶替了,注释掉可以了。