Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

process: add get_main_module() #758

Merged
merged 6 commits into from
Nov 28, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
33 changes: 32 additions & 1 deletion bindings/gumjs/gumquickprocess.c
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
/*
* Copyright (C) 2020-2022 Ole André Vadla Ravnås <[email protected]>
* Copyright (C) 2020 Francesco Tamagni <[email protected]>
* Copyright (C) 2020-2023 Francesco Tamagni <[email protected]>
*
* Licence: wxWindows Library Licence, Version 3.1
*/
Expand Down Expand Up @@ -78,6 +78,8 @@ struct _GumQuickFindRangeByAddressContext
GumQuickCore * core;
};

static void gumjs_free_main_module_value (GumQuickProcess * self);
GUMJS_DECLARE_GETTER (gumjs_process_get_main_module)
GUMJS_DECLARE_FUNCTION (gumjs_process_get_current_dir)
GUMJS_DECLARE_FUNCTION (gumjs_process_get_home_dir)
GUMJS_DECLARE_FUNCTION (gumjs_process_get_tmp_dir)
Expand Down Expand Up @@ -114,6 +116,7 @@ static const JSCFunctionListEntry gumjs_process_entries[] =
JS_PROP_STRING_DEF ("arch", GUM_SCRIPT_ARCH, JS_PROP_C_W_E),
JS_PROP_STRING_DEF ("platform", GUM_SCRIPT_PLATFORM, JS_PROP_C_W_E),
JS_PROP_INT32_DEF ("pointerSize", GLIB_SIZEOF_VOID_P, JS_PROP_C_W_E),
JS_CGETSET_DEF ("mainModule", gumjs_process_get_main_module, NULL),
JS_CFUNC_DEF ("getCurrentDir", 0, gumjs_process_get_current_dir),
JS_CFUNC_DEF ("getHomeDir", 0, gumjs_process_get_home_dir),
JS_CFUNC_DEF ("getTmpDir", 0, gumjs_process_get_tmp_dir),
Expand Down Expand Up @@ -142,6 +145,7 @@ _gum_quick_process_init (GumQuickProcess * self,

self->module = module;
self->core = core;
self->main_module_value = JS_UNINITIALIZED;

_gum_quick_core_store_module_data (core, "process", self);

Expand All @@ -163,12 +167,24 @@ void
_gum_quick_process_flush (GumQuickProcess * self)
{
g_clear_pointer (&self->exception_handler, gum_quick_exception_handler_free);
gumjs_free_main_module_value (self);
}

void
_gum_quick_process_dispose (GumQuickProcess * self)
{
g_clear_pointer (&self->exception_handler, gum_quick_exception_handler_free);
gumjs_free_main_module_value (self);
}

static void
gumjs_free_main_module_value (GumQuickProcess * self)
{
if (JS_IsUninitialized (self->main_module_value))
return;

JS_FreeValue (self->core->ctx, self->main_module_value);
self->main_module_value = JS_UNINITIALIZED;
}

void
Expand All @@ -182,6 +198,21 @@ gumjs_get_parent_module (GumQuickCore * core)
return _gum_quick_core_load_module_data (core, "process");
}

GUMJS_DEFINE_GETTER (gumjs_process_get_main_module)
{
GumQuickProcess * self;

self = gumjs_get_parent_module (core);

if (JS_IsUninitialized (self->main_module_value))
{
self->main_module_value = _gum_quick_module_new (ctx,
gum_process_get_main_module (), self->module);
}

return JS_DupValue (ctx, self->main_module_value);
}

GUMJS_DEFINE_FUNCTION (gumjs_process_get_current_dir)
{
JSValue result;
Expand Down
2 changes: 2 additions & 0 deletions bindings/gumjs/gumquickprocess.h
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
/*
* Copyright (C) 2020 Ole André Vadla Ravnås <[email protected]>
* Copyright (C) 2023 Francesco Tamagni <[email protected]>
*
* Licence: wxWindows Library Licence, Version 3.1
*/
Expand All @@ -20,6 +21,7 @@ struct _GumQuickProcess
GumQuickModule * module;
GumQuickCore * core;

JSValue main_module_value;
GumQuickExceptionHandler * exception_handler;
};

Expand Down
36 changes: 34 additions & 2 deletions bindings/gumjs/gumv8process.cpp
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
/*
* Copyright (C) 2010-2022 Ole André Vadla Ravnås <[email protected]>
* Copyright (C) 2020 Francesco Tamagni <[email protected]>
* Copyright (C) 2020-2023 Francesco Tamagni <[email protected]>
*
* Licence: wxWindows Library Licence, Version 3.1
*/
Expand Down Expand Up @@ -63,6 +63,7 @@ struct GumV8FindModuleByNameContext
GumV8Process * parent;
};

