A Word on Drivers and Compatibility

As we mentioned earlier, Ubuntu and the Linux kernel are open source projects, particularly under the GPL license. In large part due to the philosophies of the GPL, compared to Mac OS X and Windows, Linux handles drivers in a notably different fashion.

In a nutshell, the developers of the Linux kernel believe in the open source movement and wish for all related software to be open source. Furthermore they do not like the implications of attaching a closed source “binary blob” driver to the Linux kernel, because if something goes wrong it can be impossible to debug the issue if it occurs in the driver for which they do not have the code for. As such they have moral and technical objections to the Linux kernel supporting external drivers and actively prevent the creation of such drivers. This is done through mechanisms such as not having a fixed API for external drivers, and by not artificially keeping themselves from making changes to the kernel that would break external drivers. Drivers that they do have the code for can usually just be recompiled against the new kernel and are unaffected as a result. The result is that “binary blob” drivers are systematically opposed.

For the most part, this works fine. Not all hardware is supported under Linux because not everyone is willing to share the specifications and data needed to make a driver, but more than enough device manufacturers are willing to share such data that Linux generally supports non-esoteric hardware quite well. There is one class of notable hold-outs here however, and that’s the GPU manufacturers, namely ATI and NVIDIA.

 

Compared to other drivers, GPU drivers are different for two reasons. First is the sheer complexity of the drivers - besides interfacing with the hardware, the drivers are responsible for memory management, compiling/optimizing shader code, and providing a great deal of feedback. This in essence makes GPU drivers their own little operating system – one that its developers aren’t necessarily willing to share. The second significant difference here is because of the above, GPU drivers are among the only drivers that have a compelling reason to be updated regularly; they need to be updated to better support newer games and fix bugs in the complex code that runs through them.

Complicating matters further is that some intellectual property in GPUs and drivers is not the property of the company who makes the GPU. AMD doesn’t own everything in their Universal Video Decoder, and just about everyone has some SGI IP in their drivers. In the interest of protecting that IP, it is difficult to release the code for those drivers containing other companies’ IP.

Because of all of this, manufacturer-supplied GPU drivers are not always open source. Intel and S3 do well in this respect (largely because they have few tricks to hide, I suspect), but hyper-competitive NVIDIA and AMD do not. AMD has been looking to rectify this, and back in 2007 we discussed their starting work on a new open source driver. Development has been progressing slowly, and for the R6xx and R7xx hardware, the open source driver is not yet complete. Meanwhile NVIDIA has shown no real interest in an open source driver for their current hardware.

So if you want to use a modern, high-performance video card with Linux, you have little choice but to also deal with a binary blob driver for that card, and this becomes problematic since as we mentioned Linux is designed to discourage such a thing. Both AMD and NVIDIA have found ways around this, but the cost is that installing a binary driver is neither easy, or bug free.

The fundamental method that both use for accomplishing this is through the use of a kernel shim. Both analyze the headers for the kernel to identify how the kernel is organized, then they compile a shim against that kernel. The shim resolves the issues with the lack of a stable API, and the other end of the shim provides the stable API that NVIDIA and ATI need.

Ubuntu in particular takes this one step further, and in the interest of promoting greater out of the box hardware compatibility, includes a version of the binary drivers with the distribution. This is unusual for a Linux distribution and has earned Ubuntu some flak since it’s not strictly adhering to some open source ideals, but it also means that we were not forced to play with driver installers to get Ubuntu fully working. Ubuntu had no issues with both our AMD 2900XT and NVIDIA 8800GTX cards, both of which were picked specifically because we wished to test Ubuntu on suitably old hardware which would exist in time for Ubuntu to include support for it. With that said, the drivers Ubuntu includes are understandably old (once again owing to the idea of a stable platform) which means we can’t avoid installing drivers if we want better performance and application compatibility.

And this is where “easy” comes to an end. We’ll first start with AMD’s installer, the easier of the two. They have a GUI installer that puts in a driver along with a Linux version of the Catalyst Control Center. It’s Spartan, but it gets the job done.

NVIDIA on the other hand does not have a GUI installer – their installer is a text mode installer that requires shutting down the X server (the GUI) in order to install. It’s difficult to understate just how hard this makes driver installation. Not only is doing all of this completely non-obvious, but it requires interfacing with the CLI in a way we were specifically trying to avoid. It’s something that becomes bearable with experience, but I can’t call it acceptable.

