Чому трапляються помилки xrandr "BadMatch", "BadName", "Gamma Failed"?


13

Я не знайшов жодного рішення таких помилок, незважаючи на досить велику кількість користувачів, які їх мають.

Тому я хочу спробувати знайти рішення самостійно. Однак я не маю поняття, чому вони виникають ...

Хтось знає чому? Ви не можете сказати, чому виникає кожна помилка, просто одна була б чудовою!

Приклади:

Помилка BadMatch:

X Error of failed request:  BadMatch (invalid parameter attributes)
  Major opcode of failed request:  150 (RANDR)
  Minor opcode of failed request:  18 (RRAddOutputMode)
  Serial number of failed request:  18
  Current serial number in output stream:  19

Помилка BadName:

Error of failed request: BadName (named color or font does not exist)
Major opcode of failed request: 140 (RANDR)
Minor opcode of failed request: 11 (RRQueryOutputProperty)
Serial number of failed request: 39
Current serial number in output stream: 39

Помилка помилки Gamma:

xrandr: Failed to get size of gamma for output default
Screen 0: minimum 1920 x 1080, current 1920 x 1080, maximum 1920 x 1080
default connected primary 1920x1080+0+0 0mm x 0mm
   1920x1080       0.0*

Яку команду ви запускаєте для створення кожної з них?
user.dz

1
cvt resolution- то звичайне --newmode, --addmodeі --outputкоманди
TellMeWhy

Відповіді:


12

Мінімальна інформація

Ви збираєтесь задати питання, а потім додасте посилання, створене цією командою

sudo apt-get install pastebinit; sudo sh -c "lsb_release -sd; dmidecode -s system-product-name; echo ==; lshw -c display; echo ==; xrandr --verbose; echo ==; cat /etx/X11/xorg.conf" | tee ~/Desktop/ubuntu-graphic-info.txt | pastebinit


Вирішення проблем

Маленька розмова

Набагато складніше, ніж я думав, коли я намагався грати з моїм графічним процесором Intel деякий час, використовуючи xrandr. Іноді я отримую несподівані помилки. Це літній для мого досвіду.

Ось спрощений повний список стеків, наскільки я це розумію.

xrandr
  └─ Xorg (w/ driver specific module)
      └─ kernel
          └─ driver
               │ 
             graphic card
               └─ cables (kvm switch/connection adapter)
                    └─ monitor

Це дійсно великий стек для усунення неполадок, складніше зі старим обладнанням та прокатними оновленнями драйверів, навіть поганий контакт штифтом у кабелі VGA DB-15 (або дешевий кабель) може змінити значення. Насправді, більшість питань, які я читаю тут у Ask Ubuntu, стосуються просто відсутніх / неправильних даних EDID з монітора, звинувачуючи: кабелі (kvm перемикач / адаптер підключення). Це можна помітити швидко з xrandr --verboseвиводу.

У багатьох випадках драйвери обмежують деякі режими через неповні / частково неправильні EDID-дані з монітора (помилка виробника), користувач долає це, написавши користувальницький xorg.confрежим переозначення: Mode, HSync & VSync, EDID, DPI ... залежно від драйвера ( nvidiaдля приклад: Чи можна проігнорувати ID з монітора)

Я рекомендую це прочитати для досвідчених користувачів або тих, хто надає тут допомогу:

Зверніть увагу:

Будьте уважні, читаючи старі документації та пости, що пропонують рішення. Краще шукати документацію для конкретного приводу, який використовується.

  • Перевірте дату публікації, останню дату редагування або версію програмного забезпечення.
  • modeset, DRIАбо fb(фреймбуфер) Тип драйвера. (тільки майте на увазі, я не експерт).
  • Xorg багато зробив для автоматичного налаштування, тому xorg.confвін не створений за замовчуванням. Навіть якщо користувач зробив його, він не повинен створювати всі розділи, а лише переосмислює необхідне. Це своєрідна конфігурація на льоту.

Моє фіктивне розуміння цих помилок xrandr / X

Син ( xrandr), здається, не знає, на що здатний його тато або погодиться його придбати (всі можливості водія), тому він просто йде до своєї мами (Xorg) і просить її запитати у тата речі, які він хоче. Тож трапиться будь-який із наступних сценаріїв:

  • високе співвідношення: Син → (:) прийміть) Мама → (:) прийміть) тато, всі раді!
  • низьке співвідношення: Син → (: | прийняти) Мама → (відхилити XD) тато, життя важке іноді!
  • рідкісний випадок: Син → (X / відхилити) Мама -x- (: | нейтральний) тато, час на план Б!