GUMJS_DECLARE_GETTER (gumjs_process_get_main_module)
GUMJS_DECLARE_FUNCTION (gumjs_process_get_current_dir)
GUMJS_DECLARE_FUNCTION (gumjs_process_get_home_dir)
GUMJS_DECLARE_FUNCTION (gumjs_process_get_tmp_dir)
Expand Down Expand Up @@ -93,6 +94,13 @@ static gboolean gum_v8_exception_handler_on_exception (

const gchar * gum_v8_script_exception_type_to_string (GumExceptionType type);

static const GumV8Property gumjs_process_values[] =
{
{ "mainModule", gumjs_process_get_main_module, NULL },

{ NULL, NULL }
};

static const GumV8Function gumjs_process_functions[] =
{
{ "getCurrentDir", gumjs_process_get_current_dir },
Expand Down Expand Up @@ -122,6 +130,8 @@ _gum_v8_process_init (GumV8Process * self,
self->module = module;
self->core = core;

auto process_module = External::New (isolate, self);

auto process = _gum_v8_create_module ("Process", scope, isolate);
process->Set (_gum_v8_string_new_ascii (isolate, "id"),
Number::New (isolate, gum_process_get_id ()), ReadOnly);
Expand All @@ -136,7 +146,8 @@ _gum_v8_process_init (GumV8Process * self,
process->Set (_gum_v8_string_new_ascii (isolate, "codeSigningPolicy"),
String::NewFromUtf8 (isolate, gum_code_signing_policy_to_string (
gum_process_get_code_signing_policy ())).ToLocalChecked (), ReadOnly);
_gum_v8_module_add (External::New (isolate, self), process,
_gum_v8_module_add (process_module, process, gumjs_process_values, isolate);
_gum_v8_module_add (process_module, process,
gumjs_process_functions, isolate);
}

Expand All @@ -149,19 +160,40 @@ void
_gum_v8_process_flush (GumV8Process * self)
{
g_clear_pointer (&self->exception_handler, gum_v8_exception_handler_free);

delete self->main_module_value;
self->main_module_value = nullptr;
}

void
_gum_v8_process_dispose (GumV8Process * self)
{
g_clear_pointer (&self->exception_handler, gum_v8_exception_handler_free);

delete self->main_module_value;
self->main_module_value = nullptr;
}

void
_gum_v8_process_finalize (GumV8Process * self)
{
}

GUMJS_DEFINE_GETTER (gumjs_process_get_main_module)
{
auto self = module;

if (self->main_module_value == nullptr)
{
self->main_module_value = new Global<Object> (isolate,
_gum_v8_module_value_new (gum_process_get_main_module (),
self->module));
}

info.GetReturnValue ().Set (
Local<Object>::New (isolate, *module->main_module_value));
}

GUMJS_DEFINE_FUNCTION (gumjs_process_get_current_dir)
{
gchar * dir_opsys = g_get_current_dir ();
Expand Down
2 changes: 2 additions & 0 deletions bindings/gumjs/gumv8process.h
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
/*
* Copyright (C) 2010-2020 Ole André Vadla Ravnås <[email protected]>
* Copyright (C) 2023 Francesco Tamagni <[email protected]>
*
* Licence: wxWindows Library Licence, Version 3.1
*/
Expand All @@ -17,6 +18,7 @@ struct GumV8Process
GumV8Module * module;
GumV8Core * core;

v8::Global<v8::Object> * main_module_value;
GumV8ExceptionHandler * exception_handler;
};

Expand Down
20 changes: 19 additions & 1 deletion gum/backend-darwin/gumprocess-darwin.c
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
/*
* Copyright (C) 2010-2023 Ole André Vadla Ravnås <[email protected]>
* Copyright (C) 2015 Asger Hautop Drewsen <[email protected]>
* Copyright (C) 2022 Francesco Tamagni <[email protected]>
* Copyright (C) 2022-2023 Francesco Tamagni <[email protected]>
* Copyright (C) 2022 Håvard Sørbø <[email protected]>
* Copyright (C) 2023 Alex Soler <[email protected]>
*
Expand Down Expand Up @@ -448,6 +448,24 @@ _gum_process_enumerate_threads (GumFoundThreadFunc func,
gum_darwin_enumerate_threads (mach_task_self (), func, user_data);
}

gboolean
_gum_process_collect_main_module (const GumModuleDetails * details,
gpointer user_data)
{
GumModuleDetails ** out = user_data;
gum_mach_header_t * header;

header = GSIZE_TO_POINTER (details->range->base_address);
if (header->filetype == MH_EXECUTE)
{
*out = gum_module_details_copy (details);

return FALSE;
}

return TRUE;
}

void
_gum_process_enumerate_modules (GumFoundModuleFunc func,
gpointer user_data)
Expand Down
12 changes: 12 additions & 0 deletions gum/backend-freebsd/gumprocess-freebsd.c
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
/*
* Copyright (C) 2022-2023 Ole André Vadla Ravnås <[email protected]>
* Copyright (C) 2023 Francesco Tamagni <[email protected]>
*
* Licence: wxWindows Library Licence, Version 3.1
*/
Expand Down Expand Up @@ -475,6 +476,17 @@ gum_query_program_path_for_target (int target,
}
}

gboolean
_gum_process_collect_main_module (const GumModuleDetails * details,
gpointer user_data)
{
GumModuleDetails ** out = user_data;

*out = gum_module_details_copy (details);

return FALSE;
}

void
_gum_process_enumerate_modules (GumFoundModuleFunc func,
gpointer user_data)
Expand Down
12 changes: 12 additions & 0 deletions gum/backend-linux/gumprocess-linux.c
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
/*
* Copyright (C) 2010-2023 Ole André Vadla Ravnås <[email protected]>
* Copyright (C) 2023 Håvard Sørbø <[email protected]>
* Copyright (C) 2023 Francesco Tamagni <[email protected]>
*
* Licence: wxWindows Library Licence, Version 3.1
*/
Expand Down Expand Up @@ -1043,6 +1044,17 @@ gum_store_cpu_context (GumThreadId thread_id,
memcpy (user_data, cpu_context, sizeof (GumCpuContext));
}

gboolean
_gum_process_collect_main_module (const GumModuleDetails * details,
gpointer user_data)
{
GumModuleDetails ** out = user_data;

*out = gum_module_details_copy (details);

return FALSE;
}

void
_gum_process_enumerate_modules (GumFoundModuleFunc func,
gpointer user_data)
Expand Down
12 changes: 12 additions & 0 deletions gum/backend-qnx/gumprocess-qnx.c
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
/*
* Copyright (C) 2015-2023 Ole André Vadla Ravnås <[email protected]>
* Copyright (C) 2023 Francesco Tamagni <[email protected]>
*
* Licence: wxWindows Library Licence, Version 3.1
*/
Expand Down Expand Up @@ -262,6 +263,17 @@ gum_store_cpu_context (GumThreadId thread_id,
memcpy (user_data, cpu_context, sizeof (GumCpuContext));
}

gboolean
_gum_process_collect_main_module (const GumModuleDetails * details,
gpointer user_data)
{
GumModuleDetails ** out = user_data;

*out = gum_module_details_copy (details);

return FALSE;
}

void
_gum_process_enumerate_modules (GumFoundModuleFunc func,
gpointer user_data)
Expand Down
12 changes: 12 additions & 0 deletions gum/backend-windows/gumprocess-windows.c
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
/*
* Copyright (C) 2009-2023 Ole André Vadla Ravnås <[email protected]>
* Copyright (C) 2023 Francesco Tamagni <[email protected]>
*
* Licence: wxWindows Library Licence, Version 3.1
*/
Expand Down Expand Up @@ -260,6 +261,17 @@ gum_windows_get_thread_details (DWORD thread_id,
return success;
}

gboolean
_gum_process_collect_main_module (const GumModuleDetails * details,
gpointer user_data)
{
GumModuleDetails ** out = user_data;

*out = gum_module_details_copy (details);

return FALSE;
}

void
_gum_process_enumerate_modules (GumFoundModuleFunc func,
gpointer user_data)
Expand Down
3 changes: 3 additions & 0 deletions gum/gumprocess-priv.h
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
/*
* Copyright (C) 2017-2023 Ole André Vadla Ravnås <[email protected]>
* Copyright (C) 2023 Francesco Tamagni <[email protected]>
*
* Licence: wxWindows Library Licence, Version 3.1
*/
Expand All @@ -13,6 +14,8 @@ G_BEGIN_DECLS

G_GNUC_INTERNAL void _gum_process_enumerate_threads (GumFoundThreadFunc func,
gpointer user_data);
G_GNUC_INTERNAL gboolean _gum_process_collect_main_module (
const GumModuleDetails * details, gpointer user_data);
G_GNUC_INTERNAL void _gum_process_enumerate_modules (GumFoundModuleFunc func,
gpointer user_data);
G_GNUC_INTERNAL void _gum_process_enumerate_ranges (GumPageProtection prot,
Expand Down
Loading
Loading