Browse Source

Merge branch 'usb-2.4-support' into dev

pyserial_fix
Scott Petersen 10 years ago
parent
commit
d35bcb8303
1 changed files with 34 additions and 10 deletions
  1. +34
    -10
      alarmdecoder/devices.py

+ 34
- 10
alarmdecoder/devices.py View File

@@ -170,10 +170,20 @@ class USBDevice(Device):
""" """


# Constants # Constants
FTDI_VENDOR_ID = 0x0403
"""Vendor ID used to recognize `AD2USB`_ devices."""
FTDI_PRODUCT_ID = 0x6001
"""Product ID used to recognize `AD2USB`_ devices."""
PRODUCT_IDS = ((0x0403, 0x6001), (0x0403, 0x6015))
"""List of Vendor and Product IDs used to recognize `AD2USB`_ devices."""
DEFAULT_VENDOR_ID = PRODUCT_IDS[0][0]
"""Default Vendor ID used to recognize `AD2USB`_ devices."""
DEFAULT_PRODUCT_ID = PRODUCT_IDS[0][1]
"""Default Product ID used to recognize `AD2USB`_ devices."""

# Deprecated constants
FTDI_VENDOR_ID = DEFAULT_VENDOR_ID
"""DEPRECATED: Vendor ID used to recognize `AD2USB`_ devices."""
FTDI_PRODUCT_ID = DEFAULT_PRODUCT_ID
"""DEPRECATED: Product ID used to recognize `AD2USB`_ devices."""


BAUDRATE = 115200 BAUDRATE = 115200
"""Default baudrate for `AD2USB`_ devices.""" """Default baudrate for `AD2USB`_ devices."""


@@ -181,7 +191,7 @@ class USBDevice(Device):
__detect_thread = None __detect_thread = None


@classmethod @classmethod
def find_all(cls, vid=FTDI_VENDOR_ID, pid=FTDI_PRODUCT_ID):
def find_all(cls, vid=None, pid=None):
""" """
Returns all FTDI devices matching our vendor and product IDs. Returns all FTDI devices matching our vendor and product IDs.


@@ -190,8 +200,12 @@ class USBDevice(Device):
""" """
cls.__devices = [] cls.__devices = []


query = cls.PRODUCT_IDS
if vid and pid:
query = [(vid, pid)]

try: try:
cls.__devices = Ftdi.find_all([(vid, pid)], nocache=True)
cls.__devices = Ftdi.find_all(query, nocache=True)


except (usb.core.USBError, FtdiError), err: except (usb.core.USBError, FtdiError), err:
raise CommError('Error enumerating AD2USB devices: {0}'.format(str(err)), err) raise CommError('Error enumerating AD2USB devices: {0}'.format(str(err)), err)
@@ -230,7 +244,7 @@ class USBDevice(Device):


vendor, product, sernum, ifcount, description = device vendor, product, sernum, ifcount, description = device


return USBDevice(interface=sernum)
return USBDevice(interface=sernum, vid=vendor, pid=product)


@classmethod @classmethod
def start_detection(cls, on_attached=None, on_detached=None): def start_detection(cls, on_attached=None, on_detached=None):
@@ -325,7 +339,7 @@ class USBDevice(Device):
""" """
self._description = value self._description = value


def __init__(self, interface=0):
def __init__(self, interface=0, vid=None, pid=None):
""" """
Constructor Constructor


@@ -340,8 +354,15 @@ class USBDevice(Device):
self._interface = 0 self._interface = 0
self._device_number = 0 self._device_number = 0
self._serial_number = None self._serial_number = None
self._vendor_id = USBDevice.FTDI_VENDOR_ID
self._product_id = USBDevice.FTDI_PRODUCT_ID

self._vendor_id = USBDevice.DEFAULT_VENDOR_ID
if vid:
self._vendor_id = vid

self._product_id = USBDevice.DEFAULT_PRODUCT_ID
if pid:
self._product_id = pid

self._endpoint = 0 self._endpoint = 0
self._description = None self._description = None


@@ -384,6 +405,9 @@ class USBDevice(Device):
except (usb.core.USBError, FtdiError), err: except (usb.core.USBError, FtdiError), err:
raise NoDeviceError('Error opening device: {0}'.format(str(err)), err) raise NoDeviceError('Error opening device: {0}'.format(str(err)), err)


except KeyError, err:
raise NoDeviceError('Unsupported device. ({0:04x}:{1:04x}) You probably need a newer version of pyftdi.'.format(err[0][0], err[0][1]))

else: else:
self._running = True self._running = True
self.on_open() self.on_open()


Loading…
Cancel
Save