Bumblebee Intel + Nvidia sul problema della schermata nera del 15.10


10

Ho una nuova installazione di Kubuntu 15.10, ho un laptop msi GT70 con optimus.

Ho installato bumblebee bumblebee-nvidia, è assolutamente necessario perché nouveau continua a bloccarsi durante l'accesso.

Quindi ho modificato /etc/bumblebee/bumblebee.conf

# Configuration file for Bumblebee. Values should **not** be put between quotes

## Server options. Any change made in this section will need a server restart
# to take effect.
[bumblebeed]
# The secondary Xorg server DISPLAY number
VirtualDisplay=:8
# Should the unused Xorg server be kept running? Set this to true if waiting
# for X to be ready is too long and don't need power management at all.
KeepUnusedXServer=false
# The name of the Bumbleblee server group name (GID name)
ServerGroup=bumblebee
# Card power state at exit. Set to false if the card shoud be ON when     Bumblebee
# server exits.
TurnCardOffAtExit=false
# The default behavior of '-f' option on optirun. If set to "true", '-f' will
# be ignored.
NoEcoModeOverride=false
# The Driver used by Bumblebee server. If this value is not set (or empty),
# auto-detection is performed. The available drivers are nvidia and nouveau
# (See also the driver-specific sections below)
Driver=nvidia
# Directory with a dummy config file to pass as a -configdir to secondary X
XorgConfDir=/etc/bumblebee/xorg.conf.d

## Client options. Will take effect on the next optirun executed.
[optirun]
# Acceleration/ rendering bridge, possible values are auto, virtualgl and
# primus.
Bridge=auto
# The method used for VirtualGL to transport frames between X servers.
# Possible values are proxy, jpeg, rgb, xv and yuv.
VGLTransport=proxy
# List of paths which are searched for the primus libGL.so.1 when using
# the primus bridge
PrimusLibraryPath=/usr/lib/x86_64-linux-gnu/primus:/usr/lib/i386-linux-    gnu/primus
# Should the program run under optirun even if Bumblebee server or nvidia card
# is not available?
AllowFallbackToIGC=false


# Driver-specific settings are grouped under [driver-NAME]. The sections are
# parsed if the Driver setting in [bumblebeed] is set to NAME (or if auto-
# detection resolves to NAME).
# PMMethod: method to use for saving power by disabling the nvidia card, valid
# values are: auto - automatically detect which PM method to use
#         bbswitch - new in BB 3, recommended if available
#       switcheroo - vga_switcheroo method, use at your own risk
#             none - disable PM completely
# https://github.com/Bumblebee-Project/Bumblebee/wiki/Comparison-of-PM-methods

## Section with nvidia driver specific options, only parsed if Driver=nvidia
[driver-nvidia]
# Module name to load, defaults to Driver if empty or unset
KernelDriver=nvidia-304
PMMethod=auto
# colon-separated path to the nvidia libraries
LibraryPath=/usr/lib/nvidia-304:/usr/lib32/nvidia-304
# comma-separated path of the directory containing nvidia_drv.so and the
# default Xorg modules path
XorgModulePath=/usr/lib/nvidia-304/xorg,/usr/lib/xorg/modules
XorgConfFile=/etc/bumblebee/xorg.conf.nvidia

## Section with nouveau driver specific options, only parsed if Driver=nouveau
[driver-nouveau]
KernelDriver=nouveau
PMMethod=auto
XorgConfFile=/etc/bumblebee/xorg.conf.nouveau

io ho

$ cat /proc/acpi/bbswitch 
0000:01:00.0 ON

Ho inserito /etc/modules-load.d/modules.conf

i915
bbswitch

Quindi sono in grado di fare:

$ primusrun glxinfo | grep "OpenGL version"
OpenGL version string: 4.2.0 NVIDIA 304.128

Ma se riavvio tutto ciò che ho è una schermata nera , per avviare il mio sistema devo accedere in tty1 e fare:

sudo modprobe nvidia_304
sudo service sddm restart

per ottenere la schermata di accesso di Kubuntu qualche idea per risolverlo?

Anche se sostituisco nvidia-304 con nvidia-355 non riesco affatto ad avviarlo: il suggerimento di modprobe non funziona.

