diff options
author | gdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4> | 2013-01-06 09:10:58 +0000 |
---|---|---|
committer | gdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4> | 2013-01-06 09:10:58 +0000 |
commit | 739e24c329dc3ca72349dec8f4ce16b69abd62e9 (patch) | |
tree | a6bbdfdc6e60ad6045813870c135a95e054ec4cd /os/various/cpp_wrappers/ch.cpp | |
parent | aaa126da625b7d63440cf5f28e3ad69a5839def2 (diff) | |
download | ChibiOS-739e24c329dc3ca72349dec8f4ce16b69abd62e9.tar.gz ChibiOS-739e24c329dc3ca72349dec8f4ce16b69abd62e9.tar.bz2 ChibiOS-739e24c329dc3ca72349dec8f4ce16b69abd62e9.zip |
Merged another patch to the C++ wrapper.
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@5036 35acf78f-673a-0410-8e92-d51de3d6d3f4
Diffstat (limited to 'os/various/cpp_wrappers/ch.cpp')
-rw-r--r-- | os/various/cpp_wrappers/ch.cpp | 21 |
1 files changed, 19 insertions, 2 deletions
diff --git a/os/various/cpp_wrappers/ch.cpp b/os/various/cpp_wrappers/ch.cpp index c971a90aa..36eaa70df 100644 --- a/os/various/cpp_wrappers/ch.cpp +++ b/os/various/cpp_wrappers/ch.cpp @@ -47,6 +47,16 @@ namespace chibios_rt { chSysUnlock();
}
+ void System::lockFromIsr(void) {
+
+ chSysLockFromIsr();
+ }
+
+ void System::unlockFromIsr(void) {
+
+ chSysUnlockFromIsr();
+ }
+
systime_t System::getTime(void) {
return chTimeNow();
@@ -813,6 +823,13 @@ namespace chibios_rt { chPoolInit(&pool, size, provider);
}
+ MemoryPool::MemoryPool(size_t size, memgetfunc_t provider, void* p, size_t n) {
+
+ chPoolInit(&pool, size, provider);
+ chPoolLoadArray(&pool, p, n);
+ }
+
+
void MemoryPool::loadArray(void *p, size_t n) {
chPoolLoadArray(&pool, p, n);
@@ -820,12 +837,12 @@ namespace chibios_rt { void *MemoryPool::allocI(void) {
- return chPoolAlloc(&pool);
+ return chPoolAllocI(&pool);
}
void *MemoryPool::alloc(void) {
- return chPoolAllocI(&pool);
+ return chPoolAlloc(&pool);
}
void MemoryPool::free(void *objp) {
|