linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Willy Tarreau <w@1wt.eu>
To: Linus Torvalds <torvalds@osdl.org>
Cc: Linux Kernel Mailing List <linux-kernel@vger.kernel.org>
Subject: Re: An Ode to GPLv2 (was Re: GPLv3 Position Statement)
Date: Mon, 25 Sep 2006 06:40:10 +0200	[thread overview]
Message-ID: <20060925044010.GN541@1wt.eu> (raw)
In-Reply-To: <Pine.LNX.4.64.0609241917520.3952@g5.osdl.org>

Hi Linus,

On Sun, Sep 24, 2006 at 07:44:59PM -0700, Linus Torvalds wrote:
[...]
> And thus spake PJ in response:
>    "GPLv2 is not compatible with the Apache license.  It doesn't cover
>     Bitstream.  It is ambiguous about web downloads.  It allows Tivo to
>     forbid modification.  It has no patent protection clause.  It isn't
>     internationally useful everywhere, due to not matching the terms of
>     art used elsewhere.  It has no DMCA workaround or solution.  It is
>     silent about DRM."
> 
> Exactly!
> 
> That's why the GPLv2 is so great.  Exactly because it doesn't bother or
> talk about anything else than the very generic issue of "tit-for-tat". 
> 
> You see it as a failure.  I see it as a huge advantage.  The GPLv2 covers 
> the only thing that really matters, and the only thing that everybody can 
> agree on ("tit-for-tat" is really something everybody understands, and 
> sees the same way - it's totally independent of any moral judgement and 
> any philosophical, cultural or economic background).
> 
> The thing is, exactly because the GPLv2 is not talking about the details, 
> but instead talks entirely about just a very simple issue, people can get 
> together around it.  You don't have to believe in the FSF or the tooth 
> fairy to see the point of the GPLv2.  It doesn't matter if you're black or 
> white, commercial or non-commercial, man or woman, an individual or a 
> corporation - you understand tit-or-tat.

[...]
> That's also why I ended up changing the kernel license to the GPLv2. The 
> original Linux source license said basically: "Give all source back, and 
> never charge any money".  It took me a few months, but I realized that the 
> "never charge any money" part was just asinine.  It wasn't the point.  
> The point was always "give back in kind".

[...]
> And that's what the GPLv2 is.  It's "fair".  It asks everybody - 
> regardless of circumstance - for the same thing.  It asks for the effort 
> that was put into improving the software to be given back to the common 
> good.  You can use the end result any way you want (and if you want to use 
> it for "bad" things, be my guest), but we ask the same exact thing of 
> everybody - give your modifications back.
> 
> That's true grace.  Realizing that the petty concerns don't matter, 
> whether they are money or DRM, or patents, or anything else.
> 
> And that's why I chose the GPLv2.  I did it back when the $169 I paid for 
> Minix still stung me, because I just decided that that wasn't what it was 
> all about.
> 
> And I look at the additions to the GPLv3, and I still say: "That's not 
> what it's all about".
> 
> My original license was petty and into details.  I don't need to go back 
> to those days.  I found a better license.  And it's the GPLv2.

That's an interesting analysis, and it somehow reflects one I had to
do a few months back. After all the fuss about binary-only modules
incompatibility with GPLv2, I wanted to change the license of haproxy
to explicitly permit external binary-only code to be linked with it. It's
a TCP/HTTP load balancer and people might sometimes have to implement
algorithms under NDA for specific protocols, and I don't want to have
to decide for them if it is the right tool for them or not. I don't
either want to force them to release their code if I don't use it and
if nobody has contributed to it. I just wanted them to give back any
change they bring to the core.

I spend a full week-end reading other licenses, and many others looked
appealing but added specific clauses for patents, DRM, etc... which were
too restrictive for the end user. Others in turn did not make provisions
for feedback. I finally gave up, and decided that the GPLv2 was definitely
the best one for the job. I only changed all the interfacing headers to
LGPL and added a note to explicitly state that my intent was to allow
people to write binary-only modules as long as they gave back their
fixes or work on the core system they use.

