- Binary blob
In open source culture, binary blob is a pejorative term for an object file loaded into the kernel of a free or open source
operating system without publicly availablesource code . The term is not usually applied to code running outside the kernel, for exampleBIOS code,firmware images, or userland programs.When
computer hardware vendors provide complete technical documentation for their products, operating system developers are able to write hardware device drivers to be included in the operating system kernels. However, some vendors, such asNVIDIA , do not provide complete documentation for some of their products and instead provide binary-only drivers (binary blobs); this practice is most common for accelerated graphics drivers, networking devices andRAID controllers.Acceptance
When they can neither get hardware documentation nor device driver source code from a hardware vendor, some operating system projects, including
NetBSD ,FreeBSD ,DragonFly BSD , and someGNU /Linux distribution s, accept binary blobs as a fast route to the missing or enhanced functionality these blobs provide.cite web | url = http://os.newsforge.com/os/05/06/09/2132233.shtml?tid=8&tid=2 | title = BSD cognoscenti on Linux | accessdate = 2006-07-07 | last = Matzan | first = Jem | date =15 June 2005 | publisher = NewsForge See Christos Zoulas's response to "Is sharing between Free/Open/NetBSD and the Linux kernel a common occurrence? And if so, does it go both ways?"]The
OpenBSD project has a notable policy of not accepting any binary blobs into its source tree, citing not only the potential for undetectable or irreparable security flaws but also its encroachment onto the openness and freedom of their software. [cite web|last = Music composed by Ty Semaka and Jonathan Lewis. Recorded, mixed and mastered by Jonathan Lewis of Moxam Studios (1-403-233-0350). Vocals and Lyrics by Ty Semaka & Theo de Raadt. Bass guitar, organ and bubbles by Jonathan Lewis. Guitar by Tom Bagley. Drums by Jim Buick|url = http://www.openbsd.org/lyrics.html#39|title = 3.9: "Blob!"|publisher = OpenBSD|accessdate = 2006-06-22]Among GNU/Linux distributions, the
gNewSense distribution is the most known for being actively against binary blobs. TheFree Software Foundation (FSF) is actively campaigning against binary blobs and recommends gNewSense. [cite web|url=http://www.fsf.org/blogs/community/rms-ati-protest.html|title=Protest against ATI nearly led to the arrest of RMS|date=27 April 2006 |accessdate=2006-10-10|publisher=Free Software Foundation]Use via wrappers
In order to make use of binary blob drivers available for other operating systems, some projects include software wrappers: examples include
NdisWrapper forLinux and Project Evil forFreeBSD andNetBSD , both of which implementMicrosoft 's NDIS API to allow drivers written forMicrosoft Windows to be used.Problems
There are a number of reasons why binary blobs can cause problems: users cannot modify the software and distribute modified versions; blobs are unportable and typically limited to a few hardware architectures; the correctness of the driver code cannot be checked; the code cannot be audited for security by users or third parties; users are forced to trust vendors not to put backdoors and spyware into the blob; in case of bugs or vulnerabilities, the driver cannot be repaired by operating system developers; and the hardware vendor can decide not to support some operating systems or to abandon driver maintenance at any time. [cite web | url = http://kerneltrap.org/node/6497 | first = Jeremy | last = Andrews | title = Interview with Jonathan Gray and Damien Bergamini | accessdate = 2008-01-06 | date = 2006-04-19 | publisher = kerneltrap.org ]
According to Microsoft, 28% of all crashes of their Vista operating system in 2007 were due to bugs in the binary blob drivers for
Nvidia graphics cards. [cite web
url=http://arstechnica.com/news.ars/post/20080325-vista-capable-lawsuit-paints-picture-of-buggy-nvidia-drivers.html
title=Vista-capable lawsuit paints picture of buggy NVIDIA drivers
publisher=Ars technica]Firmware
Firmware , the operating software required by a device's onboardmicrocontroller that accompanies some hardware, is generally not considered to be a binary blob. However, the FSF has begun campaigning for free BIOS firmware. [cite web|url=http://www.fsf.org/campaigns/free-bios.html|title=Campaign for Free BIOS|publisher=Free Software Foundation|date=2006-11-29|accessdate=2007-01-02] Often firmware is stored in onboardflash memory , but to decrease costs and ease upgrading, some manufacturers now use external firmware uploaded by the operating system. Although the firmware is present in the operating system, it is merely copied to the device and not executed by the CPU, lessening concerns about hidden security flaws. The OpenBSD project accepts binary firmware images and will redistribute the images if the licence permits. [cite web | title = OpenBSD Works To Open Wireless Chipsets|date =November 2 2004 |publisher=KernelTrap|url = http://kerneltrap.org/node/4118 | accessdate = 2006-06-23]See also
*
LinuxBIOS
*Loadable kernel module
*Wireless security
*Proprietary firmware
*Proprietary software References
External links
*
* [http://kerneltrap.org/node/6650 KernelTrap article] on Damien Bergamini's wpi(4) driver, a blobless ipw3945 alternative for OpenBSD
* [http://kerneltrap.org/node/6497 KernelTrap interview] with Jonathan Gray and Damien Bergamini regarding binary blobs
* [http://blog.washingtonpost.com/securityfix/2006/08/the_macbook_wireless_exploit_i.html The Black Hat Wireless Exploit Interview, Verbatim] by Brian Krebs on the Washington Post's website, http://washingtonpost.com
Wikimedia Foundation. 2010.