diff options
author | andrew <andrew@FreeBSD.org> | 2013-02-04 09:28:36 +0000 |
---|---|---|
committer | andrew <andrew@FreeBSD.org> | 2013-02-04 09:28:36 +0000 |
commit | 897e2fb50579aef227fdadb07059bf19f3bbf36c (patch) | |
tree | c72214dda9049bdf2f7953b44a83f0f78dea4744 /contrib/gcc/coverage.c | |
parent | a191badca4be9f93dc348a040fa425d66aef3a25 (diff) | |
download | FreeBSD-src-897e2fb50579aef227fdadb07059bf19f3bbf36c.zip FreeBSD-src-897e2fb50579aef227fdadb07059bf19f3bbf36c.tar.gz |
Allow the unwind functions int libgcc_s to interact correctly with libthr.
_Unwind_ForcedUnwind in libgcc_s takes as one of it's parameters a stop
function to tell it when to stop unwinding. One of the stop function's
parameters is a _Unwind_Exception_Class. On most architectures this is an
int64_t, however on ARM EABI the gcc developers have made this a char array
with 8 items. While both of these take the same space they are passed into
the stop function differently, an int64_t is passed in in registers r2 and
r3, while the char[8] is passed in as a pointer to the first item in
register r2.
Because libthr expects the value to be an int64_t we would get incorrect
results when it passes a function that take an int64_t but libgcc passes in
a pointer to a char array including crashing.
The fix is to update libgcc_s to make it pass an int64_t to the stop
function and to libstdc++ as it expects _Unwind_Exception_Class to be an
array.
Diffstat (limited to 'contrib/gcc/coverage.c')
0 files changed, 0 insertions, 0 deletions