Candidate release of source code.

This commit is contained in:
Dan 2019-03-26 13:45:32 -04:00
parent db81e6b3b0
commit 79d8f164f8
12449 changed files with 2800756 additions and 16 deletions

View file

@ -0,0 +1,37 @@
<html>
<head>
<title>XML Exporter for IDA version 6</title>
<style>
filename {
font-family: monospace;
}
</style>
</head>
<body>
<h1>XML Exporter for IDA version 6</h1>
<p>
<filename>xmlexp.py</filename> and <filename>xmldr.py</filename> can be used with IDA versions 6.2 and greater.
For best results, it is recommended to use version 6.7 or greater.
</p>
<p>
<filename>xmlexp.py</filename> is a plugin to export an IDA database as an XML file.
</p>
<p>
<filename>xmlldr.py</filename> can be used as an IDA loader to build a new database using an XML file and
it can be used as an IDA plugin to add data from an XML file to an existing database.
</p>
<p>
As a loader, it loads the bytes file and builds the IDA database
using the contents of the XML file.
</p>
<p>
As a plugin, it will add information to an existing IDA database.
It will NOT load any binary data from the bytes file.
It will add symbols, comments, code, data, functions, etc. for
addresses that currently existing in the database.
</p>
<p>
Currently, the loader does not support importing memory overlays or Harvard architectures (e.g., 8051).
</p>
</body>
</html>

File diff suppressed because it is too large Load diff

File diff suppressed because it is too large Load diff

View file

@ -0,0 +1,40 @@
<html>
<head>
<title>XML Exporter for IDA version 7</title>
<style>
filename {
font-family: monospace;
}
</style>
</head>
<body>
<h1>XML Exporter for IDA version 7</h1>
<p>
The 7XX versions of the XML Exporter, Importer, and Loader can only be used
with IDA version 7.0 are greater.
</p>
<p>
<filename>xml_exporter.py</filename> is a plugin to export an IDA database as an XML file.
It must be placed in the IDA plugins folder.
</p>
<p>
<filename>xml_loader.py</filename> is an IDA loader to build a new database using an XML file.
It loads the .bytes file and builds the IDA database using the contents of
the XML file. NOTE: Currently, the loader does not support importing memory
overlays or Harvard architectures (e.g., 8051).
It must be placed in the IDA loaders folder.
</p>
<p>
<filename>xml_importer.py</filename> is a plugin to add data from an XML file to an existing
database. It will NOT load any binary data from the bytes file. It will add
symbols, comments, code, data, functions, etc. for addresses that currently
exist in the database.
It must be placed in the IDA plugins folder.
</p>
<p>
The <filename>idaxml.py</filename> module is a require import for the xml_exporter, xml_importer,
and xml_loader.
It must be placed in the IDA python folder.
</p>
</body>
</html>

View file

@ -0,0 +1,87 @@
#---------------------------------------------------------------------
# xmlldr.py - IDA XML loader
#---------------------------------------------------------------------
"""
Loader for IDA to import a XML PROGRAM file and create a new database (.idb).
This file must be placed in the IDA loaders directory.
The file idaxml.py must be placed in the IDA python directory.
"""
import ida_idaapi
import ida_idp
import ida_kernwin
import ida_pro
import idaxml
import idc
"""
Loader functions
"""
def accept_file(li, filename):
"""
Check if the file is of supported format
@param li: a file-like object which can be used to access the input data
@param n : format number. The function will be called with incrementing
number until it returns zero
@return: 0 - no more supported formats
string "name" - format name to display in the chooser dialog
dictionary { 'format': "name", 'options': integer }
options: should be 1, possibly ORed with ACCEPT_FIRST (0x8000)
to indicate preferred format
"""
if not idaxml.is_ida_version_supported():
return 0
# read 16K bytes to allow for the DTD
data = li.read(0x4000)
# look for start of <PROGRAM> element
start = data.find("<PROGRAM")
if start >= 0:
s = data.find("<PROCESSOR ")
p = data[s+11:]
e = p.find("/>")
proc = p[:e]
ida_kernwin.info("Processor specified in the XML file is:\n" + proc +
"\n\nYou must select and set the compatible " +
"IDA processor type.")
return { 'format': "XML PROGRAM file", 'options': 0x8001 }
return 0
def load_file(li, neflags, format):
"""
Load the file into database
@param li: a file-like object which can be used to access the input data
@param neflags: options selected by the user, see loader.hpp
@return: 0-failure, 1-ok
"""
global event, element
if ida_idp.get_idp_name() == None:
ida_idp.set_processor_type("metapc", ida_idp.SETPROC_LOADER)
status = 0
st = idc.set_ida_state(idc.IDA_STATUS_WORK)
xml = idaxml.XmlImporter(idaxml.LOADER, 0)
try:
status = xml.import_xml()
except idaxml.Cancelled:
msg = "XML PROGRAM import cancelled!"
print "\n" + msg
idc.warning(msg)
except idaxml.MultipleAddressSpacesNotSupported:
msg = "XML Import cancelled!"
msg += "\n\nXML Import does not currently support"
msg += "\nimporting multiple address spaces."
print "\n" + msg
idc.warning(msg)
except:
print "\nHouston, we have a problem!"
msg = "***** Exception occurred: XML loader failed! *****"
print "\n" + msg + "\n", sys.exc_type, sys.exc_value
print event, element.tag, element.attrib
idc.warning(msg)
finally:
idc.set_ida_state(st)
xml.cleanup()
return status

