mirror of
https://github.com/esp8266/Arduino.git
synced 2025-06-13 13:01:55 +03:00
Use placement new for ETSTimer - no heap fragmentation (#6164)
* Use placement new for ETSTimer - no heap fragmentation, new/delete semantics unchanged. * Make change completely invisible to derived classes at compile-time. * Fix "sizeof() incomplete type ETSTimer" error. * C++ reinterpret_cast<> instead of C-style cast. void* instead of uint32_t - fixes x86_64 server compiles. * Simplify casts. * Revert to complete placement new treatment of ETSTimer member. * Cleanup includes * Fix omitted casts * Change per review https://github.com/esp8266/Arduino/pull/6164#pullrequestreview-243583458 * wtf - local compile didn't catch this sloppy mistake * Resolves review https://github.com/esp8266/Arduino/pull/6164#discussion_r290388119 * Reviewer stated that floating point operations are inlined, software operations - reduce number of code spots to one.
This commit is contained in:
@ -1,9 +1,9 @@
|
||||
/*
|
||||
/*
|
||||
Ticker.cpp - esp8266 library that calls functions periodically
|
||||
|
||||
Copyright (c) 2014 Ivan Grokhotkov. All rights reserved.
|
||||
This file is part of the esp8266 core for Arduino environment.
|
||||
|
||||
|
||||
This library is free software; you can redistribute it and/or
|
||||
modify it under the terms of the GNU Lesser General Public
|
||||
License as published by the Free Software Foundation; either
|
||||
@ -19,21 +19,20 @@
|
||||
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
*/
|
||||
|
||||
#include <stddef.h>
|
||||
#include <stdint.h>
|
||||
|
||||
#include "c_types.h"
|
||||
#include "eagle_soc.h"
|
||||
#include "ets_sys.h"
|
||||
#include "osapi.h"
|
||||
|
||||
static const int ONCE = 0;
|
||||
static const int REPEAT = 1;
|
||||
|
||||
#include "Ticker.h"
|
||||
|
||||
namespace
|
||||
{
|
||||
constexpr int ONCE = 0;
|
||||
constexpr int REPEAT = 1;
|
||||
}
|
||||
|
||||
Ticker::Ticker()
|
||||
: _timer(nullptr)
|
||||
: _timer(nullptr)
|
||||
{
|
||||
}
|
||||
|
||||
@ -42,7 +41,12 @@ Ticker::~Ticker()
|
||||
detach();
|
||||
}
|
||||
|
||||
void Ticker::_attach_ms(uint32_t milliseconds, bool repeat, callback_with_arg_t callback, uint32_t arg)
|
||||
void Ticker::_attach_s(float seconds, bool repeat, callback_with_arg_t callback, void* arg)
|
||||
{
|
||||
_attach_ms(1000 * seconds, repeat, callback, arg);
|
||||
}
|
||||
|
||||
void Ticker::_attach_ms(uint32_t milliseconds, bool repeat, callback_with_arg_t callback, void* arg)
|
||||
{
|
||||
if (_timer)
|
||||
{
|
||||
@ -50,11 +54,11 @@ void Ticker::_attach_ms(uint32_t milliseconds, bool repeat, callback_with_arg_t
|
||||
}
|
||||
else
|
||||
{
|
||||
_timer = new ETSTimer;
|
||||
_timer = &_etsTimer;
|
||||
}
|
||||
|
||||
os_timer_setfn(_timer, reinterpret_cast<ETSTimerFunc*>(callback), reinterpret_cast<void*>(arg));
|
||||
os_timer_arm(_timer, milliseconds, (repeat)?REPEAT:ONCE);
|
||||
os_timer_setfn(_timer, callback, arg);
|
||||
os_timer_arm(_timer, milliseconds, (repeat) ? REPEAT : ONCE);
|
||||
}
|
||||
|
||||
void Ticker::detach()
|
||||
@ -63,25 +67,18 @@ void Ticker::detach()
|
||||
return;
|
||||
|
||||
os_timer_disarm(_timer);
|
||||
delete _timer;
|
||||
_timer = nullptr;
|
||||
_callback_function = nullptr;
|
||||
}
|
||||
|
||||
bool Ticker::active() const
|
||||
{
|
||||
return (bool)_timer;
|
||||
return _timer;
|
||||
}
|
||||
|
||||
void Ticker::_static_callback(void* arg)
|
||||
{
|
||||
Ticker* _this = (Ticker*)arg;
|
||||
if (_this == nullptr)
|
||||
{
|
||||
return;
|
||||
}
|
||||
if (_this->_callback_function)
|
||||
{
|
||||
Ticker* _this = reinterpret_cast<Ticker*>(arg);
|
||||
if (_this && _this->_callback_function)
|
||||
_this->_callback_function();
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user