Configurar la redirección USB

Los dispositivos USB se comparten entre Citrix Receiver y el escritorio de Linux VDA. Cuando un dispositivo USB se redirige al escritorio, el usuario puede usar ese dispositivo como si estuviera conectado localmente.  

La redirección USB incluye tres áreas principales de funcionalidad:

  • Implementación de proyectos de código abierto (VHCI)
  • Servicio VHCI
  • Servicio USB

VHCI de código abierto:

Esta parte de la redirección USB desarrolla un sistema general para compartir dispositivos USB a través de una red IP. Se compone de un controlador de kernel Linux y algunas bibliotecas de modo usuario, que le permiten comunicarse con el controlador del kernel para obtener todos los datos de USB. En la implementación de Linux VDA, Citrix reutiliza el controlador del kernel de VHCI. Todas las transferencias de datos USB que se realizan entre el Linux VDA y Citrix Receiver se encapsulan en el paquete del protocolo ICA de Citrix.

Servicio VHCI:

El servicio VHCI es un servicio de código abierto que proporciona Citrix para comunicarse con el módulo de kernel VHCI. Este servicio funciona como una puerta de enlace entre VHCI y el servicio USB de Citrix.

Servicio USB:

El servicio USB de Citrix representa un módulo que administra la virtualización y las transferencias de datos en el dispositivo USB.

Cómo funciona la redirección USB

Por lo general, si un dispositivo USB se redirige correctamente a Linux VDA, se crean uno o varios nodos de dispositivos en la ruta /dev del sistema. Sin embargo, hay veces en que una sesión activa de Linux VDA no puede usar el dispositivo redirigido. Los dispositivos USB necesitan los controladores pertinentes para poder funcionar correctamente; algunos dispositivos requieren incluso controladores especiales. Por eso, si no se proporcionan los controladores adecuados, los dispositivos USB redirigidos resultan inaccesibles para una sesión activa de Linux VDA. Para garantizar la conectividad del dispositivo USB, instale los controladores y configure el sistema correctamente.

Linux VDA admite una lista de dispositivos USB que se redirigen correctamente a y desde el cliente. Además, el dispositivo se monta correctamente (sobre todo el disco USB), lo que permite a los usuarios acceder al disco sin ninguna configuración adicional.

Configurar la redirección USB

Una directiva de Citrix controla si la redirección de dispositivos USB está habilitada o inhabilitada. Además, el tipo de dispositivo también se puede especificar con una directiva de Delivery Controller. Cuando configure la redirección USB para Linux VDA, defina la directiva y las reglas siguientes:

  • Directiva de Redirección de dispositivos USB del cliente
  • Reglas de redirección de dispositivos USB del cliente

Habilitar la directiva de redirección USB

En Citrix Studio, habilite (o inhabilite) la redirección de dispositivos USB desde y hacia el cliente (solo para hosts de estación de trabajo).

En el diálogo Modificar configuración:

  1. Seleccione la opción Permitido.
  2. Haga clic en Aceptar.

Configurar reglas de redirección USB

Después de habilitar la directiva de redirección USB, configure las reglas de redirección mediante Citrix Studio. Para ello, deberá especificar los dispositivos permitidos (o denegados) en el Linux VDA.

En el diálogo de reglas de redirección de dispositivos USB del cliente:

  1. Haga clic en Nueva para agregar una regla de redirección, o bien haga clic en Modificar para revisar una regla existente.
  2. Después de crear o modificar una regla, haga clic en Aceptar.

Para obtener más información sobre la configuración de la redirección de USB genérico, consulte Citrix Generic USB Redirection Configuration Guide.

Solucionar problemas de redirección USB

Use la información de esta sección para solucionar problemas que puedan surgir al usar Linux VDA.

No hay dispositivos en la barra de herramientas de Receiver

En algunos casos, puede que no aparezcan dispositivos en la barra de herramientas de Citrix Receiver, lo que indica que no se está realizando la redirección USB. Si tiene este problema, compruebe lo siguiente:

  • La directiva está configurada para permitir la redirección USB
  • El módulo Kernel es compatible con su kernel

