Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Teensy 3 includes new.h, declaring cxa_guard... even with gcc11 #726

Open
swanah opened this issue Nov 15, 2023 · 4 comments
Open

Teensy 3 includes new.h, declaring cxa_guard... even with gcc11 #726

swanah opened this issue Nov 15, 2023 · 4 comments

Comments

@swanah
Copy link

swanah commented Nov 15, 2023

With the update to the new version / compiler version we receive the following error:

...\framework-arduinoteensy\cores\teensy3/new.h:46:16: error: conflicting declaration of C function 'int cxa_guard_acquire(__guard*)'

I am using PlatformIO for compilation. The platform version is [email protected]. While testing I have also replaced framework/cores with the current HEAD from github. While this solved other long standing problems, it did not solve the error above.
I also looked at the code here and I see that for Teensy3 Printable.h still includes new.h leading to the above error message.

Am I correct, that the guard definitions in new.h are no longer required with the new compiler?

@swanah swanah changed the title Teensy 3 includes new.h, decalring cxa_guard... even with gcc11 Teensy 3 includes new.h, declaring cxa_guard... even with gcc11 Nov 15, 2023
@PaulStoffregen
Copy link
Owner

I can't help with PlatformIO.

I can tell you the core library was updated in several ways to use to the new toolchain. Maybe you're got those mismatched? I'd recommend compiling your program with Arduino IDE to check.

@swanah
Copy link
Author

swanah commented Nov 17, 2023

Dear Paul, I am sorry, but the current setup of our project is not easily allowing to switch to ArduinoIDE.
However, since I cannot easily compile in ArduinoIDE, I have downloaded and installed the latest ArduinoIDE + Teensyduino and compared the packages installed (i.e. the core library and the teensy tools) with those we use in our PlatformioIO setup on a file by file basis. All files are identical and I am quite certain I am using the tools and libaries consistent with this repository and teensyduino.

Some more details to our issue that might help understanding:
Our issue is triggered by functions initializing local static variables which we use in the context of implementing lazy initialized singletons. This worked in the previous Teensyduino versions including 1.57. It started throwing the error when updating to 1.58.

Looking more closely I see, that the arm-gcc in teensyduino brings along its own definition of __cxa_guard functions in libstdc++. Hence the error when the complier finds the redefinition in teensy3/new.h.

Personally I can mitigate the problem by either removing the definitions in new.h or by compiling with "-fno-threadsafe-statics".

However, I felt it might be useful to point to this problem, as I had the impression, it is an issue in the cores introduced by upgrading the compiler version.

@PaulStoffregen
Copy link
Owner

Oh, sounds like the problem is resolved, right?

@swanah
Copy link
Author

swanah commented Nov 20, 2023

I managed to create a small example (here on github) that shows the problem when using ArduinoIDE comiling for Teensy3.6.
Doing so I realized 2 things:

  • it works for Teensy 4.0 / 4.1 because -fno-threadsafe-statics is use by default (as opposed to Teensy3.6)
  • the issue is itroduced, when multiple cpp-files have to be compiled and these compilation units are not explicitly including "Arduino.h"

So in a way the issue seems to be resolved, at least for me right now.
Thanks for your help and time.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants