Merge pull request #1107 from gedankenexperimenter/bug/event-queue-leak
Fix Qukeys memory bounds violationpull/1108/head
commit
7b354403f8
@ -0,0 +1,71 @@
|
|||||||
|
/* -*- mode: c++ -*-
|
||||||
|
* Copyright (C) 2022 Keyboard.io, Inc.
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify it under
|
||||||
|
* the terms of the GNU General Public License as published by the Free Software
|
||||||
|
* Foundation, version 3.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
||||||
|
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
||||||
|
* details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "Kaleidoscope.h"
|
||||||
|
|
||||||
|
// *INDENT-OFF*
|
||||||
|
KEYMAPS(
|
||||||
|
[0] = KEYMAP_STACKED
|
||||||
|
(
|
||||||
|
XXX ,XXX ,XXX ,XXX ,XXX ,XXX ,XXX
|
||||||
|
,XXX ,XXX ,XXX ,XXX ,XXX ,XXX ,XXX
|
||||||
|
,XXX ,XXX ,XXX ,XXX ,XXX ,XXX
|
||||||
|
,XXX ,XXX ,XXX ,XXX ,XXX ,XXX ,XXX
|
||||||
|
,XXX ,XXX ,XXX ,XXX
|
||||||
|
,XXX
|
||||||
|
|
||||||
|
,XXX ,XXX ,XXX ,XXX ,XXX ,XXX ,XXX
|
||||||
|
,XXX ,XXX ,XXX ,XXX ,XXX ,XXX ,XXX
|
||||||
|
,XXX ,XXX ,XXX ,XXX ,XXX ,XXX
|
||||||
|
,XXX ,XXX ,XXX ,XXX ,XXX ,XXX ,XXX
|
||||||
|
,XXX ,XXX ,XXX ,XXX
|
||||||
|
,XXX
|
||||||
|
)
|
||||||
|
) // KEYMAPS(
|
||||||
|
// *INDENT-ON*
|
||||||
|
|
||||||
|
#include <kaleidoscope/KeyAddrEventQueue.h>
|
||||||
|
|
||||||
|
namespace kaleidoscope {
|
||||||
|
namespace plugin {
|
||||||
|
|
||||||
|
class QueueLeaker : public Plugin {
|
||||||
|
public:
|
||||||
|
EventHandlerResult afterEachCycle() {
|
||||||
|
// Shift queue without checking to be sure that queue is not empty. If
|
||||||
|
// KeyAddrEventQueue uses an unsigned integer for queue length, this will
|
||||||
|
// result in some bad behavior.
|
||||||
|
queue_.shift();
|
||||||
|
return EventHandlerResult::OK;
|
||||||
|
}
|
||||||
|
private:
|
||||||
|
KeyAddrEventQueue<8> queue_;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace plugin
|
||||||
|
} // namespace kaleidoscope
|
||||||
|
|
||||||
|
kaleidoscope::plugin::QueueLeaker QueueLeaker;
|
||||||
|
|
||||||
|
KALEIDOSCOPE_INIT_PLUGINS(QueueLeaker);
|
||||||
|
|
||||||
|
void setup() {
|
||||||
|
Kaleidoscope.setup();
|
||||||
|
}
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
Kaleidoscope.loop();
|
||||||
|
}
|
@ -0,0 +1,6 @@
|
|||||||
|
{
|
||||||
|
"cpu": {
|
||||||
|
"fqbn": "keyboardio:virtual:model01",
|
||||||
|
"port": ""
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,99 @@
|
|||||||
|
/* -*- mode: c++ -*-
|
||||||
|
* Copyright (C) 2022 Keyboard.io, Inc.
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify it under
|
||||||
|
* the terms of the GNU General Public License as published by the Free Software
|
||||||
|
* Foundation, version 3.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
||||||
|
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
||||||
|
* details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "testing/setup-googletest.h"
|
||||||
|
|
||||||
|
SETUP_GOOGLETEST();
|
||||||
|
|
||||||
|
namespace kaleidoscope {
|
||||||
|
namespace testing {
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
constexpr uint32_t t_0{0};
|
||||||
|
constexpr uint32_t t_1{1};
|
||||||
|
constexpr uint32_t t_10{10};
|
||||||
|
|
||||||
|
using ::testing::IsEmpty;
|
||||||
|
|
||||||
|
class KeyAddrEventQueueLeak : public VirtualDeviceTest {
|
||||||
|
public:
|
||||||
|
void assertTimeElapses(uint32_t interval) {
|
||||||
|
// Record time at start
|
||||||
|
uint32_t start = Kaleidoscope.millisAtCycleStart();
|
||||||
|
|
||||||
|
// Run cycles until the given amount of time has elapsed
|
||||||
|
sim_.RunForMillis(interval);
|
||||||
|
|
||||||
|
// Record time at end
|
||||||
|
uint32_t end = Kaleidoscope.millisAtCycleStart();
|
||||||
|
|
||||||
|
ASSERT_EQ((end - start), interval);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
TEST_F(KeyAddrEventQueueLeak, TimeIsConsistent) {
|
||||||
|
assertTimeElapses(1);
|
||||||
|
assertTimeElapses(1);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
assertTimeElapses(10);
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace
|
||||||
|
} // namespace testing
|
||||||
|
} // namespace kaleidoscope
|
Loading…
Reference in new issue