use of com.google.security.zynamics.binnavi.debug.models.processmanager.MemoryModule in project binnavi by google.
the class MemoryModuleParser method parseModule.
/**
* Parses a single module information message.
*
* @param node The xml node which contains the module item.
* @return The memory module object created from the information in the message.
* @throws MessageParserException Thrown if parsing the message failed.
*/
public static MemoryModule parseModule(final Node node) throws MessageParserException {
try {
final String name = getAttribute(node, "name");
final String path = getAttribute(node, "path");
final RelocatedAddress baseAddress = new RelocatedAddress(new CAddress(new BigInteger(getAttribute(node, "address"))));
final long size = Long.valueOf(getAttribute(node, "size"));
return new MemoryModule(name, path, baseAddress, size);
} catch (final Exception exception) {
throw new MessageParserException(exception.getLocalizedMessage());
}
}
use of com.google.security.zynamics.binnavi.debug.models.processmanager.MemoryModule in project binnavi by google.
the class ProcessStartParser method parse.
/**
* Parses the byte stream containing the process start packet.
*
* @param data The raw data to be parsed.
* @return The parsed process start object.
* @throws MessageParserException Thrown if an error occurred while parsing.
*/
public static ProcessStart parse(final byte[] data) throws MessageParserException {
Preconditions.checkNotNull(data, "IE00066: Data argument can not be null");
final DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
TargetProcessThread thread = null;
MemoryModule module = null;
try {
final DocumentBuilder builder = factory.newDocumentBuilder();
final Document document = builder.parse(new ByteArrayInputStream(data, 0, data.length));
final NodeList nodes = document.getFirstChild().getChildNodes();
for (int i = 0; i < nodes.getLength(); ++i) {
final Node node = nodes.item(i);
final String nodeName = node.getNodeName();
if ("thread".equals(nodeName)) {
thread = parseThreadInformation(node);
} else if ("module".equals(nodeName)) {
module = MemoryModuleParser.parseModule(node);
} else {
throw new MessageParserException(String.format("Found unknown node '%s' in process start string", nodeName));
}
}
} catch (final Exception exception) {
CUtilityFunctions.logException(exception);
throw new MessageParserException(exception.getLocalizedMessage());
}
Preconditions.checkNotNull(thread, "IE01665: E00068: Received invalid process start string (missing thread information)");
Preconditions.checkNotNull(module, "IE01668: E00069: Received invalid target process start string (missing module information)");
return new ProcessStart(thread, module);
}
use of com.google.security.zynamics.binnavi.debug.models.processmanager.MemoryModule in project binnavi by google.
the class DebuggerTest method testlisteners0.
@Test
public void testlisteners0() throws DebugExceptionWrapper, MaybeNullException, ParserConfigurationException, SAXException, IOException {
mockDebugger.connect();
mockDebugger.getProcessManager().addThread(new TargetProcessThread(0, ThreadState.RUNNING));
mockDebugger.getProcessManager().setTargetInformation(new TargetInformation(5, Lists.newArrayList(new RegisterDescription("eax", 4, true), new RegisterDescription("ebx", 4, false)), new DebuggerOptions(false, false, false, false, false, false, false, false, false, false, 12, 0, new ArrayList<DebuggerException>(), false, false, false)));
mockDebugger.connection.m_synchronizer.receivedEvent(DebuggerMessageBuilder.buildProcessStartReply(CommonTestObjects.MEMORY_MODULE));
mockDebugger.getProcessManager().getThread(0).setCurrentAddress(new RelocatedAddress(new CAddress(0)));
mockDebugger.getBreakpointManager().addBreakpoints(BreakpointType.ECHO, CommonTestObjects.BP_ADDRESS_123_SET);
final ArrayList<Pair<RelocatedAddress, Integer>> list = new ArrayList<Pair<RelocatedAddress, Integer>>();
mockDebugger.connection.m_synchronizer.receivedEvent(new EchoBreakpointSetReply(0, 0, list));
mockDebugger.connection.m_synchronizer.receivedEvent(new EchoBreakpointSetReply(0, 0, list));
mockDebugger.connection.m_synchronizer.receivedEvent(new EchoBreakpointsRemovedReply(0, 0, list));
mockDebugger.connection.m_synchronizer.receivedEvent(new EchoBreakpointsRemovedReply(0, 0, list));
mockDebugger.connection.m_synchronizer.receivedEvent(new ExceptionOccurredReply(0, 0, 0, 0, new RelocatedAddress(new CAddress(0)), "Test exception"));
mockDebugger.connection.m_synchronizer.receivedEvent(new HaltReply(0, 0, 0));
mockDebugger.connection.m_synchronizer.receivedEvent(new HaltReply(0, 0, 1));
mockDebugger.connection.m_synchronizer.receivedEvent(new ListFilesReply(0, 0, RemoteFileSystem.parse("<foo></foo>".getBytes())));
mockDebugger.connection.m_synchronizer.receivedEvent(new ListFilesReply(0, 1, null));
mockDebugger.connection.m_synchronizer.receivedEvent(new ListProcessesReply(0, 0, ProcessList.parse("<foo></foo>".getBytes())));
mockDebugger.connection.m_synchronizer.receivedEvent(new ListProcessesReply(0, 1, null));
mockDebugger.connection.m_synchronizer.receivedEvent(new MemoryMapReply(0, 0, new MemoryMap(new ArrayList<MemorySection>())));
mockDebugger.connection.m_synchronizer.receivedEvent(new MemoryMapReply(0, 1, null));
mockDebugger.connection.m_synchronizer.receivedEvent(new ModuleLoadedReply(0, 0, new MemoryModule("XXX", "YYYXXX", new RelocatedAddress(new CAddress(0)), 0), new TargetProcessThread(123, ThreadState.SUSPENDED)));
mockDebugger.connection.m_synchronizer.receivedEvent(new ModuleUnloadedReply(0, 0, new MemoryModule("XXX", "YYYXXX", new RelocatedAddress(new CAddress(0)), 0)));
mockDebugger.connection.m_synchronizer.receivedEvent(new ProcessClosedReply(0, 0));
mockDebugger.connection.m_synchronizer.receivedEvent(new ReadMemoryReply(0, 0, new CAddress(0), new byte[8]));
mockDebugger.connection.m_synchronizer.receivedEvent(new ReadMemoryReply(0, 1, null, null));
mockDebugger.connection.m_synchronizer.receivedEvent(new RegistersReply(0, 0, new RegisterValues(new FilledList<ThreadRegisters>())));
mockDebugger.connection.m_synchronizer.receivedEvent(new RegistersReply(0, 1, null));
mockDebugger.connection.m_synchronizer.receivedEvent(new RequestTargetReply(0, 0));
mockDebugger.connection.m_synchronizer.receivedEvent(new RequestTargetReply(0, 1));
mockDebugger.connection.m_synchronizer.receivedEvent(new ResumeReply(0, 0));
mockDebugger.connection.m_synchronizer.receivedEvent(new ResumeReply(0, 1));
}
use of com.google.security.zynamics.binnavi.debug.models.processmanager.MemoryModule in project binnavi by google.
the class ProcessTest method testLifeCycle.
@Test
public void testLifeCycle() {
final MockProcessListener listener = new MockProcessListener();
final ProcessManager manager = new ProcessManager();
final Process process = new Process(manager);
process.addListener(listener);
manager.setAttached(true);
assertEquals("attached;", listener.events);
process.removeListener(listener);
manager.setTargetInformation(new com.google.security.zynamics.binnavi.debug.models.targetinformation.TargetInformation(5, new FilledList<RegisterDescription>(), new DebuggerOptions(false, false, false, false, false, false, false, false, false, false, 12, 0, new ArrayList<DebuggerException>(), false, false, false)));
manager.addThread(new TargetProcessThread(0, ThreadState.RUNNING));
manager.addModule(new MemoryModule("Hannes", "C:\\Hannes.dll", new RelocatedAddress(new CAddress(0x100)), 0x100));
manager.setMemoryMap(new com.google.security.zynamics.binnavi.debug.models.processmanager.MemoryMap(Lists.newArrayList(new com.google.security.zynamics.binnavi.debug.models.processmanager.MemorySection(new CAddress(0), new CAddress(0x100)))));
manager.getMemory().store(0, new byte[] { 0, 1, 2, 3 });
process.addListener(listener);
manager.setTargetInformation(new com.google.security.zynamics.binnavi.debug.models.targetinformation.TargetInformation(5, new FilledList<RegisterDescription>(), new DebuggerOptions(false, false, false, false, false, false, false, false, false, false, 12, 0, new ArrayList<DebuggerException>(), false, false, false)));
assertEquals(0, process.getThreads().size());
assertEquals(0, process.getModules().size());
assertEquals(0, process.getMemoryMap().getSections().size());
assertEquals(false, process.getMemory().hasData(0, 4));
manager.setAttached(false);
assertEquals("attached;changedTargetInformation;detached;", listener.events);
assertEquals(0, process.getThreads().size());
assertEquals(0, process.getModules().size());
assertEquals(null, process.getTargetInformation());
assertEquals(0, process.getMemoryMap().getSections().size());
assertEquals(false, process.getMemory().hasData(0, 4));
process.removeListener(listener);
}
use of com.google.security.zynamics.binnavi.debug.models.processmanager.MemoryModule in project binnavi by google.
the class CHistoryStringBuilderTest method testComplete3.
@SuppressWarnings("unchecked")
@Test
public void testComplete3() throws DebugExceptionWrapper, ParserConfigurationException, SAXException, IOException, MessageParserException, MaybeNullException {
final CHistoryStringBuilder builder = new CHistoryStringBuilder();
builder.setDebugger(m_debugger);
m_debugger.connect();
m_synchronizer.receivedEvent(DebuggerMessageBuilder.buildProcessStartReply(mockMemoryModule));
m_debugger.getProcessManager().setTargetInformation(new TargetInformation(5, Lists.newArrayList(new RegisterDescription("eax", 4, true), new RegisterDescription("ebx", 4, false)), new DebuggerOptions(false, false, false, false, false, false, false, false, false, false, 12, 0, new ArrayList<DebuggerException>(), false, false, false)));
m_debugger.getProcessManager().addThread(new TargetProcessThread(1, ThreadState.RUNNING));
m_synchronizer.receivedEvent(new BreakpointConditionSetReply(0, 0));
m_synchronizer.receivedEvent(new BreakpointConditionSetReply(0, 1));
m_synchronizer.receivedEvent(new EchoBreakpointHitReply(0, 0, 1, new RegisterValues(Lists.<ThreadRegisters>newArrayList(new ThreadRegisters(1, Lists.newArrayList(new RegisterValue("eip", BigInteger.ONE, new byte[0], false, false)))))));
m_synchronizer.receivedEvent(new EchoBreakpointHitReply(0, 0, 1, new RegisterValues(Lists.<ThreadRegisters>newArrayList(new ThreadRegisters(1, Lists.newArrayList(new RegisterValue("eip", BigInteger.ONE, new byte[0], true, false)))))));
m_debugger.getProcessManager().addThread(new TargetProcessThread(0, ThreadState.RUNNING));
m_debugger.getProcessManager().getThread(0).setCurrentAddress(new RelocatedAddress(new CAddress(0)));
m_debugger.getBreakpointManager().addBreakpoints(BreakpointType.ECHO, BREAKPOINT_ADDRESS);
m_synchronizer.receivedEvent(new EchoBreakpointSetReply(0, 0, Lists.newArrayList(new Pair<RelocatedAddress, Integer>(BREAKPOINT_ADDRESS_RELOC, 0))));
m_synchronizer.receivedEvent(new EchoBreakpointSetReply(0, 0, Lists.newArrayList(new Pair<RelocatedAddress, Integer>(BREAKPOINT_ADDRESS_RELOC, 1))));
m_synchronizer.receivedEvent(new EchoBreakpointsRemovedReply(0, 0, Lists.newArrayList(new Pair<RelocatedAddress, Integer>(BREAKPOINT_ADDRESS_RELOC, 0))));
m_synchronizer.receivedEvent(new EchoBreakpointsRemovedReply(0, 0, Lists.newArrayList(new Pair<RelocatedAddress, Integer>(BREAKPOINT_ADDRESS_RELOC, 1))));
m_synchronizer.receivedEvent(new ExceptionOccurredReply(0, 0, 0, 0, new RelocatedAddress(new CAddress(0)), "Test exception"));
m_synchronizer.receivedEvent(new HaltReply(0, 0, 0));
m_synchronizer.receivedEvent(new HaltReply(0, 0, 1));
m_synchronizer.receivedEvent(new ListFilesReply(0, 0, RemoteFileSystem.parse("<foo></foo>".getBytes())));
m_synchronizer.receivedEvent(new ListFilesReply(0, 1, null));
m_synchronizer.receivedEvent(new ListProcessesReply(0, 0, ProcessList.parse("<foo></foo>".getBytes())));
m_synchronizer.receivedEvent(new ListProcessesReply(0, 1, null));
m_synchronizer.receivedEvent(new MemoryMapReply(0, 0, new MemoryMap(new ArrayList<MemorySection>())));
m_synchronizer.receivedEvent(new MemoryMapReply(0, 1, null));
m_synchronizer.receivedEvent(new ModuleLoadedReply(0, 0, new MemoryModule("XXX", "YYYXXX", new RelocatedAddress(new CAddress(0)), 0), new TargetProcessThread(123, ThreadState.SUSPENDED)));
m_synchronizer.receivedEvent(new ModuleUnloadedReply(0, 0, new MemoryModule("XXX", "YYYXXX", new RelocatedAddress(new CAddress(0)), 0)));
m_synchronizer.receivedEvent(new ProcessClosedReply(0, 0));
m_synchronizer.receivedEvent(new ReadMemoryReply(0, 0, new CAddress(0), new byte[8]));
m_synchronizer.receivedEvent(new ReadMemoryReply(0, 1, null, null));
m_synchronizer.receivedEvent(new RegistersReply(0, 0, new RegisterValues(new FilledList<ThreadRegisters>())));
m_synchronizer.receivedEvent(new RegistersReply(0, 1, null));
m_synchronizer.receivedEvent(new RequestTargetReply(0, 0));
m_synchronizer.receivedEvent(new RequestTargetReply(0, 1));
m_synchronizer.receivedEvent(new ResumeReply(0, 0));
m_synchronizer.receivedEvent(new ResumeReply(0, 1));
m_debugger.connect();
m_debugger.getProcessManager().addThread(new TargetProcessThread(0, ThreadState.RUNNING));
m_debugger.getProcessManager().getThread(0).setCurrentAddress(new RelocatedAddress(new CAddress(0)));
m_synchronizer.receivedEvent(new ResumeThreadReply(0, 0, 0));
m_synchronizer.receivedEvent(new ResumeThreadReply(0, 1, 0));
m_synchronizer.receivedEvent(new SearchReply(0, 0, new CAddress(0)));
m_synchronizer.receivedEvent(new SearchReply(0, 1, null));
m_synchronizer.receivedEvent(new SelectFileReply(0, 0));
m_synchronizer.receivedEvent(new SelectFileReply(0, 1));
m_debugger.getProcessManager().addThread(new TargetProcessThread(0, ThreadState.RUNNING));
m_debugger.getProcessManager().getThread(0).setCurrentAddress(new RelocatedAddress(new CAddress(0)));
m_synchronizer.receivedEvent(new SetRegisterReply(0, 0, 0, 0));
m_synchronizer.receivedEvent(new SetRegisterReply(0, 1, 0, 0));
m_synchronizer.receivedEvent(new SingleStepReply(0, 0, 0, new RelocatedAddress(new CAddress(0)), new RegisterValues(new FilledList<ThreadRegisters>())));
m_synchronizer.receivedEvent(new SingleStepReply(0, 1, 0, new RelocatedAddress(new CAddress(0)), new RegisterValues(new FilledList<ThreadRegisters>())));
m_synchronizer.receivedEvent(new StepBreakpointHitReply(0, 0, 1, new RegisterValues(Lists.<ThreadRegisters>newArrayList(new ThreadRegisters(1, Lists.newArrayList(new RegisterValue("eip", BigInteger.ONE, new byte[0], false, false)))))));
m_synchronizer.receivedEvent(new StepBreakpointHitReply(0, 0, 1, new RegisterValues(Lists.<ThreadRegisters>newArrayList(new ThreadRegisters(1, Lists.newArrayList(new RegisterValue("eip", BigInteger.ONE, new byte[0], true, false)))))));
m_debugger.getBreakpointManager().addBreakpoints(BreakpointType.STEP, BREAKPOINT_ADDRESS);
m_synchronizer.receivedEvent(new StepBreakpointSetReply(0, 0, Lists.newArrayList(new Pair<RelocatedAddress, Integer>(BREAKPOINT_ADDRESS_RELOC, 0))));
m_synchronizer.receivedEvent(new StepBreakpointSetReply(0, 1, Lists.newArrayList(new Pair<RelocatedAddress, Integer>(BREAKPOINT_ADDRESS_RELOC, 1))));
m_synchronizer.receivedEvent(new StepBreakpointsRemovedReply(0, 0, Lists.newArrayList(new Pair<RelocatedAddress, Integer>(BREAKPOINT_ADDRESS_RELOC, 0))));
m_synchronizer.receivedEvent(new StepBreakpointsRemovedReply(0, 1, Lists.newArrayList(new Pair<RelocatedAddress, Integer>(BREAKPOINT_ADDRESS_RELOC, 1))));
m_synchronizer.receivedEvent(new SuspendThreadReply(0, 0, 0));
m_synchronizer.receivedEvent(new SuspendThreadReply(0, 1, 0));
m_synchronizer.receivedEvent(new TargetInformationReply(0, 0, TargetInformationParser.parse("<foo><size>32</size><registers></registers><options></options></foo>".getBytes())));
m_synchronizer.receivedEvent(new TargetInformationReply(0, 1, null));
m_debugger.getProcessManager().addThread(new TargetProcessThread(0, ThreadState.RUNNING));
m_synchronizer.receivedEvent(new ThreadClosedReply(0, 0, 0));
m_synchronizer.receivedEvent(new ThreadClosedReply(0, 1, 0));
m_synchronizer.receivedEvent(new ThreadCreatedReply(0, 0, 0, ThreadState.RUNNING));
m_synchronizer.receivedEvent(new ThreadCreatedReply(0, 1, 0, null));
m_synchronizer.receivedEvent(new ValidateMemoryReply(0, 0, new CAddress(0), new CAddress(0)));
m_synchronizer.receivedEvent(new ValidateMemoryReply(0, 1, null, null));
m_synchronizer.receivedEvent(new WriteMemoryReply(0, 0));
m_synchronizer.receivedEvent(new WriteMemoryReply(0, 1));
m_synchronizer.receivedEvent(new TerminateReply(0, 0));
m_synchronizer.receivedEvent(new TerminateReply(0, 1));
}
Aggregations