Таким чином, ми отримуємо помилку, коли Xorg або драйвер не в змозі обробити або відмовити запит xrandr через:

  • Поточні налаштування Xorg
  • Можливості водія
  • Можливості графічного адаптера
  • Моніторинг можливостей отримав від EDID
  • Помилка в одному з них, в тому числі xrandr

Збір інформації про налагодження для загальної графіки!

Чому? Я подивився на багато питань тут , пов'язаних з xrandr& дозволу , вони пропускають багато інформації про повну настройки стека. Розглянутий набір згадував лише останню невдалу команду. Навіть я б запропонував поставити повний результат у питанні, щоб ми могли знайти подібність та зв’язати пов'язані з цим проблеми.

Якщо даних про EDID не знайдено, почніть з:

  • Як фізично пов'язаний монітор, тобто використовується KVM? Будь-який адаптер підключення, напр. HDMI для VGA?
  • Ви пробували інший кабель?
  • Що таке марка / модель монітора?

Ось список корисних команд

  1. Довідкова інформація

    sudo dmidecode -s system-product-name
    lsb_release -sd
    Xorg -version
    xrandr -v
    sudo lshw -c display
    
  2. Базова інформація

    xrandr --verbose
    cat /etx/X11/xorg.conf
    more /var/log/Xorg.0.log
    
  3. Команди та параметри налагодження

    sudo apt-get install edid-read
    ls /sys/class/drm/*/edid | xargs -i{} sh -c "echo {}; parse-edid < {}"
    
    xrandr --verbose ...
    xtrace xrandr --verbose ...
    
    #no need, only to compare between releases for changes, the default driver parameters
    sudo sh -c "ls /sys/module/<driver-module-from-lshw>/parameters/ | xargs -L1 -i{} sh -c 'echo -n {} \" \" ; cat /sys/module/<driver-module-from-lshw>/parameters/{}'"
    
    # additional desktop environment setting, for general cases, gnome/unity
    cat ~/.config/monitors.xml
    cat /etc/gnome-settings-daemon/xrandr/monitors.xml
    gsettings list-recursively org.gnome.settings-daemon.plugins.xrandr
    
  4. Розширені варіанти налагодження

    Додати Option "ModeDebug" "true"до Section "Device"в xorg.confсм NVidia налагоджувати нижче для отримання докладної інформації.

Додаткова інформація про налагодження для графіки nvidia!

  • cat /proc/driver/nvidia/version для точної версії
  • Активація інформації про налагодження nvidia в /var/log/Xorg.0.log

    gksu nvidia-settings
    # go to X configuration then export, copy only device section
    sudo mkdir /etc/X11/xorg.conf.d/
    sudo vim /etc/X11/xorg.conf.d/90_my_nvidia_hacks.conf
    # paste the device section
    
    Section "Device"
        Identifier     "Device0"
        Driver         "nvidia"
        VendorName     "NVIDIA Corporation"
        BoardName      "NVS 3100M"
        Option "ModeDebug" "true"
    EndSection
    
    # add to it this line `Option "ModeDebug" "true"`
    
  • Повна документація на file:///usr/share/doc/nvidia-*/html/, шукайте таку ж запущену версію, є багато змін у доступних опціях та налаштуваннях за замовчуванням.


Тестовий випадок налагодження з драйвером Intel

Ось випадок, що я можу його відтворити, і це здається помилкою xrandr. З xtrace& видно Xorg.0.log, що буфер кадру не змінюється в 1-й комбінації.

#Seems a bug in xrandr
#Xorg error when changing to bigger resolution without changing a previously defined scale.

#-----------
#system info

$ xrandr --version

xrandr program version       1.4.3
Server reports RandR version 1.4

$ sudo sh -c "lsb_release -dc;echo; uname -a; Xorg -version;echo; lshw -C display"

Description:    Ubuntu 15.10
Codename:   wily

Linux BlueSkies 4.2.0-25-generic #30-Ubuntu SMP Mon Jan 18 12:31:50 UTC 2016 x86_64 x86_64 x86_64 GNU/Linux