View file

@ -0,0 +1,76 @@
#---------------------------------------------------------------------
# xmlexp.py - IDA XML Exporter plugin
#---------------------------------------------------------------------
"""
Plugin for IDA which exports a XML PROGRAM document file from a database.
This file must be placed in the IDA plugins directory.
The file idaxml.py must be placed in the IDA python directory.
"""
import ida_auto
import ida_idaapi
import ida_kernwin
import idaxml
import idc
class XmlExporterPlugin(ida_idaapi.plugin_t):
"""
XML Exporter plugin class
"""
flags = 0
comment = "Export database as XML file"
help = "Export database as XML <PROGRAM> document"
wanted_name = "XML Exporter"
wanted_hotkey = "Ctrl-Shift-x"
def init(self):
"""
init function for XML Exporter plugin.
Returns:
Constant PLUGIN_OK if this IDA version supports the plugin,
else returns PLUGIN_SKIP if this IDA is older than the supported
baseline version.
"""
if idaxml.is_ida_version_supported():
return ida_idaapi.PLUGIN_OK
else:
return ida_idaapi.PLUGIN_SKIP
def run(self, arg):
"""
run function for XML Exporter plugin.
Args:
arg: Integer, non-zero value enables auto-run feature for
IDA batch (no gui) processing mode. Default is 0.
"""
st = idc.set_ida_state(idc.IDA_STATUS_WORK)
xml = idaxml.XmlExporter(arg)
try:
try:
xml.export_xml()
except idaxml.Cancelled:
ida_kernwin.hide_wait_box()
msg = "XML Export cancelled!"
print "\n" + msg
idc.warning(msg)
except:
ida_kernwin.hide_wait_box()
msg = "***** Exception occurred: XML Exporter failed! *****"
print "\n" + msg + "\n", sys.exc_type, sys.exc_value
idc.warning(msg)
finally:
xml.cleanup()
ida_auto.set_ida_state(st)
def term(self):
pass
def PLUGIN_ENTRY():
return XmlExporterPlugin()

View file

@ -0,0 +1,78 @@
#---------------------------------------------------------------------
# xmlimp.py - IDA XML Importer plugin
#---------------------------------------------------------------------
"""
Plugin for IDA to import a XML PROGRAM file into an existing open database.
This file must be placed in the IDA plugins directory.
The file idaxml.py must be placed in the IDA python directory.
"""
import ida_idaapi
import ida_pro
import idaxml
import idc
import sys
class XmlImporterPlugin(ida_idaapi.plugin_t):
"""
XML Importer plugin class
"""
flags = 0
comment = "Import XML PROGRAM file"
help = "Import XML <PROGRAM> document to database"
wanted_name = "XML Importer"
wanted_hotkey = "Ctrl-Alt-l"
def init(self):
"""
init function for XML Importer plugin.
Returns:
Constant PLUGIN_OK if this IDA version supports the plugin,
else returns PLUGIN_SKIP if this IDA is older than the supported
baseline version.
"""
if idaxml.is_ida_version_supported():
return ida_idaapi.PLUGIN_OK
else:
return ida_idaapi.PLUGIN_SKIP
def run(self, arg):
"""
run function for XML Importer plugin.
Args:
arg: Integer, a non-zero value enables auto-run feature for
IDA batch (no gui) processing mode. Default is 0.
"""
st = idc.set_ida_state(idc.IDA_STATUS_WORK)
xml = idaxml.XmlImporter(idaxml.PLUGIN, arg)
try:
try:
xml.import_xml()
except idaxml.Cancelled:
msg = "XML Import cancelled!"
print "\n" + msg
idc.warning(msg)
except idaxml.MultipleAddressSpacesNotSupported:
msg = "XML Import cancelled!"
msg += "\n\nXML Import does not currently support"
msg += "\nimporting multiple address spaces."
print "\n" + msg
idc.warning(msg)
except:
msg = "***** Exception occurred: XML Importer failed! *****"
print "\n" + msg + "\n", sys.exc_type, sys.exc_value
idc.warning(msg)
finally:
xml.cleanup()
idc.set_ida_state(st)
def term(self):
pass
def PLUGIN_ENTRY():
return XmlImporterPlugin()

File diff suppressed because it is too large Load diff