OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 5187|回复: 12

关于定时器用法的问题

[复制链接]

6

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
81
金钱
81
注册时间
2013-9-1
在线时间
3 小时
发表于 2013-9-6 11:25:40 | 显示全部楼层 |阅读模式
我写的程序是这样的

rcc->RCC_APB1ENR |=  (1<<1);  已经将TIM3的时钟使能了

#define TIM3_BASE_ADDR (volatile unsigned long*)(0x40000400)
#define TIM3_CR1   *(TIM3_BASE_ADDR+0x00)
#define TIM3_ARR *(TIM3_BASE_ADDR+0x2C) 
TIM3_ARR = 30000;
TIM3_CR1 |= (1<<7)|(1<<4); //AUTO RELOAD & DOWN COUNT_MODE
TIM3_CR1 |= (1<<0);                   //TIM3 ENABLE

在汇编里面是
TIM3_IRQHandler
    b     TIM3_IRQHandler

在main函数里面就是一个灯在闪烁的程序

但是按道理来说产生了一个更新事件中断之后,到了TIM3_IRQHandler这里应该是个死循环,灯应该停止闪烁的,是不是我设置定时器设置的不对,应该怎么设置。。。





正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

6

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
81
金钱
81
注册时间
2013-9-1
在线时间
3 小时
 楼主| 发表于 2013-9-6 11:54:08 | 显示全部楼层
发现了一个问题要在TIM3_DIER里面将更新事件中断使能。。。但是使能之后还是达不到预期效果。我觉得是不是还跟那个NVIC有什么关系的。。。但是在中文手册上好像没有任何跟NVIC有关的说明
回复 支持 反对

使用道具 举报

6

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
81
金钱
81
注册时间
2013-9-1
在线时间
3 小时
 楼主| 发表于 2013-9-6 12:50:27 | 显示全部楼层
自己顶一下。。。还没解决
回复 支持 反对

使用道具 举报

7

主题

85

帖子

0

精华

初级会员

Rank: 2

积分
163
金钱
163
注册时间
2011-3-3
在线时间
12 小时
发表于 2013-9-6 13:03:23 | 显示全部楼层
回复【3楼】lwp513:
---------------------------------
TIM3_IRQHandler 汇编里边哪里有一个[weak]标志 意为只有在其它文件中没有这个函数的时候才会执行此函数 否则被替代
回复 支持 反对

使用道具 举报

6

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
81
金钱
81
注册时间
2013-9-1
在线时间
3 小时
 楼主| 发表于 2013-9-6 13:41:45 | 显示全部楼层
回复【4楼】爱上cmu:
---------------------------------
已经将weak标识去掉,但是依然没有实现预期目标。。。我怀疑是不是那个NVIC没设置好。。。但是我找了好久手册都没找到有关NVIC的东西
回复 支持 反对

使用道具 举报

6

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
81
金钱
81
注册时间
2013-9-1
在线时间
3 小时
 楼主| 发表于 2013-9-6 13:43:49 | 显示全部楼层
回复【4楼】爱上cmu:
---------------------------------
我查了查有关weak标识,我在别的文件没有定义 TIM3_IRQHandler 这个函数,所以应该来说还是执行的是
TIM3_IRQHandler
    b     TIM3_IRQHandler
回复 支持 反对

使用道具 举报

7

主题

85

帖子

0

精华

初级会员

Rank: 2

积分
163
金钱
163
注册时间
2011-3-3
在线时间
12 小时
发表于 2013-9-6 13:57:47 | 显示全部楼层
回复【6楼】lwp513:
---------------------------------
工程贴上来给你看看
回复 支持 反对

使用道具 举报

6

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
81
金钱
81
注册时间
2013-9-1
在线时间
3 小时
 楼主| 发表于 2013-9-6 14:00:15 | 显示全部楼层
