2012-06-26 10:05:06 +00:00
|
|
|
from __future__ import absolute_import
|
|
|
|
import __init__
|
|
|
|
|
|
|
|
import os, glob, wx, threading, sys, time
|
|
|
|
|
|
|
|
from serial import Serial
|
|
|
|
|
|
|
|
from avr_isp import stk500v2
|
|
|
|
from avr_isp import ispBase
|
|
|
|
from avr_isp import intelHex
|
|
|
|
|
|
|
|
from util import machineCom
|
|
|
|
from util import profile
|
|
|
|
|
2012-06-30 09:51:43 +00:00
|
|
|
def getDefaultFirmware():
|
|
|
|
if profile.getPreference('machine_type') == 'ultimaker':
|
|
|
|
if sys.platform.startswith('linux'):
|
|
|
|
return os.path.join(os.path.dirname(os.path.abspath(__file__)), "../firmware/ultimaker_115200.hex")
|
|
|
|
else:
|
|
|
|
return os.path.join(os.path.dirname(os.path.abspath(__file__)), "../firmware/ultimaker_250000.hex")
|
|
|
|
return None
|
|
|
|
|
2012-06-26 10:05:06 +00:00
|
|
|
class InstallFirmware(wx.Dialog):
|
2012-06-30 09:51:43 +00:00
|
|
|
def __init__(self, filename = None, port = None):
|
2012-06-26 10:05:06 +00:00
|
|
|
super(InstallFirmware, self).__init__(parent=None, title="Firmware install", size=(250, 100))
|
|
|
|
if port == None:
|
|
|
|
port = profile.getPreference('serial_port')
|
2012-06-30 09:51:43 +00:00
|
|
|
if filename == None:
|
|
|
|
filename = getDefaultFirmware()
|
|
|
|
if filename == None:
|
|
|
|
wx.MessageBox('Cura does not ship with a default firmware for your machine.', 'Firmware update', wx.OK | wx.ICON_ERROR)
|
|
|
|
self.Destroy()
|
|
|
|
return
|
2012-06-26 10:05:06 +00:00
|
|
|
|
|
|
|
sizer = wx.BoxSizer(wx.VERTICAL)
|
|
|
|
|
|
|
|
self.progressLabel = wx.StaticText(self, -1, 'Reading firmware...')
|
|
|
|
sizer.Add(self.progressLabel, 0, flag=wx.ALIGN_CENTER)
|
|
|
|
self.progressGauge = wx.Gauge(self, -1)
|
|
|
|
sizer.Add(self.progressGauge, 0, flag=wx.EXPAND)
|
|
|
|
self.okButton = wx.Button(self, -1, 'Ok')
|
|
|
|
self.okButton.Disable()
|
|
|
|
self.okButton.Bind(wx.EVT_BUTTON, self.OnOk)
|
|
|
|
sizer.Add(self.okButton, 0, flag=wx.ALIGN_CENTER)
|
|
|
|
self.SetSizer(sizer)
|
|
|
|
|
|
|
|
self.filename = filename
|
|
|
|
self.port = port
|
|
|
|
|
|
|
|
threading.Thread(target=self.OnRun).start()
|
|
|
|
|
|
|
|
self.ShowModal()
|
|
|
|
self.Destroy()
|
|
|
|
return
|
|
|
|
|
|
|
|
def OnRun(self):
|
|
|
|
hexFile = intelHex.readHex(self.filename)
|
|
|
|
wx.CallAfter(self.updateLabel, "Connecting to machine...")
|
|
|
|
programmer = stk500v2.Stk500v2()
|
|
|
|
programmer.progressCallback = self.OnProgress
|
|
|
|
if self.port == 'AUTO':
|
|
|
|
for self.port in machineCom.serialList():
|
|
|
|
try:
|
|
|
|
programmer.connect(self.port)
|
|
|
|
break
|
|
|
|
except ispBase.IspError:
|
|
|
|
pass
|
|
|
|
else:
|
|
|
|
try:
|
|
|
|
programmer.connect(self.port)
|
|
|
|
except ispBase.IspError:
|
|
|
|
pass
|
|
|
|
|
|
|
|
if programmer.isConnected():
|
|
|
|
wx.CallAfter(self.updateLabel, "Uploading firmware...")
|
|
|
|
try:
|
|
|
|
programmer.programChip(hexFile)
|
|
|
|
wx.CallAfter(self.updateLabel, "Done!")
|
|
|
|
except ispBase.IspError as e:
|
|
|
|
wx.CallAfter(self.updateLabel, "Failed to write firmware.\n" + str(e))
|
|
|
|
|
|
|
|
programmer.close()
|
|
|
|
wx.CallAfter(self.okButton.Enable)
|
|
|
|
return
|
|
|
|
wx.MessageBox('Failed to find machine for firmware upgrade\nIs your machine connected to the PC?', 'Firmware update', wx.OK | wx.ICON_ERROR)
|
|
|
|
wx.CallAfter(self.Close)
|
|
|
|
|
|
|
|
def updateLabel(self, text):
|
|
|
|
self.progressLabel.SetLabel(text)
|
|
|
|
self.Layout()
|
|
|
|
|
|
|
|
def OnProgress(self, value, max):
|
|
|
|
wx.CallAfter(self.progressGauge.SetRange, max)
|
|
|
|
wx.CallAfter(self.progressGauge.SetValue, value)
|
|
|
|
|
|
|
|
def OnOk(self, e):
|
|
|
|
self.Close()
|
|
|
|
|
|
|
|
def OnClose(self, e):
|
|
|
|
self.Destroy()
|
|
|
|
|