O sistema não detecta a porta do monitor hot-plugged (através do conector de raio)

9

Meu monitor externo (conectado ao meu laptop através de um raio) funciona bem se conectado antes da inicialização. No entanto, uma vez desconectado ou desconectado, o xrandr não detectará mais o monitor reconectado.

Estou executando Arch Linux, usando bumblebeepara manipulação de placas gráficas. A placa externa é conectada através do conector do raio. Alguém poderia me dizer o que há de errado com a máquina e como posso fazer o hotplug? Obrigado.


[Detalhe da depuração]

Após vários threads no bumblebeee udevadm, fiz vários testes e fiz um script de hotplug. No entanto, o problema ainda não está resolvido. O resultado é publicado como abaixo.

Para o zangão, não modifiquei muito, pois o segundo monitor é bem detectado quando não está conectado à tomada.

Para problemas relacionados ao hot plug. Eu fiz o seguinte:

Quando o monitor está funcionando normalmente, xrandr --queryretorna

Screen 0: minimum 8 x 8, current 2944 x 1080, maximum 32767 x 32767
eDP1 connected primary 1920x1080+0+0 (normal left inverted right x axis y axis) 382mm x 215mm
   1920x1080     60.02*+

...

DP1 connected 1024x768+1920+0 (normal left inverted right x axis y axis) 0mm x 0mm
   1024x768      60.00* 

...

Ao desconectar o monitor do DP2 com udevadm monitor --environment --udevaberto, as informações coletadas são:

UDEV  [979.022342] change   /devices/pci0000:00/0000:00:02.0/drm/card0 (drm)
ACTION=change
DEVNAME=/dev/dri/card0
DEVPATH=/devices/pci0000:00/0000:00:02.0/drm/card0
DEVTYPE=drm_minor
HOTPLUG=1
ID_FOR_SEAT=drm-pci-0000_00_02_0
ID_PATH=pci-0000:00:02.0
ID_PATH_TAG=pci-0000_00_02_0
MAJOR=226
MINOR=0
SEQNUM=2650
SUBSYSTEM=drm
TAGS=:master-of-seat:uaccess:seat:
USEC_INITIALIZED=3775241

E ao conectar o monitor:

UDEV  [1111.426386] change   /devices/pci0000:00/0000:00:02.0/drm/card0 (drm)
ACTION=change
DEVNAME=/dev/dri/card0
DEVPATH=/devices/pci0000:00/0000:00:02.0/drm/card0
DEVTYPE=drm_minor
HOTPLUG=1
ID_FOR_SEAT=drm-pci-0000_00_02_0
ID_PATH=pci-0000:00:02.0
ID_PATH_TAG=pci-0000_00_02_0
MAJOR=226
MINOR=0
SEQNUM=2651
SUBSYSTEM=drm
TAGS=:seat:uaccess:master-of-seat:
USEC_INITIALIZED=3775241

UDEV  [1111.522857] change   /devices/pci0000:00/0000:00:02.0/drm/card0 (drm)
ACTION=change
DEVNAME=/dev/dri/card0
DEVPATH=/devices/pci0000:00/0000:00:02.0/drm/card0
DEVTYPE=drm_minor
HOTPLUG=1
ID_FOR_SEAT=drm-pci-0000_00_02_0
ID_PATH=pci-0000:00:02.0
ID_PATH_TAG=pci-0000_00_02_0
MAJOR=226
MINOR=0
SEQNUM=2652
SUBSYSTEM=drm
TAGS=:seat:uaccess:master-of-seat:
USEC_INITIALIZED=3775241

Parece que udevé capaz de detectar o hardware quando o monitor está conectado, por isso configurei uma regra do udev para ajudar a xrandrusar o novo monitor. Meu script para /etc/udev/rules.d/95-monitor-hotplug.rulesé o seguinte:

ACTION=="change", SUBSYSTEM=="drm", RUN+="/usr/local/bin/hotplug_monitor.sh"

E /usr/local/bin/hotplug_monitor.shé

#!/bin/sh
export XAUTHORITY=/home/chong/.Xauthority

function connectDP1(){
    DISPLAY=:0 xrandr --output DP1 --auto --right-of eDP1
}

