2011-07-29 22:20:50 +08:00
|
|
|
#
|
|
|
|
#
|
|
|
|
#
|
|
|
|
|
|
|
|
from PySide.QtCore import *
|
2011-08-18 00:13:04 +08:00
|
|
|
from PySide.QtGui import *
|
2011-07-29 22:20:50 +08:00
|
|
|
|
|
|
|
import pykd
|
|
|
|
|
|
|
|
|
2011-08-18 00:13:04 +08:00
|
|
|
class UpdateEvent( QEvent ):
|
2011-07-29 22:20:50 +08:00
|
|
|
def __init__(self):
|
2011-08-18 00:13:04 +08:00
|
|
|
QEvent.__init__(self, QEvent.Type(QEvent.User + 1))
|
|
|
|
|
|
|
|
|
|
|
|
class GoThread( QThread ):
|
|
|
|
|
|
|
|
def __init__(self, func):
|
2011-07-29 22:20:50 +08:00
|
|
|
QThread.__init__(self)
|
2011-08-18 00:13:04 +08:00
|
|
|
self.start()
|
|
|
|
self.func = func
|
2011-07-29 22:20:50 +08:00
|
|
|
|
|
|
|
def run(self):
|
2011-08-18 00:13:04 +08:00
|
|
|
self.func()
|
|
|
|
app.postEvent( mainForm, UpdateEvent() )
|
|
|
|
self.exit()
|
2011-07-29 22:20:50 +08:00
|
|
|
|
|
|
|
|
2011-08-18 00:13:04 +08:00
|
|
|
class DisasmWidget( QDockWidget ):
|
|
|
|
|
|
|
|
def __init__( self ):
|
|
|
|
QDockWidget.__init__( self )
|
|
|
|
self.setWindowTitle( "Disassembler" )
|
|
|
|
self.textArea = QTextEdit()
|
|
|
|
self.textArea.setReadOnly( True )
|
|
|
|
self.setWidget( self.textArea )
|
|
|
|
|
|
|
|
|
|
|
|
def onUpdate( self ):
|
|
|
|
|
|
|
|
disasm = pykd.disasm()
|
|
|
|
disasmStr = disasm.instruction() + "\n"
|
|
|
|
for i in xrange(50):
|
|
|
|
disasmStr += disasm.next() + "\n"
|
|
|
|
|
|
|
|
self.textArea.setPlainText( disasmStr )
|
|
|
|
|
|
|
|
|
|
|
|
class RegistersWidget( QDockWidget ):
|
|
|
|
|
|
|
|
def __init__( self ):
|
|
|
|
QDockWidget.__init__( self )
|
|
|
|
self.setWindowTitle( "Registers" )
|
|
|
|
self.textArea = QTextEdit()
|
|
|
|
self.setWidget( self.textArea )
|
|
|
|
|
|
|
|
def onUpdate( self ):
|
|
|
|
|
|
|
|
s = ""
|
|
|
|
|
|
|
|
for reg in self.getRegisterSet():
|
|
|
|
s += "%s %x ( %d )\r\n" % ( reg.name(), reg.value(), reg.value() )
|
|
|
|
|
|
|
|
self.textArea.setPlainText( s )
|
|
|
|
|
|
|
|
|
|
|
|
def getRegisterSet(self):
|
|
|
|
regSet=[]
|
|
|
|
try:
|
|
|
|
i = 0
|
|
|
|
while True:
|
|
|
|
reg = pykd.cpuReg(i)
|
|
|
|
regSet.append(reg)
|
|
|
|
i += 1
|
|
|
|
|
|
|
|
except pykd.BaseException:
|
|
|
|
pass
|
|
|
|
|
|
|
|
return regSet
|
|
|
|
|
|
|
|
|
|
|
|
class StackWidget( QDockWidget ):
|
|
|
|
|
|
|
|
def __init__( self ):
|
|
|
|
QDockWidget.__init__( self )
|
|
|
|
self.setWindowTitle( "Stack" )
|
|
|
|
self.textArea = QTextEdit()
|
|
|
|
self.setWidget( self.textArea )
|
|
|
|
|
|
|
|
def onUpdate( self ):
|
|
|
|
|
|
|
|
s = ""
|
|
|
|
|
|
|
|
stackFrames = pykd.getCurrentStack()
|
|
|
|
for frame in stackFrames:
|
|
|
|
s += pykd.findSymbol( frame.instructionOffset ) + " (%x)" % frame.instructionOffset + "\n"
|
|
|
|
|
|
|
|
self.textArea.setPlainText( s )
|
2011-07-29 22:20:50 +08:00
|
|
|
|
|
|
|
|
|
|
|
class MainForm( QMainWindow ):
|
2011-08-18 00:13:04 +08:00
|
|
|
|
|
|
|
updated = Signal()
|
2011-07-29 22:20:50 +08:00
|
|
|
|
|
|
|
def __init__( self ):
|
|
|
|
|
2011-08-18 00:13:04 +08:00
|
|
|
|
2011-07-29 22:20:50 +08:00
|
|
|
QMainWindow.__init__( self, None )
|
|
|
|
self.setWindowTitle("Pykd Debugger Sample")
|
2011-08-18 00:13:04 +08:00
|
|
|
self.setDockNestingEnabled( True )
|
|
|
|
|
|
|
|
self.goThread = None
|
|
|
|
|
2011-07-29 22:20:50 +08:00
|
|
|
|
|
|
|
fileMenu = QMenu( "&File" )
|
|
|
|
fileMenu.addAction( "Open process...", self.onOpenProcess )
|
|
|
|
fileMenu.addAction( "Exit", self.onExit )
|
|
|
|
self.menuBar().addMenu( fileMenu )
|
|
|
|
|
2011-08-18 00:13:04 +08:00
|
|
|
|
|
|
|
debugMenu = QMenu( "Debug" )
|
|
|
|
debugMenu.addAction( "Break", self.onBreak )
|
|
|
|
debugMenu.addAction( "Go", self.onGo )
|
|
|
|
debugMenu.addAction( "Step", self.onStep )
|
|
|
|
self.menuBar().addMenu( debugMenu )
|
|
|
|
|
|
|
|
|
|
|
|
viewMenu = QMenu( "View" )
|
|
|
|
viewMenu.addAction( "Disasm", self.onDisasmShow )
|
|
|
|
viewMenu.addAction( "Regsiters", self.onRegistersShow )
|
|
|
|
viewMenu.addAction( "Stack", self.onStackShow )
|
|
|
|
self.menuBar().addMenu( viewMenu )
|
|
|
|
|
|
|
|
self.disasmWidget = DisasmWidget()
|
|
|
|
self.disasmWidget.setVisible( False )
|
|
|
|
self.addDockWidget( Qt.LeftDockWidgetArea, self.disasmWidget )
|
|
|
|
self.updated.connect(self.disasmWidget.onUpdate )
|
|
|
|
|
|
|
|
self.registersWidget = RegistersWidget()
|
|
|
|
self.registersWidget.setVisible( False )
|
|
|
|
self.addDockWidget( Qt.LeftDockWidgetArea, self.registersWidget )
|
|
|
|
self.updated.connect(self.registersWidget.onUpdate )
|
|
|
|
|
|
|
|
self.stackWidget = StackWidget()
|
|
|
|
self.stackWidget.setVisible( False )
|
|
|
|
self.addDockWidget( Qt.LeftDockWidgetArea, self.stackWidget )
|
|
|
|
self.updated.connect(self.stackWidget.onUpdate )
|
|
|
|
|
2011-07-29 22:20:50 +08:00
|
|
|
self.resize( 800, 600 )
|
|
|
|
|
|
|
|
|
|
|
|
|
2011-08-18 00:13:04 +08:00
|
|
|
def stopGoThread( self ):
|
|
|
|
|
|
|
|
if self.goThread != None and self.goThread.isRunning():
|
|
|
|
self.goThread.quit()
|
|
|
|
self.goThread.wait(10000)
|
|
|
|
|
|
|
|
|
|
|
|
def event( self, ev ):
|
|
|
|
|
|
|
|
if ev.type() == QEvent.User + 1:
|
|
|
|
self.onUpdate()
|
|
|
|
return True
|
|
|
|
else:
|
|
|
|
return QMainWindow.event( self, ev )
|
|
|
|
|
2011-07-29 22:20:50 +08:00
|
|
|
|
|
|
|
|
|
|
|
def onOpenProcess( self ):
|
|
|
|
fileDlg = QFileDialog( self )
|
|
|
|
fileDlg.setNameFilter( self.tr("Executable (*.exe)" ) )
|
|
|
|
|
2011-08-18 00:13:04 +08:00
|
|
|
pykd.startProcess( fileDlg.getOpenFileName()[0] )
|
|
|
|
|
|
|
|
self.goThread = GoThread( pykd.go )
|
|
|
|
|
|
|
|
|
|
|
|
def onBreak( self ):
|
|
|
|
pykd.breakin()
|
|
|
|
|
|
|
|
def onGo( self ):
|
|
|
|
self.stopGoThread()
|
|
|
|
self.goThread = GoThread( pykd.go )
|
2011-07-29 22:20:50 +08:00
|
|
|
|
2011-08-18 00:13:04 +08:00
|
|
|
def onStep( self ):
|
|
|
|
self.stopGoThread()
|
|
|
|
self.goThread = GoThread( pykd.step )
|
2011-07-29 22:20:50 +08:00
|
|
|
|
|
|
|
def onExit( self ):
|
|
|
|
self.close()
|
|
|
|
|
2011-08-18 00:13:04 +08:00
|
|
|
def onDisasmShow( self ):
|
|
|
|
self.disasmWidget.setVisible( not self.disasmWidget.isVisible() )
|
|
|
|
|
|
|
|
def onRegistersShow( self ):
|
|
|
|
self.registersWidget.setVisible( not self.registersWidget.isVisible() )
|
|
|
|
|
|
|
|
|
|
|
|
def onStackShow( self ):
|
|
|
|
self.stackWidget.setVisible( not self.stackWidget.isVisible() )
|
|
|
|
|
|
|
|
def onUpdate( self ):
|
|
|
|
self.updated.emit()
|
|
|
|
|
2011-07-29 22:20:50 +08:00
|
|
|
|
|
|
|
def main():
|
|
|
|
|
2011-08-18 00:13:04 +08:00
|
|
|
global app
|
|
|
|
global mainForm
|
|
|
|
|
2011-07-29 22:20:50 +08:00
|
|
|
app = QApplication( [] )
|
|
|
|
mainForm = MainForm()
|
|
|
|
mainForm.show()
|
|
|
|
exitres = app.exec_()
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|