/src/libunwind/src/mi/flush_cache.c
Line | Count | Source (jump to first uncovered line) |
1 | | /* libunwind - a platform-independent unwind library |
2 | | Copyright (C) 2002-2005 Hewlett-Packard Co |
3 | | Contributed by David Mosberger-Tang <davidm@hpl.hp.com> |
4 | | |
5 | | This file is part of libunwind. |
6 | | |
7 | | Permission is hereby granted, free of charge, to any person obtaining |
8 | | a copy of this software and associated documentation files (the |
9 | | "Software"), to deal in the Software without restriction, including |
10 | | without limitation the rights to use, copy, modify, merge, publish, |
11 | | distribute, sublicense, and/or sell copies of the Software, and to |
12 | | permit persons to whom the Software is furnished to do so, subject to |
13 | | the following conditions: |
14 | | |
15 | | The above copyright notice and this permission notice shall be |
16 | | included in all copies or substantial portions of the Software. |
17 | | |
18 | | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
19 | | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
20 | | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND |
21 | | NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE |
22 | | LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION |
23 | | OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION |
24 | | WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ |
25 | | |
26 | | #include "libunwind_i.h" |
27 | | #include <stdatomic.h> |
28 | | |
29 | | void |
30 | | unw_flush_cache (unw_addr_space_t as, unw_word_t lo UNUSED, unw_word_t hi UNUSED) |
31 | 1 | { |
32 | 1 | #if !UNW_TARGET_IA64 |
33 | 1 | struct unw_debug_frame_list *w = as->debug_frames; |
34 | | |
35 | 1 | while (w) |
36 | 0 | { |
37 | 0 | struct unw_debug_frame_list *n = w->next; |
38 | |
|
39 | 0 | if (w->index) |
40 | 0 | mi_munmap (w->index, w->index_size); |
41 | |
|
42 | 0 | mi_munmap (w->debug_frame, w->debug_frame_size); |
43 | 0 | mi_munmap (w, sizeof (*w)); |
44 | 0 | w = n; |
45 | 0 | } |
46 | 1 | as->debug_frames = NULL; |
47 | 1 | #endif |
48 | | |
49 | | /* clear dyn_info_list_addr cache: */ |
50 | 1 | as->dyn_info_list_addr = 0; |
51 | | |
52 | | /* This lets us flush caches lazily. The implementation currently |
53 | | ignores the flush range arguments (lo-hi). This is OK because |
54 | | unw_flush_cache() is allowed to flush more than the requested |
55 | | range. */ |
56 | 1 | atomic_fetch_add (&as->cache_generation, 1); |
57 | 1 | } |