0 votos

No se puede abrir el puerto serie usando simplemente el script de python en macOS Catalina: [Errno 16] El recurso está ocupado

En un nuevo MacBook16 ejecución de Catalina (10.15.1) recibo el siguiente error al intentar conectarse a un FTDI FT232R USB UART dispositivo.

Python 2.7.17 (v2.7.17:c2f86d86e6, Oct 19 2019, 16:07:15) 
[GCC 4.2.1 Compatible Apple LLVM 6.0 (clang-600.0.57)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> import serial
>>> ser = serial.Serial('/dev/tty.usbserial-A106NU2I', 38400, timeout=1)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/Users/cbagwell/.virtualenvs/toolbelt/lib/python2.7/site-packages/serial/serialutil.py", line 240, in __init__
    self.open()
  File "/Users/cbagwell/.virtualenvs/toolbelt/lib/python2.7/site-packages/serial/serialposix.py", line 268, in open
    raise SerialException(msg.errno, "could not open port {}: {}".format(self._port, msg))
serial.serialutil.SerialException: [Errno 16] could not open port /dev/tty.usbserial-A106NU2I: [Errno 16] Resource busy: '/dev/tty.usbserial-A106NU2I'

Veo los eventos siguientes en virtud de la aplicación de Consola:

006002.877344 python@(null): AppleUSBHostUserClient::openGated: could not open provider USB3.0 Hub             . provider already opened for exclusive access by a kernel client
006002.878136 python@(null): AppleUSBHostUserClient::openGated: could not open provider USB2.0 Hub             . provider already opened for exclusive access by a kernel client

Así que parece que algunos kernel cliente ya tiene el directorio "/dev/tty.usbserial-A106NU2I" archivo abierto con acceso exclusivo.

Mi pregunta es, ¿cómo puedo determinar el kernel de cliente (o extensión del kernel?) tiene este archivo abierto?

He intentado usar "sudo lsof | grep tty" y no se ve nada allí.

El dispositivo es visible y reconocida en Acerca de este Mac -> Informe de Sistema -> USB

Gracias!

1voto

Spooks Puntos 2667

Yo tenía el mismo problema, puerto serie recurso ocupado y no podía ver que el proceso utilizado.

He encontrado este hilo aquí: https://forums.developer.apple.com/thread/124414

Se recomienda instalar la versión más reciente del controlador FTDI, 2.4.2, que se encuentran aquí: https://www.ftdichip.com/Drivers/VCP.htm

Que hizo el truco.

Saludos

AppleAyuda.com

AppleAyuda es una comunidad de usuarios de los productos de Apple en la que puedes resolver tus problemas y dudas.
Puedes consultar las preguntas de otros usuarios, hacer tus propias preguntas o resolver las de los demás.

Powered by:

X