當(dāng)前位置:首頁(yè) > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]前段時(shí)間把自己以前用的單片機(jī)定時(shí)器整理出來(lái),我稱(chēng)之為簡(jiǎn)單定時(shí)器,這種簡(jiǎn)單定時(shí)器比較適合定時(shí)器使用量少的程序中,如果定時(shí)器數(shù)量要求多,精度要求高,效率就會(huì)有問(wèn)題,為此,俺就實(shí)現(xiàn)了一個(gè)時(shí)間輪定時(shí)器,簡(jiǎn)單測(cè)

前段時(shí)間把自己以前用的單片機(jī)定時(shí)器整理出來(lái),我稱(chēng)之為簡(jiǎn)單定時(shí)器,這種簡(jiǎn)單定時(shí)器比較適合定時(shí)器使用量少的程序中,如果定時(shí)器數(shù)量要求多,精度要求高,效率就會(huì)有問(wèn)題,為此,俺就實(shí)現(xiàn)了一個(gè)時(shí)間輪定時(shí)器,簡(jiǎn)單測(cè)試下來(lái)效果非常不錯(cuò)。

1 #ifndef __SOFT_TIMER_H__

2 #define __SOFT_TIMER_H__

3

4 #define EVENT_TYPE_ONESHOT 0

5 #define EVENT_TYPE_PERIODIC 1

6

7 #define TMR_POOL_SIZE 20 // 定時(shí)器池,即可用定時(shí)器個(gè)數(shù)

8 #define TMR_WHEEL_SIZE 8 // 時(shí)間輪的粒度

9

10 #define HANDLE int

11

12 typedef void (*pTimerProc)(void*);

13

14 void TimerInit(void);

15 HANDLE SetTimer(unsigned long uElapse,pTimerProc pFunc,void *para,unsigned int Tmr_type);

16 void KillTimer(HANDLE hTmr);

17 void TimerServer(void); // call in main loop

18 void TimerSignal(void); // call it in timer isr

19 unsigned long TmrGetTime(void);

20

21 #endif

簡(jiǎn)單介紹一下:

SetTimer():參數(shù)uElapse:定時(shí)器超時(shí)時(shí)間.參數(shù)pFunc:定時(shí)器超時(shí)回調(diào)函數(shù).參數(shù)para:定時(shí)器超時(shí)回調(diào)函數(shù)參數(shù).參數(shù)Tmr_type:定時(shí)器類(lèi)型,EVENT_TYPE_ONESHOT為單次定時(shí)器,定時(shí)器超時(shí)后,會(huì)被自動(dòng)刪除.EVENT_TYPE_PERIODIC表示周期性定時(shí)器,使用完后需主動(dòng)刪除。返回值:返回定時(shí)器id,用于刪除定時(shí)器。KillTimer():刪除由SetTimer()創(chuàng)建的定時(shí)器。
TimerServer():定時(shí)器管理函數(shù),需在主循環(huán)中調(diào)用。
TimerSignal():定時(shí)器信號(hào)函數(shù),提供定時(shí)器運(yùn)行所需節(jié)拍數(shù),需在硬件定時(shí)器中斷中調(diào)用,例如,硬件定時(shí)器10ms中斷一次,在中斷中調(diào)用TimerSignal(),則時(shí)間輪定時(shí)器的節(jié)拍時(shí)間為10ms.
TmrGetTime():記錄定時(shí)器的節(jié)拍數(shù)

1 #include "timer.h"

2

3 typedef struct _tagTimer{

4 unsigned int elapse;

5 unsigned int interval;

6 void *prev;

7 void *next;

8 TimerProc pFunc;

9 void *para;

10 unsigned char state;

11 unsigned char event_type;

12 unsigned char timeout;

13 }Timer_Typedef;

14

15 typedef struct _tagTimerWheel{

16 Timer_Typedef *pFirst;

17 unsigned int entries;

18 }TimerWheel_Typedef;

19

20 #define TMR_STATE_FREE 0

21 #define TMR_STATE_STOP 1

22 #define TMR_STATE_RUNNING 3

23

24 static Timer_Typedef _timerArray[TMR_POOL_SIZE]={0};

25 static TimerWheel_Typedef TmrWheel[TMR_WHEEL_SIZE]={0};

26 static Timer_Typedef* tmr_free_list;

27 static unsigned tmr_free_slot = 0;

28 static unsigned _tmr_tick = 0;

29

30

31 static Timer_Typedef* Tmr_alloc(void);

32 static void Tmr_free(Timer_Typedef* pTmr);

33 static void Tmr_link(Timer_Typedef* pTmr);

34 static void Tmr_unlink(Timer_Typedef* pTmr);

35

36

37 void TimerInit(void)