回复【7楼】爱上cmu:
---------------------------------
;/*****************************************************************************/
;/* STM32F10x.s: Startup file for ST STM32F10x device series                  */
;/*****************************************************************************/
;/* <<< Use Configuration Wizard in Context Menu >>>                          */
;/*****************************************************************************/
;/* This file is part of the uVision/ARM development tools.                   */
;/* Copyright (c) 2005-2007 Keil Software. All rights reserved.               */
;/* This software may only be used under the terms of a valid, current,       */
;/* end user licence from KEIL for a compatible version of KEIL software      */
;/* development tools. Nothing else gives you the right to use this software. */
;/*****************************************************************************/


;// <h> Stack Configuration
;//   <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
;// </h>

Stack_Size      EQU     0x00000200

                AREA    STACK, NOINIT, READWRITE, ALIGN=3
Stack_Mem       SPACE   Stack_Size
__initial_sp


;// <h> Heap Configuration
;//   <o>  Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
;// </h>

Heap_Size       EQU     0x00000000

                AREA    HEAP, NOINIT, READWRITE, ALIGN=3
__heap_base
Heap_Mem        SPACE   Heap_Size
__heap_limit


                RESERVE8
                THUMB


; Vector Table Mapped to Address 0 at Reset

                AREA    RESET, DATA, READONLY
                EXPORT  __Vectors

__Vectors       DCD     __initial_sp              ; Top of Stack
                DCD     Reset_Handler             ; Reset Handler
                DCD     NMI_Handler               ; NMI Handler
                DCD     HardFault_Handler         ; Hard Fault Handler
                DCD     MemManage_Handler         ; MPU Fault Handler
                DCD     BusFault_Handler          ; Bus Fault Handler
                DCD     UsageFault_Handler        ; Usage Fault Handler
                DCD     0                         ; Reserved
                DCD     0                         ; Reserved
                DCD     0                         ; Reserved
                DCD     0                         ; Reserved
                DCD     SVC_Handler               ; SVCall Handler
                DCD     DebugMon_Handler          ; Debug Monitor Handler
                DCD     0                         ; Reserved
                DCD     endSV_Handler            ; endSV Handler
                DCD     SysTick_Handler           ; SysTick Handler

                ; External Interrupts
                DCD     WWDG_IRQHandler           ; Window Watchdog
                DCD     VD_IRQHandler            ; VD through EXTI Line detect
                DCD     TAMPER_IRQHandler         ; Tamper
                DCD     RTC_IRQHandler            ; RTC
                DCD     FLASH_IRQHandler          ; Flash
                DCD     RCC_IRQHandler            ; RCC
                DCD     EXTI0_IRQHandler          ; EXTI Line 0
                DCD     EXTI1_IRQHandler          ; EXTI Line 1
                DCD     EXTI2_IRQHandler          ; EXTI Line 2
                DCD     EXTI3_IRQHandler          ; EXTI Line 3
                DCD     EXTI4_IRQHandler          ; EXTI Line 4
                DCD     DMAChannel1_IRQHandler    ; DMA Channel 1
                DCD     DMAChannel2_IRQHandler    ; DMA Channel 2
                DCD     DMAChannel3_IRQHandler    ; DMA Channel 3
                DCD     DMAChannel4_IRQHandler    ; DMA Channel 4
                DCD     DMAChannel5_IRQHandler    ; DMA Channel 5
                DCD     DMAChannel6_IRQHandler    ; DMA Channel 6
                DCD     DMAChannel7_IRQHandler    ; DMA Channel 7
                DCD     ADC_IRQHandler            ; ADC
                DCD     USB_HP_CAN_TX_IRQHandler  ; USB High riority or CAN TX
                DCD     USB_LP_CAN_RX0_IRQHandler ; USB Low  riority or CAN RX0
                DCD     CAN_RX1_IRQHandler        ; CAN RX1
                DCD     CAN_SCE_IRQHandler        ; CAN SCE
                DCD     EXTI9_5_IRQHandler        ; EXTI Line 9..5
                DCD     TIM1_BRK_IRQHandler       ; TIM1 Break
                DCD     TIM1_UP_IRQHandler        ; TIM1 Update
                DCD     TIM1_TRG_COM_IRQHandler   ; TIM1 Trigger and Commutation
                DCD     TIM1_CC_IRQHandler        ; TIM1 Capture Compare
                DCD     TIM2_IRQHandler           ; TIM2
                DCD     TIM3_IRQHandler           ; TIM3
                DCD     TIM4_IRQHandler           ; TIM4
                DCD     I2C1_EV_IRQHandler        ; I2C1 Event
                DCD     I2C1_ER_IRQHandler        ; I2C1 Error
                DCD     I2C2_EV_IRQHandler        ; I2C2 Event
                DCD     I2C2_ER_IRQHandler        ; I2C2 Error
                DCD     SPI1_IRQHandler           ; SPI1
                DCD     SPI2_IRQHandler           ; SPI2
                DCD     USART1_IRQHandler         ; USART1
                DCD     USART2_IRQHandler         ; USART2
                DCD     USART3_IRQHandler         ; USART3
                DCD     EXTI15_10_IRQHandler      ; EXTI Line 15..10
                DCD     RTCAlarm_IRQHandler       ; RTC Alarm through EXTI Line
                DCD     USBWakeUp_IRQHandler      ; USB Wakeup from suspend


                AREA    |.text|, CODE, READONLY