As a result, developers are free to choose how they work, and the type
of contribution they expect from others, but they must respect the
work of others. *That* is what I consider fair use.

Just my 2 cents,
Willy


  reply	other threads:[~2006-09-25  5:03 UTC|newest]

Thread overview: 188+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2006-09-22 16:15 GPLv3 Position Statement James Bottomley
2006-09-22 16:16 ` James Bottomley
2006-09-22 17:49 ` The GPL: No shelter for the Linux kernel? Adrian Bunk
2006-09-22 18:00   ` Greg KH
2006-09-22 18:01   ` Manu Abraham
2006-09-22 20:04   ` David Schwartz
2006-09-22 21:25     ` Linus Torvalds
2006-09-22 21:44     ` Linus Torvalds
2006-09-23  0:11       ` David Schwartz
2006-09-23  1:36         ` Linus Torvalds
2006-09-23  7:28         ` Paul Jackson
2006-09-23  8:05       ` Manu Abraham
2006-09-23 15:32       ` Oleg Verych
     [not found]         ` <Pine.LNX.4.64.0609230941530.4388@g5.osdl.org>
2006-09-23 21:04           ` Forwarded message from Linus Torvalds <torvalds@osdl.org> Oleg Verych
2006-09-27  1:19             ` The GPL: No shelter for the Linux kernel? Oleg Verych
2006-09-23  8:10     ` Jan Engelhardt
2006-09-23 17:38       ` David Schwartz
2006-09-23 18:00       ` Linus Torvalds
2006-09-23 18:14         ` Petr Baudis
2006-09-24  7:53           ` Jan Engelhardt
2006-09-24 16:34             ` Linus Torvalds
2006-09-25  5:59               ` Jan Engelhardt
2006-09-25 15:14                 ` Linus Torvalds
     [not found] ` <200609221359.39519.gene.heskett@verizon.net>