function disconnectDP1(){
    DISPLAY=:0 xrandr --output DP1 --off
}

function connectDP2(){
    DISPLAY=:0 xrandr --output DP2 --auto --right-of eDP1
}

function disconnectDP2(){
    DISPLAY=:0 xrandr --output DP2 --off
}

xrandr | grep "DP1 connected" &> /dev/null && connectDP1 || disconnectDP1
xrandr | grep "DP2 connected" &> /dev/null && connectDP2 || disconnectDP2

O script é executado e encerrado normalmente, mas depois xrandr --queryainda é exibido DP1e DP2desconectado.

Chong
fonte
Estou enfrentando exatamente o mesmo comportamento. Também no Arch. Eu tentei sem o zangão, bem como com os drivers proprietários da nvidia sem sorte. Você tentou com o nouveau?
19415 Johnride
@Johnride Minha placa gráfica é a Maxwell Architecture. Nouveau ainda não fez isso funcionar. Atualmente, estou usando a porta HDMI e o driver NVIDIA direto. Parece que eles estão funcionando bem.
Chong
este vai ser fixada em uma das seguintes sementes de bugzilla.kernel.org/show_bug.cgi?id=115121
Alguém encontrou uma solução? Eu tenho um kernel mais novo que o mencionado acima e ainda tenho o mesmo problema que o Chong. Recebo a porta de rede, a webcam e o usb detectados e funcionando, mas não a tela.
dvdgc13
#! / bin / bash (não sh), caso contrário, a instrução de função está com erro
nd34567s32e 7/07

Respostas:

1

Encontrei seu código e persisti na tentativa de fazê-lo funcionar. Sob condições, eu poderia fazê-lo funcionar com um paradigma "se então". o "xrandr | grep" SEMPRE falhou em ser executado quando acionado como gatilho do udev, mas funcionou se eu o executasse manualmente. Fui forçado a dividi-lo em dois scripts.

Embora meu dispositivo seja diferente (StarTech CDPVGDVHDMDP), postarei minha versão aqui.

Primeiro, achei útil recarregar as regras do udev ao solucionar problemas:

sudo udevadm control --reload-rules

Meu dispositivo era um pouco diferente e descobri que o subsistema "hidraw" era algo que eu poderia ativar. Além disso, fui forçado a executar / bin / bash / path / to / script "; caso contrário, não foi executado. Esta é minha regra do udev (/etc/udev/rules.d/95-monitor-hotplug.rules):

ACTION=="remove", SUBSYSTEM=="hidraw", RUN+="/bin/bash /home/user/scripts/hotunplug-displayport.sh"
ACTION=="add", SUBSYSTEM=="hidraw", RUN+="/bin/bash /home/user/scripts/hotplug-displayport.sh"

Este é o meu script hotplug

#!/bin/bash
export XAUTHORITY=/home/user/.Xauthority
DISPLAY=:0 /usr/bin/xrandr --addmode DP-1 1680x1050
DISPLAY=:0 /usr/bin/xrandr --output DP-1 --right-of  eDP-1 --mode 1680x1050
echo "$(date) : Hotplug Connect DP-1" >> /var/log/hotplug.txt
DISPLAY=:0 /usr/bin/xrandr --addmode DP-2 1680x1050
DISPLAY=:0 /usr/bin/xrandr --output DP-2 --right-of  eDP-1 --mode 1680x1050
echo "$(date) : Hotplug Connect DP-2" >> /var/log/hotplug.txt

Este é o meu script hot-unplug

#!/bin/bash
export XAUTHORITY=/home/user/.Xauthority
DISPLAY=:0 /usr/bin/xrandr --output DP-1 --off
echo "$(date) : Hotplug Disconnect DP-1" >> /var/log/hotplug.txt
DISPLAY=:0 /usr/bin/xrandr --output DP-2 --off
echo "$(date) : Hotplug Disconnect DP-2" >> /var/log/hotplug.txt
nd34567s32e
fonte
Desde que postei isso, desativei o script hotUNplug, pois não é necessário e, na verdade, ocultei problemas ao conectar outros dispositivos USB.
nd34567s32e