Driver upgrades are an issue on both sides, because the installers are not completely capable of finding and eliminating older versions of the binary drivers. In one instance, for the NVIDIA drivers we had to track down a rather sizable shell script that automatically deleted the old drivers before installing the new ones, as that was deemed the “right” way to install the drivers. We had less of an issue with ATI’s drivers, but to be fair the primary card I used for my time with Ubuntu was the 8800GTX. I can’t confidently say that there are not other issues that I may have not run in to.

The Ubuntu community does supply tools to help with GPU driver installations, Once such tool is EnvyNG, which reduces the driver installation process to selecting what driver you want to install and it does the rest. This is a far easier way to install drivers, in the right situation it’s even easier than it already is under Windows. But it suffers from needing to have the latest driver data hardcoded in to it, which means you can only use it to install drivers it knows about, and nothing newer. It’s not regularly updated (as of this writing the latest driver versions it has are NV 173.14.12 and ATI Catalyst 8.6) so it’s good for installing newer drivers, but not the newest drivers.

The other tool is access to Ubuntu’s Personal Package Archives, which are a collection of user-built binaries that can be installed through the Ubuntu package manager (more on this later). It’s harder to use than EnvyNG, but anyone can build a PPA, which makes updates more likely. As it’s user-generated however, this still means that there won’t always be the latest drivers available, which means we’re still back to using ATI and NVIDIA’s installers.

As it stands, installing new GPU drivers on Ubuntu is between an annoyance and unbearable, depending on how many hoops you need to jump through. It’s certainly not easy.

The other problem with GPU drivers is that they do not always stay working. Among the issues we encountered was ATI’s driver failing to work after installing an Ubuntu update, and an NVIDIA driver that kept rebooting the system during testing for reasons we never determined (once we wiped the system, all was well).

Our final issue with the state of GPU drivers on Ubuntu is their overall quality. With a bit of digging we can come up with issues on both sides of the isle, so it’s not as if either side is clean here. But with that said, we only ended up experiencing issues with ATI’s drivers. We encountered some oddities when moving windows that was eventually fixed in the Catalyst 9.3 drivers. It turns out that the problem was that ATI’s drivers lacked support for redirected OpenGL rendering; Linux guru Phoronix has a great article on what this is, including videos, that explains the importance of this change.

Ultimately we hate to sound like we’re beating a dead horse here, but we can’t ignore the GPU driver situation on Ubuntu (and really, Linux as a whole). The drivers have too many issues, and installing newer drivers to fix those issues is too hard. Things could be worse, Ubuntu could only distribute driver updates with OS updates ala Apple, but they could also be better. For the moment it’s the weakest point for Ubuntu when it comes to installing it on a high-end system.

What’s the Value of Technical Support, Anyhow? The Package Manager – A Love/Hate Relationship
Comments Locked

195 Comments