; Reset Handler

Reset_Handler   ROC
                EXPORT  Reset_Handler             [WEAK]
                IMPORT  __main
                LDR     R0, =__main
                BX      R0
                ENDP


; Dummy Exception Handlers (infinite loops which can be modified)                

NMI_Handler     ROC
                EXPORT  NMI_Handler               [WEAK]
                B       .
                ENDP
HardFault_Handler\
                ROC
                EXPORT  HardFault_Handler         [WEAK]
                B       .
                ENDP
MemManage_Handler\
                PROC
                EXPORT  MemManage_Handler         [WEAK]
                B       .
                ENDP
BusFault_Handler\
                PROC
                EXPORT  BusFault_Handler          [WEAK]
                B       .
                ENDP
UsageFault_Handler\
                PROC
                EXPORT  UsageFault_Handler        [WEAK]
                B       .
                ENDP
SVC_Handler     PROC
                EXPORT  SVC_Handler               [WEAK]
                B       .
                ENDP
DebugMon_Handler\
                PROC
                EXPORT  DebugMon_Handler          [WEAK]
                B       .
                ENDP
PendSV_Handler  PROC
                EXPORT  PendSV_Handler            [WEAK]
                B       .
                ENDP
SysTick_Handler PROC
                EXPORT  SysTick_Handler           [WEAK]
                B       .
                ENDP

Default_Handler PROC

                EXPORT  WWDG_IRQHandler           [WEAK]
                EXPORT  PVD_IRQHandler            [WEAK]
                EXPORT  TAMPER_IRQHandler         [WEAK]
                EXPORT  RTC_IRQHandler            [WEAK]
                EXPORT  FLASH_IRQHandler          [WEAK]
                EXPORT  RCC_IRQHandler            [WEAK]
                EXPORT  EXTI0_IRQHandler          [WEAK]
                EXPORT  EXTI1_IRQHandler          [WEAK]
                EXPORT  EXTI2_IRQHandler          [WEAK]
                EXPORT  EXTI3_IRQHandler          [WEAK]
                EXPORT  EXTI4_IRQHandler          [WEAK]
                EXPORT  DMAChannel1_IRQHandler    [WEAK]
                EXPORT  DMAChannel2_IRQHandler    [WEAK]
                EXPORT  DMAChannel3_IRQHandler    [WEAK]
                EXPORT  DMAChannel4_IRQHandler    [WEAK]
                EXPORT  DMAChannel5_IRQHandler    [WEAK]
                EXPORT  DMAChannel6_IRQHandler    [WEAK]
                EXPORT  DMAChannel7_IRQHandler    [WEAK]
                EXPORT  ADC_IRQHandler            [WEAK]
                EXPORT  USB_HP_CAN_TX_IRQHandler  [WEAK]
                EXPORT  USB_LP_CAN_RX0_IRQHandler [WEAK]
                EXPORT  CAN_RX1_IRQHandler        [WEAK]
                EXPORT  CAN_SCE_IRQHandler        [WEAK]
                EXPORT  EXTI9_5_IRQHandler        [WEAK]
                EXPORT  TIM1_BRK_IRQHandler       [WEAK]
                EXPORT  TIM1_UP_IRQHandler        [WEAK]
                EXPORT  TIM1_TRG_COM_IRQHandler   [WEAK]
                EXPORT  TIM1_CC_IRQHandler        [WEAK]
                EXPORT  TIM2_IRQHandler           [WEAK]
                EXPORT  TIM3_IRQHandler           
                EXPORT  TIM4_IRQHandler           [WEAK]
                EXPORT  I2C1_EV_IRQHandler        [WEAK]
                EXPORT  I2C1_ER_IRQHandler        [WEAK]
                EXPORT  I2C2_EV_IRQHandler        [WEAK]
                EXPORT  I2C2_ER_IRQHandler        [WEAK]
                EXPORT  SPI1_IRQHandler           [WEAK]
                EXPORT  SPI2_IRQHandler           [WEAK]
                EXPORT  USART1_IRQHandler         [WEAK]
                EXPORT  USART2_IRQHandler         [WEAK]
                EXPORT  USART3_IRQHandler         [WEAK]
                EXPORT  EXTI15_10_IRQHandler      [WEAK]
                EXPORT  RTCAlarm_IRQHandler       [WEAK]
                EXPORT  USBWakeUp_IRQHandler      [WEAK]

