licensing revision 1.3
1$NetBSD: licensing,v 1.3 2026/01/31 12:35:12 nia Exp $
2
3NetBSD Licensing
4================
5
6In an ideal world, the entire of NetBSD should be available under
7simple permissive software licenses. The 2-clause BSD license is
8recommended for new contributions.
9
10Background: GPL in base
11-----------------------
12
13In the 1990s, the BSD developers at CSRG realized their toolchain was
14falling behind alternatives. One of the reasons for this was Sun
15choosing to lock their compiler behind a paywall - as a result, Sun's
16users went out in search of freeware alternatives. They found GNU's GCC,
17and immediately formed a new community around improving it.
18Eventually, various GNU tools found their way into BSD.
19
20We would like to eliminate the use of the GNU General Public License
21in the base system. This provides a number of advantages: less worrying
22about license compatibility, easier sharing of code between NetBSD
23components, less likelihood of being sued for redistributing NetBSD
24binaries, less legalese and need for lawyers to interpret it,
25and an overall reduction in GNU info pages.
26
27As a general rule, most GPL code in NetBSD provides programs that
28are "nice to have", but not fully essential for a working system,
29so redistributors have an option to remove or replace them.
30
31For example, some NetBSD ports can be built using Clang as the
32toolchain instead of GCC (see mk.conf(5), HAVE_LLVM).
33
34GPL codes lives under the following directories to ensure clean
35separation:
36
37* src/external/gpl2
38* src/external/gpl3
39* src/sys/external/gpl2
40
41Background: Advertising clause
42------------------------------
43
44At some point, Berkeley added the following clause to their license
45for the free parts of BSD UNIX:
46
47 * 3. All advertising materials mentioning features or use of this software
48 *    must display the following acknowledgement:
49 *      This product includes software developed by [copyright holder].
50
51With time, this clause came to be seen as onerous: there is already
52a requirement to credit copyright holders in the documentation of
53redistributions, and it's very difficult to enforce. At various points,
54distributing NetBSD required including hundreds of "This product
55includes software developed [...]" statements. It also makes it more
56complicated to include NetBSD code in projects under other licenses.
57
58Berkeley removed the advertising clause in 1999, and clarified their
59stance against including it in 2012. However, there are lots of
60instances where it has been copy and pasted by other people and
61organizations. Therefore, its removal from NetBSD is mostly a social
62challenge.
63
64Technical priorities
65--------------------
66
67The directory under external/gpl2 contains several programs that
68could be replaced. Most of them are quite old versions now, chosen
69to avoid GPLv3:
70
71* diffutils - Replaced with FreeBSD-derived diff(1). MKBSDDIFF is now
72  the default.
73* grep - Could be replaced with FreeBSD grep(1). Someone needs to
74  compare the performance. Other grep implementations in C likely
75  exist. A MKBSDGREP option exists, but the copy is probably old.
76* rcs - Supposedly OpenBSD developed a compatible replacement.
77* xcvs - Priority for removal as we transition away from CVS.
78* groff - Mostly replaced by mandoc(1), although some non-manual use
79  cases (e.g. distrib/notes) continue to rely on groff. Optional -
80  a MKGROFF option exists. Such files could also be converted to
81  plain text.
82* send-pr - Part of our infrastructure, but basically optional -
83  alternatives like the gnats web interface exist.
84* gawk - Needed only by other GNU software?
85* gmake - Needed only by other GNU software.
86* texinfo - Needed only by other GNU software.
87
88The directory under sys/external/gpl2 mainly contains device tree
89sources, providing platform definition files for embedded system
90boards. Removing this would break a lot of platforms.
91
92The directory under external/gpl3 only contains toolchain-relevant
93files, and can be mostly avoided with HAVE_LLVM=yes and elftoolchain.
94
95Social and legal tasks
96----------------------
97
98A list of advertising clauses that still apply can be found in:
99
100	src/distrib/notes/common/legal.common
101
102This file should be kept in sync as copyright holders are contacted.
103
104There are several high-priority targets for the removal of the
105advertising clause:
106
107* Lawrence Berkeley Laboratory advertising clauses are very widespread.
108  It is unclear whether Berkeley granted permission to remove such
109  clauses (FreeBSD apparently think so). Berkeley should be contacted
110  for clarification.
111* Harvard University 4-clauses licenses are widespread, and it's
112  possible someone knows an insider who could accelerate the process
113  of getting permission to fix them.
114* Wasabi Systems copyrights are very widespread in NetBSD. They were
115  "the NetBSD company" of their time. It is unclear who currently owns
116  Wasabi Systems' intellectual property. Someone should figure this out,
117  or we should use Foundation funds to acquire it.
118* 4-clause BSD licenses are also found in the tree belonging to
119  Cisco (primarily in SCTP code). It's also possible someone knows an
120  insider who could accelerate the process.
121
122Otherwise, the social and legal tasks mostly involve trying to find
123old contributors' current email addresses, and asking them for
124permission to relicense. This strategy has been somewhat successful,
125and should be completed before doing so is no longer possible.
126