[PATCH v2 dwarves 1/5] dwarf_loader: introduce pre/post cus__load_module hooks to conf_load

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Preparation for making btf_encoder.functions table shared between
encoders.

Shared table can be built as soon as Elf struct is extracted from
Dwfl_Module, which happens in cus__proces_dwflmod.

Signed-off-by: Ihor Solodrai <ihor.solodrai@xxxxx>
---
 dwarf_loader.c | 21 ++++++++++++++-------
 dwarves.h      | 18 ++++++++++++++++--
 2 files changed, 30 insertions(+), 9 deletions(-)

diff --git a/dwarf_loader.c b/dwarf_loader.c
index e54a16c..fb42eb5 100644
--- a/dwarf_loader.c
+++ b/dwarf_loader.c
@@ -3723,13 +3723,6 @@ static int cus__load_module(struct cus *cus, struct conf_load *conf,
 	return DWARF_CB_OK;
 }
 
-struct process_dwflmod_parms {
-	struct cus	 *cus;
-	struct conf_load *conf;
-	const char	 *filename;
-	uint32_t	 nr_dwarf_sections_found;
-};
-
 static int cus__process_dwflmod(Dwfl_Module *dwflmod,
 				void **userdata __maybe_unused,
 				const char *name __maybe_unused,
@@ -3753,10 +3746,24 @@ static int cus__process_dwflmod(Dwfl_Module *dwflmod,
 	Dwarf *dw = dwfl_module_getdwarf(dwflmod, &dwbias);
 
 	int err = DWARF_CB_OK;
+	if (parms->conf->pre_cus__load_module) {
+		err = parms->conf->pre_cus__load_module(parms, dwflmod, dw, elf);
+		if (err)
+			return DWARF_CB_ABORT;
+	}
+
 	if (dw != NULL) {
 		++parms->nr_dwarf_sections_found;
 		err = cus__load_module(cus, parms->conf, dwflmod, dw, elf,
 				       parms->filename);
+		if (err)
+			return err;
+	}
+
+	if (parms->conf->post_cus__load_module) {
+		err = parms->conf->post_cus__load_module(parms, dwflmod, dw, elf);
+		if (err)
+			return DWARF_CB_ABORT;
 	}
 	/*
 	 * XXX We will fall back to try finding other debugging
diff --git a/dwarves.h b/dwarves.h
index f147b2b..3b346c7 100644
--- a/dwarves.h
+++ b/dwarves.h
@@ -36,6 +36,7 @@
 #define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]) + __must_be_array(arr))
 
 struct cu;
+struct cus;
 
 enum load_steal_kind {
 	LSK__KEEPIT,
@@ -58,6 +59,13 @@ typedef uint32_t type_id_t;
 struct btf;
 struct conf_fprintf;
 
+struct process_dwflmod_parms {
+	struct cus	 *cus;
+	struct conf_load *conf;
+	const char	 *filename;
+	uint32_t	 nr_dwarf_sections_found;
+};
+
 /** struct conf_load - load configuration
  * @thread_exit - called at the end of a thread, 1st user: BTF encoder dedup
  * @extra_dbg_info - keep original debugging format extra info
@@ -106,6 +114,14 @@ struct conf_load {
 	struct conf_fprintf	*conf_fprintf;
 	int			(*threads_prepare)(struct conf_load *conf, int nr_threads, void **thr_data);
 	int			(*threads_collect)(struct conf_load *conf, int nr_threads, void **thr_data, int error);
+	int			(*pre_cus__load_module)(struct process_dwflmod_parms *parms,
+							Dwfl_Module *mod,
+							Dwarf *dw,
+							Elf *elf);
+	int			(*post_cus__load_module)(struct process_dwflmod_parms *parms,
+							 Dwfl_Module *mod,
+							 Dwarf *dw,
+							 Elf *elf);
 };
 
 /** struct conf_fprintf - hints to the __fprintf routines
@@ -167,8 +183,6 @@ struct conf_fprintf {
 	uint8_t    skip_emitting_modifier:1;
 };
 
-struct cus;
-
 struct cus *cus__new(void);
 void cus__delete(struct cus *cus);
 
-- 
2.43.0







[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux