This repository has been archived by the owner on Dec 28, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* first implementation for fakelaser and fakepowermeter * fix fake powermeter * append skeleton for device thorlabs * Fix hunting lock because of timeout lack * integrate hunt for thorlabs PM100A * save tree config when loaded * work on powermeter interface * start working with lbx_488, it seems that ftdi usb does not work directly... need to investigate * thorlabs PM100A: append read interface * cobolt scan ok, usage nok * improve tty serial connector * communication ok with devices, need to implement drivers now * apend function to debug cobolt commands * Fake blc ok * start working on connector serial_low_usb * up * connector serila_low_usb ok for oxxius * start integrating oxxisu lbx488 * on/off laser * up oxxius support * oxxius almost ok, need to fix precision issues * oxxius lbx488 support ok * cobolt 05-01 almost ok * update power meter with acq freq * update decimals management * cobolt 05-01 ok * manage decimals limitation on powermeter * allow multiple hunt on oxxisu * set the powermeter to 5 decimals * after a set on atts for blc, poll read value before leaving
- Loading branch information
1 parent
746a48d
commit 7e1e73b
Showing
54 changed files
with
2,708 additions
and
88 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
|
||
|
||
# from .thorlabs_pm100.connector import ConnectorThorlabsPM100 | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,182 @@ | ||
import time | ||
import asyncio | ||
import logging | ||
import aioserial | ||
|
||
import usb | ||
|
||
|
||
from .serial_base import ConnectorSerialBase | ||
from panduza_platform.log.driver import driver_logger | ||
|
||
from .udev_tty import SerialPortFromUsbSetting | ||
|
||
class ConnectorSerialLowUsb(ConnectorSerialBase): | ||
""" | ||
""" | ||
|
||
# Hold instances mutex | ||
__MUTEX = asyncio.Lock() | ||
|
||
# Contains instances | ||
__INSTANCES = {} | ||
|
||
# Local logs | ||
log = driver_logger("ConnectorSerialLowUsb") | ||
|
||
########################################################################### | ||
########################################################################### | ||
|
||
@staticmethod | ||
async def Get(**kwargs): | ||
"""Singleton main getter | ||
:Keyword Arguments: | ||
* *usb_vendor* (``str``) -- | ||
ID_VENDOR_ID | ||
* *usb_model* (``str``) -- | ||
ID_MODEL_ID | ||
""" | ||
# Log | ||
ConnectorSerialLowUsb.log.debug(f"Get connector for {kwargs}") | ||
|
||
async with ConnectorSerialLowUsb.__MUTEX: | ||
|
||
# Log | ||
ConnectorSerialLowUsb.log.debug(f"Lock acquired !") | ||
|
||
if "usb_vendor" in kwargs: | ||
usb_vendor = kwargs["usb_vendor"] | ||
if "usb_model" in kwargs: | ||
usb_model = kwargs["usb_model"] | ||
|
||
usb_serial_short="" | ||
if "usb_serial_short" in kwargs: | ||
usb_serial_short = kwargs["usb_serial_short"] | ||
|
||
instance_name = str(f"{usb_vendor}_{usb_model}_{usb_serial_short}") | ||
print(instance_name) | ||
|
||
# Create the new connector | ||
if not (instance_name in ConnectorSerialLowUsb.__INSTANCES): | ||
ConnectorSerialLowUsb.__INSTANCES[instance_name] = None | ||
try: | ||
new_instance = ConnectorSerialLowUsb(**kwargs) | ||
# await new_instance.connect() | ||
|
||
ConnectorSerialLowUsb.__INSTANCES[instance_name] = new_instance | ||
ConnectorSerialLowUsb.log.info("connector created") | ||
except Exception as e: | ||
ConnectorSerialLowUsb.__INSTANCES.pop(instance_name) | ||
raise Exception('Error during initialization').with_traceback(e.__traceback__) | ||
else: | ||
ConnectorSerialLowUsb.log.info("connector already created, use existing instance") | ||
|
||
# Return the previously created | ||
return ConnectorSerialLowUsb.__INSTANCES[instance_name] | ||
|
||
########################################################################### | ||
########################################################################### | ||
|
||
def __init__(self, **kwargs): | ||
"""Constructor | ||
""" | ||
|
||
# Init local mutex | ||
self._mutex = asyncio.Lock() | ||
|
||
# Init command mutex | ||
self._cmd_mutex = asyncio.Lock() | ||
|
||
|
||
usb_vendor = kwargs.get("usb_vendor") | ||
usb_model = kwargs.get("usb_model") | ||
usb_serial_short = kwargs.get("usb_serial_short") | ||
|
||
# ConnectorSerialLowUsb.log.error("pooook") | ||
# print(usb_vendor, usb_model, usb_serial_short) | ||
|
||
dev = None | ||
devs = usb.core.find(idVendor=usb_vendor, idProduct=usb_model, find_all=True) | ||
for dev in devs: | ||
if dev.serial_number == usb_serial_short: | ||
dev = dev | ||
|
||
|
||
if dev is None: | ||
raise ValueError('Device not found') | ||
# print(dev) | ||
dev.reset() | ||
dev.set_configuration() | ||
|
||
cfg = dev.get_active_configuration() | ||
intf = cfg[(0,0)] | ||
# print(intf) | ||
|
||
# Take first output/input endpoint avaiable | ||
|
||
self.ep_out = usb.util.find_descriptor( | ||
intf, | ||
# match the first OUT endpoint | ||
custom_match = \ | ||
lambda e: \ | ||
usb.util.endpoint_direction(e.bEndpointAddress) == \ | ||
usb.util.ENDPOINT_OUT) | ||
|
||
self.ep_in = usb.util.find_descriptor( | ||
intf, | ||
# match the first OUT endpoint | ||
custom_match = \ | ||
lambda e: \ | ||
usb.util.endpoint_direction(e.bEndpointAddress) == \ | ||
usb.util.ENDPOINT_IN) | ||
|
||
|
||
|
||
# ============================================================================= | ||
# OVERRIDE FROM SERIAL_BASE | ||
|
||
# --- | ||
|
||
async def read(self, n_bytes = None): | ||
"""Read from UART using asynchronous mode | ||
""" | ||
async with self._mutex: | ||
data_array_b = self.ep_in.read(self.ep_in.wMaxPacketSize) | ||
bytes_object = data_array_b.tobytes() | ||
return bytes_object | ||
|
||
# --- | ||
|
||
async def write(self, message, time_lock_s=None): | ||
"""write to UART using asynchronous mode | ||
""" | ||
|
||
async with self._mutex: | ||
try: | ||
# write the data | ||
cmd = message.encode() | ||
packet_to_send = cmd + b'\x00' * (self.ep_out.wMaxPacketSize - len(cmd)) | ||
self.ep_out.write(packet_to_send) | ||
|
||
except Exception as e: | ||
raise Exception('Error during writing to uart').with_traceback(e.__traceback__) | ||
|
||
|
||
async def write_and_read(self, message, time_lock_s=None, n_bytes = None): | ||
"""Read from UART using asynchronous mode | ||
""" | ||
async with self._mutex: | ||
try: | ||
# write the data | ||
cmd = message.encode() | ||
packet_to_send = cmd + b'\x00' * (self.ep_out.wMaxPacketSize - len(cmd)) | ||
self.ep_out.write(packet_to_send) | ||
|
||
# Read | ||
data_array_b = self.ep_in.read(self.ep_in.wMaxPacketSize) | ||
bytes_object = data_array_b.tobytes() | ||
return bytes_object | ||
except Exception as e: | ||
raise Exception('Error during writing to uart').with_traceback(e.__traceback__) |
Oops, something went wrong.