X.Org X Server 1.17.2
Release Date: 2015-06-16
X Protocol Version 11, Revision 0
Build Operating System: Linux 3.13.0-68-generic x86_64 Ubuntu
Current Operating System: Linux BlueSkies 4.2.0-25-generic #30-Ubuntu SMP Mon Jan 18 12:31:50 UTC 2016 x86_64
Kernel command line: BOOT_IMAGE=/boot/vmlinuz-4.2.0-25-generic root=UUID=9f0530d5-e0eb-43fa-b99b-000fa742cf10 ro persistent quiet splash vt.handoff=7
Build Date: 12 November 2015  05:33:29PM
xorg-server 2:1.17.2-1ubuntu9.1 (For technical support please see http://www.ubuntu.com/support) 
Current version of pixman: 0.32.6
    Before reporting problems, check http://wiki.x.org
    to make sure that you have the latest version.

  *-display               
       description: VGA compatible controller
       product: 3rd Gen Core processor Graphics Controller
       vendor: Intel Corporation
       physical id: 2
       bus info: pci@0000:00:02.0
       version: 09
       width: 64 bits
       clock: 33MHz
       capabilities: msi pm vga_controller bus_master cap_list rom
       configuration: driver=i915 latency=0
       resources: irq:26 memory:f6400000-f67fffff memory:e0000000-efffffff ioport:f000(size=64)

$ sudo sh -c "ls /sys/module/i915/parameters/ | xargs -L1 -i{} sh -c 'echo -n {} \" \" ; cat /sys/module/i915/parameters/{}'"

disable_display  N
disable_power_well  1
disable_vtd_wa  N
edp_vswing  0
enable_cmd_parser  1
enable_execlists  0
enable_fbc  -1
enable_hangcheck  Y
enable_ips  1
enable_ppgtt  1
enable_psr  0
enable_rc6  3
fastboot  N
invert_brightness  0
load_detect_test  N
lvds_channel_mode  0
lvds_downclock  0
lvds_use_ssc  -1
mmio_debug  0
modeset  -1
nuclear_pageflip  N
panel_ignore_lid  1
prefault_disable  N
preliminary_hw_support  0
reset  Y
semaphores  -1
use_mmio_flip  0
vbt_sdvo_panel_type  -1
verbose_state_checks  Y

$ modinfo i915 

filename:       /lib/modules/4.2.0-25-generic/kernel/drivers/gpu/drm/i915/i915.ko
license:        GPL and additional rights
description:    Intel Graphics
author:         Intel Corporation
author:         Tungsten Graphics, Inc.
firmware:       i915/skl_dmc_ver1.bin
srcversion:     BB05D6968744E69AEA30DC2
...
depends:        drm_kms_helper,drm,video,i2c-algo-bit
intree:         Y
vermagic:       4.2.0-25-generic SMP mod_unload modversions

$ xrandr

Screen 0: minimum 8 x 8, current 1726 x 768, maximum 32767 x 32767
LVDS1 connected primary 1366x768+0+0 (normal left inverted right x axis y axis) 309mm x 173mm
   1366x768      60.07*+  40.02  
   1360x768      59.80    59.96  
   1280x720      60.00  
   1024x768      60.00  
   1024x576      60.00  
   960x540       60.00  
   800x600       60.32    56.25  
   864x486       60.00  
   640x480       59.94  
   720x405       60.00  
   680x384       60.00  
   640x360       60.00  
DP1 disconnected (normal left inverted right x axis y axis)
DP2 disconnected (normal left inverted right x axis y axis)
DP3 disconnected (normal left inverted right x axis y axis)
HDMI1 disconnected (normal left inverted right x axis y axis)
HDMI2 disconnected (normal left inverted right x axis y axis)
HDMI3 disconnected (normal left inverted right x axis y axis)
VGA1 connected 360x200+1366+0 (normal left inverted right x axis y axis) 410mm x 230mm
   1366x768      59.79 +
   1280x1024     60.02  
   1280x720      60.00  
   1024x768      60.00  
   800x600       60.32  
   640x480       60.00  
   720x400       70.08* 
VIRTUAL1 disconnected (normal left inverted right x axis y axis)

Other info not collected 

$ grep intel /var/log/Xorg.0.log

#-------------------------
#case reproducing & debug

## 1st combination different mode & same scale
$ xrandr --output VGA1 --mode 720x400 --right-of LVDS1 --scale 0.5x0.5
$ xtrace xrandr --verbose --output VGA1 --mode 1366x768 --right-of LVDS1 --scale 0.5x0.5

000:<:0030: 28: RANDR-Request(140,21): SetCrtcConfig crtc=0x00000040 timestamp=0x00000000 config timestamp=0x00010a4d x=0 y=0 mode=0x00000000 rr=Rotate_0 outputs=;
000:>:0030:32: Reply to SetCrtcConfig: status=Success(0x00)
screen 0: 1726x768 453x202 mm  96.57dpi
crtc 1:      720x400  70.08 +1366+0 "VGA1"
000:<:0031: 20: RANDR-Request(140,7): SetScreenSize window=0x000000d9 width=1726 height=768 width[mm]=453 height[mm]=202
000:<:0032: 32: RANDR-Request(140,21): SetCrtcConfig crtc=0x00000040 timestamp=0x00000000 config timestamp=0x00010a4d x=1366 y=0 mode=0x000000fc rr=Rotate_0 outputs=0x0000004a;
000:>:0032:32: Reply to SetCrtcConfig: status=Success(0x00)

screen 0: 2049x768 538x202 mm  96.57dpi
crtc 1:     1366x768  59.79 +1366+0 "VGA1"
000:<:002f:  4: Request(36): GrabServer 
000:<:0030: 20: RANDR-Request(140,7): SetScreenSize window=0x000000d9 width=2049 height=768 width[mm]=538 height[mm]=202
000:<:0031: 32: RANDR-Request(140,21): SetCrtcConfig crtc=0x00000040 timestamp=0x00000000 config timestamp=0x00010a4d x=1366 y=0 mode=0x000000f8 rr=Rotate_0 outputs=0x0000004a;
000:>:0030:Error 8=Match: major=140, minor=7, bad=217
000:>:0031:32: Reply to SetCrtcConfig: status=Success(0x00)
X Error of failed request:  BadMatch (invalid parameter attributes)
  Major opcode of failed request:  140 (RANDR)
  Minor opcode of failed request:  7 (RRSetScreenSize)
  Serial number of failed request:  48
  Current serial number in output stream:  49

## 2nd combination same mode & different scale
$ xtrace xrandr --verbose --output VGA1 --mode 1366x768 --right-of LVDS1 --scale 1x1
$ xtrace xrandr --verbose --output VGA1 --mode 1366x768 --right-of LVDS1 --scale 0.5x0.5

screen 0: 2732x768 718x202 mm  96.57dpi
crtc 1:     1366x768  59.79 +1366+0 "VGA1"
000:<:002f:  4: Request(36): GrabServer 
000:<:0030: 20: RANDR-Request(140,7): SetScreenSize window=0x000000d9 width=2732 height=768 width[mm]=718 height[mm]=202
000:<:0031: 56: RANDR-Request(140,26): SetCrtcTransform crtc=0x00000040 transform={matrix=1.000000,0.000000,0.000000,0.000000,1.000000,0.000000,0.000000,0.000000,1.000000;}; filter name='nearest' filter params=;
000:<:0032: 32: RANDR-Request(140,21): SetCrtcConfig crtc=0x00000040 timestamp=0x00000000 config timestamp=0x00010a4d x=1366 y=0 mode=0x000000f8 rr=Rotate_0 outputs=0x0000004a;
000:>:0032:32: Reply to SetCrtcConfig: status=Success(0x00)

000:<:0030: 28: RANDR-Request(140,21): SetCrtcConfig crtc=0x00000040 timestamp=0x00000000 config timestamp=0x00010a4d x=0 y=0 mode=0x00000000 rr=Rotate_0 outputs=;
000:>:0030:32: Reply to SetCrtcConfig: status=Success(0x00)
screen 0: 2049x768 538x202 mm  96.57dpi
crtc 1:     1366x768  59.79 +1366+0 "VGA1"
000:<:0031: 20: RANDR-Request(140,7): SetScreenSize window=0x000000d9 width=2049 height=768 width[mm]=538 height[mm]=202
000:<:0032: 56: RANDR-Request(140,26): SetCrtcTransform crtc=0x00000040 transform={matrix=0.500000,0.000000,0.000000,0.000000,0.500000,0.000000,0.000000,0.000000,1.000000;}; filter name='bilinear' filter params=;
000:<:0033: 32: RANDR-Request(140,21): SetCrtcConfig crtc=0x00000040 timestamp=0x00000000 config timestamp=0x00010a4d x=1366 y=0 mode=0x000000f8 rr=Rotate_0 outputs=0x0000004a;
000:>:0033:32: Reply to SetCrtcConfig: status=Success(0x00)

$ tail /var/log/Xorg.0.log

##1st 
[  6644.557] (II) intel(0): resizing framebuffer to 1726x768
[  6644.560] (II) intel(0): switch to mode 720x400@70.1 on VGA1 using pipe 1, position (1366, 0), rotation normal, reflection none
[  6660.882] (II) intel(0): switch to mode 1366x768@59.8 on VGA1 using pipe 1, position (1366, 0), rotation normal, reflection none

##2nd
[  6804.638] (II) intel(0): resizing framebuffer to 2732x768
[  6804.647] (II) intel(0): switch to mode 1366x768@59.8 on VGA1 using pipe 1, position (1366, 0), rotation normal, reflection none
[  6817.753] (II) intel(0): resizing framebuffer to 2049x768
[  6817.757] (II) intel(0): switch to mode 1366x768@59.8 on VGA1 using pipe 1, position (1366, 0), rotation normal, reflection none

Чудові випадки з інших питань

  • xrandr: Failed to get size of gamma for output default

    Підтримка драйверів або Немає проблеми з завантаженням диска, це відомо nomodesetі старовинною графікою. xrandrне працює добре без KMS. Показники:

    1. sudo lshw -c displayможе *-display UNCLAIMEDтакож бути driver=порожнім.
    2. maximum 1920 x 1080розмір буфера точно розмір екрану , як мінімум, більшість графіки зараз maximum 8192 x 8192, maximum 16384 x 16384або навіть 32Kx32K.
    3. Немає звичайної назви з'єднання default!
    4. Програмне забезпечення візуалізації OpenGL використовується, перевірте glxinfo, приклад: Gallium3D/llvmpipe.

    Відтворити подібне питання

    Створіть віртуальну скриньку Ubuntu без установки гостьових доповнень / модулів (до яких належить графічний драйвер vbox). Це буде дуже повільно, і це станеться з реальною машиною.

  • X Error of failed request: BadMatch (invalid parameter attributes) (Властивість RRQueryOutputProperty)

    Неправильне ім'я властивості, яке використовується xrandr --output .. --set <name> <value>, користувач повинен спершу перевірити наявність наявних властивостей xrandr --prop. Тут вирішено той самий випадок:

    Неможливо змінити яскравість у ноутбуці

    Доступні властивості залежать від використовуваного драйвера та адаптера, тому це може бути результатом попередньої точки випуску драйвера, оскільки немає властивостей, оголошених xrandr.

    Відтворити подібне питання

    xrandr --output <connection-name> --set whatever 0
    
  • X Error of failed request: BadMatch (invalid parameter attributes) (RRAddOutputMode)

    Мою сьогоднішню теорію, планую перевірити пізніше, коли встигну. задокументовано це тут. тож я не забуваю, і інші можуть дати відгуки.

    Помилка, яка виникає з, xrandr .. --addmodeколи драйвер відмовляється від неї, через перевірку EDID. Я помітив, що nvidia видаляє деякі режими після включення "ModeDebug". Або:

    1. Дані EDID з монітора не є ідеальними
    2. Драйвери не надійні в обробці EDID
    3. Згенерований запис режиму не знаходиться в діапазоні монітора, оголошеному в EDID

    Рішення (1 і 2) - це призначене для користувача заміщення Hsync / Vsync / PixelClock або повний локальний файл EDID, деякі драйвери можуть ігнорувати EDID.

    (3) рішення - спробувати ввести інший режим. Зауважте різницю

    $ cvt 1280 800 60
    # 1280x800 59.81 Hz (CVT 1.02MA) hsync: 49.70 kHz; pclk: 83.50 MHz
    Modeline "1280x800_60.00"   83.50  1280 1352 1480 1680  800 803 809 831 -hsync +vsync
    
    $ gtf 1280 800 60
    
      # 1280x800 @ 60.00 Hz (GTF) hsync: 49.68 kHz; pclk: 83.46 MHz
      Modeline "1280x800_60.00"  83.46  1280 1344 1480 1680  800 801 804 828  -HSync +Vsync
    
     # reduce mode only for flat monitors
     $ cvt -r 1280 800 60
    # 1280x800 59.91 Hz (CVT 1.02MA-R) hsync: 49.31 kHz; pclk: 71.00 MHz
    Modeline "1280x800R"   71.00  1280 1328 1360 1440  800 803 809 823 +hsync -vsync
    

    Деякі випадки вирішуються, змінивши vsync, наприклад, трохи нижче 1280 800 59.80.


1
Це те, про що я починав думати ... ти, здається, ви дізналися величезну кількість за такий короткий час. Я перевірю всі команди / файли, які ви дали, і побачу, як я можу розширити це. Ще раз дякую Sneetsher!
TellMeWhy

@DevRobot, я помітив, що ви шукали джерело xrandr, тому я подумав, що вас більше цікавить налагодження. Я додав цікавий випадок, який міг би відтворити його з усією інформацією, яку я міг зібрати.
user.dz

2
Нічого собі, яка ретельна робота.
Яків Влійм

Де на землі ти все це знайшов ??
TellMeWhy

@DevRobot, Ну, коли я вперше поставив відповідь, я починаю слідкувати за справами про графічний стек тут, в АС. І більше цікавлять пости, які отримали рішення. Також я провів деякий час, намагаючись відтворити деякі проблеми та читаючи деякі зовнішні документи (я зв'язав ті, які мені здалися цікавими).
user.dz
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.