My Thinkpad P16 gen 2 internal display only works with graphical desktops when Discrete graphics are selected. When hybrid graphics are selected in BIOS, everything is OK until the graphical desktop environment tries to launch, then the internal display freezes with an underscore character in upper left corner in text mode. The HDMI out continues to work.
I ordered this computer from Lenovo with custom specs, with Ubuntu 22.04, but when it came, actually there was no OS installed at all. I confirmed this carefully. Anyway it's ok, I went ahead and installed Ubuntu 24.04 without a problem and it worked ok for a while. They advertised it as coming with Ubuntu 22.04 (when I specced it out), so it should work with 22.04; since there was actually no OS at all, I installed 24.04 instead of 22.04, and it worked fine for a long time.
After initially setting it up, with internal monitor working fine with hybrid graphics and a graphical desktop environment (both Gnome desktop originally and later Cinnamon), I went to clamshell mode and used it exclusively in clamshell with an external HDMI monitor, which also worked ok.
After a long time of clamshell only (HDMI out only), I needed to take the laptop somewhere and discovered the internal monitor did not actually work any more as soon as the graphical desktop manager started. In other words, everything is OK until the graphical desktop environment tries to launch, then internal display freezes with an underscore character in upper left corner in text mode. The HDMI out continues to work. So I am not sure when the internal monitor stopped being functional with graphical environments as I was clamshell only for a few months. Unfortunately it could be tied to a specific thing I did or a specific install or uninstall that I did, but I don't know what it would be as I didn't detect it before due to the fact that I only clamshelled it.
The one method I've found of getting the internal display to work with a graphic environment is to set graphics mode to discrete graphics in BIOS. However, the problems with that include that I don't get the onboard sound, and Virtualbox doesn't want to launch my VMs with discrete graphics.
I've done all of the following trying to get the internal display to show a GUI with hybrid graphics with no success:
-Used both GDM and LightDM with Gnome and Cinnamon desktop environments, with wayland and X11 each
-All sorts of command line defaults in Grub, including the following and variants thereof (currently commented, but I used them before)
Code:
#GRUB_CMDLINE_LINUX_DEFAULT="i915.force_probe=a788 i915.modeset=1 nvidia-drm.modeset=1 i915.enable_guc=3"
#GRUB_CMDLINE_LINUX_DEFAULT="nomodeset i915.force_probe=a788"
#GRUB_CMDLINE_LINUX_DEFAULT="i915.modeset=1 acpi_backlight=vendor intel_iommu=on acpi_osi=\"Windows 2015\""
#GRUB_CMDLINE_LINUX_DEFAULT="i915.modeset=1 acpi_osi=Linux acpi_backlight=vendor intel_iommu=on"
#GRUB_CMDLINE_LINUX_DEFAULT="nvidia-drm.modeset=1 i915.modeset=1 acpi_osi=Linux"
#GRUB_CMDLINE_LINUX_DEFAULT="acpi_osi=Linux nvidia-drm.modeset=1 btusb.enable_autosuspend=0 intel_iommu=on i915.modeset=1 acpi_backlight=vendor"
#GRUB_CMDLINE_LINUX_DEFAULT="quiet splash nomodeset"
#GRUB_CMDLINE_LINUX_DEFAULT=""
#GRUB_CMDLINE_LINUX_DEFAULT="quiet splash nomodeset split_lock_detect=off"
-Set prime to intel, NVIDIA, blacklisted intel or NVIDIA and tried to boot with one or the other that way
-Reinstalled NVIDIA drivers in recovery mode after scorched earth purging of all traces of the prior installs using both NVIDIA's .run file and the apt-get repos
-Reinstalled lightdm, gdm, cinnamon, gnome desktop, xorg, etc. after scorched earth purging of all traces of prior installs
-Tried the following kernels:
ii linux-image-6.8.0-38-generic 6.8.0-38.38 amd64 Signed kernel image generic
ii linux-image-6.8.0-39-generic 6.8.0-39.39 amd64 Signed kernel image generic
ii linux-image-6.9.12-x64v3-xanmod1
-Run apt-get update & apt-get upgrade, and purged and reinstalled every related package I can think of numerous times
I'm at a loss here about how to proceed. I know it *can* work because when I did a fresh install, it did work, but I am out of ideas. I could do a fresh reinstall, though that would take a long time (especially with disk encryption), and may not even solve the problem or let me know how to avoid it happening again.
FWIW, here are the results of $ journalctl -b 0 | grep -i -e nvidia -e intel -e gpu, from my current session with discrete graphics selected.
Code:
Journal file /var/log/journal/3896cb836fb54877836a1c5b0928ffc1/system@00061e84932b9110-fcfc2bf59397404f.journal~ is truncated, ignoring file.
Aug 04 00:36:39 comp kernel: Command line: BOOT_IMAGE=/vmlinuz-6.8.0-39-generic root=/dev/mapper/ubuntu--vg-ubuntu--lv ro i915.force_probe=a788 i915.modeset=1 nvidia-drm.modeset=1 i915.enable_guc=3
Aug 04 00:36:39 comp kernel: Intel GenuineIntel
Aug 04 00:36:39 comp kernel: Kernel command line: BOOT_IMAGE=/vmlinuz-6.8.0-39-generic root=/dev/mapper/ubuntu--vg-ubuntu--lv ro i915.force_probe=a788 i915.modeset=1 nvidia-drm.modeset=1 i915.enable_guc=3
Aug 04 00:36:39 comp kernel: smpboot: CPU0: 13th Gen Intel(R) Core(TM) i9-13950HX (family: 0x6, model: 0xb7, stepping: 0x1)
Aug 04 00:36:39 comp kernel: Performance Events: XSAVE Architectural LBR, PEBS fmt4+-baseline, AnyThread deprecated, Alderlake Hybrid events, 32-deep LBR, full-width counters, Intel PMU driver.
Aug 04 00:36:39 comp kernel: DMAR: Intel(R) Virtualization Technology for Directed I/O
Aug 04 00:36:39 comp kernel: intel_pstate: Intel P-state driver initializing
Aug 04 00:36:39 comp kernel: intel_pstate: HWP enabled
Aug 04 00:36:39 comp kernel: intel-lpss 0000:00:15.0: enabling device (0000 -> 0002)
Aug 04 00:36:39 comp kernel: idma64 idma64.0: Found Intel integrated DMA 64-bit
Aug 04 00:36:39 comp kernel: intel-lpss 0000:00:15.3: enabling device (0000 -> 0002)
Aug 04 00:36:39 comp kernel: idma64 idma64.1: Found Intel integrated DMA 64-bit
Aug 04 00:36:40 comp kernel: input: Intel HID events as /devices/platform/INTC1070:00/input/input18
Aug 04 00:36:40 comp kernel: intel_pmc_core INT33A1:00: initialized
Aug 04 00:36:40 comp kernel: intel_rapl_msr: PL4 support detected.
Aug 04 00:36:40 comp kernel: Intel(R) Wireless WiFi driver for Linux
Aug 04 00:36:40 comp kernel: intel_rapl_common: Found RAPL domain package
Aug 04 00:36:40 comp kernel: intel_rapl_common: Found RAPL domain core
Aug 04 00:36:40 comp kernel: intel_rapl_common: Found RAPL domain psys
Aug 04 00:36:40 comp kernel: snd_hda_intel 0000:00:1f.3: DSP detected with PCI class/subclass/prog-if info 0x040380
Aug 04 00:36:40 comp kernel: snd_hda_intel 0000:00:1f.3: Digital mics found on Skylake+ platform, using SOF driver
Aug 04 00:36:40 comp kernel: snd_hda_intel 0000:01:00.1: enabling device (0000 -> 0002)
Aug 04 00:36:40 comp kernel: snd_hda_intel 0000:01:00.1: Disabling MSI
Aug 04 00:36:40 comp kernel: snd_hda_intel 0000:01:00.1: Handle vga_switcheroo audio client
Aug 04 00:36:40 comp kernel: intel_rapl_common: Found RAPL domain package
Aug 04 00:36:40 comp kernel: input: HDA NVidia HDMI/DP,pcm=3 as /devices/pci0000:00/0000:00:01.0/0000:01:00.1/sound/card0/input19
Aug 04 00:36:40 comp kernel: input: HDA NVidia HDMI/DP,pcm=7 as /devices/pci0000:00/0000:00:01.0/0000:01:00.1/sound/card0/input20
Aug 04 00:36:40 comp kernel: input: HDA NVidia HDMI/DP,pcm=8 as /devices/pci0000:00/0000:00:01.0/0000:01:00.1/sound/card0/input21
Aug 04 00:36:40 comp kernel: input: HDA NVidia HDMI/DP,pcm=9 as /devices/pci0000:00/0000:00:01.0/0000:01:00.1/sound/card0/input22
Aug 04 00:36:40 comp kernel: iwlwifi 0000:00:14.3: Detected Intel(R) Wi-Fi 6E AX211 160MHz, REV=0x430
Aug 04 00:36:40 comp kernel: sof-audio-pci-intel-tgl 0000:00:1f.3: DSP detected with PCI class/subclass/prog-if info 0x040380
Aug 04 00:36:40 comp kernel: sof-audio-pci-intel-tgl 0000:00:1f.3: Digital mics found on Skylake+ platform, using SOF driver
Aug 04 00:36:40 comp kernel: sof-audio-pci-intel-tgl 0000:00:1f.3: DSP detected with PCI class/subclass/prog-if 0x040380
Aug 04 00:36:40 comp kernel: sof-audio-pci-intel-tgl 0000:00:1f.3: use msi interrupt mode
Aug 04 00:36:40 comp kernel: nvidia: loading out-of-tree module taints kernel.
Aug 04 00:36:40 comp kernel: nvidia: module license 'NVIDIA' taints kernel.
Aug 04 00:36:40 comp kernel: nvidia: module license taints kernel.
Aug 04 00:36:40 comp kernel: sof-audio-pci-intel-tgl 0000:00:1f.3: hda codecs found, mask 1
Aug 04 00:36:40 comp kernel: sof-audio-pci-intel-tgl 0000:00:1f.3: using HDA machine driver skl_hda_dsp_generic now
Aug 04 00:36:40 comp kernel: sof-audio-pci-intel-tgl 0000:00:1f.3: DMICs detected in NHLT tables: 2
Aug 04 00:36:40 comp kernel: sof-audio-pci-intel-tgl 0000:00:1f.3: Firmware paths/files for ipc type 0:
Aug 04 00:36:40 comp kernel: sof-audio-pci-intel-tgl 0000:00:1f.3: Firmware file: intel/sof/sof-rpl-s.ri
Aug 04 00:36:40 comp kernel: sof-audio-pci-intel-tgl 0000:00:1f.3: Topology file: intel/sof-tplg/sof-hda-generic-2ch.tplg
Aug 04 00:36:40 comp kernel: sof-audio-pci-intel-tgl 0000:00:1f.3: Firmware info: version 2:2:0-57864
Aug 04 00:36:40 comp kernel: sof-audio-pci-intel-tgl 0000:00:1f.3: Firmware: ABI 3:22:1 Kernel ABI 3:23:0
Aug 04 00:36:40 comp kernel: sof-audio-pci-intel-tgl 0000:00:1f.3: unknown sof_ext_man header type 3 size 0x30
Aug 04 00:36:40 comp kernel: nvidia-nvlink: Nvlink Core is being initialized, major device number 511
Aug 04 00:36:40 comp kernel: nvidia 0000:01:00.0: enabling device (0006 -> 0007)
Aug 04 00:36:40 comp kernel: nvidia 0000:01:00.0: vgaarb: VGA decodes changed: olddecodes=io+mem,decodes=none:owns=none
Aug 04 00:36:40 comp kernel: sof-audio-pci-intel-tgl 0000:00:1f.3: Firmware info: version 2:2:0-57864
Aug 04 00:36:40 comp kernel: sof-audio-pci-intel-tgl 0000:00:1f.3: Firmware: ABI 3:22:1 Kernel ABI 3:23:0
Aug 04 00:36:40 comp kernel: intel_tcc_cooling: Programmable TCC Offset detected
Aug 04 00:36:40 comp kernel: NVRM: loading NVIDIA UNIX x86_64 Kernel Module 535.183.01 Sun May 12 19:39:15 UTC 2024
Aug 04 00:36:40 comp kernel: nvidia-modeset: Loading NVIDIA Kernel Mode Setting Driver for UNIX platforms 535.183.01 Sun May 12 19:31:08 UTC 2024
Aug 04 00:36:40 comp kernel: [drm] [nvidia-drm] [GPU ID 0x00000100] Loading driver
Aug 04 00:36:41 comp kernel: Bluetooth: hci0: Found device firmware: intel/ibt-1040-0041.sfi
Aug 04 00:36:41 comp kernel: [drm] Initialized nvidia-drm 0.0.0 20160202 for 0000:01:00.0 on minor 1
Aug 04 00:36:41 comp systemd[1]: Starting systemd-backlight@backlight:nvidia_0.service - Load/Save Screen Backlight Brightness of backlight:nvidia_0...
Aug 04 00:36:41 comp systemd[1]: Finished systemd-backlight@backlight:nvidia_0.service - Load/Save Screen Backlight Brightness of backlight:nvidia_0.
Aug 04 00:36:41 comp kernel: nvidia_uvm: module uses symbols nvUvmInterfaceDisableAccessCntr from proprietary module nvidia, inheriting taint.
Aug 04 00:36:41 comp kernel: nvidia-uvm: Loaded the UVM driver, major device number 508.
Aug 04 00:36:42 comp kernel: Bluetooth: hci0: Found Intel DDC parameters: intel/ibt-1040-0041.ddc
Aug 04 00:36:42 comp kernel: Bluetooth: hci0: Applying Intel DDC parameters completed
Aug 04 00:38:09 comp systemd[1]: Starting gpu-manager.service - Detect the available GPUs and deal with any system changes...
Aug 04 00:38:09 comp systemd[1]: Starting nvidia-persistenced.service - NVIDIA Persistence Daemon...
Aug 04 00:38:09 comp nvidia-persistenced[2311]: Verbose syslog connection opened
Aug 04 00:38:09 comp nvidia-persistenced[2311]: Now running with user ID 125 and group ID 130
Aug 04 00:38:09 comp nvidia-persistenced[2311]: Started (2311)
Aug 04 00:38:09 comp nvidia-persistenced[2311]: device 0000:01:00.0 - registered
Aug 04 00:38:09 comp nvidia-persistenced[2311]: Local RPC services initialized
Aug 04 00:38:09 comp systemd[1]: Started nvidia-persistenced.service - NVIDIA Persistence Daemon.
Aug 04 00:38:09 comp systemd-logind[2346]: Watching system buttons on /dev/input/event10 (Intel HID events)
Aug 04 00:38:09 comp sensors[2371]: GPU: +42.0°C
Aug 04 00:38:10 comp systemd[1]: gpu-manager.service: Deactivated successfully.
Aug 04 00:38:10 comp systemd[1]: Finished gpu-manager.service - Detect the available GPUs and deal with any system changes.
Aug 04 01:44:34 comp kernel: [drm:nv_drm_master_set [nvidia_drm]] *ERROR* [nvidia-drm] [GPU ID 0x00000100] Failed to grab modeset ownership
It's difficult to know if any particular entry has any significance as the more I vary all the various things I can vary, various messages and errors come up in the logs and change depending on the setup, but repsonding to all of them doesn't seem to fix the issue.
Any really smart people know how I can troubleshoot further? Thanks!