Software:OpenBSD

From HandWiki
Revision as of 20:54, 31 August 2021 by imported>Wikisleeper (url)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Short description: Security-focused Unix-like operating system
OpenBSD
Puffy, the pufferfish mascot of OpenBSD posing in the official logo.
Free, Functional, and Secure
Openbsd61 desktop.png
OpenBSD 6.1 default desktop with various utilities: top, xterm, xclock, xcalc, glxgears
DeveloperThe OpenBSD Project
Written inC, assembly, Perl, Unix shell
OS familyUnix-like
Working stateCurrent
Source modelOpen source
Initial releaseJuly 1996; 28 years ago (1996-07)
|Final release|Latest release}}7.4 (16 October 2023; 13 months ago (2023-10-16)) [±]
Package managerOpenBSD package tools[1]
PlatformsAlpha, x86-64, ARMv7, ARMv8 (64-bit), PA-RISC, IA-32, LANDISK, Omron LUNA-88K, Loongson, MIPS64, PowerPC, SPARC64[2]
Kernel typeMonolithic
UserlandBSD
Default user interfaceModified pdksh, X11 (FVWM)
LicenseBSD, ISC, other permissive licenses[3]

OpenBSD is a security-focused, free and open-source, Unix-like operating system based on the Berkeley Software Distribution (BSD). Theo de Raadt created OpenBSD in 1995 by forking NetBSD. According to the website, the OpenBSD project emphasizes "portability, standardization, correctness, proactive security and integrated cryptography."[4]

The OpenBSD project maintains portable versions of many subsystems as packages for other operating systems. Because of the project's preferred BSD license, many components are reused in proprietary and corporate-sponsored software projects. Android's Bionic C standard library is based on OpenBSD code,[5] LLVM uses OpenBSD's regular expression library,[6] and Windows 10 uses OpenSSH (OpenBSD Secure Shell) with LibreSSL.[7]

The word "open" in the name OpenBSD refers to the availability of the operating system's source code on the Internet, although the word "open" in the name OpenSSH means "OpenBSD". It also refers to the wide range of hardware platforms the system supports.[8]

History

Bar chart showing the proportion of users of each BSD variant from a 2005 BSD usage survey.[9][n 1]

In December 1994, Theo de Raadt, a founding member of the NetBSD project, was asked to resign from the NetBSD core team.[10][11] In October 1995, De Raadt founded OpenBSD, a new project forked from NetBSD 1.0. The initial release, OpenBSD 1.2, was made in July 1996, followed by OpenBSD 2.0 in October of the same year.[12] Since then, the project has issued a release every six months, each of which is supported for one year.

On 25 July 2007, OpenBSD developer Bob Beck announced the formation of the OpenBSD Foundation, a Canadian non-profit organization formed to "act as a single point of contact for persons and organizations requiring a legal entity to deal with when they wish to support OpenBSD."[13]

It is hard to determine how widely OpenBSD is used, because the developers do not publish or collect usage statistics. In September 2005, the BSD Certification Group surveyed BSD users, showing that 33 percent used OpenBSD,[9] behind FreeBSD with 77 percent and ahead of NetBSD with 16 percent.[n 1]

Uses

OpenBSD startup in console mode
OpenBSD console login and welcome message

Network appliances

OpenBSD features a robust TCP/IP networking stack, and can be used as a router[14] or wireless access point.[15] OpenBSD's security enhancements, built-in cryptography, and packet filter make it suitable for security purposes such as firewalls,[16] intrusion-detection systems, and VPN gateways.

Several proprietary systems are based on OpenBSD, including devices from Armorlogic (Profense web application firewall), Calyptix Security,[17] GeNUA,[18] RTMX,[19] and .vantronix.[20]

Foreign operating systems

Some versions of Microsoft's Services for UNIX, an extension to the Windows operating system to provide Unix-like functionality, use much OpenBSD code included in the Interix interoperability suite,[21][22] developed by Softway Systems Inc., which Microsoft acquired in 1999.[23][24] Core Force, a security product for Windows, is based on OpenBSD's pf firewall.[25]

Personal computers

OpenBSD ships with Xenocara,[26] an implementation of the X Window System, and is suitable as a desktop operating system for personal computers, including laptops.[27][28]:xl (As of September 2018), OpenBSD includes approximately 8000 packages in its software repository,[29] including desktop environments such as GNOME, Plasma 4, and Xfce, and web browsers such as Firefox and Chromium.[30] The project also includes three window managers in the main distribution: cwm, FVWM (part of the default configuration for Xenocara), and twm.[31]

Servers

OpenBSD features a full server suite and can be configured as a mail server, web server, FTP server, DNS server, router, firewall, NFS file server, or any combination of these.

Security

Shortly after OpenBSD was created, De Raadt was contacted by a local security software company named Secure Networks (later acquired by McAfee).[32][33] They were developing a network security auditing tool called Ballista,[n 2] which was intended to find and exploit software security flaws. This coincided with De Raadt's interest in security, so the two cooperated leading up to the release of OpenBSD 2.3.[34] This collaboration helped to define security as the focus of the OpenBSD project.[35]

