diff options
author | van Hauser <vh@thc.org> | 2021-03-25 19:42:27 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-03-25 19:42:27 +0100 |
commit | 00a53a870d7ccd24e13e6cb2bbbd7535964f7737 (patch) | |
tree | 18a123e6c48bb9d3ffd31e87c818c35da60cb562 /frida_mode/test/testinstr.py | |
parent | 0029c1a83ef03825c2d19c73151189f159458496 (diff) | |
parent | 1725e6be316b57e89df2a077710b66b684b55242 (diff) | |
download | afl++-00a53a870d7ccd24e13e6cb2bbbd7535964f7737.tar.gz |
Merge pull request #833 from WorksButNotTested/frida
Frida
Diffstat (limited to 'frida_mode/test/testinstr.py')
-rwxr-xr-x | frida_mode/test/testinstr.py | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/frida_mode/test/testinstr.py b/frida_mode/test/testinstr.py new file mode 100755 index 00000000..8f5fe886 --- /dev/null +++ b/frida_mode/test/testinstr.py @@ -0,0 +1,32 @@ +#!/usr/bin/python3 +import argparse +from elftools.elf.elffile import ELFFile + +def process_file(file, section, base): + with open(file, 'rb') as f: + for sect in ELFFile(f).iter_sections(): + if (sect.name == section): + start = base + sect.header['sh_offset'] + end = start + sect.header['sh_size'] + print ("0x%016x-0x%016x" % (start, end)) + return + + print ("Section '%s' not found in '%s'" % (section, file)) + +def hex_value(x): + return int(x, 16) + +def main(): + parser = argparse.ArgumentParser(description='Process some integers.') + parser.add_argument('-f', '--file', dest='file', type=str, + help='elf file name', required=True) + parser.add_argument('-s', '--section', dest='section', type=str, + help='elf section name', required=True) + parser.add_argument('-b', '--base', dest='base', type=hex_value, + help='elf base address', required=True) + + args = parser.parse_args() + process_file (args.file, args.section, args.base) + +if __name__ == "__main__": + main() \ No newline at end of file |