aboutsummaryrefslogtreecommitdiffstats
path: root/support
diff options
context:
space:
mode:
Diffstat (limited to 'support')
-rwxr-xr-xsupport/scripts/reset.py60
1 files changed, 39 insertions, 21 deletions
diff --git a/support/scripts/reset.py b/support/scripts/reset.py
index 7cafefc..9be5607 100755
--- a/support/scripts/reset.py
+++ b/support/scripts/reset.py
@@ -1,25 +1,25 @@
#!/usr/bin/python
-# NOTE: On Mac OSX this script must be run as sudo?
-
import serial
import os
import sys
from struct import pack
-def get_maple_device_path_osx():
- """Try to find the device file for the Maple on OS X. If there
- are multiple possibilities, ask the user what to do. If the user
- chooses not to say, returns None."""
- possible_maple_paths = [x for x in os.listdir('/dev') if \
- 'tty.usbmodem' in x]
- if len(possible_maple_paths) == 1:
- return possible_maple_paths[0]
+def get_maple_device_path(file_prefix):
+ """Try to find the device file for the Maple on OS X; assuming
+ that it looks like /dev/<file_prefix>*. If there are multiple
+ possibilities, ask the user what to do. If the user chooses not
+ to say, returns None."""
+ possible_paths = [os.path.join('/dev', x) for x in os.listdir('/dev') \
+ if x.startswith(file_prefix)]
+ if len(possible_paths) == 0:
+ return None
+ elif len(possible_paths) == 1:
+ return possible_paths[0]
else:
- print 'Attempting to reset Maple, but found multiple ' + \
- 'candidates for the Maple device:'
- for (i,p) in enumerate(possible_maple_paths):
- print '\t%d. %s' % (i+1,os.path.join('/dev',p))
+ print 'Found multiple candidates for the Maple device:'
+ for (i,p) in enumerate(possible_paths):
+ print '\t%d. %s' % (i+1, p)
prompt = 'Enter a number to select one, or q to quit: '
while True:
@@ -31,20 +31,37 @@ def get_maple_device_path_osx():
except ValueError:
pass
else:
- if 0 <= i-1 < len(possible_maple_paths):
- return os.path.join('/dev',possible_maple_paths[i-1])
+ if 0 <= i-1 < len(possible_paths):
+ return possible_paths[i-1]
+
prompt = 'Please enter a number from the list, or q to quit: '
os_sysname = os.uname()[0]
if os_sysname == 'Linux':
- maple_path = '/dev/maple'
+ maple_path = get_maple_device_path('ttyACM')
+ # fall back on /dev/maple if that doesn't work
+ if maple_path is None:
+ maple_path = '/dev/maple'
+ print 'Could not find Maple serial port; defaulting to /dev/maple.'
elif os_sysname == 'Darwin':
- maple_path = get_maple_device_path_osx()
- if maple_path is None: sys.exit()
+ maple_path = get_maple_device_path('tty.usbmodem')
else:
- # TODO [mbolivar] special cases for windows, BSD, whatever?
+ # TODO [mbolivar] what to do for windows, BSD, whatever?
maple_path = '/dev/maple'
+if maple_path is None:
+ print 'Could not find the Maple serial port for reset.', \
+ 'Perhaps this is your first upload, or the board is already', \
+ 'in bootloader mode.'
+ print
+ print "If your sketch doesn't upload, try putting your Maple", \
+ 'into bootloader mode manually by pressing the RESET button', \
+ 'then letting it go and quickly pressing button BUT', \
+ '(hold for several seconds).'
+ sys.exit()
+
+print 'Using %s as Maple serial port' % maple_path
+
try:
ser = serial.Serial(maple_path, baudrate=115200, xonxoff=1)
ser.open()
@@ -65,5 +82,6 @@ try:
ser.close()
except:
- print "Failed to open the serial port for reset, perhaps this is your first upload or the board was already in bootloader mode"
+ print 'Failed to open serial port %s for reset.' % maple_path
+ sys.exit()