Fixed memory leak in tmr.alarm()

This commit is contained in:
dnc40085 2015-05-14 04:40:57 -07:00
parent 608d5f6be0
commit 4f097cf063
1 changed files with 11 additions and 0 deletions

View File

@ -11,12 +11,19 @@
static os_timer_t alarm_timer[NUM_TMR]; static os_timer_t alarm_timer[NUM_TMR];
static int alarm_timer_cb_ref[NUM_TMR] = {LUA_NOREF,LUA_NOREF,LUA_NOREF,LUA_NOREF,LUA_NOREF,LUA_NOREF,LUA_NOREF}; static int alarm_timer_cb_ref[NUM_TMR] = {LUA_NOREF,LUA_NOREF,LUA_NOREF,LUA_NOREF,LUA_NOREF,LUA_NOREF,LUA_NOREF};
static bool alarm_timer_repeat[NUM_TMR]= {0,0,0,0,0,0,0};
void alarm_timer_common(lua_State* L, unsigned id){ void alarm_timer_common(lua_State* L, unsigned id){
if(alarm_timer_cb_ref[id] == LUA_NOREF) if(alarm_timer_cb_ref[id] == LUA_NOREF)
return; return;
lua_rawgeti(L, LUA_REGISTRYINDEX, alarm_timer_cb_ref[id]); lua_rawgeti(L, LUA_REGISTRYINDEX, alarm_timer_cb_ref[id]);
lua_call(L, 0, 0); lua_call(L, 0, 0);
if(alarm_timer_repeat[id]==0)
{
if(alarm_timer_cb_ref[id] != LUA_NOREF)
luaL_unref(L, LUA_REGISTRYINDEX, alarm_timer_cb_ref[id]);
}
} }
void alarm_timer_cb0(void *arg){ void alarm_timer_cb0(void *arg){
@ -118,6 +125,7 @@ static int tmr_alarm( lua_State* L )
stack++; stack++;
if ( repeat != 1 && repeat != 0 ) if ( repeat != 1 && repeat != 0 )
return luaL_error( L, "wrong arg type" ); return luaL_error( L, "wrong arg type" );
alarm_timer_repeat[id]=repeat;
} }
// luaL_checkanyfunction(L, stack); // luaL_checkanyfunction(L, stack);
@ -141,6 +149,9 @@ static int tmr_stop( lua_State* L )
MOD_CHECK_ID( tmr, id ); MOD_CHECK_ID( tmr, id );
os_timer_disarm(&(alarm_timer[id])); os_timer_disarm(&(alarm_timer[id]));
if(alarm_timer_cb_ref[id] != LUA_NOREF)
luaL_unref(L, LUA_REGISTRYINDEX, alarm_timer_cb_ref[id]);
return 0; return 0;
} }