Ecco la mia configurazione con lspci :

$ lspci|grep -i vga
00:02.0 VGA compatible controller: Intel Corporation 4th Gen Core Processor Integrated Graphics Controller (rev 06)
01:00.0 VGA compatible controller: NVIDIA Corporation GK104M [GeForce GTX 870M] (rev ff)

MODIFICARE:

Alcune informazioni correlate e possibili soluzioni http://forum.ubuntu-it.org/viewtopic.php?p=4760241 (in italiano) https://www.kubuntuforums.net/showthread.php?69190-Bumblebee-Nvidia355&p=381043

Inoltre c'è effettivamente un bug con il modulo i915 sul kernel 4.2 https://bugs.launchpad.net/ubuntu/+source/linux/+bug/1494903

EDIT2 (soluzione di calabrone funzionante):

Sono riuscito a fare questo lavoro https://www.kubuntuforums.net/showthread.php?69190-Bumblebee-Nvidia355&p=381043

  1. installa nvidia-355 e nvidia-prime
  2. selezionare il driver Intel nel pannello NVIDIA e disconnettersi
  3. installa solo bumblebee (non bumblebee-nvidia)
  4. modifica secondo necessità /etc/bumblebee/bumblebee.conf line22 KernelDriver = nvidia sostituisce nvidia-current con nvidia-355
  5. /etc/bumblebee/xorg.conf.nvidia decomment BusID "PCI: 01: 00: 0" come descritto qui /ubuntu/29044...vices-detected ,
  6. ora puoi avviare sotto la scheda Intel e usare optirun e primusrun. Finora funziona per me, prova con primusrun glxinfo

EDIT3: ( mag 03/12/2015 )

Usando ppa: graphics-drivers / ppa e ppa: xorg-edgers / ppa , dopo un aggiornamento e un riavvio, ho avuto una schermata nera usando 358.16-0ubuntu0 ~ gpu15.10.2 .

Così ho eliminato tutto e poi ho appena installato bumblee-nvidia nvidia-358 , ho modificato /etc/bumblebee/bumblebee.conf e ho fatto il riavvio di bumblebeed sudo service .

Ha funzionato di nuovo dopo un riavvio.


Ho avuto un problema simile ora eseguo kernel 4.4, xorg-edger e nvidia 358 e tutto funziona bene (nvidia 361 ora funziona)
Calin,


Risposte:


10

Dato che hai un hardware GPU abbastanza nuovo, dovresti usare anche nuovi driver e software NVIDIA.

Sostituire calabrone con nvidia-primeper passare tra integrata e grafica dedicata .

Reinstallare i driver NVIDIA, ma prima disinstallare tutto il software NVIDIA e rimuovere il calabrone.

Apri un terminale ed esegui:

sudo apt-get purge nvidia* '^bumblebee.*'  
sudo reboot  

Quando viene visualizzato il menu di avvio di GRUB : Evidenziare la voce di menu Ubuntu e premere il Etasto.
Aggiungi il nouveau.modeset=0parametro alla fine della linea Linux ... Quindi premi F10per avviare.

