-
Notifications
You must be signed in to change notification settings - Fork 206
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
Fix #411, rework exception handling in CFE #653
Fix #411, rework exception handling in CFE #653
Conversation
a903b36
to
077f168
Compare
077f168
to
100e7ee
Compare
Move exception handling to a PSP function. In this approach the CFE only logs data after the event as a background job. Replaces the CFE_ES_ProcessCoreException with a simple notification that causes the ES background job to run, which in turn polls the PSP for logged exceptions and writes entries to the ES ER log. Both the PSP execption scan and the ER log file dump are converted to background jobs.
d4f62ed
to
4eb937b
Compare
Correct items flagged as warnings in documenation build, and remove now-unused definition in sample platform config
4eb937b
to
87b87c8
Compare
Should be ready for merge now. |
This was reviewed in a special topic on 2020-04-30, but may want to mention this in a CCB again. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good to me.
My only concern is making sure we have a way to preserve exception context information and get it to the ground. Can probably address this in the PSP.
CCB-20200506 - APPROVED. Also covered in special topic on 4/30 |
Sorry for the delay in posting my comments.
|
In the current framework, yes, I think this is reasonable. The "mcp750-vxworks" PSP is primarily a test/reference platform and it is likely/expected that CFE is the only service running within the system. It is also consistent with the way MCP750 has worked before. As the exception hook is implemented in the board-specific code this could do something else on other platforms, such as ignoring the exception if it was generated from a task outside CFE. But even still, assuming whatever actually did generate the exception was a necessary service, it might be warranted to restart the processor if it fails anyway.
This PR does not change anything in |
I wrote this up as a separate issue, see #687 |
The exception hook does not manage the CFE task. Maybe CFE could call a board specific function to do something else after CFE has determined it not a CFE task. |
Another thought the CFE exception handler could return and let the board specific code decide to restart or not. |
If the exception is not relevant to CFE then the hook can just drop it and not log it, or it can do something else entirely. Any exceptions which ARE written to the internal buffer are assumed to be related to CFE and will trigger a restart if no specific action is configured. This is entirely up to the PSP as to how to disposition. The current implementation just assumes that everything is related to CFE because that is expected to be the only thing running. |
Describe the contribution
Move exception handling to a PSP function. In this approach the CFE only logs data after the event as a background job.
Replaces the CFE_ES_ProcessCoreException with a simple notification that causes the ES background job to run, which in turn polls the PSP for logged exceptions and writes entries to the ES ER log.
Both the PSP execption scan and the ER log file dump are converted to background jobs.
Fixes #411
Fixes #76
Testing performed
Validate CFE exception handling behavior on POSIX and VxWorks (not implemented on RTEMS).
Add divide by zero "bug" to sample_app for testing.
Confirm exception is logged correctly
Confirm ER dump to file works
Expected behavior changes
No change from CMD/TLM perspective
API
CFE_ES_ProcessCoreException
is removed, replaced with async event.System(s) tested on
Ubuntu 20.04 LTS 64-bit
VxWorks 6.9 on MCP750
Additional context
Needs corresponding changes in PSP
Contributor Info - All information REQUIRED for consideration of pull request
Joseph Hickey, Vantage Systems, Inc.