1 from __future__ import absolute_import
4 import os, glob, wx, threading, sys, time
6 from serial import Serial
8 from avr_isp import stk500v2
9 from avr_isp import ispBase
10 from avr_isp import intelHex
12 from util import profile
23 key=_winreg.OpenKey(_winreg.HKEY_LOCAL_MACHINE,"HARDWARE\\DEVICEMAP\\SERIALCOMM")
26 baselist+=[_winreg.EnumValue(key,i)[1]]
30 return baselist+glob.glob('/dev/ttyUSB*') + glob.glob('/dev/ttyACM*') +glob.glob("/dev/tty.usb*")+glob.glob("/dev/cu.*")+glob.glob("/dev/rfcomm*")
32 class InstallFirmware(wx.Dialog):
33 def __init__(self, filename, port = None):
34 super(InstallFirmware, self).__init__(parent=None, title="Firmware install", size=(250, 100))
36 port = profile.getPreference('serial_port')
38 sizer = wx.BoxSizer(wx.VERTICAL)
40 self.progressLabel = wx.StaticText(self, -1, 'Reading firmware...')
41 sizer.Add(self.progressLabel, 0, flag=wx.ALIGN_CENTER)
42 self.progressGauge = wx.Gauge(self, -1)
43 sizer.Add(self.progressGauge, 0, flag=wx.EXPAND)
44 self.okButton = wx.Button(self, -1, 'Ok')
45 self.okButton.Disable()
46 self.okButton.Bind(wx.EVT_BUTTON, self.OnOk)
47 sizer.Add(self.okButton, 0, flag=wx.ALIGN_CENTER)
50 self.filename = filename
53 threading.Thread(target=self.OnRun).start()
61 hexFile = intelHex.readHex(self.filename)
62 wx.CallAfter(self.updateLabel, "Connecting to machine...")
63 programmer = stk500v2.Stk500v2()
64 programmer.progressCallback = self.OnProgress
65 if self.port == 'AUTO':
66 for self.port in serialList():
68 programmer.connect(self.port)
70 except ispBase.IspError:
74 programmer.connect(self.port)
75 except ispBase.IspError:
78 if programmer.isConnected():
79 wx.CallAfter(self.updateLabel, "Uploading firmware...")
81 programmer.programChip(hexFile)
82 wx.CallAfter(self.updateLabel, "Done!")
83 except ispBase.IspError as e:
84 wx.CallAfter(self.updateLabel, "Failed to write firmware.\n" + str(e))
87 wx.CallAfter(self.okButton.Enable)
89 wx.MessageBox('Failed to find machine for firmware upgrade\nIs your machine connected to the PC?', 'Firmware update', wx.OK | wx.ICON_ERROR)
90 wx.CallAfter(self.Close)
92 def updateLabel(self, text):
93 self.progressLabel.SetLabel(text)
96 def OnProgress(self, value, max):
97 wx.CallAfter(self.progressGauge.SetRange, max)
98 wx.CallAfter(self.progressGauge.SetValue, value)
103 def OnClose(self, e):
106 class VirtualPrinter():
108 self.readList = ['start\n']
110 self.targetTemp = 0.0
112 def write(self, data):
113 if self.readList == None:
115 print "Send: %s" % (data.rstrip())
118 self.targetTemp = float(data[data.find('S')+1:])
122 self.readList.append("ok T:%f/%f\n" % (self.temp, self.targetTemp))
124 self.readList.append("ok\n")
127 if self.readList == None:
130 self.temp = (self.temp + self.targetTemp) / 2
131 while len(self.readList) < 1:
136 if self.readList == None:
139 print "Recv: %s" % (self.readList[0].rstrip())
140 return self.readList.pop(0)
146 def __init__(self, port = None, baudrate = None):
148 port = profile.getPreference('serial_port')
150 baudrate = int(profile.getPreference('serial_baud'))
153 programmer = stk500v2.Stk500v2()
154 for port in serialList():
156 print "Connecting to: %s %i" % (port, baudrate)
157 programmer.connect(port)
159 self.serial = Serial(port, baudrate, timeout=2)
161 except ispBase.IspError:
162 print "Error while connecting to %s %i" % (port, baudrate)
165 print "Unexpected error while connecting to serial port:" + port, sys.exc_info()[0]
167 elif port == 'VIRTUAL':
168 self.serial = VirtualPrinter()
171 self.serial = Serial(port, baudrate, timeout=2)
173 print "Unexpected error while connecting to serial port:" + port, sys.exc_info()[0]
177 if self.serial == None:
179 ret = self.serial.readline()
181 # print "Recv: " + ret.rstrip()
185 if self.serial != None:
193 return self.serial != None
195 def sendCommand(self, cmd):
196 if self.serial == None:
198 #print 'Send: ' + cmd
199 self.serial.write(cmd + '\n')