2006-09-22 18:08   ` GPLv3 Position Statement James Bottomley
2006-09-22 18:30     ` Gene Heskett
2006-09-22 18:34       ` Jeff Garzik
2006-09-22 18:52         ` Gene Heskett
2006-09-22 19:05       ` Alan Cox
2006-09-22 18:54         ` Gene Heskett
2006-09-25  6:33       ` Marc Perkel
2006-09-22 20:42 ` Jeff Garzik
2006-09-23 11:38 ` Florian Weimer
2006-09-25  2:44 ` An Ode to GPLv2 (was Re: GPLv3 Position Statement) Linus Torvalds
2006-09-25  4:40   ` Willy Tarreau [this message]
2006-09-25 12:00     ` Arjan van de Ven
2006-09-25 13:07       ` Willy Tarreau
2006-09-28  0:12         ` H. Peter Anvin
2006-09-25  8:53 ` GPLv3 Position Statement Michiel de Boer
2006-09-25  9:06   ` Russell King
2006-09-25 10:51   ` Neil Brown
2006-09-25 11:31     ` Alan Cox
2006-09-25 16:10       ` Thomas Gleixner
2006-09-29 10:15         ` Helge Hafting
2006-09-29 11:07           ` Alan Cox
2006-09-29 14:02           ` Stephen Clark
2006-09-29 16:51           ` Linus Torvalds
2006-09-29 17:47             ` Alan Cox
2006-09-29 17:49               ` Linus Torvalds
2006-09-29 18:17                 ` Linus Torvalds
2006-09-29 18:26                 ` Alan Cox
2006-09-29 18:27                   ` Linus Torvalds
2006-09-29 18:40                     ` Linus Torvalds
2006-09-29 19:59                       ` alan
2006-09-29 20:06                         ` Linus Torvalds
2006-09-29 20:21                           ` alan
2006-09-29 20:32                             ` alan
2006-09-29 23:12                               ` Gene Heskett
2006-09-29 23:25                                 ` Randy Dunlap
2006-09-29 23:53                                   ` Gene Heskett
2006-09-30  0:31                                     ` Vadim Lobanov
2006-09-30  3:36                                       ` Gene Heskett
2006-09-30  4:37                                         ` Vadim Lobanov
2006-09-30  4:54                                           ` Randy Dunlap
2006-09-30  6:10                                             ` Vadim Lobanov
2006-09-29 21:11                             ` Chris Smith
2006-09-29 21:33                               ` alan
2006-09-29 20:51                           ` alan
2006-09-29 21:25                       ` Theodore Tso
2006-09-29 21:29                       ` Alan Cox
2006-10-02  8:46             ` Helge Hafting
2006-09-29 19:43           ` jdow
2006-09-30 18:38           ` Thomas Gleixner
2006-09-30 20:49             ` Alan Cox
2006-09-30 20:38               ` Thomas Gleixner
2006-09-25 14:27     ` Lee Revell
2006-09-25 19:05       ` Jan Engelhardt
2006-09-25 20:58       ` Gene Heskett
2006-09-25 22:10         ` linux-os (Dick Johnson)
2006-09-26 21:32       ` Oleg Verych
2006-09-25 19:46     ` Jeff Garzik
2006-09-25 21:10       ` Gene Heskett
2006-09-25 11:11   ` Jan Engelhardt
2006-09-25 14:12   ` James Bottomley
2006-09-25 16:50   ` Linus Torvalds
2006-09-25 17:26   ` James Bottomley
2006-09-25 15:30 ` Xavier Bestel
2006-09-27  1:11 ` Sergey Panov
2006-09-27  5:55   ` Jan Engelhardt
2006-09-27  7:36     ` Sergey Panov
2006-09-27  8:58       ` Jan Engelhardt
2006-09-27 12:19         ` Alan Cox
2006-09-27 17:28           ` Linus Torvalds
2006-09-27 18:37             ` Chase Venters
2006-09-27 19:11               ` Linus Torvalds
2006-09-29 12:42                 ` Pavel Machek
2006-09-27 22:58               ` Theodore Tso
2006-09-27 23:16                 ` Chase Venters
2006-09-28  0:03                   ` Neil Brown
2006-09-28  0:08                     ` David Miller
2006-09-28  0:18                   ` Linus Torvalds
2006-09-28  0:54                     ` Patrick McFarland
2006-09-28  3:15                       ` Linus Torvalds
2006-09-28  3:47                         ` Sergey Panov
2006-09-28  4:13                           ` Linus Torvalds
2006-09-28  5:05                             ` Sergey Panov
2006-09-28  4:39                           ` Chase Venters
2006-09-28  5:13                             ` Trond Myklebust
2006-09-28  5:15                             ` Jeff Garzik
2006-09-28  5:27                               ` Sergey Panov
2006-09-28  5:34                                 ` Jeff Garzik
2006-09-28  7:30                                 ` Al Viro
2006-09-28 13:55                             ` Lennart Sorensen
2006-09-28 14:19                               ` DervishD
2006-09-28 14:40                                 ` Jörn Engel
2006-09-28 14:59                                   ` DervishD
2006-09-28 15:04                                   ` Linus Torvalds
2006-09-28 15:20                                     ` Jörn Engel
2006-09-28 15:31                                       ` Linus Torvalds
2006-09-28 15:46                                       ` Björn Steinbrink
2006-09-28 15:24                                     ` Linus Torvalds
2006-09-29  0:26                                       ` Neil Brown
2006-09-29  6:22                                         ` Linus Torvalds
2006-09-29  1:34                                     ` jdow
2006-09-29  6:08                                     ` Jan Engelhardt
2006-09-29  7:07                                       ` Linus Torvalds
2006-09-29  7:18                                       ` David Schwartz
2006-09-29  2:29                                   ` David Schwartz
2006-09-29  2:45                                     ` Neil Brown
2006-09-29  3:05                                       ` Björn Steinbrink
2006-09-29  3:31                                         ` David Schwartz
2006-09-29  5:37                                           ` Björn Steinbrink
2006-09-29  7:18                                       ` David Schwartz
     [not found]                                     ` <20060928225008.ded4fa2c.seanlkml@sympatico.ca>
