User:Lemma/KDE4-NVIDIA
The problem
KDE4's performance on newer NVIDIA cards of the 8xxx and 9xxx series is currently pretty choppy. For as long as I've been trying running KDE4 I had to fight an unresponsive plasma and some windows that just wouldn't resize with more than 0.5 fps.
The remedy
Lately I've been reading up on a thread on the NVIDIA forums. I found out that performance can be increased dramatically by doing the following:
- Install the latest NVIDIA graphics driver (173.14.09 works fine for me)
- Make sure you the NVIDIA kernel module gets loaded by either rebooting or rmmod/modprobe (Of course you'll also have to restart xorg)
- Set the following options:
$ nvidia-settings -a InitialPixmapPlacement=2 -a GlyphCache=1
If you're lucky your KDE4 will be snappier than ever. If you're unlucky and it stays the same or gets even worse, try experimenting with the value of InitialPixmapPlacement, setting it to 1 or 3.
Apart from that I had to play around with the Advanced Effects settings as kwin's performance seemed to have dropped.
Making it permanent
Driver options set using the nvidia-settings tool reset back to default as soon as your xserver exits. To make it permanent you have to put this command
nvidia-settings -a InitialPixmapPlacement=2 -a GlyphCache=1 &
in your autostart.
Additionally, you can try the following options in your xorg.conf, in the device section (nvidia):
Option "RenderAccel" "true" Option "UseEvents" "false" Option "TripleBuffer" "1" Option "DamageEvents" "1" Option "BackingStore" "1" Option "PixmapCacheSize" "70000" Option "OnDemandVBlankInterrupts" "true"
They should speed up things as well. You might want to try other, higher values for PixmapCacheSize.
Benchmarking Changes
After making the above changes, you can use the Canvas speed test benchmark below to test and see if it did affect performance. Run the Canvas test with InitialPixmapPlacement=1 and InitialPixmapPlacement=2 to see the difference in time taken. (Note: It may not work with Konqueror, try using Firefox 3)
http://intertwingly.net/stories/2006/07/10/penroseTiling.html
Canvas can also be tested at http://blobsallad.se/
Experiences
Here I'd like to collect some information about the circumstances this setup will work better in. Please post your experiences to the table below:
Name | Card | Kernel | Version | I.P.P. | G.C. | Improvement |
---|---|---|---|---|---|---|
Lemma | 8600 GTS | 2.6.25 | 177.13 (beta) | 2 | 1 | huge |
Lemma | 8600 GTS | 2.6.25 | 173.14.09 (stable) | 2 | 1 | huge |
Teo | Quadro NVS 140M (same chip as 8400M) | 2.6.25 | 177.78 (beta) | 2 | 1 | the improvement is significantly more noticeable than with stable drivers but still not enough for normal use |
Teo | GeForce 8800GT | 2.6.25 | 177.70 (beta) | 2 | 1 | huge, KDE4 is completely usable now, both Plasma and KWin effects |
ehamberg | 8400GS | 2.6.25 | 173.14.09 (stable) | 2 | 1 | huge |
Brandon | 8800GTS 640mb | 2.6.26 | 173.14.09 (stable) | 2 | 1 | huge(not a lot when resizing windows but scrolling in the folderview is smooth now) |
friedreich | 8800GTS 640mb | 2.6.25.9-2-pae | 173.14.09 (stable) | 2 | 1 | huge (after playing with advanced compositing options absolutely smooth (opengl, texture from pixmap, trilinear, direct rendering), keep thumbnails of hidden windows), still dogslow when adding widgets and doing animations the 1st time, putting the lines into xorg.conf doesn't work |
Johannes Köster | Geforce 8600GT | 2.6.25-debian | 173.14.09 | 2 | 1 | rather big, but only if I use shared memory as opengl mode. texture from pixmap causes long hangs every few minutes. |
Armando Jagucki | Geforce 8800GT | 2.6.24 | 173.14.09 | 2 | 1 | Huge. Scrolling in folder views does not lag anymore, and the desktop switching window-shuffle animation is silky smooth whereas before it would hiccup. |
rivo | 9600GT | 2.6.22 (Gutsy) | 173.14.09 | 2 | 1 | huge. Plasma is now actually usable (was very painful before). KWin is also very smooth now. |
Nikolavp | 8500 GT | 2.6.25-2 | 173.14.09-3 | 2 | 1 | Huge difference, saved my day. |
zulu9 | 8500 GT | 2.6.26-2.slh.6-sidux-686 | 177.67 | 2 | 1 | Huge! No kwin hangups anymore (like with 173.xx). Runs nicely with effects enabled. I also followed the instructions on the nvidia-forums [1]. |
Xmister | 8600 GTS | 2.6.24-20 | 169.12 | 2 | 0 | It runs much better with this driver, IPP helps a lot for this too. |
Fuchs | nvs140m (G8400M) | 2.6.26 | 173.14.12 and 173.14.05 and 177 beta (same results) | 2 | 1 | Not that much of a difference, as 2D was already good with the xorg.conf options listed above. A nVidia employee recently wrote that the XRender / KDE4 issues are being addressed right now and should be fixed in the 177 final release. Please be patient. |
padde | GeForce 8400M GT | 2.6.26 (Gentoo/64) | 177.13 | 2 | 1 | Window resizing is finally possible. Scrolling still choppy, but much better (you wouldn't believe how much it sucked before)... |
Pingus | GeForce 9500M GS | 2.6.25.11 | 173.14.09_2.6.25.5_1.1-0.1 | 2 | 1 | Huge. |
Ghirai | GeForce 8600 GT | FreeBSD 7.0-RELEASE, i386 | 173.14.12 | 2 | 1 | Fixed the resizing issue, scrolling in folders is a lot more smoother. However, every once in a while, minimizing/maximizing grinds to a total halt (framerate drops to 0); after couple seconds, everything is back to normal. Apart from this big annoyance, everything is perfect (framerate stays between 40 and 60 no matter what i do). |
tex | GeForce 9600 GT | 2.6.26.3 x86_64 | 177.67 (x86_64) | 2 | 1 | Huge. Please note that I'm running an TwinView Setup (2 DFP). |
Ingar | GeForce 8800 GTS 640mb | 2.6.26-ARCH x86_64 | 173.14.12 (x86_64) | 2 | 1 | Huge. Desktop switching, scrolling and konsole work smooth. |
vanRijn | Quadro NVS 140M (rev a1) | 2.6.25.16-0.1-pae (OpenSUSE 11) | 177.78 | 1 | 1 | Finally! I can actually use KDE4! Note that IPP=2 is MUCH worse for me than IPP=1. |
- I.P.P. = InitialPixmapPlacement
- G.C. = GlyphCache
Known problems
I haven't done a lot of testing using this setup, so in case you encounter any unwanted effects (on 3D applications or other 2D applications), please put them below.
- Following those steps with cards from the 7xxx series is said to increase GPU temperature a lot. [2]
- On changing kwin's effects settings might not be possible because on applying the changes X might freeze for a period of time longer than the 10 seconds you have to confirm the change.
- The Yakuake terminal has scrolling problems after these changes, it also takes long to appear / disappear, regardless of the animation speed you set.