Skip to content

Commit

Permalink
Update gotcha
Browse files Browse the repository at this point in the history
  • Loading branch information
daboehme committed Mar 13, 2024
1 parent 0206a20 commit cdcd881
Show file tree
Hide file tree
Showing 21 changed files with 1,908 additions and 1,810 deletions.
44 changes: 25 additions & 19 deletions ext/gotcha/include/gotcha/gotcha.h
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ without even the IMPLIED WARRANTY OF MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the terms and conditions of the GNU Lesser General Public License
for more details. You should have received a copy of the GNU Lesser General
Public License along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/

/*!
Expand All @@ -22,18 +22,19 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* The intended use pattern is as follows
*
* TODO ON-INTERFACE-SOLID: document the interface
* usage
* TODO ON-INTERFACE-SOLID: document the
*interface usage
*
******************************************************************************
*/
#ifndef GOTCHA_H
#define GOTCHA_H

#include "gotcha/gotcha_types.h"
#include <link.h>

#if defined(__cplusplus)
#include "gotcha/gotcha_types.h"

#if defined(__cplusplus)
extern "C" {
#endif

Expand All @@ -45,19 +46,20 @@ extern "C" {
* \param name The name of the function you want to get a pointer to
* \param ret_type The return type of the function you want a pointer to
* \param ... A comma separated list of the types of the parameters
* to the function you're getting a pointer to
* to the function you're getting a pointer to
******************************************************************************
*/

#define GOTCHA_MAKE_FUNCTION_PTR(name, ret_type, ...) ret_type(*name)(__VA_ARGS__)
#define GOTCHA_MAKE_FUNCTION_PTR(name, ret_type, ...) \
ret_type (*name)(__VA_ARGS__)

#define GOTCHA_EXPORT __attribute__((__visibility__("default")))

/*!
******************************************************************************
*
* \fn enum gotcha_error_t gotcha_wrap(struct gotcha_binding_t* bindings,
* void** wrappers, void*** originals,
* \fn enum gotcha_error_t gotcha_wrap(struct gotcha_binding_t* bindings,
* void** wrappers, void*** originals,
* int num_actions);
*
* \brief Makes GOTCHA wrap the functions picked in gotcha_prepare_symbols
Expand All @@ -70,8 +72,9 @@ extern "C" {
******************************************************************************
*/

GOTCHA_EXPORT enum gotcha_error_t gotcha_wrap(struct gotcha_binding_t* bindings, int num_actions, const char* tool_name);

GOTCHA_EXPORT enum gotcha_error_t gotcha_wrap(struct gotcha_binding_t *bindings,
int num_actions,
const char *tool_name);

/*!
******************************************************************************
Expand All @@ -88,7 +91,8 @@ GOTCHA_EXPORT enum gotcha_error_t gotcha_wrap(struct gotcha_binding_t* bindings,
*
******************************************************************************
*/
GOTCHA_EXPORT enum gotcha_error_t gotcha_set_priority(const char* tool_name, int priority);
GOTCHA_EXPORT enum gotcha_error_t gotcha_set_priority(const char *tool_name,
int priority);

/*!
******************************************************************************
Expand All @@ -104,28 +108,30 @@ GOTCHA_EXPORT enum gotcha_error_t gotcha_set_priority(const char* tool_name, int
*
******************************************************************************
*/
GOTCHA_EXPORT enum gotcha_error_t gotcha_get_priority(const char* tool_name, int *priority);
GOTCHA_EXPORT enum gotcha_error_t gotcha_get_priority(const char *tool_name,
int *priority);

/*!
******************************************************************************
*
* \fn enum void* gotcha_get_wrappee(gotcha_wrappee_handle_t)
*
* \brief Given a GOTCHA wrapper's handle, returns the wrapped function for it to call
* \brief Given a GOTCHA wrapper's handle, returns the wrapped function for it
*to call
*
* \param handle The wrappee handle to return the function pointer for
*
******************************************************************************
*/
GOTCHA_EXPORT void* gotcha_get_wrappee(gotcha_wrappee_handle_t handle);
GOTCHA_EXPORT void *gotcha_get_wrappee(gotcha_wrappee_handle_t handle);

GOTCHA_EXPORT void gotcha_filter_libraries_by_name(const char* nameFilter);
GOTCHA_EXPORT void gotcha_filter_libraries_by_name(const char *nameFilter);
GOTCHA_EXPORT void gotcha_only_filter_last();
GOTCHA_EXPORT void gotcha_set_library_filter_func(int(*new_func)(struct link_map*));
GOTCHA_EXPORT void gotcha_set_library_filter_func(
int (*new_func)(struct link_map *));
GOTCHA_EXPORT void gotcha_restore_library_filter_func();


#if defined(__cplusplus)
#if defined(__cplusplus)
}
#endif

Expand Down
28 changes: 15 additions & 13 deletions ext/gotcha/include/gotcha/gotcha_types.h
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ without even the IMPLIED WARRANTY OF MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the terms and conditions of the GNU Lesser General Public License
for more details. You should have received a copy of the GNU Lesser General
Public License along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
/*!
******************************************************************************
Expand All @@ -24,33 +24,35 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#ifndef GOTCHA_TYPES_H
#define GOTCHA_TYPES_H

#if defined(__cplusplus)
#if defined(__cplusplus)
extern "C" {
#endif

typedef void* gotcha_wrappee_handle_t;
typedef void *gotcha_wrappee_handle_t;

/*!
* The representation of a Gotcha action
* as it passes through the pipeline
*/
typedef struct gotcha_binding_t {
const char* name; //!< The name of the function being wrapped
void* wrapper_pointer; //!< A pointer to the wrapper function
gotcha_wrappee_handle_t* function_handle; //!< A pointer to the function being wrapped
}gotcha_binding_t;
const char *name; //!< The name of the function being wrapped
void *wrapper_pointer; //!< A pointer to the wrapper function
gotcha_wrappee_handle_t
*function_handle; //!< A pointer to the function being wrapped
} gotcha_binding_t;

