blob: 4c78625b818c0bc3482422f3b250e86078cc4620 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
#!/usr/bin/python
# -*- coding: utf-8 -*-
# Il arrive que les segments englobent partiellement des sections.
#
# Cela peut être problématique si une section contient une chaîne de taille
# n qui se retrouve à cheval sur deux zones (la section des chaînes découpée
# en deux par exemple).
#
# Au moment d'associer l'instruction chargée à la zone de départ, cette
# dernière n'est pas assez grande car elle ne représente pas la section
# en entier.
from chrysacase import ChrysalideTestCase
from pychrysalide.analysis import LoadedBinary
from pychrysalide.analysis.contents import FileContent
from threading import Event
import os
import sys
class TestOverlappingAreas(ChrysalideTestCase):
"""TestCase for BSS segment overlapping string section."""
@classmethod
def setUpClass(cls):
super(TestOverlappingAreas, cls).setUpClass()
cls.log('Compile binary "overlapping_areas" if needed...')
fullname = sys.modules[cls.__module__].__file__
dirpath = os.path.dirname(fullname)
os.system('make -C %s overlapping_areas 2>&1 > /dev/null' % dirpath)
def testOOBSectionName(self):
"""Avoid crashing because of overlapping binary areas."""
fullname = sys.modules[self.__class__.__module__].__file__
filename = os.path.basename(fullname)
baselen = len(fullname) - len(filename)
cnt = FileContent(fullname[:baselen] + 'overlapping_areas')
self.assertIsNotNone(cnt)
binary = LoadedBinary(cnt)
def disass_done(binary):
worker.set()
binary.connect('disassembly-done', disass_done)
worker = Event()
binary.analyse()
worker.wait()
|