WWDG_IRQHandler
PVD_IRQHandler
TAMPER_IRQHandler
RTC_IRQHandler
FLASH_IRQHandler
RCC_IRQHandler
EXTI0_IRQHandler
EXTI1_IRQHandler
EXTI2_IRQHandler
EXTI3_IRQHandler
EXTI4_IRQHandler
DMAChannel1_IRQHandler
DMAChannel2_IRQHandler
DMAChannel3_IRQHandler
DMAChannel4_IRQHandler
DMAChannel5_IRQHandler
DMAChannel6_IRQHandler
DMAChannel7_IRQHandler
ADC_IRQHandler
USB_HP_CAN_TX_IRQHandler
USB_LP_CAN_RX0_IRQHandler
CAN_RX1_IRQHandler
CAN_SCE_IRQHandler
EXTI9_5_IRQHandler
TIM1_BRK_IRQHandler
TIM1_UP_IRQHandler
TIM1_TRG_COM_IRQHandler
TIM1_CC_IRQHandler
TIM2_IRQHandler

TIM3_IRQHandler
b TIM3_IRQHandler

TIM4_IRQHandler
I2C1_EV_IRQHandler
I2C1_ER_IRQHandler
I2C2_EV_IRQHandler
I2C2_ER_IRQHandler
SPI1_IRQHandler
SPI2_IRQHandler
USART1_IRQHandler
USART2_IRQHandler
USART3_IRQHandler
EXTI15_10_IRQHandler
RTCAlarm_IRQHandler
USBWakeUp_IRQHandler

                B       .

                ENDP


                ALIGN


; User Initial Stack & Heap

                IF   EF:__MICROLIB
                
                EXPORT  __initial_sp
                EXPORT  __heap_base
                EXPORT  __heap_limit
                
                ELSE
                
                IMPORT  __use_two_region_memory
                EXPORT  __user_initial_stackheap
__user_initial_stackheap

                LDR     R0, =  Heap_Mem
                LDR     R1, =(Stack_Mem + Stack_Size)
                LDR     R2, = (Heap_Mem +  Heap_Size)
                LDR     R3, = Stack_Mem
                BX      LR

                ALIGN

                ENDIF


                END

-------------------------------------------------------------------------------------------------------------------------------------------

#define GPIOD_CR   (*((volatile unsigned long*)(0x40011400 + 0x0)))
#define GPIOD_BSRR  (*((volatile unsigned long*)(0x40011400 + 0x10)))
//#define RCC_APB2ENR (*((volatile unsigned long*)(0x40021000 + 0x18)))

#define RCC_BASE_ADDR (volatile unsigned long*)(0x40021000)

