diff options
author | Florian Weimer <fw@deneb.enyo.de> | 2019-10-28 19:49:46 +0100 |
---|---|---|
committer | Florian Weimer <fweimer@redhat.com> | 2019-10-29 18:11:36 +0100 |
commit | 8c59ed1f7454cba46c29ceba07322a75f9eb78ad (patch) | |
tree | b2a6f0b4f55a39907c1e1bd8b1d2bb5658bd7b87 /include/link.h | |
parent | 93e07b2f9ef6825c7165f4587d2204464c83959a (diff) | |
download | glibc-fw/bug25112.zip glibc-fw/bug25112.tar.gz glibc-fw/bug25112.tar.bz2 |
Remove all loaded objects if dlopen fails [BZ #20839]fw/bug25112
Diffstat (limited to 'include/link.h')
-rw-r--r-- | include/link.h | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/include/link.h b/include/link.h index 1184201..2bf6339 100644 --- a/include/link.h +++ b/include/link.h @@ -79,6 +79,21 @@ struct r_search_path_struct int malloced; }; +/* Type used by the l_nodelete member. */ +enum link_map_nodelete +{ + /* This link map can be deallocated. */ + link_map_nodelete_inactive, + + /* This link map cannot be deallocated. */ + link_map_nodelete_active, + + /* This link map cannot be deallocated after dlopen has succeded. + dlopen turns this into link_map_nodelete_active. dlclose treats + this intermediate state as link_map_nodelete_active. */ + link_map_nodelete_pending, +}; + /* Structure describing a loaded shared object. The `l_next' and `l_prev' members form a chain of all the shared objects loaded at startup. @@ -203,6 +218,10 @@ struct link_map freed, ie. not allocated with the dummy malloc in ld.so. */ + /* Actually of type enum link_map_nodelete. Separate byte due to + concurrent access. Only valid for l_type == lt_loaded. */ + unsigned char l_nodelete; + #include <link_map.h> /* Collected information about own RPATH directories. */ |