OpenBSD includes numerous features designed to improve security, such as:

  • Secure alternatives to POSIX functions in the C standard library, such as strlcat for strcat and strlcpy for strcpy[36]
  • Toolchain alterations, including a static bounds checker[37]
  • Memory protection techniques to guard against invalid accesses, such as ProPolice and the W^X page protection feature
  • Strong cryptography and randomization[38]
  • System call and filesystem access restrictions to limit process capabilities[39]

To reduce the risk of a vulnerability or misconfiguration allowing privilege escalation, many programs have been written or adapted to make use of privilege separation, privilege revocation and chrooting. Privilege separation is a technique, pioneered on OpenBSD and inspired by the principle of least privilege, where a program is split into two or more parts, one of which performs privileged operations and the other—almost always the bulk of the code—runs without privilege.[40] Privilege revocation is similar and involves a program performing any necessary operations with the privileges it starts with then dropping them. Chrooting involves restricting an application to one section of the file system, prohibiting it from accessing areas that contain private or system files. Developers have applied these enhancements to OpenBSD versions of many common applications, such as tcpdump, file, tmux, smtpd, and syslogd.[41]

OpenBSD developers were instrumental in the creation and development of OpenSSH (aka OpenBSD Secure Shell), which is developed in the OpenBSD CVS repositories. OpenBSD Secure Shell is based on the original SSH.[42] It first appeared in OpenBSD 2.6 and is now by far the most popular SSH client and server, available on many operating systems.[43]

The project has a policy of continually auditing source code for problems, work that developer Marc Espie has described as "never finished ... more a question of process than of a specific bug being hunted." He went on to list several typical steps once a bug is found, including examining the entire source tree for the same and similar issues, "try[ing] to find out whether the documentation ought to be amended", and investigating whether "it's possible to augment the compiler to warn against this specific problem."[44]

Security record

The OpenBSD website features a prominent reference to the system's security record. Until June 2002, it read:

In June 2002, Mark Dowd of Internet Security Systems disclosed a bug in the OpenSSH code implementing challenge–response authentication.[45] This vulnerability in the OpenBSD default installation allowed an attacker remote access to the root account, which was extremely serious not only to OpenBSD, but also to the large number of other operating systems that were using OpenSSH by that time.[46] This problem necessitated the adjustment of the slogan on the OpenBSD website to:

The quote remained unchanged as time passed, until on March 13, 2007, when Alfredo Ortega of Core Security Technologies[47] disclosed a network-related remote vulnerability.[48] The quote was subsequently changed to:

This statement has been criticized because the default install contains few running services, and many use cases require additional services.[49] Also, because the ports tree contains unaudited third-party software, it is easy for users to compromise security by installing or improperly configuring packages. However, the project maintains that the slogan is intended to refer to a default install and that it is correct by that measure.

One of the fundamental ideas behind OpenBSD is a drive for systems to be simple, clean, and secure by default. The default install is quite minimal, which the project states is to ensure novice users "do not need to become security experts overnight",[50] which fits with open-source and code auditing practices considered important elements of a security system.[51]

Alleged backdoor

On 11 December 2010, Gregory Perry, a former technical consultant for the Federal Bureau of Investigation (FBI), emailed De Raadt alleging that the FBI had paid some OpenBSD ex-developers 10 years prior to insert backdoors into the OpenBSD Cryptographic Framework. De Raadt made the email public on 14 December by forwarding it to the openbsd-tech mailing list and suggested an audit of the IPsec codebase.[52][53] De Raadt's response was skeptical of the report and he invited all developers to independently review the relevant code. In the weeks that followed, bugs were fixed but no evidence of backdoors was found.[54] De Raadt stated "I believe that NetSec was probably contracted to write backdoors as alleged. If those were written, I don't believe they made it into our tree. They might have been deployed as their own product."[55]

Criticisms

In December 2017, Ilja van Sprundel, director at IOActive, gave a talk at the CCC[56] as well as DEF CON,[57] entitled "Are all BSDs created equally? — A survey of BSD kernel vulnerabilities.", in which he stated that although OpenBSD was the clear winner of the BSDs in terms of security, "Bugs are still easy to find in those kernels, even in OpenBSD".

Two years later, in 2019, a talk named "A systematic evaluation of OpenBSD’s mitigations" was given[58] at the CCC, arguing that while OpenBSD has some effective mitigations, a significant part of them are "useless at best and based on pure luck and superstition", arguing for a more rational approach when it comes to designing them.[59]

Hardware compatibility

Supported platforms and devices are listed in the OpenBSD Supported Platforms Notes.[60] Other configurations may also work, but simply have not been tested or documented yet. Rough automatically extracted lists of supported device ids are available in a third party repository.[61]

In 2020, a new project was introduced to automatically collect information about tested hardware configurations.[62]

Subprojects

Many open source projects started as components of OpenBSD, including:



Some subsystems have been integrated into other BSD operating systems,[71][72][73] and many are available as packages for use in other Unix-like systems.[74][75][76]

Linux administrator Carlos Fenollosa commented on moving from Linux to OpenBSD that the system is faithful to the Unix philosophy of small, simple tools that work together well: "Some base components are not as feature-rich, on purpose. Since 99% of the servers don't need the flexibility of Apache, OpenBSD's httpd will work fine, be more secure, and probably faster".[77] He characterized the developer community's attitude to components as: "When the community decides that some module sucks, they develop a new one from scratch. OpenBSD has its own NTPd, SMTPd and, more recently, HTTPd. They work great".[77] As a result, OpenBSD is relatively prolific in creating components that become widely reused by other systems.