Installa i driver proprietari NVIDIA stabili dai repository Ubuntu (non si applica a Ubuntu 12.04:

sudo apt-get update
sudo apt-get install nvidia-352 nvidia-prime
sudo reboot

Quando si desidera utilizzare i driver più recenti, installarli dal driver GPU proprietario PPA:

sudo add-apt-repository ppa:graphics-drivers/ppa
sudo apt-get update
sudo apt-get install nvidia-355 nvidia-prime
sudo reboot  

1
Grazie, questo sembra funzionare, ho anche dovuto creare un file /etc/modprobe.d/blacklist-nouveau.confcontenente blacklist nouveau options nouveau modeset=0
Kwaadpepper,

Ho anche un'altra domanda: la tua conoscenza potrebbe funzionare anche se il calabrone? Perché con nvidia-prime non è possibile avviare un programma specifico utilizzando nvidia quando si utilizza la scheda grafica Intel, è primusrunstato un grande affare
Kwaadpepper,

1
@Kwaadpepper: bumblebee sembra essere in qualche modo deprezzato e sempre più deboli di problemi - l'ultima versione ha 2,5 anni - nvidia-prime è un rimpiazzo che funziona semplicemente - l'unico aspetto negativo è che non è possibile avviare un singolo programma specifico soprattutto - ma la cosa più importante è: la tua macchina è in esecuzione ora! Sono contento che funzioni per te - quindi ... goditi l'esperienza Ubuntu! :)
cl-netbox,

4
Assicurati di non ottenere nvidia-current: quello è un vecchio driver che mi ha portato alla schermata nera.
Ciro Santilli 1 病毒 审查 六四 事件 法轮功

Funziona come un campione su 18.04 con questo e la correzione temporanea di nomodeset su Asus SCAR Strix.
RobotHumans,

6

Riuscito a far funzionare il calabrone a Wily dopo troppi mal di testa inutili, senza quell'orribile nvidia.

Come altri sospettavano, è a causa di gpu-manager. Qualunque cosa sia, sta scontando tutto la configurazione di aggiornamento-alternativa. Mascherare quel servizio e reinstallare bumblebee [-nvidia] risolve tutti i problemi, ora la scheda si accende e si spegne via optirun come previsto e non ci sono più schermate nere all'avvio.

sudo systemctl mask gpu-manager.service
sudo apt-get install --reinstall bumblebee bumblebee-nvidia

Assicurati anche che non ci siano /etc/X11/xorg.conf non funzionanti.


6

Anche se tutto sembra funzionare, provare quanto segue mostra che l'interruttore bbswitch non può spegnere correttamente la scheda nvidia:

cat /proc/acpi/bbswitch
primusrun glxinfo|grep OpenGL
sleep 1
cat /proc/acpi/bbswitch

Quindi ho reinstallato bumblebee-nvidia, ha funzionato fino al riavvio del sistema. Dopo aver approfondito il problema, ho notato che le alternative di aggiornamento vengono aggiornate dopo il riavvio del sistema e ho notato che gpu-manager lo sta causando. (esegui semplicemente "sudo gpu-manager" e vedrai che è aggiornato)

gpu-manager viene eseguito dopo l'avvio di lightdm. quindi, come soluzione rapida, l'ho disabilitato.

ora tutto funziona come previsto. dopo aver eseguito qualcosa con optirun o primusrun, bbswitch spegne correttamente nvidia quando termina il processo.

Per riassumere, ecco il mio riepilogo per installare tutto da zero (eseguilo manualmente leggendo i commenti):

sudo add-apt-repository ppa:graphics-drivers/ppa
sudo apt-get update

sudo apt-get purge -y nvidia* bumblebee bumblebee-nvidia bbswitch-dkms primus
sudo apt-get install nvidia-355

#switch to intel
sudo tee /etc/prime-discrete <<< off

#reboot is recommended at this point

sudo add-apt-repository ppa:bumblebee/stable
sudo apt-get update
sudo apt-get install bumblebee primus

#sudo gedit /etc/modules
#  add the line "bbswitch load_state=0"

#sudo gedit /etc/modprobe.d/bumblebee.conf
#and make sure the following line exists
#  blacklist nvidia-355

#sudo gedit /etc/bumblebee/bumblebee.conf
#  change line 22 "Driver=" to "Driver=nvidia"
#  change all nvidia-current to nvidia-355

#sudo gedit /etc/bumblebee/xorg.conf.nvidia
#  uncomment BusID line if it is commented and make sure it corresponds to the correct BusID

#disable gpu-manager as it changes i386-linux-gnu_gl_conf and x86_64-linux-gnu_gl_conf
sudo systemctl mask gpu-manager.service

EDIT: ho rimosso le modifiche di rc.local perché gpu-manager era in esecuzione non solo in fase di esecuzione ma anche durante l'utilizzo del sistema. Pertanto l'ho disabilitato completamente.


Ben fatto, è stato davvero difficile da trovare, funziona anche con nvidia-361
GuySoft

1
Per ottenere il BusID, utilizzare quanto seguelspci | grep NVIDIA
Karl Morrison,

Anche il 14.04 doveva andare nel file /etc/init/gpu-manager.conf e commentare tutto l'inizio in linea
Karl Morrison,
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.