ARM LPC2103定时器中断方式寄存器设置

发布时间:2023-03-07  

定时器查询方式定时器初始化:

1、设置定时器分频数,为(x+1)分频

2、匹配通道X中断并复位TxTC

3、比较值(1S定时值)

4、启动并复位TxTC


如:

T1PR = 99; // 设置定时器0分频为100分频,得110592Hz

T1MCR = 0x03; // 匹配通道0匹配中断并复位T0TC

T1MR0 = 110592/2; // 比较值(1S定时值)

T1TCR = 0x03; // 启动并复位T0TC

T1TCR = 0x01;

研究了好长一段时间,LPC210X的定时器,查询方式定时很简单如上面,但中断方式要操作好多寄存器,太麻烦,一直是一头雾水。好不容易理出了思路,现将一段例程粘贴备忘。

#include 《intrinsics.h》

#include 《stdio.h》

#include 《iolpc2103.h》

// OSC [Hz]

#define FOSC 11059200UL

// Core clk [Hz]

#define FCCLK FOSC

// Per clk [Hz]

#define PCCLK (FOSC/4)

// Timer tick per second

#define TICK_PER_SEC (4UL)

#define TIM_PER_S(Val) (PCCLK/Val)

#define MAX_TICK_PER TIM_PER_S(20)

#define MIN_TICK_PER TIM_PER_S(5)

// Timer Delta period [ms]

#define DELTA_PER (50UL)

#define TIM_DPER ((PCCLK*DELTA_PER)/1000UL)

#define LED_MASK 1《《18

/*************************************************************************

* 函数名称:irq_handler

* 入口参数:无

* 返回参数:无

* 描 述:IRQ handler

*************************************************************************/

#pragma vector=IRQV

__irq __arm void irq_handler (void)

{

void (*interrupt_function)();

unsigned int vector;

vector = VICVectAddr; //获得中断向量

interrupt_function = (void(*)())vector;

if(interrupt_function != NULL)

{

interrupt_function(); //调用中断指向的函数

}

else

{

VICVectAddr = 0; //清除在VIC中的中断

}

}

/*************************************************************************

* 函数名称: Timer0Handler

* 入口参数: 无

* 返回参数: 无

* 说 明: Timer 0 handler

*************************************************************************/

void Timer0Handler (void)

{

// clear interrupt flag

T0IR_bit.MR0INT = 1;

// Change patern

if ((IOSET & LED_MASK) == 0)

IOSET = LED_MASK; //关闭LED

else

IOCLR = LED_MASK;

//pNextPattern = pNextPattern-》pNextPattern; //调整当前的链表

VICVectAddr = 0;

}

/*************************************************************************

* 函数名称: VicInit

* 入口参数: 无

* 返回参数: 无

* 说 明: Init VIC module

*************************************************************************/

void VicInit (void)

{

// Assign all interrupt chanels to IRQ

VICIntSelect = 0;

// Diasable all interrupts

VICIntEnClear = 0xFFFFFFFF;

// Clear all software interrutps

VICSoftIntClear = 0xFFFFFFFF;

// VIC registers can be accessed in User or privileged mode

VICProtection = 0;

// Clear interrupt

VICVectAddr = 0;

// Clear address of the Interrupt Service routine (ISR) for non-vectored IRQs.

VICDefVectAddr = 0;

// Clear address of the Interrupt Service routine (ISR) for vectored IRQs.

VICVectAddr0 = VICVectAddr1 = VICVectAddr2 = VICVectAddr3 =

VICVectAddr4 = VICVectAddr5 = VICVectAddr6 = VICVectAddr7 =

VICVectAddr8 = VICVectAddr9 = VICVectAddr10 = VICVectAddr11 =

VICVectAddr12 = VICVectAddr13 = VICVectAddr14 = VICVectAddr15 = 0;

// Disable all vectored IRQ slots

VICVectCntl0 = VICVectCntl1 = VICVectCntl2 = VICVectCntl3 =

VICVectCntl4 = VICVectCntl5 = VICVectCntl6 = VICVectCntl7 =

VICVectCntl8 = VICVectCntl9 = VICVectCntl10 = VICVectCntl11 =

VICVectCntl12 = VICVectCntl13 = VICVectCntl14 = VICVectCntl15 = 0;

}

/*************************************************************************

* 函数名称: Init_timer0

* 入口参数: 无

* 返回参数: 无

* 说 明: Init tiner0

*************************************************************************/

void Init_timer0(void)

{

/*

// Init timer

// Reset and stop timer0

T0TCR = 2;

// Set timer counters mode - clock by PCLK

T0CTCR = 0;

// Set timer prescaler

T0PR = 0;

// Set timer period

T0MR0 = PCCLK/TICK_PER_SEC;

// Set mack action - interrupt by MACH0 enable, reset counter

T0MCR = 3;

// No external action

T0EMR = 0;

*/

T0TCR = 2;

T0CTCR = 0;

T0PR = 0;

T0MR0 = PCCLK/TICK_PER_SEC;

T0MCR = 3;

T0EMR = 0;

// Assign to IRQ

VICIntSelect_bit.TIMER0 = 0;

// Set interrupt slots

VICVectAddr0 = (unsigned int) Timer0Handler;

VICVectCntl0_bit.NUMBER = VIC_TIMER0;

VICVectCntl0_bit.ENABLED = 1;

// Timer 0 interrupt enable

VICIntEnable_bit.TIMER0 = 1;

// Enable timer0

T0TCR = 1;

}

/*************************************************************************

* 函数名称: Init_Gpio

* 入口参数: 无

* 返回参数: 无

* 说 明: Init GPIO

*************************************************************************/

void Init_Gpio(void)

{

// Init GPIO

PINSEL0 = PINSEL1 = 0;

// Disable fast IO

SCS_bit.GPIO0M = 0;

// Set pins connect to LEDs as outputs

IODIR = LED_MASK;

// All LEDs off

IOCLR = LED_MASK;

}

/*************************************************************************

* 函数名称: Init_pll

* 入口参数: 无

* 返回参数: 无

* 说 明: Init PLL

*************************************************************************/

void Init_pll(void)

{

// Disable PLL

PLLCON = 0;

// Write Feed

PLLFEED = 0xAA;

PLLFEED = 0x55;

// Set periphery divider /4

APBDIV_bit.APBDIV = 0;

// Set MAM fully enable

MAMCR_bit.MODECTRL = 0;

MAMTIM_bit.CYCLES = 3;

MAMCR_bit.MODECTRL = 2;

}

/*************************************************************************

* 函数名称: main

* 入口参数: 无

* 返回参数: 无

* 描 述: main

*************************************************************************/

void main(void)

{

Init_pll();

// Memory map init flash memory is maped on 0 address

#ifdef FLASH

MEMMAP_bit.MAP = 1;

#else

MEMMAP_bit.MAP = 2;

#endif

__disable_interrupt();

VicInit();

Init_Gpio();

Init_timer0();

__enable_interrupt();

while(1)

{};

}


文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

相关文章

    为高优先级         //步骤一:波特率配置,由定时器1的益处率决定     TMOD = 0x20;//0010 0000 = 0x20,定时器1设置为工作方式2,8位自动装载的定时器     TH1......
    位则是负责与外部中断有关的设置。选择了定时器的工作方式之后,就需要由一个寄存器来允许它是否可以工作,TCON就是这个功能。 黄色 则是外部计数,外部每产生一个脉冲,计数器加1,当计数器都为一,产生一次溢出。由TH0,TL0(值得是定时器......
    中断或者软件查询等待时间结束。 定时与计数在本质是一致的,都是通过计数时钟信号的下降沿个数实现。 定时/计数器的方式寄存器和控制寄存器 1)工作方式寄存器TMOD TMOD用来设置定时/计数器的启动方式,选择的时钟源,设置工作方式......
    11.0592MHZ的振荡器频率F=1/11.0592)N为定时器的工作方式(关于定时/计数器的4中工作方式,以下会有具体介绍):  方式0时,N=13(此为TH为8位,TL为5位) 方式1时,N=16......
    计数器所构成的16位计数器。 TCON 寄存器。TCON为控制寄存器,用来控制两个定时器/计数器的启动和停止。 TMOD寄存器。TMOD为工作方式控制寄存器,用来设置定时器/计数器的工作方式。 二、定时器的......
    字节与低半字节间的进、借位)。 例:57H+3AH(01010111+00111010) F0:用户标志位 由用户(编程人员)决定什么时候用,什么时候不用。 RS1、RS0:工作寄存器组选择位 通过修改PSW中的......
    进、借位(高半字节与低半字节间的进、借位)。 例:57H+3AH(01010111+00111010) F0:用户标志位 由用户(编程人员)决定什么时候用,什么时候不用。 RS1、RS0:工作寄存器......
    频率和预置数等因素有关。 七、定时/计数器的工作方式 2 有什么特点?适用于哪些应用场合? 答:工作方式2 具有初值自动重新加载和循环工作的特点,适用于产生固定脉宽的脉冲信号,和作为串行口波特率发生器使用。 八、一个定时器的定时......
    发出请求,以便解决故障。 定时器的使用步骤 1.打开总中断: EA(ENABLE ALL) = 1; 2.设置定时器工作方式: TMOD寄存器定时器/计数器模式控制寄存器 其中M1和M0是定时器工作方式......
    率为fosc/32。 ② 方式1 和方式3 的波特率可变,由定时器1 的溢出率决定。 当定时器T1 用作波特率发生器时,通常选用定时初值自动重装的工作方式2( 注意:不要把定时器的工作方式与串行口的工作方式......

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>