Los dispositivos USB se ven en la barra de herramientas de Receiver, pero tienen la etiqueta de restringidos por directiva, lo que provoca un error de redirección

Este problema ocurre por la configuración de directiva del dispositivo. En tales casos:

  • Configure la directiva de Linux VDA para habilitar la redirección
  • Compruebe si se han configurado restricciones de directiva adicionales en el Registro de Receiver. Puede que sea un parámetro del Registro de Receiver el que bloquee el dispositivo. Consulte DeviceRules en la ruta de Registro para comprobar que no se haya denegado el acceso del dispositivo mediante este parámetro:

    HKEY_LOCAL_MACHINE\SOFTWARE\Citrix\ICA Client\GenericUSB

Para obtener más información, consulte How to Configure Automatic Redirection of USB Devices en el sitio de asistencia técnica de Citrix.

El dispositivo USB se redirige correctamente, pero no lo puedo usar en mi sesión

Por lo general, solo se pueden redirigir los dispositivos USB admitidos. Sin embargo, en algunos casos, otros tipos de dispositivo pueden redirigirse a una sesión activa de Linux VDA. En esos casos, por cada dispositivo redirigido, se crea en la ruta /dev del sistema un nodo cuyo propietario es el usuario. Sin embargo, son los controladores y la configuración los que determinan si el usuario puede usar el dispositivo. Si hay un dispositivo conectado pero inaccesible, agréguelo a una directiva sin restricciones.

Nota:

En el caso de unidades USB, Linux VDA configura y monta el disco. El usuario (y solo el propietario que lo instaló) puede acceder al disco sin ninguna configuración adicional. Puede que no sea el caso para dispositivos que no consten en la lista de los dispositivos admitidos.

Compilación del módulo de kernel VHCI

La redirección USB depende de los módulos de kernel VHCI (usb-vhci-hcd.ko y usb-vhci-iocif.ko). Esos módulos forman parte de la distribución de Linux VDA (como parte del paquete RPM). Se compilan en función de los kernels de la distribución oficial de Linux y se indican en la siguiente tabla:

Distribución respaldada de Linux Versión de kernel
RHEL 6.9 2.6.32-696.10.3.el6.x86_64
RHEL 7.4 3.10.0-693.el7.x86_64
SUSE 12.3 4.4.73-5-default
Ubuntu 16.04 4.4.0-45-generic

Importante:

Si el kernel de la máquina no es compatible con el controlador creado por Citrix para Linux VDA, es posible que el servicio USB no se inicie. En este caso, puede utilizar la funcionalidad Redirección USB solamente si compila sus propios módulos de kernel VHCI.

Compruebe si el kernel es coherente con los módulos generados por Citrix

En la línea de comandos, ejecute el siguiente comando para comprobar si el kernel es coherente:

insmod /opt/Citrix/VDA/lib64/usb-vhci-hcd.ko

Si el comando se ejecuta correctamente, el módulo del kernel se ha cargado correctamente y la versión es coherente con la instalada por Citrix.

Si el comando se ejecuta con errores, significa que el kernel no es coherente con el módulo de Citrix y se debe volver a generar.

Recompilación del módulo de kernel VHCI

