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

Canary memory / stack check. #7

Open
ermtl opened this issue Mar 25, 2020 · 5 comments
Open

Canary memory / stack check. #7

ermtl opened this issue Mar 25, 2020 · 5 comments
Labels
enhancement New feature or request SAFETY This issue is about safety features and bugs

Comments

@ermtl
Copy link
Owner

ermtl commented Mar 25, 2020

To detect memory & stack corruption, a known good and easy way is to add canaries.
For good protection, all the canaries should not have the same value and they should be spread among other variables and several of them (8seems reasonable) should be put, if possible at both ends of the stack and at both ends of the variables area.
Any corruption detected by the checking function means something seriously wrong happened. If it happens, it should just write an error code to EEPROM and call a handler. Upon the next start, an error message should be displayed to alert the user that the machine could be unreliable.

the handler should decide what to do next. Usually activate an alarm and maybe stop. For a medical device, we should ask advice from a MD about the best option (stop or keep going with a serious risk).

An important point is to look at the resulting assembly code and check that the compiler did not "optimize" the canaries either by removing them, merging them or grouping them all together. also the stack canaries location relative to the variables and stack should be checked.
This is a job for a compiler wizard !

Info about canaries:
https://en.wikipedia.org/wiki/Buffer_overflow_protection#Canaries
Info about stack overflows and stack canaries:
https://en.wikipedia.org/wiki/Stack_buffer_overflow

This not being specific to the project, it could be done as a as a separate, independent project.

@ermtl ermtl added enhancement New feature or request help wanted Extra attention is needed SAFETY This issue is about safety features and bugs labels Mar 25, 2020
@mattd3v
Copy link

mattd3v commented Mar 25, 2020

Could the use of more C++ STL data structures help manage overflows, without adding as much code?

@Blimpyway
Copy link

I worry more by not having a watchdog timer.

What do you mean by code corruption? AVRDUDE (or other flasher) does verify the code after it was written. Do you really think you (or something else like the program itself or an EMP) can change after it was flashed ?
If this was a thing somebody on either arduino or avrfreaks forum would freak about it.

wdt_example.zip

@ermtl
Copy link
Owner Author

ermtl commented Mar 26, 2020

mattd3v: Do you have an example of those structures being used on an Arduino ?

Blimpyway : The final code will have a watchdog timer. I did not add it for now as if people make mistakes in the code, it's easy to brick the board, and the program will need to be wiped out completely, reflashing the bootloader won't help. So people trying the code would lose their hardware (not everyone knows how to flash the entire chip).

If you look in my other repository, I worked on a version of the Adafruit_Sleepydog and added a mod that prevent bricking Chinese clones. I'll have to make it into a different library as Adafruit did not accept the pull.
https://github.com/ermtl/Adafruit_SleepyDog

@miguel5612
Copy link

#ifdef Canary
disable sensorFeature and safe memory
#endif
Same to arduino pro mini ATMEGA 168

@ahogen
Copy link

ahogen commented Apr 5, 2020

That watchdog example looks cool!

The GCC compiler flag -fstack-protector will call a void __stack_chk_fail(void) function if stack corruption is detected. Also the flag -fstack-limit-symbol=__StackLimit is interesting (where __StackLimit is a symbol from the linker script). Those options require modifying compiler flags, which isn't simple or convenient to do in the Arduino IDE.

The project could use a Makefile where the build arguments can be controlled by this project instead of the Arduino Foundation.

@ermtl ermtl removed the help wanted Extra attention is needed label Apr 21, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request SAFETY This issue is about safety features and bugs
Projects
None yet
Development

No branches or pull requests

5 participants