aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCristian Maglie <c.maglie@bug.st>2014-09-06 12:42:25 +0200
committerCristian Maglie <c.maglie@bug.st>2014-09-06 12:42:25 +0200
commita4496b927bb7889ed076e7b7f0cc27fa0c4b9b75 (patch)
tree73ed5ef74695e8061c860783b7ffb46c73830fe0
parentdf778925a852608461d6153aa81c6336bb7966e7 (diff)
Correct implementation of gcc specific internal functions
The following empty stubs has been replaced by the gcc flag -fno-threadsafe-static: int __cxa_guard_acquire(__guard *); void __cxa_guard_release (__guard *); void __cxa_guard_abort (__guard *); The following empty stubs has been moved into their specific module abi.cpp: void __cxa_pure_virtual(void) __attribute ((noreturn)); void __cxa_deleted_virtual(void) __attribute ((noreturn)); Fix #107
-rw-r--r--cores/arduino/abi.cpp35
-rw-r--r--cores/arduino/new.cpp12
-rw-r--r--cores/arduino/new.h8
-rw-r--r--platform.txt2
4 files changed, 39 insertions, 18 deletions
diff --git a/cores/arduino/abi.cpp b/cores/arduino/abi.cpp
new file mode 100644
index 0000000..8d719b8
--- /dev/null
+++ b/cores/arduino/abi.cpp
@@ -0,0 +1,35 @@
+/*
+ Copyright (c) 2014 Arduino. All right reserved.
+
+ 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
+ version 2.1 of the License, or (at your option) any later version.
+
+ This library 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 Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with this library; if not, write to the Free Software
+ Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+*/
+
+#include <stdlib.h>
+
+extern "C" void __cxa_pure_virtual(void) __attribute__ ((__noreturn__));
+extern "C" void __cxa_deleted_virtual(void) __attribute__ ((__noreturn__));
+
+void __cxa_pure_virtual(void) {
+ // We might want to write some diagnostics to uart in this case
+ //std::terminate();
+ abort();
+}
+
+void __cxa_deleted_virtual(void) {
+ // We might want to write some diagnostics to uart in this case
+ //std::terminate();
+ abort();
+}
+
diff --git a/cores/arduino/new.cpp b/cores/arduino/new.cpp
index b81031e..1486012 100644
--- a/cores/arduino/new.cpp
+++ b/cores/arduino/new.cpp
@@ -1,7 +1,7 @@
-#include <new.h>
-void * operator new(size_t size)
-{
+#include <stdlib.h>
+
+void *operator new(size_t size) {
return malloc(size);
}
@@ -20,9 +20,3 @@ void operator delete[](void * ptr)
free(ptr);
}
-int __cxa_guard_acquire(__guard *g) {return !*(char *)(g);};
-void __cxa_guard_release (__guard *g) {*(char *)g = 1;};
-void __cxa_guard_abort (__guard *) {};
-
-void __cxa_pure_virtual(void) {};
-
diff --git a/cores/arduino/new.h b/cores/arduino/new.h
index 991c86c..50756f9 100644
--- a/cores/arduino/new.h
+++ b/cores/arduino/new.h
@@ -12,13 +12,5 @@ void * operator new[](size_t size);
void operator delete(void * ptr);
void operator delete[](void * ptr);
-__extension__ typedef int __guard __attribute__((mode (__DI__)));
-
-extern "C" int __cxa_guard_acquire(__guard *);
-extern "C" void __cxa_guard_release (__guard *);
-extern "C" void __cxa_guard_abort (__guard *);
-
-extern "C" void __cxa_pure_virtual(void);
-
#endif
diff --git a/platform.txt b/platform.txt
index f7e6734..9a2565f 100644
--- a/platform.txt
+++ b/platform.txt
@@ -21,7 +21,7 @@ compiler.c.elf.flags=-w -Os -Wl,--gc-sections
compiler.c.elf.cmd=avr-gcc
compiler.S.flags=-c -g -x assembler-with-cpp
compiler.cpp.cmd=avr-g++
-compiler.cpp.flags=-c -g -Os -w -fno-exceptions -ffunction-sections -fdata-sections -MMD
+compiler.cpp.flags=-c -g -Os -w -fno-exceptions -ffunction-sections -fdata-sections -fno-threadsafe-statics -MMD
compiler.ar.cmd=avr-ar
compiler.ar.flags=rcs
compiler.objcopy.cmd=avr-objcopy