diff options
author | Andreas Gampe <agampe@google.com> | 2014-09-09 19:53:48 -0700 |
---|---|---|
committer | Andreas Gampe <agampe@google.com> | 2014-09-10 15:50:42 -0700 |
commit | 928f72bd75c385ba2708c58521171a77264d4486 (patch) | |
tree | 86f7fa7a21e3f6d21c9cab2d4fffe4aaa42dc458 /runtime/fault_handler.h | |
parent | dab9ed52f2df7189b81ccf3237b030ff638a492a (diff) | |
download | art-928f72bd75c385ba2708c58521171a77264d4486.zip art-928f72bd75c385ba2708c58521171a77264d4486.tar.gz art-928f72bd75c385ba2708c58521171a77264d4486.tar.bz2 |
ART: Fix things for valgrind
Wire up valgrind gtests. Add valgrind-test-art-host, currently
only depending on valgrind-test-art-host-gtest32.
Fix an Alloc setting to allow running valgrind.
Refactor the fault handler to manage (and correctly release) the
handlers.
Fix minor failure-case leaks exposed by tests.
Failing tests:
The optimizing compiler is leaking non-arena-ed structures
(e.g., assembler buffers), as code generators are not destroyed.
The solution has been moved to a follow-up CL.
Note: All 64b tests are failing as we cannot allocate a heap.
Change-Id: I7f854cfd098d9f68107ce492363e7dba9a82b9fa
Diffstat (limited to 'runtime/fault_handler.h')
-rw-r--r-- | runtime/fault_handler.h | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/runtime/fault_handler.h b/runtime/fault_handler.h index bb26780..8b66a6f 100644 --- a/runtime/fault_handler.h +++ b/runtime/fault_handler.h @@ -39,10 +39,17 @@ class FaultManager { ~FaultManager(); void Init(); + + // Unclaim signals. + void Release(); + + // Unclaim signals and delete registered handlers. void Shutdown(); void HandleFault(int sig, siginfo_t* info, void* context); void HandleNestedSignal(int sig, siginfo_t* info, void* context); + + // Added handlers are owned by the fault handler and will be freed on Shutdown(). void AddHandler(FaultHandler* handler, bool generated_code); void RemoveHandler(FaultHandler* handler); |