OpenBSD runs nearly all of its standard daemons within chroot and privsep security structures by default, as part of hardening the base system.[77]

The Calgary Internet Exchange was formed in 2012, in part to serve the needs of the OpenBSD project.[78]

Third-party components

OpenBSD includes a number of third-party components, many with OpenBSD-specific patches,[30] such as X.Org, Clang[79] (the default compiler on several architectures), GCC,[37][n 3] Perl, NSD, Unbound, ncurses, GNU binutils, GDB, and AWK.

Development

OpenBSD developers at c2k1 hackathon at MIT, June 2001

Development is continuous, and team management is open and tiered. Anyone with appropriate skills may contribute, with commit rights being awarded on merit and De Raadt acting as coordinator.[28]:xxxv Two official releases are made per year, with the version number incremented by 0.1,[80] and these are each supported for twelve months (two release cycles).[81] Snapshot releases are also available at frequent intervals.

Maintenance patches for supported releases may be applied manually or by updating the system against the patch branch of the CVS repository for that release.[82] Alternatively, a system administrator may opt to upgrade using a snapshot release and then regularly update the system against the -current branch of the CVS repository, in order to gain pre-release access to recently added features.

The generic OpenBSD kernel provided by default is strongly recommended for end users, in contrast to operating systems that recommend user kernel customization.[83]

Packages outside the base system are maintained by CVS through a ports tree and are the responsibility of the individual maintainers, known as porters. As well as keeping the current branch up to date, porters are expected to apply appropriate bug-fixes and maintenance fixes to branches of their package for OpenBSD's supported releases. Ports are generally not subject to the same continuous auditing as the base system due to lack of manpower.

Binary packages are built centrally from the ports tree for each architecture. This process is applied for the current version, for each supported release, and for each snapshot. Administrators are recommended to use the package mechanism rather than build the package from the ports tree, unless they need to perform their own source changes.

OpenBSD's developers regularly meet at special events called hackathons,[84] where they "sit down and code", emphasizing productivity.[85]

OpenBSD hackathon s2k17

Most new releases include a song.[86]

Open source and open documentation

OpenBSD is known for its high-quality documentation.[87][88]

When OpenBSD was created, De Raadt decided that the source code should be available for anyone to read. At the time, a small team of developers generally had access to a project's source code.[89] Chuck Cranor[90] and De Raadt concluded this practice was "counter to the open source philosophy" and inconvenient to potential contributors. Together, Cranor and De Raadt set up the first public, anonymous CVS server. De Raadt's decision allowed users to "take a more active role", and established the project's commitment to open access.[89]

OpenBSD does not include closed source binary drivers in the source tree, nor do they include code requiring the signing of non-disclosure agreements.[91]

Since OpenBSD is based in Canada, no United States export restrictions on cryptography apply, allowing the distribution to make full use of modern algorithms for encryption. For example, the swap space is divided into small sections and each section is encrypted with its own key, ensuring that sensitive data does not leak into an insecure part of the system.[16]

OpenBSD randomizes various behaviors of applications, making them less predictable and thus more difficult to attack. For example, PIDs are created and associated randomly to processes; the bind system call uses random port numbers; files are created with random inode numbers; and IP datagrams have random identifiers.[92] This approach also helps expose bugs in the kernel and in user space programs.

The OpenBSD policy on openness extends to hardware documentation: in the slides for a December 2006 presentation, De Raadt explained that without it "developers often make mistakes writing drivers", and pointed out that "the [oh my god, I got it to work] rush is harder to achieve, and some developers just give up."[93] He went on to say that vendor-supplied binary drivers are unacceptable for inclusion in OpenBSD, that they have "no trust of vendor binaries running in our kernel" and that there is "no way to fix [them] ... when they break."[93]

Licensing

OpenBSD maintains a strict license policy,[3] preferring the ISC license and other variants of the BSD license. The project attempts to "maintain the spirit of the original Berkeley Unix copyrights," which permitted a "relatively un-encumbered Unix source distribution."[3] The widely used Apache License and GNU General Public License are considered overly restrictive.[94]

In June 2001, triggered by concerns over Darren Reed's modification of IPFilter's license wording, a systematic license audit of the OpenBSD ports and source trees was undertaken.[95] Code in more than a hundred files throughout the system was found to be unlicensed, ambiguously licensed or in use against the terms of the license. To ensure that all licenses were properly adhered to, an attempt was made to contact all the relevant copyright holders: some pieces of code were removed, many were replaced, and others, such as the multicast routing tools mrinfo and map-mbone, were relicensed so that OpenBSD could continue to use them.[96][97] Also removed during this audit was all software produced by Daniel J. Bernstein. At the time, Bernstein requested that all modified versions of his code be approved by him prior to redistribution, a requirement to which OpenBSD developers were unwilling to devote time or effort.[98][99][100]

Because of licensing concerns, the OpenBSD team has reimplemented software from scratch or adopted suitable existing software. For example, OpenBSD developers created the PF packet filter after unacceptable restrictions were imposed on IPFilter. PF first appeared in OpenBSD 3.0[101] and is now available in many other operating systems.[102] OpenBSD developers have also replaced GPL-licensed tools (such as CVS, diff, grep and pkg-config) with permissively licensed equivalents.[103][104]

Funding

Although the operating system and its portable components are used in commercial products, De Raadt says that little of the funding for the project comes from the industry: "traditionally all our funding has come from user donations and users buying our CDs (our other products don't really make us much money). Obviously, that has not been a lot of money."[80]

For a two-year period in the early 2000s, the project received funding from DARPA, which "paid the salaries of 5 people to work completely full-time, bought about $30k in hardware, and paid for 3 hackathons", from the POSSE project.[80]

In 2006, the OpenBSD project experienced financial difficulties.[105] The Mozilla Foundation[106] and GoDaddy[107] are among the organizations that helped OpenBSD to survive. However, De Raadt expressed concern about the asymmetry of funding: "I think that contributions should have come first from the vendors, secondly from the corporate users, and thirdly from individual users. But the response has been almost entirely the opposite, with almost a 15-to-1 dollar ratio in favor of the little people. Thanks a lot, little people!"[80]

On 14 January 2014, Bob Beck issued a request for funding to cover electrical costs. If sustainable funding was not found, Beck suggested the OpenBSD project would shut down.[108] The project soon received a US$20,000 donation from Mircea Popescu, the Romanian creator of the MPEx bitcoin stock exchange, paid in bitcoins.[109] The project raised US$150,000[110] in response to the appeal, enabling it to pay its bills and securing its short-term future.[109] Since 2014, several large contributions to the OpenBSD Foundation have come from corporations such as Microsoft,[111] Facebook, and Google as well as the Core Infrastructure Initiative.[112]

During the 2016 and 2017 fundraising campaigns, Smartisan, a Chinese company, was the leading financial contributor to the project.[113][114]

Distribution

OpenBSD is freely available in various ways: the source can be retrieved by anonymous CVS,[115] and binary releases and development snapshots can be downloaded by FTP, HTTP, and rsync.[116] Prepackaged CD-ROM sets through version 6.0 can be ordered online for a small fee, complete with an assortment of stickers and a copy of the release's theme song. These, with their artwork and other bonuses, have been one of the project's few sources of income, funding hardware, Internet service, and other expenses.[117] Beginning with version 6.1, CD-ROM sets are no longer released.

OpenBSD provides a package management system for easy installation and management of programs which are not part of the base operating system.[118] Packages are binary files which are extracted, managed and removed using the package tools. On OpenBSD, the source of packages is the ports system, a collection of Makefiles and other infrastructure required to create packages. In OpenBSD, the ports and base operating system are developed and released together for each version: this means that the ports or packages released with, for example, 4.6 are not suitable for use with 4.5 and vice versa.[118]

Songs and artwork

3D-rendered, animated OpenBSD mascot Puffy

Initially, OpenBSD used a haloed version of the BSD daemon mascot drawn by Erick Green, who was asked by De Raadt to create the logo for the 2.3 and 2.4 versions of OpenBSD. Green planned to create a full daemon, including head and body, but only the head was completed in time for OpenBSD 2.3. The body as well as pitchfork and tail was completed for OpenBSD 2.4.[119]

OpenBSD 2.3 cover

Subsequent releases used variations such as a police daemon by Ty Semaka,[120] but eventually settled on a pufferfish named Puffy.[121] Since then, Puffy has appeared on OpenBSD promotional material and featured in release songs and artwork.

The promotional material of early OpenBSD releases did not have a cohesive theme or design, but later the CD-ROMs, release songs, posters and tee-shirts for each release have been produced with a single style and theme, sometimes contributed to by Ty Semaka of the Plaid Tongued Devils.[86] These have become a part of OpenBSD advocacy, with each release expounding a moral or political point important to the project, often through parody.[122]

Themes have included Puff the Barbarian in OpenBSD 3.3, which included an 80s rock song and parody of Conan the Barbarian alluding to open documentation,[86] The Wizard of OS in OpenBSD 3.7, related to the project's work on wireless drivers, and Hackers of the Lost RAID, a parody of Indiana Jones referencing the new RAID tools in OpenBSD 3.8.

See also

Notes

  1. 1.0 1.1 Multiple selections were permitted as a user may use multiple BSD variants side by side.
  2. Later renamed to Cybercop Scanner after SNI was purchased by Network Associates.
  3. (As of April 2018), either Clang 5.0.1, GCC 4.2.1 or GCC 3.3.6 is shipped, depending on the platform.[79][37]