2006-09-29  2:50                                       ` Sean
2006-09-29  7:18                                         ` David Schwartz
2006-10-02  8:55                                         ` Maybe it's time to fork the GPL License - create the Linux license? Marc Perkel
2006-10-02  9:14                                           ` Jesper Juhl
2006-10-02  9:23                                             ` Marc Perkel
2006-10-03 10:31                                             ` Jan Engelhardt
2006-10-03 15:34                                               ` Marc Perkel
2006-10-02  9:18                                           ` Dumitru Ciobarcianu
2006-10-02  9:25                                           ` Patrick McFarland
2006-10-02 18:26                                             ` James Dickens
2006-10-03 20:59                                           ` Ivan Dimitrov
2006-10-03 21:00                                             ` Chase Venters
2006-10-03 21:17                                             ` It's not GNU/Linux - it's jusy LINUX Marc Perkel
2006-10-03 21:41                                               ` Neil Brown
2006-10-04 20:09                                                 ` Jan Engelhardt
2006-10-04 20:53                                                   ` linux-os (Dick Johnson)
2006-10-03 21:41                                               ` Adam Henley
2006-10-03 21:47                                                 ` Marc Perkel
2006-10-03 21:58                                                   ` Chase Venters
2006-10-03 22:00                                                   ` Hua Zhong
2006-10-04  1:17                                                     ` Patrick Draper
2006-10-04  2:06                                                       ` Patrick McFarland
2006-10-04 15:16                                                         ` Patrick Draper
2006-10-03 22:10                                                   ` M4y3c0
2006-10-03 22:02                                           ` Maybe it's time to fork the GPL License - create the Linux license? Daniel Barkalow
2006-09-28 14:51                                 ` GPLv3 Position Statement Simon Oosthoek
2006-09-28 15:07                                   ` DervishD
2006-09-28 15:38                               ` Linus Torvalds
2006-09-28 18:34                             ` Linus Torvalds
2006-09-28 17:16                         ` linux-os (Dick Johnson)
2006-09-28 18:59                           ` Segher Boessenkool
2006-09-28 19:34                             ` linux-os (Dick Johnson)
2006-09-28 20:01                               ` Oleg Verych
2006-09-28 23:12                                 ` Gene Heskett
2006-09-29  8:04                           ` Jan Engelhardt
2006-09-28  1:35                     ` Al Viro
2006-09-28  3:13                       ` Sergey Panov
2006-09-28  3:36                         ` Linus Torvalds
2006-09-28  1:53                     ` Alan Cox
2006-09-28  9:41                     ` Jörn Engel
2006-09-28  9:55                       ` Jeff Garzik
2006-09-28 14:45                         ` Linus Torvalds
2006-09-28 15:19                           ` Alan Cox
2006-09-28 14:40                       ` Linus Torvalds
2006-09-28  2:34                   ` Gene Heskett
2006-09-28  8:04             ` Jan Engelhardt
2006-09-28 13:50               ` Christer Weinigel
2006-09-28 20:43               ` Linus Torvalds
2006-09-27 18:01         ` Theodore Tso
2006-09-27 12:32     ` Theodore Tso
2006-09-27 21:05       ` David Schwartz
2006-09-29 12:47       ` Pavel Machek
2006-09-27 17:00     ` Linus Torvalds
2006-09-28  8:18       ` Jan Engelhardt
2006-09-28  9:39       ` Samuel Tardieu
2006-09-27 16:08   ` Greg KH

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20060925044010.GN541@1wt.eu \
    --to=w@1wt.eu \
    --cc=linux-kernel@vger.kernel.org \
    --cc=torvalds@osdl.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).