/*!
* The representation of an error (or success) of a Gotcha action
*/
typedef enum gotcha_error_t {
GOTCHA_SUCCESS = 0, //!< The call succeeded
GOTCHA_FUNCTION_NOT_FOUND, //!< The call looked up a function which could not be found
GOTCHA_INTERNAL, //!< Internal gotcha error
GOTCHA_INVALID_TOOL //!< Invalid tool name
}gotcha_error_t;
GOTCHA_SUCCESS = 0, //!< The call succeeded
GOTCHA_FUNCTION_NOT_FOUND, //!< The call looked up a function which could not
//!< be found
GOTCHA_INTERNAL, //!< Internal gotcha error
GOTCHA_INVALID_TOOL //!< Invalid tool name
} gotcha_error_t;

#if defined(__cplusplus)
#if defined(__cplusplus)
}
#endif

Expand Down
27 changes: 15 additions & 12 deletions ext/gotcha/src/elf_ops.c
Original file line number Diff line number Diff line change
Expand Up @@ -10,17 +10,20 @@ without even the IMPLIED WARRANTY OF MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the terms and conditions of the GNU Lesser General Public License
for more details. You should have received a copy of the GNU Lesser General
Public License along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/

#include "elf_ops.h"
#include "libc_wrappers.h"

#include <elf.h>

#include "libc_wrappers.h"
struct gnu_hash_header {
uint32_t nbuckets; //!< The number of buckets to hash symbols into
uint32_t symndx; //!< Index of the first symbol accessible via hashtable in the symbol table
uint32_t maskwords; //!< Number of words in the hash table's bloom filter
uint32_t shift2; //!< The bloom filter's shift count
uint32_t nbuckets; //!< The number of buckets to hash symbols into
uint32_t symndx; //!< Index of the first symbol accessible via hashtable in
//!< the symbol table
uint32_t maskwords; //!< Number of words in the hash table's bloom filter
uint32_t shift2; //!< The bloom filter's shift count
};

static uint32_t gnu_hash_func(const char *str) {
Expand All @@ -43,15 +46,14 @@ static uint32_t gnu_hash_func(const char *str) {
*/

signed long lookup_gnu_hash_symbol(const char *name, ElfW(Sym) * syms,
ElfW(Half) *versym,
char *symnames,
ElfW(Half) * versym, char *symnames,
void *sheader) {
uint32_t *buckets, *vals;
uint32_t hash_val;
uint32_t cur_sym, cur_sym_hashval;
signed long latest_sym = -1;
ElfW(Half) latest_sym_ver = 0;
struct gnu_hash_header *header = (struct gnu_hash_header *) (sheader);
struct gnu_hash_header *header = (struct gnu_hash_header *)(sheader);

buckets = (uint32_t *)(((unsigned char *)(header + 1)) +
(header->maskwords * sizeof(ElfW(Addr))));
Expand Down Expand Up @@ -99,8 +101,8 @@ static unsigned long elf_hash(const unsigned char *name) {
}

signed long lookup_elf_hash_symbol(const char *name, ElfW(Sym) * syms,
ElfW(Half) *versym,
char *symnames, ElfW(Word) * header) {
ElfW(Half) * versym, char *symnames,
ElfW(Word) * header) {
ElfW(Word) *nbucket = header + 0;
ElfW(Word) *buckets = header + 2;
ElfW(Word) *chains = buckets + *nbucket;
Expand All @@ -112,7 +114,8 @@ signed long lookup_elf_hash_symbol(const char *name, ElfW(Sym) * syms,
while (y != STN_UNDEF) {
if (gotcha_strcmp(name, symnames + syms[y].st_name) == 0) {
if (!versym) {
return y;
// in general all libs would have version but it is a guard condition.
return y; // GCOVR_EXCL_LINE
}

if ((versym[y] & 0x7fff) > latest_sym_ver) {
Expand Down
Loading

0 comments on commit cdcd881

Please sign in to comment.