diff options
Diffstat (limited to 'src/analysis')
-rw-r--r-- | src/analysis/disass/routines.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/src/analysis/disass/routines.c b/src/analysis/disass/routines.c index 3e0aa71..94afbe4 100644 --- a/src/analysis/disass/routines.c +++ b/src/analysis/disass/routines.c @@ -304,6 +304,18 @@ void g_routines_study_handle_blocks(GRoutinesStudy *study, size_t index) knight = begin_dragon_knight(study->proc, coverage, range, start); + + /** + * FIXME + * L'état 'knight == NULL' peut avoir deux origines : + * - soit le binaire est mal-formé. + * - soit le désassemblage s'est mal déroulé. + * Dans les deux cas, on obtient un symbole qui n'a pas d'instruction de départ. + * A traiter autrement qu'en filtrant sur knight... + */ + if (knight == NULL) return; + + /* Traitement par blocs */ detect_loops_in_code(knight); |