The use and distribution of open source and free software is subject to a few well-known and widely advertised licenses, as we discussed in Chapter 1. There are, nevertheless, some issues surrounding Linux’s licensing that keep resurfacing and seem to cause confusion. These uncertainties revolve around the fact that the Linux kernel is itself distributed under the terms of the GNU GPL.
Over time, Linus Torvalds and other kernel developers have helped shed some light on the limits and reaches of the kernel’s licensing. This appendix presents some of the messages published by Linus and other kernel developers regarding three aspects of the kernel’s licensing: the use of non-GPL applications, the use of binary-only modules, and the general licensing issues surrounding the kernel’s source code.
To avoid any confusion regarding the status of applications running on top of the Linux kernel, Linus Torvalds added the following preamble to the kernel’s license:
NOTE! This copyright does *not* cover user programs that use kernel services by normal system calls - this is merely considered normal use of the kernel, and does *not* fall under the heading of "derived work". Also note that the GPL below is copyrighted by the Free Software Foundation, but the instance of code that it refers to (the Linux kernel) is copyrighted by me and others who actually wrote it. Also note that the only valid version of the GPL as far as the kernel is concerned is _this_ license (ie v2), unless explicitly otherwise stated. Linus Torvalds
Recurring controversy has erupted over loadable kernel modules not distributed under the terms of the GPL. Many companies already ship such binary modules and many industry players contend that such modules are permitted. Yet many Linux kernel developers have come out rather strongly against this practice. Here are some messages sent to the Linux kernel mailing list by Linus Torvalds and Alan Cox that provide some insight as to the use of binary modules.
From: [email protected] (Linus Torvalds) Subject: Re: Kernel interface changes (was Re: cdrecord problems on Date: 1999-02-05 7:13:23 In article <[email protected]>, John Alvord <[email protected]> wrote: >On Thu, 4 Feb 1999 22:37:06 -0500 (EST), "Theodore Y. Ts'o" ><[email protected]> wrote: >> >>And as a result, I've seen more than a few MIT users decide to give up >>on Linux and move over to NetBSD. I think this is bad, and I'm hoping >>we can take just a little bit more care in the 2.2 series than we did in >>the 2.0 series. Is that really too much to ask? Yes. I think it is. I will strive for binary compatibility for modules, but I _expect_ that it will be broken. It's just too easy to have to make changes that break binary-only modules, and I have too little incentive to try to avoid it. If people feel this is a problem, I see a few alternatives: - don't use stuff with binary-only modules. Just say no. - work hard at making a source-version of the thing available (it doesn't have to be under the GPL if it's a module, but it has to be available as source so that it can be recompiled). - don't upgrade - drop Linux >I suggest we treat binary compatibility problems as bugs which need to >be resolved during the 2.2 lifetime. Even with all care, some changes >will occur because of mistakes... if we cure them, there will be >limited impact to users. It's often not mistakes. Things sometimes have to change, and I personally do not care for binary-only modules enough to even care. If people want to use Linux, they have to live with this. In 2.2.x, the basics may be stable enough that maybe the binary module interface won't actually change. I don't know. That would be good, but if it is not to be, then it is not to be. I _allow_ binary-only modules. I allow them because I think that sometimes I cannot morally require people to make sources available to projects like AFS where those sources existed before Linux. HOWEVER, that does not mean that I have to _like_ AFS as a binary-only module. Quite frankly, I hope AFS dies a slow and painful death with people migrating to better alternatives (coda, whatever). Or that somebody makes an AFS client available in source form, either as a clone or through the original people. As it is, what has AFS done for me lately? Nothing. So why should I care? Linus
From: [email protected] (Linus Torvalds) Subject: Re: Kernel interface changes (was Re: cdrecord problems on Date: 1999-02-07 8:15:24 In article <[email protected]>, H. Peter Anvin <[email protected]> wrote: > >* Linus Torvalds has no interest whatsoever in developing such a > plug-in ABI. Someone else is welcome to do it. No, it's even more than that. I _refuse_ to even consider tying my hands over some binary-only module. Hannu Savolainen tried to add some layering to make the sound modules more "portable" among Linux kernel versions, and I disliked it for two reasons: - extra layers decrease readability, and sometimes make for performance problems. The readability thing is actually the larger beef I had with this: I just don't want to see drivers start using some strange wrapper format that has absolutely nothing to do with how they work. - I _want_ people to expect that interfaces change. I _want_ people to know that binary-only modules cannot be used from release to release. I want people to be really really REALLY aware of the fact that when they use a binary-only module, they tie their hands. Note that the second point is mainly psychological, but it's by far the most important one. Basically, I want people to know that when they use binary-only modules, it's THEIR problem. I want people to know that in their bones, and I want it shouted out from the rooftops. I want people to wake up in a cold sweat every once in a while if they use binary-only modules. Why? Because I'm a prick, and I want people to suffer? No. Because I _know_ that I will eventually make changes that break modules. And I want people to expect them, and I never EVER want to see an email in my mailbox that says "Damn you, Linus, I used this binary module for over two years, and it worked perfectly across 150 kernel releases, and Linux-5.6.71 broke it, and you had better fix your kernel". See? I refuse to be at the mercy of any binary-only module. And that's why I refuse to care about them - not because of any really technical reasons, not because I'm a callous bastard, but because I refuse to tie my hands behind my back and hear somebody say "Bend Over, Boy, Because You Have It Coming To You". I allow binary-only modules, but I want people to know that they are _only_ ever expected to work on the one version of the kernel that they were compiled for. Anything else is just a very nice unexpected bonus if it happens to work. And THAT, my friend, is why when somebody complains about AFS, I tell them to go screw themselves, and not come complaining to me but complain to the AFS boys and girls. And why I'm not very interested in changing that. Linus
This is a response to a posting by Theodore Ts’O.
From: Alan Cox <[email protected]> Subject: Re: [ANNOUNCE] Generalised Kernel Hooks Interface (GKHI) Date: 2000-11-09 14:26:33 > Actually, he's been quite specific. It's ok to have binary modules as > long as they conform to the interface defined in /proc/ksyms. What is completely unclear is if he has the authority to say that given that there is code from other people including the FSF merged into the tree. I've taken to telling folks who ask about binary modules to talk to their legal department. The whole question is simply to complicated for anyone else to work on. Alan
From: Linus Torvalds <[email protected]> Subject: Re: [PATCH] make LSM register functions GPLonly exports Date: 2002-10-17 17:08:19 Note that if this fight ends up being a major issue, I'm just going to remove LSM and let the security vendors do their own thing. So far - I have not seen a lot of actual usage of the hooks - seen a number of people who still worry that the hooks degrade performance in critical areas - the worry that people use it for non-GPL'd modules is apparently real, considering Crispin's reply. I will re-iterate my stance on the GPL and kernel modules: There is NOTHING in the kernel license that allows modules to be non-GPL'd. The _only_ thing that allows for non-GPL modules is copyright law, and in particular the "derived work" issue. A vendor who distributes non-GPL modules is _not_ protected by the module interface per se, and should feel very confident that they can show in a court of law that the code is not derived. The module interface has NEVER been documented or meant to be a GPL barrier. The COPYING clearly states that the system call layer is such a barrier, so if you do your work in user land you're not in any way beholden to the GPL. The module interfaces are not system calls: there are system calls used to _install_ them, but the actual interfaces are not. The original binary-only modules were for things that were pre-existing works of code, ie drivers and filesystems ported from other operating systems, which thus could clearly be argued to not be derived works, and the original limited export table also acted somewhat as a barrier to show a level of distance. In short, Crispin: I'm going to apply the patch, and if you as a copyright holder of that file disagree, I will simply remove all of he LSM code from the kernel. I think it's very clear that a LSM module is a derived work, and thus copyright law and the GPL are not in any way unclear about it. If people think they can avoid the GPL by using function pointers, they are WRONG. And they have always been wrong. Linus
From: Linus Torvalds <[email protected]> Subject: Re: [PATCH] make LSM register functions GPLonly exports Date: 2002-10-17 17:25:12 On Thu, 17 Oct 2002, Linus Torvalds wrote: > > If people think they can avoid the GPL by using function pointers, they > are WRONG. And they have always been wrong. Side note: it should be noted that legally the GPLONLY note is nothing but a strong hint and has nothing to do with the license (and only matters for the _enforcement_ of said license). The fact is: - the kernel copyright requires the GPL for derived works anyway. - if a company feels confident that they can prove in court that their module is not a derived work, the GPL doesn't matter _anyway_, since a copyright license at that point is meaningless and wouldn't cover the work regardless of whether we say it is GPLONLY or not. (In other words: for provably non-derived works, whatever kernel license we choose is totally irrelevant) So the GPLONLY is really a big red warning flag: "Danger, Will Robinson". It doesn't have any real legal effect on the meaning of the license itself, except in the sense that it's another way to inform users about the copyright license (think of it as a "click through" issue - GPLONLY forces you to "click through" the fact that the kernel is under the GPL and thus derived works have to be too). Clearly "click through" _has_ been considered a legally meaningful thing, in that it voids the argument that somebody wasn't aware of the license. It doesn't change what you can or cannot do, but it has some meaning for whether it could be wilful infringement or just honest mistake. Linus
This is a fairly long explanation by Linus Torvalds regarding the kernel’s licensing and how this licensing applies to foreign code:
Feel free to post/add this. I wrote it some time ago for a corporate lawyer who wondered what the "GPL exception" was. Names and companies removed not because I think they are ashamed, but because I don't want people to read too much into them. Linus ----- Date: Fri, 19 Oct 2001 13:16:45 -0700 (PDT) From: Linus Torvalds <[email protected]> To: Xxxx Xxxxxx <[email protected]> Subject: Re: GPL, Richard Stallman, and the Linux kernel [ This is not, of course, a legal document, but if you want to forward it to anybody else, feel free to do so. And if you want to argue legal points with me or point somehting out, I'm always interested. To a point ;-] On Fri, 19 Oct 2001, Xxxx Xxxxxx wrote: > > I've been exchanging e-mail with Richard Stallman for a couple of > weeks about the finer points of the GPL. I feel your pain. > I've have spent time pouring through mailing list archives, usenet, > and web search engines to find out what's already been covered about > your statement of allowing dynamically loaded kernel modules with > proprietary code to co-exist with the Linux kernel. So far I've > been unable to find anything beyond vague statements attributed to > you. If these issues are addressed somewhere already, please refer > me. Well, it really boils down to the equivalent of "_all_ derived modules have to be GPL'd". An external module doesn't really change the GPL in that respect. There are (mainly historical) examples of UNIX device drivers and some UNIX filesystems that were pre-existing pieces of work, and which had fairly well-defined and clear interfaces and that I personally could not really consider any kind of "derived work" at all, and that were thus acceptable. The clearest example of this is probably the AFS (the Andrew Filesystem), but there have been various device drivers ported from SCO too. > Issue #1 > = = = = = = = = > Currently the GPL version 2 license is the only license covering the > Linux kernel. I cannot find any alternative license explaining the > loadable kernel module exception which makes your position difficult > to legally analyze. > > There is a note at the top of www.kernel.org/pub/linux/kernel/COPYING, > but that states "user programs" which would clearly not apply to > kernel modules. > > Could you clarify in writing what the exception precisely states? Well, there really is no exception. However, copyright law obviously hinges on the definition of "derived work", and as such anything can always be argued on that point. I personally consider anything a "derived work" that needs special hooks in the kernel to function with Linux (ie it is _not_ acceptable to make a small piece of GPL-code as a hook for the larger piece), as that obviously implies that the bigger module needs "help" from the main kernel. Similarly, I consider anything that has intimate knowledge about kernel internals to be a derived work. What is left in the gray area tends to be clearly separate modules: code that had a life outside Linux from the beginning, and that do something self-containted that doesn't really have any impact on the rest of the kernel. A device driver that was originally written for something else, and that doesn't need any but the standard UNIX read/write kind of interfaces, for example. > Issue #2 > = = = = = = = = > I've found statements attributed to you that you think only 10% of > the code in the current kernel was written by you. By not being the > sole copyright holder of the Linux kernel, a stated exception to > the GPL seems invalid unless all kernel copyright holders agreed on > this exception. How does the exception cover GPL'd kernel code not > written by you? Has everyone contributing to the kernel forfeited > their copyright to you or agreed with the exception? Well, see above about the lack of exception, and about the fundamental gray area in _any_ copyright issue. The "derived work" issue is obviously a gray area, and I know lawyers don't like them. Crazy people (even judges) have, as we know, claimed that even obvious spoofs of a work that contain nothing of the original work itself, can be ruled to be "derived". I don't hold views that extreme, but at the same time I do consider a module written for Linux and using kernel infrastructures to get its work done, even if not actually copying any existing Linux code, to be a derived work by default. You'd have to have a strong case to _not_ consider your code a derived work.. > Issue #3 > = = = = = = = = > This issue is related to issue #1. Exactly what is covered by the > exception? For example, all code shipped with the Linux kernel > archive and typically installed under /usr/src/linux, all code under > /usr/src/linux except /usr/src/linux/drivers, or just the code in > the /usr/src/linux/kernel directory? See above, and I think you'll see my point. The "user program" exception is not an exception at all, for example, it's just a more clearly stated limitation on the "derived work" issue. If you use standard UNIX system calls (with accepted Linux extensions), your program obviously doesn't "derive" from the kernel itself. Whenever you link into the kernel, either directly or through a module, the case is just a _lot_ more muddy. But as stated, by default it's obviously derived - the very fact that you _need_ to do something as fundamental as linking against the kernel very much argues that your module is not a stand-alone thing, regardless of where the module source code itself has come from. > Issue #4 > = = = = = = = = > This last issue is not so much a issue for the Linux kernel > exception, but a request for comment. > > Richard and I both agree that a "plug-in" and a "dynamically > loaded kernel module" are effectively the same under the GPL. Agreed. The Linux kernel modules had (a long time ago), a more limited interface, and not very many functions were actually exported. So five or six years ago, we could believably claim that "if you only use these N interfaces that are exported from the standard kernel, you've kind of implicitly proven that you do not need the kernel infrastructure". That was never really documented either (more of a guideline for me and others when we looked at the "derived work" issue), and as modules were more-and-more used not for external stuff, but just for dynamic loading of standard linux modules that were distributed as part of the kernel anyway, the "limited interfaces" argument is no longer a very good guideline for "derived work". So these days, we export many internal interfaces, not because we don't think that they would "taint" the linker, but simply because it's useful to do dynamic run-time loading of modules even with standard kernel modules that _are_ supposed to know a lot about kernel internals, and are obviously "derived works".. > However we disagree that a plug-in for a GPL'd program falls > under the GPL as asserted in the GPL FAQ found in the answer: > http://www.gnu.org/licenses/gpl-faq.html#GPLAndPlugins. I think you really just disagree on what is derived, and what is not. Richard is very extreme: _anything_ that links is derived, regardless of what the arguments against it are. I'm less extreme, and I bet you're even less so (at least you might like to argue so). > My assertion is that plug-ins are written to an interface, not a > program. Since interfaces are not GPL'd, a plug-in cannot be GPL'd > until the plug-in and program are placed together and run. That is > done by the end user, not the plug-in creator. I agree, but also disrespectfully disagree ;) It's an issue of what a "plug-in" is - is it a way for the program to internally load more modules as it needs them, or is it _meant_ to be a public, published interface. For example, the "system call" interface could be considered a "plug-in interface", and running a user mode program under Linux could easily be construed as running a "plung-in" for the Linux kernel. No? And there, I obviously absolutely agree with you 100%: the interface is published, and it's _meant_ for external and independent users. It's an interface that we go to great lengths to preserve as well as we can, and it's an interface that is designed to be independent of kernel versions. But maybe somebody wrote his program with the intention to dynamically load "actors" as they were needed, as a way to maintain a good modularity, and to try to keep the problem spaces well-defined. In that case, the "plug-in" may technically follow all the same rules as the system call interface, even though the author doesn't intend it that way. So I think it's to a large degree a matter of intent, but it could arguably also be considered a matter of stability and documentation (ie "require recompilation of the plug-in between version changes" would tend to imply that it's an internal interface, while "documented binary compatibility across many releases" implies a more stable external interface, and less of a derived work) Does that make sense to you? > I asked Richard to comment on several scenarios involving plug-ins > explain whether or not they were in violation of the GPL. So far he > as only addressed one and has effectively admitted a hole. This is > the one I asked that he's responded to: > [A] non-GPL'd plug-in writer writes a plug-in for a non-GPL'd > program. Another author writes a GPL'd program making the > first author's plug-ins compatible with his program. Are now > the plug-in author's plug-ins now retroactively required to be > GPL'd? > > His response: > No, because the plug-in was not written to extend this program. > > I find it suspicious that whether or not the GPL would apply to the > plug-in depends on the mindset of the author. The above makes no sense if you think of it as a "plug in" issue, but it makes sense if you think of it as a "derived work" issue, along with taking "intent" into account. I know lawyers tend to not like the notion of "intent", because it brings in another whole range of gray areas, but it's obviously a legal reality. Ok, enough blathering from me. I'd just like to finish off with a few comments, just to clarify my personal stand: - I'm obviously not the only copyright holder of Linux, and I did so on purpose for several reasons. One reason is just because I hate the paperwork and other cr*p that goes along with copyright assignments. Another is that I don't much like copyright assignments at all: the author is the author, and he may be bound by my requirement for GPL, but that doesn't mean that he should give his copyright to me. A third reason, and the most relevant reason here, is that I want people to _know_ that I cannot control the sources. I can write you a note to say that "for use XXX, I do not consider module YYY to be a derived work of my kernel", but that would not really matter that much. Any other Linux copyright holder might still sue you. This third reason is what makes people who otherwise might not trust me realize that I cannot screw people over. I am bound by the same agreement that I require of everybody else, and the only special status I really have is a totally non-legal issue: people trust me. (Yes, I realize that I probably would end up having more legal status than most, even apart from the fact that I still am the largest single copyright holder, if only because of appearances) - I don't really care about copyright law itself. What I care about is my own morals. Whether I'd ever sue somebody or not (and quite frankly, it's the last thing I ever want to do - if I never end up talking to lawyers in a professional context, I'll be perfectly happy. No disrespect intended) will be entirely up to whether I consider what people do to me "moral" or not. Which is why intent matters to me a lot - both the intent of the person/corporation doign the infringement, _and_ the intent of me and others in issues like the module export interface. Another way of putting this: I don't care about "legal loopholes" and word-wrangling. - Finally: I don't trust the FSF. I like the GPL a lot - although not necessarily as a legal piece of paper, but more as an intent. Which explains why, if you've looked at the Linux COPYING file, you may have noticed the explicit comment about "only _this_ particular version of the GPL covers the kernel by default". That's because I agree with the GPL as-is, but I do not agree with the FSF on many other matters. I don't like software patents much, for example, but I do not want the code I write to be used as a weapon against companies that have them. The FSF has long been discussing and is drafting the "next generation" GPL, and they generally suggest that people using the GPL should say "v2 or at your choice any later version". Linux doesn't do that. The Linux kernel is v2 ONLY, apart from a few files where the author put in the FSF extension (and see above about copyright assignments why I would never remove such an extension). The "v2 only" issue might change some day, but only after all documented copyright holders agree on it, and only after we've seen what the FSF suggests. From what I've seen so far from the FSF drafts, we're not likely to change our v2-only stance, but there might of course be legal reasons why we'd have to do something like it (ie somebody challenging the GPLv2 in court, and part of it to be found unenforceable or similar would obviously mean that we'd have to reconsider the license). Linus PS. Historically, binary-only modules have not worked well under Linux, quite regardless of any copyright issues. The kernel just develops too quickly for binary modules to work well, and nobody really supports them. Companies like RedHat etc tend to refuse to have anything to do with binary modules, because if something goes wrong there is nothing they can do about it. So I just wanted to let you know that the _legal_ issue is just the beginning. Even though you probably don't personally care ;)
3.144.86.121