38 {

39 int i = 0;

40 for(i=0;i

41 {

42 _timerArray[i].next = (void*)(&_timerArray[i+1]);

43 }

44 _timerArray[TMR_POOL_SIZE-1].next = (void*)0;

45 tmr_free_list = _timerArray;

46 tmr_free_slot = TMR_POOL_SIZE;

47

48 for(i=0;i

49 {

50 TmrWheel[i].pFirst = (void*)0;

51 TmrWheel[i].entries = 0;

52 }

53 }

54

55 HANDLE SetTimer(unsigned long uElapse,TimerProc pFunc,void *para,unsigned int Tmr_type)

56 {

57 int unused_slot = -1;

58 Timer_Typedef *pTmr = (Timer_Typedef *)0;

59

60 pTmr = Tmr_alloc();

61 if(pTmr) unused_slot = pTmr - _timerArray;

62

63 if(unused_slot != -1)

64 {

65 _timerArray[unused_slot].pFunc = pFunc;

66 _timerArray[unused_slot].para = para;

67 _timerArray[unused_slot].interval = uElapse;

68 _timerArray[unused_slot].event_type = Tmr_type;

69 _timerArray[unused_slot].state = 1;

70 Tmr_link(pTmr);

71 }

72 return unused_slot;

73 }

74

75 void KillTimer(HANDLE hTmr)

76 {

77 if((hTmr >= 0)&&(hTmr < TMR_POOL_SIZE))

78 {

79 switch(_timerArray[hTmr].state)

80 {

81 case TMR_STATE_STOP:

82 Tmr_free(&_timerArray[hTmr]);

83 break;

84 case TMR_STATE_RUNNING:

85 Tmr_unlink(&_timerArray[hTmr]);

86 Tmr_free(&_timerArray[hTmr]);

87 break;

88 default:

89 break;

90 }

91 _timerArray[hTmr].timeout = 0;

92 }

93 }

94

95 void TimerServer(void)

96 {

97 int i = 0;

98 Timer_Typedef* pTmr = _timerArray;

99 for(i = 0;i

100 {

101 if((pTmr->timeout)&&(pTmr->pFunc))

102 {

103 (*(pTmr->pFunc))(pTmr->para);

104 pTmr->timeout = 0;

105 }

106 pTmr++;

107 }

108 }

109

110

111 void TimerSignal(void)

112 {

113 int spoke = 0;

114 Timer_Typedef* pTmr,*pNext;

115

116 ++_tmr_tick;

117 spoke = _tmr_tick%TMR_WHEEL_SIZE;

118 pTmr = TmrWheel[spoke].pFirst;

119 while(pTmr)

120 {

121 pNext = pTmr->next;

122 if(pTmr->elapse == _tmr_tick)

123 {

124 Tmr_unlink(pTmr);

125 if(pTmr->event_type == EVENT_TYPE_PERIODIC)

126 {

127 Tmr_link(pTmr);

128 }

129 else

130 {

131 Tmr_free(pTmr);

132 }

133 pTmr->timeout = 1;

134 }

135 pTmr = pNext;

136 }

137 }

138

139 static void Tmr_link(Timer_Typedef* pTmr)

140 {

141 int spoke;

142 TimerWheel_Typedef *pWhl;

143 pTmr->state = TMR_STATE_RUNNING;

144 pTmr->elapse = pTmr->interval + _tmr_tick;

145 spoke = pTmr->elapse%TMR_WHEEL_SIZE;

146 pWhl = &TmrWheel[spoke];

147

148 if(pWhl->pFirst) pWhl->pFirst->prev = pTmr;

149

150 pTmr->next = pWhl->pFirst;

151 pWhl->pFirst = pTmr;

152 pWhl->entries++;

153 }

154

155 static void Tmr_unlink(Timer_Typedef* pTmr)

156 {

157 int spoke;

158 TimerWheel_Typedef *pWhl;

159 pTmr->state = TMR_STATE_STOP;

160 spoke = pTmr->elapse%TMR_WHEEL_SIZE;

161 pWhl = &TmrWheel[spoke];

162

163 if(pWhl->pFirst == pTmr)

164 {

165 pWhl->pFirst = pTmr->next;

166 if(pTmr->next) ((Timer_Typedef*)pTmr->next)->prev = (void*)0;

167 }

168 else

169 {

170 ((Timer_Typedef*)pTmr->prev)->next = pTmr->next;

171 if(pTmr->next) ((Timer_Typedef*)pTmr->next)->prev = pTmr->prev;

172 }

173 pWhl->entries--;

174 }

175

176

177 static Timer_Typedef* Tmr_alloc(void)

178 {

179 Timer_Typedef *pTmr = (Timer_Typedef*)0;

180 if(tmr_free_list)

181 {

182 pTmr = tmr_free_list;

183 tmr_free_list = tmr_free_list->next;

184 tmr_free_slot--;

185 }

186 return pTmr;

187 }

188

189

190

191 static void Tmr_free(Timer_Typedef* pTmr)

192 {

193 pTmr->state = TMR_STATE_FREE;

194 pTmr->prev = (Timer_Typedef*)0;

195 pTmr->next = tmr_free_list;

196 tmr_free_list = pTmr;

197 tmr_free_slot++;

198 }

199

200 unsigned long TmrGetTime(void)

201 {

202 ret

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車(chē)的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車(chē)技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車(chē)工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車(chē)。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車(chē) 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱(chēng),數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱(chēng)"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