Si el módulo de kernel no corresponde a la versión de Citrix, lleve a cabo lo siguiente:

  1. Descargue el código fuente de LVDA desde el sitio de descargas de Citrix. Seleccione el archivo incluido en la sección “Linux Virtual Delivery Agent (orígenes)”.

  2. Restaure los archivos desde el archivo citrix-linux-vda-sources.zip; puede obtener los archivos de origen VHCI en linux-vda-sources/vhci-hcd-1.15.tar.bz2; puede restaurar los archivos VHCI mediante tar xvfvhci-hcd-1.15.tar.bz2.

  3. Compile el módulo de kernel en función de los archivos de encabezado y del archivo Module.symvers. Siga estos pasos para instalar los archivos de encabezado del kernel y crear Module.symvers en función de la distribución pertinente de Linux:

    RHEL/CentOS:

    yum install kernel-devel
    

    SUSE 12:

    zypper install kernel-devel
    zypper install kernel-source
    

    Ubuntu 16.04:

    apt-get install linux-headers
    

    Sugerencia:

    Si la instalación se realiza correctamente, se creará una carpeta de kernel como:

    /usr/src/kernels/3.10.0-327.10.1.el7.x86_64

  4. En la carpeta /usr/src/kernels/3.10.0-327.10.1.el7.x86_64, verifique que el archivo Module.symvers está presente. Si este archivo no está en la carpeta, compile el kernel para obtenerlo (por ejemplo, make oldconfig; make prepare; make modules; make) o cópielo desde /usr/src/kernels/3.10.0-327.10.1.el7.x86_64-obj/x86_64/defaults/module.*

  5. En el archivo vhci-hcd-1.15/Makefile, cambie el Makefile de VCHI y defina KDIR con el directorio de kernel:

    #KDIR = $(BUILD_PREFIX)/lib/modules/$(KVERSION)/build
    KDIR = /usr/src/kernels/3.10.0-327.10.1.el7.x86_64
    
  6. En la carpeta vhci-hcd-1.15/, ejecute make para crear el kernel de VHCI.

    Nota:

    Si la compilación es correcta, usb-vhci-hcd.ko y usb-vhci-iocifc.ko se crean en la carpeta vhci-hcd-1.15/.

  7. Reemplace el módulo de kernel con el recién compilado: cp -f usb-vhci-*.ko /opt/Citrix/VDA/lib64/

  8. Reinicie el servicio USB: service ctxusbsd restart.

  9. Cierre la sesión y vuelva a iniciarla. Compruebe si la redirección USB está funcionando.

Dispositivos USB respaldados

Se ha comprobado que los dispositivos siguientes admiten esta versión de VDA para Linux. Los demás dispositivos se pueden usar libremente, pero con resultados inesperados:

Dispositivos de almacenamiento USB VID:PID Sistema de archivos
Netac Technology Co., Ltd 0dd8:173c FAT32
Kingston Datatraveler 101 II 0951:1625 FAT32
Kingston Datatraveler GT101 G2 1567:8902 FAT32
Unidad flash SanDisk SDCZ80 0781:5580 FAT32
SanDisk Cruzer 16 GB 1058:10B8 FAT32
WD HDD 0781:5567 FAT32
Mouse 3D por USB VID:PID
3DConnexion SpaceMouse Pro 046d: c62b
Escáner USB VID:PID
Epson Perfection V330 Photo 04B8: 0142

Problemas conocidos

  • No se puede desmontar el disco USB redirigido. Para controlar el acceso a todos los discos USB redirigidos desde Citrix Receiver, Linux VDA administra todos esos dispositivos con privilegios administrativos para que solo el propietario pueda acceder al dispositivo redirigido. Por eso, el usuario no puede desmontar el dispositivo sin privilegios administrativos.

    Imagen localizada

  • Se pierde el archivo cuando se detiene la redirección del disco USB. Si redirige un disco USB a una sesión y lo modifica (por ejemplo, crea archivos en él) y, justo después, detiene la redirección en la barra de herramientas de Receiver, el archivo modificado (o creado) se puede perder. Este problema se produce porque, cuando escribe datos en un sistema de archivos, el sistema monta la memoria caché en el sistema de esos archivos. Los datos no se escriben en el disco en sí. Si deja de redirigir el dispositivo desde la barra de herramientas de Receiver, no hay tiempo para que los datos se vuelquen en el disco, por lo que se pierden. Para resolver este problema, use el comando de sincronización en un terminal para vaciar datos en el disco antes de detener la redirección USB.

    Imagen localizada

  • Se puede producir un error de generación para kernels específicos de Ubuntu 16. El error aparece como implicit declaration of function ‘copy_to_user’, como se muestra a continuación:

    Imagen localizada

    El error ocurre debido a cambios en el archivo de encabezado en los kernels. Como solución temporal, agregue la línea #include <linux/uaccess.h> al archivo vhci-hcd-1.15/usb-vhci-iocifc.c.

    Imagen localizada