微波EDA网,见证研发工程师的成长!
首页 > 研发问答 > 无线和射频 > TI Zigbee设计交流 > CC2530在Z-STACK中使用定时器

CC2530在Z-STACK中使用定时器

时间:10-02 整理:3721RD 点击:

1.如果CC2530一直使用定时器计时,功率大概是多少?

2.z-stack协议栈中,osal_start_timerEx()这个API计时精确吗?

3.如果在使用Z-stack协议栈完成单位时间内p0口中断次数统计的功能,有什么好的方案吗?

Q1: 如果CC2530一直使用定时器计时,功率大概是多少?

看数据手册,有给外设电流大小。或者接个万用表实测下电流就好了。

PARAMETER TEST CONDITIONS MIN TYP MAX UNIT
Digital regulator on. 16-MHz RCOSC running. No radio, crystals, or peripherals active.
3.4 mA
Medium CPU activity: normal flash access(1), no RAM access
32-MHz XOSC running. No radio or peripherals active.
6.5 8.9 mA
Medium CPU activity: normal flash access(1), no RAM access
32-MHz XOSC running, radio in RX mode, –50-dBm input power, no peripherals active, CPU 20.5 mA idle
32-MHz XOSC running, radio in RX mode at -100-dBm input power (waiting for signal), no 24.3 29.6 mA Core current peripherals active, CPU idle Icore consumption 32-MHz XOSC running, radio in TX mode, 1-dBm output power, no peripherals active, CPU idle 28.7 mA
32-MHz XOSC running, radio in TX mode, 4.5-dBm output power, no peripherals active, CPU 33.5 39.6 mA idle
Power mode 1. Digital regulator on; 16-MHz RCOSC and 32-MHz crystal oscillator off; 0.2 0.3 mA 32.768-kHz XOSC, POR, BOD and sleep timer active; RAM and register retention
Power mode 2. Digital regulator off; 16-MHz RCOSC and 32-MHz crystal oscillator off; 1 2 μA 32.768-kHz XOSC, POR, and sleep timer active; RAM and register retention
Power mode 3. Digital regulator off; no clocks; POR active; RAM and register retention 0.4 1 μA
Peripheral Current Consumption (Adds to core current Icore for each peripheral unit activated)
Timer 1 Timer running, 32-MHz XOSC used 90 μA
Timer 2 Timer running, 32-MHz XOSC used 90 μA
Timer 3 Timer running, 32-MHz XOSC used 60 μA
Iperi Timer 4 Timer running, 32-MHz XOSC used 70 μA
Sleep timer Including 32.753-kHz RCOSC 0.6 μA
ADC When converting 1.2 mA
Erase 1 mA
Flash
Burst write peak current 6 mA

2.z-stack协议栈中,osal_start_timerEx()这个API计时精确吗?

毫秒级吧,看你的应用需求。

原文地址:http://www.kaleidscope.cn:1020/archives/1056

以下为部分内容:

Zigbee协议栈中如果要实现一个定时事件或者延时的话,有很多种方法,定时事件呢其实就是我们熟悉的使用定时器来定时,产生定时事件,当然也可以用来延时。 1、协议栈定时器HalTimerConfig ZigBee协议栈提供了定时器的使用接口,在hal层调用HalTimerConfig即可配置使用,而定时器2被协议栈占用了,所以只有使用1、3、4三个定时器。 在hal_timer.h中我们可以看到几个定时器的定义:

/* Timer ID definitions */

#define HAL_TIMER_0 0x00 // 8bit timer

#define HAL_TIMER_1 0x01 // 16bit Mac timer

#define HAL_TIMER_2 0x02 // 8bit timer

#define HAL_TIMER_3 0x03 // 16bit timer

#define HAL_TIMER_MAX 4 // Max number of timer

所以和硬件中的定时器是有区别的,经过了映射,这里需要注意一下。

* HAL_TIMER_0 --> HW Timer 3 8bit

* HAL_TIMER_2 --> HW Timer 4 8bit

* HAL_TIMER_3 --> HW Timer 1 16bit

如果我们要使用协议栈的定时器进行相关操作,只需进行定时器的配置即可:

extern uint8 extern uint8 HalTimerConfig ( uint8 timerId,uint8 opMode,uint8 channel,uint8 channelMode,bool intEnable,halTimerCBack_t cback );

opMode - Operation mode操作方式共3种

* channel - Channel where the counter operates on选择通道,对应IO口

* channelMode - Mode of that channel通道的模式

* intEnable -可中断

* cBack - Pointer to the callback function 中断函数

然后在回调函数中进行处理相关事件即可。

void timer_callback(uint8 timerId, uint8 channel, uint8 channelMode);

2、使用寄存器直接操作

直接使用寄存器就更简单了,就把CC2530当做一个单片机用就可以了,这里我拿了我以前写的代码给大家演示,注释有错的地方请忽略,大概就这样吧。

void InitT3(void)

{

T3CTL |= 0x08 ; //开溢出中断

T3IE = 1; //开总中断和T3中断

T3CTL|=0X12; //,128/16000000*N=0.5S,N=65200

T3CC0 = 0x01;

T3CTL &= ~0X03; //自动重装 00->0xff

T3CTL |=0X10; //启动

}

void timer1Init(void)

{/*设置定时器T1,128分频,模模式,从0计数到T1CC0*/

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top