typedef struct _RCC
{
unsigned long RCC_CR;
unsigned long RCC_CFGR;
unsigned long RCC_CIR;
unsigned long RCC_APB2RSTR;
unsigned long RCC_APB1RSTR;
unsigned long RCC_AHBENR;
unsigned long RCC_APB2ENR;
unsigned long RCC_APB1ENR;
unsigned long RCC_BDCR;
unsigned long RCC_CSR;
}RCC;

void timer3_init()
{
#define TIM3_BASE_ADDR (volatile unsigned long*)(0x40000400)
#define TIM3_CR1   *(TIM3_BASE_ADDR+0x00)
#define TIM3_ARR *(TIM3_BASE_ADDR+0x2C) 
#define TIM3_CNT *(TIM3_BASE_ADDR+0x24)
#define TIM3_DIER *(TIM3_BASE_ADDR+0x0c)
#define TIM3_PSC *(TIM3_BASE_ADDR+0x28)
#define SETENA0 (*(volatile unsigned long*)(0xE000E104))
TIM3_ARR = 30000;
//TIM3_CNT = 30000;
TIM3_PSC = 3600-1;
TIM3_DIER |= 1<<0;

//TIM3_CR1 |= (1<<7)|(1<<4);   //AUTO RELOAD
TIM3_CR1 |= (1<<0);     //TIM3 ENABLE
SETENA0 |= 1<<(15+29);

}

void system_init()
{
RCC* rcc =(void*)RCC_BASE_ADDR;

rcc->RCC_CFGR |= (0x7<<18); //PLLMUL = 9
rcc->RCC_CFGR |= (1<<17)|(1<<16)|(4<<8); //HSE IN NOT DIV & HCLK=PCLK/2

rcc->RCC_CR |= (1<<16); //HSE ON
rcc->RCC_CR |= (1<<24); //PLL ENABLE
rcc->RCC_CFGR |= (0x2<<0); //USE PLL AS system clock
rcc->RCC_APB1ENR |=  (1<<1);  
}

int main()
{
unsigned int c = 0;
RCC* rcc =(void*)RCC_BASE_ADDR;

system_init();
timer3_init();
  
  rcc->RCC_APB2ENR |= (3 << 5);  //IOPDEN = 1
  GPIOD_CR = 1<<8;
  while(1) {
    GPIOD_BSRR |= (1 << 18);  // ON
    for(c = 0; c < 500000; c++);
    GPIOD_BSRR |= (1 << 2);   // OFF
    for(c = 0; c < 500000; c++);
  }
  return 0;
}

边学习边写的代码有点乱
回复 支持 反对

使用道具 举报

6

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
81
金钱
81
注册时间
2013-9-1
在线时间
3 小时
 楼主| 发表于 2013-9-6 14:01:09 | 显示全部楼层
回复【7楼】爱上cmu:
---------------------------------
但是不管怎么样我觉得都要设置那个叫NVIC的玩意啊。。。
回复 支持 反对

使用道具 举报

6

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
81
金钱
81
注册时间
2013-9-1
在线时间
3 小时
 楼主| 发表于 2013-9-6 14:02:38 | 显示全部楼层
回复【9楼】lwp513:
---------------------------------
tim3的时钟使能放在了systeminit里面rcc->RCC_APB1ENR |=  (1<<1);
回复 支持 反对

使用道具 举报

6

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
81
金钱
81
注册时间
2013-9-1
在线时间
3 小时
 楼主| 发表于 2013-9-6 14:55:13 | 显示全部楼层
还是自己顶一下
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2013-9-6 21:29:05 | 显示全部楼层
TIM3_IRQHandler 
b TIM3_IRQHandler 
 这种用法,没测试过,呵呵。
我习惯在c语言里面实现TIM3_IRQHandler 函数
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

6

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
81
金钱
81
注册时间
2013-9-1
在线时间
3 小时
 楼主| 发表于 2013-9-6 23:03:20 | 显示全部楼层
回复【12楼】正点原子:
---------------------------------
在C函数里面实现while(1)也是不行的
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-13 18:36

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表