xref: /aosp_15_r20/external/strace/mmap_cache.h (revision cf84ac9a129d8ea9952db616b4e9b904c4bdde56)
1*cf84ac9aSAndroid Build Coastguard Worker /*
2*cf84ac9aSAndroid Build Coastguard Worker  * Copyright (c) 2013-2018 The strace developers.
3*cf84ac9aSAndroid Build Coastguard Worker  *
4*cf84ac9aSAndroid Build Coastguard Worker  * Redistribution and use in source and binary forms, with or without
5*cf84ac9aSAndroid Build Coastguard Worker  * modification, are permitted provided that the following conditions
6*cf84ac9aSAndroid Build Coastguard Worker  * are met:
7*cf84ac9aSAndroid Build Coastguard Worker  * 1. Redistributions of source code must retain the above copyright
8*cf84ac9aSAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer.
9*cf84ac9aSAndroid Build Coastguard Worker  * 2. Redistributions in binary form must reproduce the above copyright
10*cf84ac9aSAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer in the
11*cf84ac9aSAndroid Build Coastguard Worker  *    documentation and/or other materials provided with the distribution.
12*cf84ac9aSAndroid Build Coastguard Worker  * 3. The name of the author may not be used to endorse or promote products
13*cf84ac9aSAndroid Build Coastguard Worker  *    derived from this software without specific prior written permission.
14*cf84ac9aSAndroid Build Coastguard Worker  *
15*cf84ac9aSAndroid Build Coastguard Worker  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
16*cf84ac9aSAndroid Build Coastguard Worker  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
17*cf84ac9aSAndroid Build Coastguard Worker  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
18*cf84ac9aSAndroid Build Coastguard Worker  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
19*cf84ac9aSAndroid Build Coastguard Worker  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
20*cf84ac9aSAndroid Build Coastguard Worker  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
21*cf84ac9aSAndroid Build Coastguard Worker  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
22*cf84ac9aSAndroid Build Coastguard Worker  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23*cf84ac9aSAndroid Build Coastguard Worker  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
24*cf84ac9aSAndroid Build Coastguard Worker  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25*cf84ac9aSAndroid Build Coastguard Worker  */
26*cf84ac9aSAndroid Build Coastguard Worker 
27*cf84ac9aSAndroid Build Coastguard Worker #ifndef STRACE_MMAP_CACHE_H
28*cf84ac9aSAndroid Build Coastguard Worker #define STRACE_MMAP_CACHE_H
29*cf84ac9aSAndroid Build Coastguard Worker 
30*cf84ac9aSAndroid Build Coastguard Worker /*
31*cf84ac9aSAndroid Build Coastguard Worker  * Keep a sorted array of cache entries,
32*cf84ac9aSAndroid Build Coastguard Worker  * so that we can binary search through it.
33*cf84ac9aSAndroid Build Coastguard Worker  */
34*cf84ac9aSAndroid Build Coastguard Worker 
35*cf84ac9aSAndroid Build Coastguard Worker struct mmap_cache_t {
36*cf84ac9aSAndroid Build Coastguard Worker 	struct mmap_cache_entry_t *entry;
37*cf84ac9aSAndroid Build Coastguard Worker 	void (*free_fn)(struct tcb *, const char *caller);
38*cf84ac9aSAndroid Build Coastguard Worker 	unsigned int size;
39*cf84ac9aSAndroid Build Coastguard Worker 	unsigned int generation;
40*cf84ac9aSAndroid Build Coastguard Worker };
41*cf84ac9aSAndroid Build Coastguard Worker 
42*cf84ac9aSAndroid Build Coastguard Worker struct mmap_cache_entry_t {
43*cf84ac9aSAndroid Build Coastguard Worker 	/**
44*cf84ac9aSAndroid Build Coastguard Worker 	 * example entry:
45*cf84ac9aSAndroid Build Coastguard Worker 	 * 7fabbb09b000-7fabbb09f000 r-xp 00179000 fc:00 1180246 /lib/libc-2.11.1.so
46*cf84ac9aSAndroid Build Coastguard Worker 	 *
47*cf84ac9aSAndroid Build Coastguard Worker 	 * start_addr  is 0x7fabbb09b000
48*cf84ac9aSAndroid Build Coastguard Worker 	 * end_addr    is 0x7fabbb09f000
49*cf84ac9aSAndroid Build Coastguard Worker 	 * mmap_offset is 0x179000
50*cf84ac9aSAndroid Build Coastguard Worker 	 * protections is MMAP_CACHE_PROT_READABLE|MMAP_CACHE_PROT_EXECUTABLE
51*cf84ac9aSAndroid Build Coastguard Worker 	 * major       is 0xfc
52*cf84ac9aSAndroid Build Coastguard Worker 	 * minor       is 0x00
53*cf84ac9aSAndroid Build Coastguard Worker 	 * binary_filename is "/lib/libc-2.11.1.so"
54*cf84ac9aSAndroid Build Coastguard Worker 	 */
55*cf84ac9aSAndroid Build Coastguard Worker 	unsigned long start_addr;
56*cf84ac9aSAndroid Build Coastguard Worker 	unsigned long end_addr;
57*cf84ac9aSAndroid Build Coastguard Worker 	unsigned long mmap_offset;
58*cf84ac9aSAndroid Build Coastguard Worker 	unsigned char protections;
59*cf84ac9aSAndroid Build Coastguard Worker 	unsigned long major, minor;
60*cf84ac9aSAndroid Build Coastguard Worker 	char *binary_filename;
61*cf84ac9aSAndroid Build Coastguard Worker };
62*cf84ac9aSAndroid Build Coastguard Worker 
63*cf84ac9aSAndroid Build Coastguard Worker enum mmap_cache_protection {
64*cf84ac9aSAndroid Build Coastguard Worker 	MMAP_CACHE_PROT_READABLE   = 1 << 0,
65*cf84ac9aSAndroid Build Coastguard Worker 	MMAP_CACHE_PROT_WRITABLE   = 1 << 1,
66*cf84ac9aSAndroid Build Coastguard Worker 	MMAP_CACHE_PROT_EXECUTABLE = 1 << 2,
67*cf84ac9aSAndroid Build Coastguard Worker 	MMAP_CACHE_PROT_SHARED     = 1 << 3,
68*cf84ac9aSAndroid Build Coastguard Worker };
69*cf84ac9aSAndroid Build Coastguard Worker 
70*cf84ac9aSAndroid Build Coastguard Worker enum mmap_cache_rebuild_result {
71*cf84ac9aSAndroid Build Coastguard Worker 	MMAP_CACHE_REBUILD_NOCACHE,
72*cf84ac9aSAndroid Build Coastguard Worker 	MMAP_CACHE_REBUILD_READY,
73*cf84ac9aSAndroid Build Coastguard Worker 	MMAP_CACHE_REBUILD_RENEWED,
74*cf84ac9aSAndroid Build Coastguard Worker };
75*cf84ac9aSAndroid Build Coastguard Worker 
76*cf84ac9aSAndroid Build Coastguard Worker typedef bool (*mmap_cache_search_fn)(struct mmap_cache_entry_t *, void *);
77*cf84ac9aSAndroid Build Coastguard Worker 
78*cf84ac9aSAndroid Build Coastguard Worker extern void
79*cf84ac9aSAndroid Build Coastguard Worker mmap_cache_enable(void);
80*cf84ac9aSAndroid Build Coastguard Worker 
81*cf84ac9aSAndroid Build Coastguard Worker extern enum mmap_cache_rebuild_result
82*cf84ac9aSAndroid Build Coastguard Worker mmap_cache_rebuild_if_invalid(struct tcb *, const char *caller);
83*cf84ac9aSAndroid Build Coastguard Worker 
84*cf84ac9aSAndroid Build Coastguard Worker extern struct mmap_cache_entry_t *
85*cf84ac9aSAndroid Build Coastguard Worker mmap_cache_search(struct tcb *, unsigned long ip);
86*cf84ac9aSAndroid Build Coastguard Worker 
87*cf84ac9aSAndroid Build Coastguard Worker extern struct mmap_cache_entry_t *
88*cf84ac9aSAndroid Build Coastguard Worker mmap_cache_search_custom(struct tcb *, mmap_cache_search_fn, void *);
89*cf84ac9aSAndroid Build Coastguard Worker 
90*cf84ac9aSAndroid Build Coastguard Worker #endif /* !STRACE_MMAP_CACHE_H */
91