References

  1. "Package Management". OpenBSD Frequently Asked Questions. https://www.openbsd.org/faq/faq15.html#PkgMgmt. 
  2. "Platforms". OpenBSD. http://www.openbsd.org/plat.html. 
  3. 3.0 3.1 3.2 "Copyright Policy". OpenBSD. http://www.openbsd.org/policy.html. 
  4. OpenBSD Project (2020-05-19). "OpenBSD". https://www.openbsd.org/. 
  5. "Android's C Library Has 173 Files of Unchanged OpenBSD Code". http://undeadly.org/cgi?action=article&sid=20140506132000. 
  6. "LLVM Release License". http://releases.llvm.org/7.0.0/LICENSE.TXT. 
  7. "OpenSSH for Windows". https://twitter.com/nocentino/status/996843655112613888. 
  8. Grimes, Roger A. (29 December 2006). "New year's resolution No. 1: Get OpenBSD". InfoWorld. http://www.infoworld.com/article/2659465/security/new-year-s-resolution-no--1--get-openbsd.html. 
  9. 9.0 9.1 BSD Usage Survey (Report). The BSD Certification Group. 31 October 2005. p. 9. http://www.bsdcertification.org/downloads/pr-20051031-usage-survey-en-en.pdf. Retrieved 16 September 2012. 
  10. Glass, Adam (23 December 1994). "Theo De Raadt". netbsd-users (Mailing list).
  11. de Raadt, Theo (29 March 2009). "Archive of the mail conversation leading to Theo de Raadt's departure". http://www.theos.com/deraadt/coremail.html. 
  12. De Raadt, Theo (18 October 1996). "The OpenBSD 2.0 release". openbsd-announce (Mailing list).
  13. "Announcing – The OpenBSD Foundation". OpenBSD Journal. 26 July 2007. http://undeadly.org/cgi?action=article&sid=20070726015128. 
  14. "OpenBSD PF - Building a Router". https://www.openbsd.org/faq/pf/example1.html. 
  15. "Building an OpenBSD wireless access point". https://ctors.net/2013/12/30/openbsd_wireless_access_point. 
  16. 16.0 16.1 McIntire, Tim (8 August 2006). "Take a closer look at OpenBSD". Developerworks. IBM. http://www.ibm.com/developerworks/aix/library/au-openbsd.html. 
  17. "AccessEnforcer Model AE800". Calyptix Security. http://www.calyptix.com/products/models/ae800/. 
  18. "High Resistance Firewall genugate". GeNUA. https://www.genua.de/en/products/high-resistance-firewall-genugate.html. 
  19. "RTMX O/S IEEE Real Time POSIX Operating Systems". RTMX. http://www.rtmx.com/. "RTMX O/S is a product extension to OpenBSD Unix-like operating system with emphasis on embedded, dedicated applications." 
  20. ".vantronix secure system". Compumatica secure networks. http://www.vantronix.com/. "The Next Generation Firewall is not a standalone device, it is a Router for operation in security critical environments with high requirements for availability, comprehensive support as well as reliable and trusted systems powered by OpenBSD." 
  21. Dohnert, Roberto J. (2004-01-21), "Review of Windows Services for UNIX 3.5", OSNews (David Adams), http://www.osnews.com/story/5751 
  22. Reiter, Brian (2010-01-26). "WONTFIX: select(2) in SUA 5.2 ignores timeout". brianreiter.org. https://brianreiter.org/2010/01/26/wontfix-select2-in-sua-5-2-ignores-timeout/. 
  23. "Microsoft Acquires Softway Systems To Strengthen Future Customer Interoperability Solutions", Microsoft News Center (Microsoft), 1999-09-17, http://www.microsoft.com/en-us/news/press/1999/sept99/softwaypr.aspx 
  24. "Milltech Consulting Inc.". 2019. https://www.milltech.com/about. 
  25. "Core Force", Core Labs, http://corelabs.coresecurity.com/index.php?module=Wiki&action=view&type=project&name=Core_Force, retrieved 2011-12-13, "CORE FORCE provides inbound and outbound stateful packet filtering for TCP/IP protocols using a Windows port of OpenBSD's PF firewall, granular file system and registry access control and programs' integrity validation." 
  26. 26.0 26.1 "About Xenocara". Xenocara. https://xenocara.org/. 
  27. Tzanidakis, Manolis (21 April 2006). "Using OpenBSD on the desktop". Linux.com. http://archive09.linux.com/articles/52930. 
  28. 28.0 28.1 Lucas, Michael W. (April 2013). Absolute OpenBSD: Unix for the Practical Paranoid (2nd ed.). San Francisco, California: No Starch Press. ISBN 978-1-59327-476-4. https://www.nostarch.com/obenbsd2e. 
  29. "OpenPorts.se Statistics". OpenPorts.se. http://openports.se/statistics.php. 
  30. 30.0 30.1 "OpenBSD 6.0". OpenBSD. https://www.openbsd.org/59.html. 
  31. "The X Windows System". OpenBSD Frequently Asked Questions. http://www.openbsd.org/faq/faq11.html. "OpenBSD ships with the cwm(1), fvwm(1) and twm(1) window managers, [...]" 
  32. Varghese, Sam (8 October 2004). "Staying on the cutting edge". The Age. http://www.theage.com.au/articles/2004/10/07/1097089476287.html. 
  33. Laird, Cameron; Staplin, George Peter (17 July 2003). "The Essence of OpenBSD". ONLamp. http://www.onlamp.com/pub/a/bsd/2003/07/17/openbsd_core_team.html. 
  34. De Raadt, Theo (19 December 2005). "2.3 release announcement". openbsd-misc (Mailing list). Without [SNI's] support at the right time, this release probably would not have happened.
  35. Wayner, Peter (13 July 2000). "18.3 Flames, Fights, and the Birth of OpenBSD". Free For All: How Linux and the Free Software Movement Undercut the High Tech Titans (1st ed.). HarperBusiness. ISBN 978-0-06-662050-3. http://www.jus.uio.no/sisu/free_for_all.peter_wayner/index.html. Retrieved 13 December 2011. 
  36. Miller, Todd C.; De Raadt, Theo (6 June 1999). "strlcpy and strlcat - Consistent, Safe, String Copy and Concatenation". USENIX Annual Technical Conference. Monterey, California. http://www.usenix.org/events/usenix99/millert.html. Retrieved 13 December 2011. 
  37. 37.0 37.1 37.2 "gcc-local – local modifications to gcc". OpenBSD manual pages. http://man.openbsd.org/OpenBSD-6.0/man1/gcc-local.1. 
  38. De Raadt, Theo; Hallqvist, Niklas; Grabowski, Artur; Keromytis, Angelos D.; Provos, Niels (6 June 1999). "Cryptography in OpenBSD: An Overview". USENIX Annual Technical Conference. Monterey, California. https://www.usenix.org/legacy/publications/library/proceedings/usenix99/deraadt.html. Retrieved 27 May 2016. 
  39. "Pledge() - A New Mitigation Mechanism". https://www.openbsd.org/papers/hackfest2015-pledge/mgp00002.html. 
  40. Provos, Niels (9 August 2003). "Privilege Separated OpenSSH". http://www.citi.umich.edu/u/provos/ssh/privsep.html. 
  41. "Innovations". https://www.openbsd.org/innovations.html. "Privilege separation: [...] The concept is now used in many OpenBSD programs, for example [...] etc." 
  42. "Project History and Credits". OpenSSH. http://www.openssh.com/history.html. 
  43. "SSH usage profiling". OpenSSH. http://www.openssh.com/usage/. 
  44. Biancuzzi, Federico (18 March 2004). "An Interview with OpenBSD's Marc Espie". ONLamp. http://www.onlamp.com/pub/a/bsd/2004/03/18/marc_espie.html. 
  45. Internet Security Systems. OpenSSH Remote Challenge Vulnerability, June 26, 2002. Visited December 17, 2005.
  46. A partial list of affected operating systems.
  47. Core Security Technologies' homepage.
  48. Core Security Technologies. OpenBSD's IPv6 mbufs remote kernel buffer overflow. March 13, 2007. Visited March 13, 2007.
  49. Brindle, Joshua (2008-03-30), "Secure doesn't mean anything", Security Blog, http://securityblog.org/brindle/2008/03/30/secure-doesnt-mean-anything/, retrieved 2011-12-13 
  50. "Security". OpenBSD. http://www.openbsd.org/security.html. "Secure by Default." 
  51. Wheeler, David A. (3 March 2003). "2.4. Is Open Source Good for Security?". Secure Programming for Linux and Unix HOWTO. http://www.dwheeler.com/secure-programs/Secure-Programs-HOWTO/open-source-security.html. Retrieved 13 December 2011. 
  52. De Raadt, Theo (14 December 2010). "Allegations regarding OpenBSD IPSEC". openbsd-tech (Mailing list). Retrieved 28 May 2016.
  53. Holwerda, Thom (14 December 2010). "FBI Added Secret Backdoors to OpenBSD IPSEC". OSNews. http://www.osnews.com/story/24136/_FBI_Added_Secret_Backdoors_to_OpenBSD_IPSEC_. 
  54. Ryan, Paul (23 December 2010). "OpenBSD code audit uncovers bugs, but no evidence of backdoor". Ars Technica. https://arstechnica.com/open-source/news/2010/12/openbsd-code-audit-uncovers-bugs-but-no-evidence-of-backdoor.ars. 
  55. Mathew J. Schwartz (22 December 2010). "OpenBSD Founder Believes FBI Built IPsec Backdoor". InformationWeek: DARKreading. http://www.darkreading.com/vulnerabilities-and-threats/openbsd-founder-believes-fbi-built-ipsec-backdoor/d/d-id/1095055. 
  56. Van Sprundel, Ilja (December 2017). "Are all BSDs created equally? — A survey of BSD kernel vulnerabilities.". https://media.ccc.de/v/34c3-8968-are_all_bsds_created_equally. 
  57. Van Sprundel, Ilja (July 2017). "Are all BSDs created equally? — A survey of BSD kernel vulnerabilities.". https://media.defcon.org/DEF%20CON%2025/DEF%20CON%2025%20presentations/DEF%20CON%2025%20-%20Ilja-van-Sprundel-BSD-Kern-Vulns.pdf. 
  58. "Lecture: A systematic evaluation of OpenBSD's mitigations". December 2019. https://fahrplan.events.ccc.de/congress/2019/Fahrplan/events/10519.html. 
  59. "Is OpenBSD secure?". 29 December 2019. https://isopenbsdsecu.re/. 
  60. "OpenBSD Supported Platforms". OpenBSD Foundation. https://www.openbsd.org/plat.html. 
  61. "OpenBSD 6.7: ids of supported devices". BSD Hardware Project. https://github.com/bsdhw/Drivers/blob/master/openbsd/openbsd-6.7.list. 
  62. "OpenBSD Hardware Trends". BSD Hardware Project. https://github.com/bsdhw/Trends/tree/master/Dist/OpenBSD. 
  63. "src/usr.sbin/httpd/". https://cvsweb.openbsd.org/cgi-bin/cvsweb/src/usr.sbin/httpd/. 
  64. "web/obhttpd: OpenBSD http server". https://www.freshports.org/www/obhttpd/. 
  65. "LibreSSL". https://www.libressl.org. 
  66. 66.0 66.1 "OpenBGPD". http://www.openbgpd.org. 
  67. "OpenIKED". https://www.openiked.org. 
  68. "OpenNTPD". http://www.openntpd.org. 
  69. "OpenSMTPD". https://www.opensmtpd.org. 
  70. "OpenSSH". https://www.openssh.com. 
  71. "Contents of /stable/10/crypto/openssh/README". https://svnweb.freebsd.org/base/stable/10/crypto/openssh/README?view=markup. "This is the port of OpenBSD's excellent OpenSSH to Linux and other Unices." 
  72. "src/crypto/external/bsd/openssh/dist/README – view – 1.4". http://cvsweb.netbsd.org/bsdweb.cgi/src/crypto/external/bsd/openssh/dist/README?rev=1.4&content-type=text/x-cvsweb-markup&only_with_tag=MAIN. 
  73. "dragonfly.git/blob – crypto/openssh/README". https://gitweb.dragonflybsd.org/dragonfly.git/blob/HEAD:/crypto/openssh/README. "This is the port of OpenBSD's excellent OpenSSH to Linux and other Unices." 
  74. "Arch Linux – openssh 7.2p2-1 (x86_64)". Arch Linux. https://www.archlinux.org/packages/core/x86_64/openssh/. 
  75. "openssh". OpenSUSE. https://software.opensuse.org/package/openssh. 
  76. "Debian – Details of package openssh-client in jessie". Debian. https://packages.debian.org/jessie/openssh-client. 
  77. 77.0 77.1 77.2 https://cfenollosa.com/blog/openbsd-from-a-veteran-linux-user-perspective.html
  78. De Raadt, Theo (18 June 2013). "An Internet Exchange for Calgary". http://www.yycix.ca/talks/cuug-2013-06-18/an-internet-exchange-for-Calgary.pdf. 
  79. 79.0 79.1 "clang-local – OpenBSD-specific behavior of LLVM/clang". OpenBSD manual pages. http://man.openbsd.org/OpenBSD-6.2/man1/clang-local.1. 
  80. 80.0 80.1 80.2 80.3 Andrews, Jeremy (2 May 2006). "Interview: Theo de Raadt". KernelTrap. http://kerneltrap.org/node/6550. 
  81. "OpenBSD's flavors". OpenBSD Frequently Asked Questions. https://www.openbsd.org/faq/faq5.html#Flavors. 
  82. "Applying patches in OpenBSD". OpenBSD Frequently Asked Questions. https://www.openbsd.org/faq/faq10.html#Patches. 
  83. "Migrating to OpenBSD". OpenBSD Frequently Asked Questions. http://www.openbsd.org/faq/faq1.html#OtherUnixes. 
  84. "Hackathons". OpenBSD. https://www.openbsd.org/hackathons.html. 
  85. "Interview: Theo de Raadt of OpenBSD". NewsForge. 28 March 2006. https://www.linux.com/news/interview-theo-de-raadt-openbsd/. 
  86. 86.0 86.1 86.2 "Release Songs". OpenBSD. http://www.openbsd.org/lyrics.html. 
  87. Chisnall, David (20 January 2006). "BSD: The Other Free UNIX Family". InformIT. http://www.informit.com/articles/article.aspx?p=439601&seqNum=3. 
  88. Smith, Jesse (18 November 2013). "OpenBSD 5.4: Puffy on the Desktop". http://distrowatch.com/weekly.php?issue=20131118#feature. 
  89. 89.0 89.1 Cranor, Chuck D.; De Raadt, Theo (6 June 1999). "Opening the Source Repository with Anonymous CVS". USENIX Annual Technical Conference. Monterey, California. https://www.usenix.org/legacy/event/usenix99/cranor_f.html. Retrieved 13 December 2011. 
  90. Cranor, Chuck D.. "Chuck Cranor's Home Page". http://chuck.cranor.org/. "I also hosted and helped create the first Anonymous CVS server on the Internet (the original anoncvs.openbsd.org [...]" 
  91. "Project Goals". http://www.openbsd.org/goals.html. "Integrate good code from any source with acceptable licenses. [...], NDAs are never acceptable." 
  92. De Raadt, Theo; Hallqvist, Niklas; Grabowski, Artur; Keromytis, Angelos D.; Provos, Niels (6 June 1999). "Cryptography in OpenBSD: An Overview". USENIX Annual Technical Conference. Monterey, California. https://www.usenix.org/legacy/publications/library/proceedings/usenix99/deraadt.html. Retrieved 1 February 2014. 
  93. 93.0 93.1 De Raadt, Theo (5 December 2006). "Presentation at OpenCON". http://www.openbsd.org/papers/opencon06-docs/index.html. 
  94. Matzan, Jem (15 June 2005). "BSD cognoscenti on Linux". NewsForge. Linux.com. https://www.linux.com/news/bsd-cognoscenti-linux. 
  95. Gasperson, Tina (6 June 2001). "OpenBSD and ipfilter still fighting over license disagreement". Linux.com. http://www.linux.com/feature/12774. 
  96. "src/usr.sbin/mrinfo/mrinfo.c – view – 1.7". cvsweb.openbsd.org. 31 July 2001. http://cvsweb.openbsd.org/cgi-bin/cvsweb/src/usr.sbin/mrinfo/mrinfo.c?rev=1.7&content-type=text/x-cvsweb-markup. "New license from Xerox! This code is now FREE! Took a while and a lot of mails, but it is worth it." 
  97. "src/usr.sbin/map-mbone/mapper.c – view – 1.5". cvsweb.openbsd.org. 31 July 2001. http://cvsweb.openbsd.org/cgi-bin/cvsweb/src/usr.sbin/map-mbone/mapper.c?rev=1.5&content-type=text/x-cvsweb-markup. "New license from Xerox! This code is now FREE! Took a while and a lot of mails, but it is worth it." 
  98. De Raadt, Theo (24 August 2001). "Re: Why were all DJB's ports removed? No more qmail?". openbsd-misc (Mailing list). Archived from the original on 19 April 2016.
  99. Bernstein, Daniel J. (27 August 2001). "Re: Why were all DJB's ports removed? No more qmail?". openbsd-misc (Mailing list). Archived from the original on 4 February 2012.
  100. Espie, Marc (28 August 2001). "Re: Why were all DJB's ports removed? No more qmail?". openbsd-misc (Mailing list). Archived from the original on 19 April 2016.
  101. Hartmeier, Daniel (10 June 2002). "Design and Performance of the OpenBSD Stateful Packet Filter (pf)". USENIX Annual Technical Conference. Monterey, California. https://www.usenix.org/legacy/event/usenix02/tech/freenix/hartmeier.html. Retrieved 13 December 2011. 
  102. The OpenBSD PF Packet Filter Book: PF for NetBSD, FreeBSD, DragonFly and OpenBSD. Reed Media Services. 2006. ISBN 0-9790342-0-5. http://www.reedmedia.net/books/pf-book/. Retrieved 19 May 2016. 
  103. "New BSD licensed CVS replacement for OpenBSD". https://slashdot.org/story/52396. 
  104. "pkg-config(1)". https://man.openbsd.org/pkg-config.1. 
  105. "OpenBSD Project in Financial Danger". Slashdot. 21 March 2006. http://slashdot.org/story/06/03/21/1555243/openbsd-project-in-financial-danger. 
  106. "Mozilla Foundation Donates $10K to OpenSSH". Slashdot. 4 April 2006. http://slashdot.org/story/06/04/04/1820228/mozilla-foundation-donates-10k-to-openssh. 
  107. "GoDaddy.com Donates $10K to Open Source Development Project". The Hosting News. 19 April 2006. http://www.thehostingnews.com/article2217.html. 
  108. Beck, Bob (14 January 2014). "Request for Funding our Electricity". openbsd-misc (Mailing list). Retrieved 17 May 2016.
  109. 109.0 109.1 Bright, Peter (20 January 2014). "OpenBSD rescued from unpowered oblivion by $20K bitcoin donation". Ars Technica. https://arstechnica.com/information-technology/2014/01/openbsd-rescued-from-unpowered-oblivion-by-20k-bitcoin-donation/. 
  110. "The OpenBSD Foundation 2014 Fundraising Campaign". OpenBSD Foundation. http://www.openbsdfoundation.org/campaign2014.html. 
  111. McAllister, Neil (8 July 2015). "Microsoft rains cash on OpenBSD Foundation, becomes top 2015 donor". https://www.theregister.co.uk/2015/07/08/microsoft_donates_to_openbsd_foundation/. 
  112. "Contributors". OpenBSD Foundation. http://www.openbsdfoundation.org/contributors.html. 
  113. "OpenBSD Donors". http://www.openbsdfoundation.org/contributors.html. 
  114. "Smartisan Makes Another Iridium Donation to the OpenBSD Foundation". http://undeadly.org/cgi?action=article&sid=20170817195416. 
  115. "Anonymous CVS". OpenBSD. http://www.openbsd.org/anoncvs.html. 
  116. "Mirrors". OpenBSD. http://www.openbsd.org/ftp.html. 
  117. "Orders". OpenBSD. http://www.openbsd.org/orders.html. 
  118. 118.0 118.1 "Packages and Ports". OpenBSD Frequently Asked Questions. http://www.openbsd.org/faq/faq15.html. 
  119. "OpenBSD". http://www.mckusick.com/beastie/shirts/openbsd.html. 
  120. De Raadt, Theo (19 May 1999). "OpenBSD 2.5 Release Announcement". openbsd-announce (Mailing list). Archived from the original on 14 March 2014. OpenBSD 2.5 introduces the new Cop daemon image done by cartoonist Ty Semeka.
  121. "OpenBSD 2.7". OpenBSD. http://www.openbsd.org/27.html. 
  122. Matzan, Jem (1 December 2006). "OpenBSD 4.0 review". Software in Review. http://www.softwareinreview.com/bsd/openbsd_4.0_review.html. "Each OpenBSD release has a graphical theme and a song that goes with it. The theme reflects a major concern that the OpenBSD programmers are addressing or bringing to light." 

External links