View All Comments

  • tabuvudu - Saturday, August 29, 2009 - link

    The article is a good job overall. Below are a few of my own observations concerning the article and linux in general.

    ###Package manager
    I never used Ubuntu, so cannot comment on apt. I tried SuSE, mandriva and eventually ended up with Gentoo. I think package managers are the best part of linux. Gentoo's portage and 'emerge --sync' allows you to be always up-to-date in terms of software, no need to ever reinstall the system. It is CLI-based and sometimes you do have to play a bit with USE-flags and compatibility, but in general 99.99% of my software needs can be satisfied by portage.

    ###Command Line Interface
    For my home needs I switched from windows to linux about 4 years ago. At work I still use windows, but that is due to corporate policies rather than preference. Originally CLI was something terrifying. It took me some time to learn and adapt, but now I do most of system tasks in CLI.

    ###Video drivers
    I does take some effort when doing something non-standard (1080p projector connected to HDMI via av-receiver). But in general in gentoo it is usually as easy as typing 'emerge [nvidia]/[ati]-drivers'. Even double-monitor setups, which I have two. Dont forget the open-source xorg drivers, which are usually fine for simple desktop and come pre-bundled.

    ###Gaming...
    ...is much harder under linux. In my case not relevant, as I spent less than 1% of my time to that over the past 2 years. Others may find this a real obstacle for migration.

    ###Syncing...
    ...your devices is also a headache. I even once succeeded in syncing my windows mobile 5 device with evolution. But amount of efforts taken for that was far too great. I never even tried syncing my nokia phones after that.

    ###Usage scenarios
    I think you judge Ubuntu (and linux in general) in very windows-centric usage patterns. Ubuntu is unlikely to out-windows the original, although OSX seems to have done just that. Even the approach is windows-centric - you take a windows app and compare linux against it. The point is that linux in general allows user to open and develop completely different usage scenarios, which are beyond windows. Allow me to elaborate on the basis of my own experience.

    ###In search of killer app...
    You note in the article that there is no linux killer app. I disagree.
    1. I run linux homeserver. It has proxy (squid) and attached antivirus filter (clamav+squidclamav). It has array of software raid (mdadm). I also run web-server (apache) with gallery of photos (gallery2). There is a mail server (postfix) for a few accounts. Filesharing is done via nfs and samba. Finally I run mythtv backend server with 4 tuners. I never tried to replicate this software stack in windows, it is likely possible but require some pretty expensive licenses. Some of the thing like mythtv server are impossible under windows to the best of my knowledge.

    2. dvdrip + transcode allows me to rip dvds and transcode them simultaneously on 4 client machines with total 12 processing cores. Transcoding is usually done under 15 mins.

    3. I mentioned mythtv. I have centralised server and a number of clients. TV at the house is done via LAN, i.e. small x86 boxes with output to TV screen. Integrated mythtv client interface allows watching movies or listening to music from central storage, light browsing and so on at every TV.

    4. The small x86 boxes are network-booted from server (in.tftpd + nfs). This allows easy management of software, i.e. single image for all clients. Never tried that under windows, likely possible but costly.

    5. One of the clients is an HP thin-client with only 1G of local storage. I ended up network-booting it anyway, but initially compiled a full gentoo system (kernel, X, fully-fledged window manager (XFCE-4), mythtv client, browser (firefox), mail client (claws-mail), media player (mplayer + GUI)) under 1G. If I spent a bit more time, I think I could even fit office in that space. Not possible under windows.

    6. There are other things that i have not even explored. Like asterisk for ip telephony. Or projects like opengoo, which allow you to run your own server-based set of office apps.

    ###The bottomline
    I think a fair comparison should not focus on things that windows is known to do best. I think getting familiar with linux will enable one to find his own killer app, which cant be replicated in windows at reasonable cost. But this would require a reasonable time and efforts, which are beyond the scope of the article.

  • tabuvudu - Saturday, August 29, 2009 - link

    a couple of more things which i forgot to mention in my previous post:

    ###mounting network shares
    your troubles seemed quite strange to me. Maybe this is because of Ubuntu implementation. This is usually done very well by linux. I do it in /etc/fstab. I agree with some previous posters, this is largely due to lack of linux experience, so should not be used in final assessment.

    ###benchmarks
    are quite useless. I dont think you should dedicate much time in the article to that. For majority of desktop applications, plus or minus 10-15% does not make much difference.

    ###other interesting projects
    another example of ltsp. Again, there are alternatives in windows, but licensed and pricey.
  • Kjella - Friday, August 28, 2009 - link

    If you have a Windows CD lying around I highly recommend using virtualbox and installing Windows on it. For any low-performance application it'll work 100%, but it's not made for gaming. But except for gaming it should reduce your dual boot time to near zero. WINE is great for hackers and idealists but unless the application got a platinum/gold rating new users should not use it.

    As for support time, let me put it this way... do you keep XP for 10 years to run 10 year old installations? As the distro is for the most time supplying the applications, it's like being stuck ten years in the past. This is more like a free upgrade from Office 97 -> XP (2000) -> 2003 -> 2007 -> 2010 every few years.

    Is it pefect? No. But a lot of it is that Canonical can't tell you the easy ways of fixing things. Most of the things on this page should be done first time you boot a fresh Ubuntu install:

    https://help.ubuntu.com/community/RestrictedFormat...">https://help.ubuntu.com/community/RestrictedFormat...

    Good luck to everyone that feel like trying :)
  • yasbane - Friday, August 28, 2009 - link

    It's great to see Linux on the front page of Anandtech once again!

    Linux use on the Desktop is getting more attention, and its use is growing (though still only a very small fraction of the total market). I'm a huge fan of Linux (as well as Solaris and BSD), and I found Ryan's review very fair and informative. As with any OS, it is important to accept weaknesses as well as strengths, so that it can grow and improve. The strength of Linux has mostly been in the server world, but especially in the last couple of years, it has become much more user friendly on the desktop. These days, I have been able to install it on machines for people with no prior familiarity of Linux, and have found, in most cases no significant issues. There are definitely still things that can be improved though, (audio issues are the biggest one), but overall it is good news. Some people have commented 'Why bother? Windows does everything I need!', but I think competition is a good thing for desktop computing (and just about anywhere), as the saga of Internet Explorer's decline in the demise of Netscape proved. Mac OS X of course is there, especially at the higher end, but Linux is also beginning to make an impact on generic hardware (Netbooks being a good example), which has meant that Microsoft has had to lift its game and drop prices.

    To answer Ryan's question, in terms of what I would like to see for Linux on Anandtech: in addition to benchmarks for consumer hardware running Linux, guides such as building a home server or HTPC, where using Linux is an appropriate option, alongside Mac or Windows; for some things, such as gaming there's much less point of course. IT Anandtech used to feature Linux server and virtualisation benchmarks, which made a lot of sense since Linux's greatest strength is in servers, although these benchmarks and reviews have been mysteriously absent lately. And of course, news from the world of Linux, such as new products with Linux on them, new kernel features, popular distro releases such as Ubuntu, and general headlines (e.g., Dell's recent comment that netbook return rates were no higher for Linux than for Windows).

    Great to read the comments. Many thanks, Anandtech!

  • beginner99 - Friday, August 28, 2009 - link

    This explains why I'm not using and won't use Linux in the near future for my regular PC. As long as I need windows anyway (and pay) there is for me even as "above average" user no need for Linux. I think I can do anything I need on windows, so why should I get Linux additionally to Windows? Makes no sense for me and not for most other users that are not developers, geeks or idealists.
    That will only change if you do not need windows at all, eg. you can game on Linux with same performance than on windows.

    The only thing I can imagine using Linux is on a HTPC. Take one of the new ION nettops without OS and put on LinuxMCE or Linux with XBMC. But I have no idea how easy that is and how good it works. But there I would really benefit from the fact that Linux is free. (else the whole price will go up by like by 50% ;)).
    I might actually try.
  • kc77 - Friday, August 28, 2009 - link

    As someone who has used Ubuntu primarily for at least 4 years now I can say there are things that only come with time. Namely what applications to use for what. I primarily use Ubuntu because out of the box it installs most of the stuff I need right out of the box. However, that doesn't mean it installs EVERYTHING you need. Particularly when it comes to audio management. That package manager is your GOD in more ways than one once you realize that aside from running the latest drivers (which aside from us there aren't many other people that do and you aren't gaming on Linux unless you are using Cedega or Crossover) it provides you really with just about any program you need.

    So...
    Audio Management - Remember you can mix and match KDE/Gnome. So for this I would use Amarok 1.4. It can sync with iPods and offers the ability to have your music collection residing in a SQL database. That alone had me smiling for days. I have about 70GB of music which it can catalog in about 5 min. Try that in iTunes or WMP. With it being in MYSQL any program I want to have access to my
    collection can. In 9.04 you'll need to add the repository as it installs 2.0 of Amarok by default (which isn't as feature rich).

    As an aside, Rhythmbox can now rip from inside the program. It might just be because you are using 8.04 but I know it does it now. However, Sound Juicer gives you more options with MP3 Tags as well as file types.

    Video Editing / Mastering

    If you want a program like Nero Vision, check out Devede, ManDVD is pretty good for DVD mastering. Both of those should be in the Package Manager. If they aren't their web sites offer debs. Just download and double-click.

    Burning
    If you don't like Brasero head to the package manager and get K3B. It's about as close to Nero as one can get.

    SMB
    The problems you've experienced are due to version. Browsing the root of a server has been fixed. It takes a little longer for the shares to appear than I would like it to, but it does work now.
    Mapping "drives" as it were depends on the route you take. "Connect to Server" I believe creates a mount point under your media folder. I really haven't had much of a problem with this as most programs do recognize bookmarks, and for all of my shares one of the first things I do is set it in my FSTAB which essentially hard links my shares which avoids the problem entirely as every program can see a mount point. Basically there's about 5 different ways to go about this issue just choose the one that works best.

    ISOs
    One thing with ISO is that File Roller reads them natively. So unzip it and install from there. It's not like hard drive space is scare now a days.

    Customization
    My closing thought is that remember Ubuntu is not Gnome. Meaning that Ubuntu just creates the packages for it's distribution. Everything in linux is customizable. Don't like the bar at the bottom? Delete it. Want a tray like OSX? There's tons to choose from. I've done some OS modding and I can make Gnome look like Windows XP or Mac OSx (and mimic it's functionality). You aren't limited here.

    Thats' the thing with linux the more time you spend (and really I'm talking about days here not months) the more programs you'll come across which will do what you want. Don't like Transmission? Use Ktorrent. Hell even Utorrent works very well with Wine.


    Overall I liked your review.... even though I've had to wait for it...




  • dfonseca - Thursday, August 27, 2009 - link

    Great article, congrats. Looking forward for part 2.

    My only criticism is that for both intermediate (topic-specific) verdicts and final (first?) thoughts, the non-techie average-joe end user point of view is given way too much weight. Not only do these people not read AT, but they also don't use objective judgement to decide their OSs. These are the people who will go with the flow, which will be dictated by other people. In short, the article focuses on helping joe6pack, but joe6pack doesn't care.

    I believe it would be more productive, when passing comparative judgement, to narrow the focus on aspects more strongly connected to wide adoption - deployment (installation & out-of-the-box functionality), large-scale maintenance ease, support, productivity (office) software, and why not, bang for buck. Some of them are already being considered, and maybe they just need to be given higher relevance.

    Cheers
  • dontruman - Thursday, August 27, 2009 - link

    I have used Windows since the 3.0 days and am currently running RC7 on my home desktop. I think that it is significant that the hardware resources required by Ubuntu and Linux in general are much lower than Windows and can give new life to an old laptop or desktop. Ubuntu recognized and set up all the hardware without a hitch on my Dell Inspiron E1505 and my newer office Q9550 quad. A reasonably older system running on Linux can perform standard tasks at speeds close or equal to newer hardware running any of the Windows operating systems. The boot time for Ubuntu is also significantly shorter.

    It's no coincidence that the ASUS PC1000 netbook, with its solid state hard drive ships with Linux. Mine came with a version of Mandriva linux that is obviously designed for newbies, and doesn't provide nearly as large a set of software repositories as Ubuntu. I replaced it with Eee specific version of Ubuntu and have been very pleased with results. It quickly performs daily tasks such as office work via Openoffice 2.5, browsing (I use Opera) and email (Thunderbird). The difference in observable speed between my Eee and the i7 system I recently built is negligible. Of course I'm not talking about CPU intensive tasks, including Google Earth, where the i7 is many magnitudes faster. But for everyday mobile tasks I use the Eee. (The Inspiron is way too hot).

    I have to disagree about the Synaptic Package Manager. You can Google 3rd party Linux repositeries, such as Medibuntu,that contain multimedia codecs and other interesting Linux software. (Be careful & research 3rd party repositories to avoid unpleasant surprises.) You can add these 3rd party repositories to your permanent list of software sources so that when updates to that software are created Ubuntu notifies you and allows you to accept the updates you want. Using a USB powered external DVD drive I can watch movies on my Eee or rip & compress them on the i7 system and put them on a flash drive or card. Once you get the comression formats tuned you have a good, light weight, computer/multimedia system with excellent battery life; good for two movies. All this on a two year old Intel Atom powered netbook.

    I've played around with Linux for some time but I found it too alien & command line driven using a command set that has very little in common with MS or DR DOS. But over the last several years Linux has been improving at an accelerating rate. All that's needed now is a high quality Wine (Windows emulator) program that will allow you to run all your Windows specific software on Linux without a performance loss. It's a difficult undertaking but Wine has been steadily improving and there are now commercial Linux distros that guarantee compatability with specific Windows programs.

    I recommend putting it on an old hard drive & give it a whirl. And try several versions; there are a lot of free ones out there. I recommend Ubuntu, OpenSUSE and Mandriva for starts. Why pay for the cow when you can get the milk for free?
  • fffblackmage - Thursday, August 27, 2009 - link

    Unfortunately, most of the same problems mentioned in the article are keeping me from switching to Ubuntu as my primary OS. As far as gaming is concerned, I'll be going with Win7 (I'm still using XP atm).

    If I ever get a netbook or non-gaming laptop, I'll certainly consider Ubuntu. However, the likelihood of moving to Ubuntu when the laptop comes with Win7 will probably be very small, unless I can somehow get a refund for not using Win7.

    Also, I guess some people do like the new GUI in MS Office. I found it annoying as I'm still using to the old GUI. But I suppose in time, I may learn to accept it like how I eventually accepted the XP look.
  • sanjeev - Thursday, August 27, 2009 - link

    Yesterday, the manufacturer was Canon, today its "Canonical". Is Ubuntu manufactured by different(or types) vendors ?
    ... just asking :).

    I'm yet to finish 25 (+ 11) more pages .

Log in

Don't have an account? Sign up now