Free Software Free Society Selected Essays of Richard Stallman 2nd Edition Edition Richard Stallman Available All Format
Free Software Free Society Selected Essays of Richard Stallman 2nd Edition Edition Richard Stallman Available All Format
                                                DOWNLOAD EBOOK
     Free Software Free Society Selected Essays of Richard
  Stallman 2nd Edition Edition Richard Stallman pdf download
Available Formats
https://ebookgate.com/product/free-software-free-society-selected-
essays-of-richard-m-stallman-first-printing-edition-richard-m-
stallman/
ebookgate.com
https://ebookgate.com/product/free-as-in-freedom-2-0-richard-stallman-
and-the-free-software-revolution-2nd-edition-sam-williams/
ebookgate.com
https://ebookgate.com/product/gnu-emacs-manual-14th-edition-richard-m-
stallman/
ebookgate.com
https://ebookgate.com/product/debugging-with-gdb-the-gnu-source-level-
debugger-9th-edition-richard-m-stallman/
ebookgate.com
Philosophical Essays on Free Stuff 1st Edition Robyn
Ferrell
https://ebookgate.com/product/philosophical-essays-on-free-stuff-1st-
edition-robyn-ferrell/
ebookgate.com
https://ebookgate.com/product/understanding-open-source-and-free-
software-licensing-andrew-m-st-laurent/
ebookgate.com
https://ebookgate.com/product/emerging-free-and-open-source-software-
practices-1st-edition-sulayman-k-sowe/
ebookgate.com
https://ebookgate.com/product/culture-society-and-sexuality-a-
reader-2nd-edition-richard-parker/
ebookgate.com
Our Fate Essays on God and Free Will 1st Edition John
Martin Fischer
https://ebookgate.com/product/our-fate-essays-on-god-and-free-
will-1st-edition-john-martin-fischer/
ebookgate.com
Richard Stallman is the prophet of the free software movement. He understood
the dangers of software patents years ago. Now that this has become a crucial
issue in the world, buy this book and read what he said.
—Tim Berners-Lee, inventor of the World Wide Web
By his hugely successful efforts to establish the idea of “Free Software,” Stallman
has made a massive contribution to the human condition. His contribution com-
bines elements that have technical, social, political, and economic consequences.
—Gerald Jay Sussman, Matsushita Professor of Electrical Engineering, MIT
RMS is the leading philosopher of software. You may dislike some of his atti-
tudes, but you cannot avoid his ideas. This slim volume will make those ideas
readily accessible to those who are confused by the buzzwords of rampant com-
mercialism. This book needs to be widely circulated and widely read.
—Peter Salus, computer science writer, book reviewer, and UNIX historian
Richard is the leading force of the free software movement. This book is very
important to spread the key concepts of free software world-wide, so everyone
can understand it. Free software gives people freedom to use their creativity.
—Masayuki Ida, professor, Graduate School of International Management,
Aoyama Gakuin University
Free Software, Free Society
                      Selected Essays of Richard M. Stallman
                                              Second Edition
Richard M. Stallman
This is the second edition of Free Software, Free Society: Selected Essays of
Richard M. Stallman.
Foreword . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . v
Preface to the Second Edition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ix
Foreword
    Every generation has its philosopher—a writer or an artist who captures the
imagination of a time. Sometimes these philosophers are recognized as such;
often it takes generations before the connection is made real. But recognized
or not, a time gets marked by the people who speak its ideals, whether in the
whisper of a poem, or the blast of a political movement.
    Our generation has a philosopher. He is not an artist, or a professional writer.
He is a programmer. Richard Stallman began his work in the labs of MIT, as
a programmer and architect building operating system software. He has built
his career on a stage of public life, as a programmer and an architect founding
a movement for freedom in a world increasingly defined by “code.”
    “Code” is the technology that makes computers run. Whether inscribed in
software or burned in hardware, it is the collection of instructions, first written in
words, that directs the functionality of machines. These machines—computers—
increasingly define and control our life. They determine how phones connect,
and what runs on TV. They decide whether video can be streamed across a
broadband link to a computer. They control what a computer reports back to
its manufacturer. These machines run us. Code runs these machines.
    What control should we have over this code? What understanding? What
freedom should there be to match the control it enables? What power?
    These questions have been the challenge of Stallman’s life. Through his works
and his words, he has pushed us to see the importance of keeping code “free.”
Not free in the sense that code writers don’t get paid, but free in the sense that
the control coders build be transparent to all, and that anyone have the right
to take that control, and modify it as he or she sees fit. This is “free software”;
“free software” is one answer to a world built in code.
    “Free.” Stallman laments the ambiguity in his own term. There’s nothing to
lament. Puzzles force people to think, and this term “free” does this puzzling
work quite well. To modern American ears, “free software” sounds utopian,
impossible. Nothing, not even lunch, is free. How could the most important
words running the most critical machines running the world be “free.” How
could a sane society aspire to such an ideal?
    Yet the odd clink of the word “free” is a function of us, not of the term. “Free”
has different senses, only one of which refers to “price.” A much more funda-
mental sense of “free” is the “free,” Stallman says, in the term “free speech,” or
perhaps better in the term “free labor.” Not free as in costless, but free as in
limited in its control by others. Free software is control that is transparent, and
open to change, just as free laws, or the laws of a “free society,” are free when
they make their control knowable, and open to change. The aim of Stallman’s
“free software movement” is to make as much code as it can transparent, and
subject to change, by rendering it “free.”
    The mechanism of this rendering is an extraordinarily clever device called
“copyleft” implemented through a license called GPL. Using the power of copy-
right law, “free software” not only assures that it remains open, and subject to
change, but that other software that takes and uses “free software” (and that
technically counts as a “derivative”) must also itself be free. If you use and adapt
a free software program, and then release that adapted version to the public,
the released version must be as free as the version it was adapted from. It must,
or the law of copyright will be violated.
    “Free software,” like free societies, has its enemies. Microsoft has waged a
war against the GPL, warning whoever will listen that the GPL is a “dangerous”
license. The dangers it names, however, are largely illusory. Others object to
the “coercion” in GPL’s insistence that modified versions are also free. But a
condition is not coercion. If it is not coercion for Microsoft to refuse to permit
users to distribute modified versions of its product Office without paying it
(presumably) millions, then it is not coercion when the GPL insists that modified
versions of free software be free too.
    And then there are those who call Stallman’s message too extreme. But
extreme it is not. Indeed, in an obvious sense, Stallman’s work is a simple
translation of the freedoms that our tradition crafted in the world before code.
“Free software” would assure that the world governed by code is as “free” as our
tradition that built the world before code.
    For example: A “free society” is regulated by law. But there are limits that
any free society places on this regulation through law: No society that kept its
laws secret could ever be called free. No government that hid its regulations
from the regulated could ever stand in our tradition. Law controls. But it does
so justly only when visibly. And law is visible only when its terms are knowable
and controllable by those it regulates, or by the agents of those it regulates
(lawyers, legislatures).
    This condition on law extends beyond the work of a legislature. Think about
the practice of law in American courts. Lawyers are hired by their clients to
advance their clients’ interests. Sometimes that interest is advanced through lit-
igation. In the course of this litigation, lawyers write briefs. These briefs in turn
affect opinions written by judges. These opinions decide who wins a particular
case, or whether a certain law can stand consistently with a constitution.
    All the material in this process is free in the sense that Stallman means.
Legal briefs are open and free for others to use. The arguments are transparent
(which is different from saying they are good) and the reasoning can be taken
without the permission of the original lawyers. The opinions they produce can
be quoted in later briefs. They can be copied and integrated into another brief
or opinion. The “source code” for American law is by design, and by principle,
open and free for anyone to take. And take lawyers do—for it is a measure of
Foreword                                                                         vii
a great brief that it achieves its creativity through the reuse of what happened
before. The source is free; creativity and an economy is built upon it.
    This economy of free code (and here I mean free legal code) doesn’t starve
lawyers. Law firms have enough incentive to produce great briefs even though
the stuff they build can be taken and copied by anyone else. The lawyer is a
craftsman; his or her product is public. Yet the crafting is not charity. Lawyers
get paid; the public doesn’t demand such work without price. Instead this
economy flourishes, with later work added to the earlier.
    We could imagine a legal practice that was different—briefs and arguments
that were kept secret; rulings that announced a result but not the reasoning.
Laws that were kept by the police but published to no one else. Regulation that
operated without explaining its rule.
    We could imagine this society, but we could not imagine calling it “free.”
Whether or not the incentives in such a society would be better or more efficiently
allocated, such a society could not be known as free. The ideals of freedom, of life
within a free society, demand more than efficient application. Instead, openness
and transparency are the constraints within which a legal system gets built, not
options to be added if convenient to the leaders. Life governed by software code
should be no less.
    Code writing is not litigation. It is better, richer, more productive. But the
law is an obvious instance of how creativity and incentives do not depend upon
perfect control over the products created. Like jazz, or novels, or architecture,
the law gets built upon the work that went before. This adding and changing
is what creativity always is. And a free society is one that assures that its most
important resources remain free in just this sense.
    This book collects the writing of Richard Stallman in a manner that will make
its subtlety and power clear. The essays span a wide range, from copyright to
the history of the free software movement. They include many arguments not
well known, and among these, an especially insightful account of the changed
circumstances that render copyright in the digital world suspect. They will serve
as a resource for those who seek to understand the thought of this most powerful
man—powerful in his ideas, his passion, and his integrity, even if powerless in
every other way. They will inspire others who would take these ideas, and build
upon them.
    I don’t know Stallman well. I know him well enough to know he is a hard
man to like. He is driven, often impatient. His anger can flare at friend as easily
as foe. He is uncompromising and persistent; patient in both.
    Yet when our world finally comes to understand the power and danger of
code—when it finally sees that code, like laws, or like government, must be
transparent to be free—then we will look back at this uncompromising and
persistent programmer and recognize the vision he has fought to make real: the
vision of a world where freedom and knowledge survives the compiler. And we
will come to see that no man, through his deeds or words, has done as much to
make possible the freedom that this next society could have.
viii                                         Free Software, Free Society, 2nd ed.
    We have not earned that freedom yet. We may well fail in securing it. But
whether we succeed or fail, in these essays is a picture of what that freedom could
be. And in the life that produced these words and works, there is inspiration
for anyone who would, like Stallman, fight to create this freedom.
                                                              Lawrence Lessig
Lawrence Lessig is a Professor of Law at Harvard Law School, the director of the
Edmond J. Safra Foundation Center for Ethics, and the founder of Stanford Law
School’s Center for Internet and Society. For much of his career, he focused his
work on law and technology, especially as it affects copyright. He is the author of
numerous books and has served as a board member of many organizations,
including the Free Software Foundation.
Preface to the Second Edition                                                  ix
    A program is free software if users have all of these freedoms. Thus, you
should be free to redistribute copies, either with or without modifications, either
gratis or charging a fee for distribution, to anyone anywhere. Being free to do
these things means (among other things) that you do not have to ask or pay for
permission to do so.
    You should also have the freedom to make modifications and use them pri-
vately in your own work or play, without even mentioning that they exist. If
you do publish your changes, you should not be required to notify anyone in
particular, or in any particular way.
    The freedom to run the program means the freedom for any kind of person or
organization to use it on any kind of computer system, for any kind of overall job
and purpose, without being required to communicate about it with the developer
or any other specific entity. In this freedom, it is the user’s purpose that matters,
not the developer’s purpose; you as a user are free to run the program for your
Copyright c 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2004, 2005, 2006, 2007, 2009,
2010 Free Software Foundation, Inc.
    The free software definition was first published in 1996, on http://gnu.org.
This version is part of Free Software, Free Society: Selected Essays of Richard M.
Stallman, 2nd ed. (Boston: GNU Press, 2010).
Verbatim copying and distribution of this entire chapter are permitted worldwide,
without royalty, in any medium, provided this notice is preserved.
4                                            Free Software, Free Society, 2nd ed.
purposes, and if you distribute it to someone else, she is then free to run it for
her purposes, but you are not entitled to impose your purposes on her.
    The freedom to redistribute copies must include binary or executable forms of
the program, as well as source code, for both modified and unmodified versions.
(Distributing programs in runnable form is necessary for conveniently installable
free operating systems.) It is OK if there is no way to produce a binary or
executable form for a certain program (since some languages don’t support that
feature), but you must have the freedom to redistribute such forms should you
find or develop a way to make them.
    In order for freedoms 1 and 3 (the freedom to make changes and the freedom
to publish improved versions) to be meaningful, you must have access to the
source code of the program. Therefore, accessibility of source code is a necessary
condition for free software. Obfuscated “source code” is not real source code and
does not count as source code.
    Freedom 1 includes the freedom to use your changed version in place of the
original. If the program is delivered in a product designed to run someone else’s
modified versions but refuse to run yours—a practice known as “tivoization” or
(in its practitioners’ perverse terminology) as “secure boot”—freedom 1 becomes
a theoretical fiction rather than a practical freedom. This is not sufficient. In
other words, these binaries are not free software even if the source code they are
compiled from is free.
    One important way to modify a program is by merging in available free
subroutines and modules. If the program’s license says that you cannot merge
in a suitably licensed existing module—for instance, if it requires you to be
the copyright holder of any code you add—then the license is too restrictive to
qualify as free.
    Freedom 3 includes the freedom to release your modified versions as free
software. A free license may also permit other ways of releasing them; in other
words, it does not have to be a copyleft license. However, a license that requires
modified versions to be nonfree does not qualify as a free license.
    In order for these freedoms to be real, they must be permanent and irre-
vocable as long as you do nothing wrong; if the developer of the software has
the power to revoke the license, or retroactively change its terms, without your
doing anything wrong to give cause, the software is not free.
    However, certain kinds of rules about the manner of distributing free software
are acceptable, when they don’t conflict with the central freedoms. For example,
copyleft (very simply stated) is the rule that when redistributing the program,
you cannot add restrictions to deny other people the central freedoms. This rule
does not conflict with the central freedoms; rather it protects them.
    “Free software” does not mean “noncommercial.” A free program must be
available for commercial use, commercial development, and commercial distri-
bution. Commercial development of free software is no longer unusual; such free
commercial software is very important. You may have paid money to get copies
of free software, or you may have obtained copies at no charge. But regardless
Chapter 1: The Free Software Definition                                            5
of how you got your copies, you always have the freedom to copy and change
the software, even to sell copies.
    Whether a change constitutes an improvement is a subjective matter. If your
modifications are limited, in substance, to changes that someone else considers
an improvement, that is not freedom.
    However, rules about how to package a modified version are acceptable, if
they don’t substantively limit your freedom to release modified versions, or your
freedom to make and use modified versions privately. Thus, it is acceptable for
the license to require that you change the name of the modified version, remove
a logo, or identify your modifications as yours. As long as these requirements are
not so burdensome that they effectively hamper you from releasing your changes,
they are acceptable; you’re already making other changes to the program, so you
won’t have trouble making a few more.
    Rules that “if you make your version available in this way, you must make
it available in that way also” can be acceptable too, on the same condition. An
example of such an acceptable rule is one saying that if you have distributed a
modified version and a previous developer asks for a copy of it, you must send
one. (Note that such a rule still leaves you the choice of whether to distribute
your version at all.) Rules that require release of source code to the users for
versions that you put into public use are also acceptable.
    In the GNU Project, we use copyleft to protect these freedoms legally for
everyone. But noncopylefted free software also exists. We believe there are
important reasons why it is better to use copyleft, but if your program is non-
copylefted free software, it is still basically ethical. (See “Categories of Free and
Nonfree Software” (p. 77) for a description of how “free software,” “copylefted
software” and other categories of software relate to each other.)
    Sometimes government export control regulations and trade sanctions can
constrain your freedom to distribute copies of programs internationally. Software
developers do not have the power to eliminate or override these restrictions, but
what they can and must do is refuse to impose them as conditions of use of
the program. In this way, the restrictions will not affect activities and people
outside the jurisdictions of these governments. Thus, free software licenses must
not require obedience to any export regulations as a condition of any of the
essential freedoms.
    Most free software licenses are based on copyright, and there are limits on
what kinds of requirements can be imposed through copyright. If a copyright-
based license respects freedom in the ways described above, it is unlikely to have
some other sort of problem that we never anticipated (though this does happen
occasionally). However, some free software licenses are based on contracts, and
contracts can impose a much larger range of possible restrictions. That means
there are many possible ways such a license could be unacceptably restrictive
and nonfree.
    We can’t possibly list all the ways that might happen. If a contract-based
license restricts the user in an unusual way that copyright-based licenses cannot,
6                                             Free Software, Free Society, 2nd ed.
and which isn’t mentioned here as legitimate, we will have to think about it, and
we will probably conclude it is nonfree.
    When talking about free software, it is best to avoid using terms like “give
away” or “for free,” because those terms imply that the issue is about price, not
freedom. Some common terms such as “piracy” embody opinions we hope you
won’t endorse. See “Words to Avoid (or Use with Care)” (p. 93) for a discussion
of these terms. We also have a list of proper translations of “free software” into
various languages (p. 253).
    Finally, note that criteria such as those stated in this free software definition
require careful thought for their interpretation. To decide whether a specific
software license qualifies as a free software license, we judge it based on these
criteria to determine whether it fits their spirit as well as the precise words. If
a license includes unconscionable restrictions, we reject it, even if we did not
anticipate the issue in these criteria. Sometimes a license requirement raises an
issue that calls for extensive thought, including discussions with a lawyer, before
we can decide if the requirement is acceptable. When we reach a conclusion
about a new issue, we often update these criteria to make it easier to see why
certain licenses do or don’t qualify.
    If you are interested in whether a specific license qualifies as a free software
license, see our list of licenses, at http://gnu.org/licenses/license-list.
html. If the license you are concerned with is not listed there, you can ask us
about it by sending us email at [email protected].
    If you are contemplating writing a new license, please contact the Free Soft-
ware Foundation first by writing to that address. The proliferation of different
free software licenses means increased work for users in understanding the li-
censes; we may be able to help you find an existing free software license that
meets your needs.
    If that isn’t possible, if you really need a new license, with our help you can
ensure that the license really is a free software license and avoid various practical
problems.
Beyond Software
Software manuals must be free, for the same reasons that software must be free,
and because the manuals are in effect part of the software.
   The same arguments also make sense for other kinds of works of practical
use—that is to say, works that embody useful knowledge, such as educational
works and reference works. Wikipedia is the best-known example.
   Any kind of work can be free, and the definition of free software has been
extended to a definition of free cultural works1 applicable to any kind of works.
    1
        See http://freedomdefined.org.
Chapter 2: The GNU Project                                                              7
Copyright c 1998, 2001, 2002, 2005, 2006, 2007, 2008, 2010 Richard Stallman
    The original version of this essay was published in Open Sources: Voices from
the Open Source Revolution, by Chris DiBona and others (Sebastopol: O’Reilly
Media, 1999), under the title “The GNU Operating System and the Free Software
Movement.” This version is part of Free Software, Free Society: Selected Essays of
Richard M. Stallman, 2nd ed. (Boston: GNU Press, 2010).
Verbatim copying and distribution of this entire chapter are permitted worldwide,
without royalty, in any medium, provided this notice is preserved.
8                                            Free Software, Free Society, 2nd ed.
The decision to start the GNU Project was based on a similar spirit.
Free as in Freedom
The term “free software” is sometimes misunderstood—it has nothing to do with
price. It is about freedom. Here, therefore, is the definition of free software.
    A program is free software, for you, a particular user, if:
  • You have the freedom to run the program as you wish, for any purpose.
  • You have the freedom to modify the program to suit your needs. (To
    make this freedom effective in practice, you must have access to the source
    code, since making changes in a program without having the source code
    is exceedingly difficult.)
  • You have the freedom to redistribute copies, either gratis or for a fee.
  • You have the freedom to distribute modified versions of the program, so
    that the community can benefit from your improvements.
GNU Emacs
I began work on GNU Emacs in September 1984, and in early 1985 it was
beginning to be usable. This enabled me to begin using Unix systems to do
editing; having no interest in learning to use vi or ed, I had done my editing on
other kinds of machines until then.
    At this point, people began wanting to use GNU Emacs, which raised the
question of how to distribute it. Of course, I put it on the anonymous ftp server
on the MIT computer that I used. (This computer, prep.ai.mit.edu, thus
12                                              Free Software, Free Society, 2nd ed.
became the principal GNU ftp distribution site; when it was decommissioned a
few years later, we transferred the name to our new ftp server.) But at that
time, many of the interested people were not on the Internet and could not get
a copy by ftp. So the question was, what would I say to them?
    I could have said, “Find a friend who is on the net and who will make a copy
for you.” Or I could have done what I did with the original PDP-10 Emacs: tell
them, “Mail me a tape and a SASE (self-addressed stamped envelope), and I
will mail it back with Emacs on it.” But I had no job, and I was looking for ways
to make money from free software. So I announced that I would mail a tape
to whoever wanted one, for a fee of $150. In this way, I started a free software
distribution business, the precursor of the companies that today distribute entire
Linux-based GNU systems.
    Copyleft uses copyright law, but flips it over to serve the opposite of its usual
purpose: instead of a means for restricting a program, it becomes a means for
keeping the program free.
    The central idea of copyleft is that we give everyone permission to run the pro-
gram, copy the program, modify the program, and distribute modified versions—
but not permission to add restrictions of their own. Thus, the crucial freedoms
that define “free software” are guaranteed to everyone who has a copy; they
become inalienable rights.
    For an effective copyleft, modified versions must also be free. This ensures
that work based on ours becomes available to our community if it is published.
When programmers who have jobs as programmers volunteer to improve GNU
software, it is copyleft that prevents their employers from saying, “You can’t
share those changes, because we are going to use them to make our proprietary
version of the program.”
    The requirement that changes must be free is essential if we want to ensure
freedom for every user of the program. The companies that privatized the X
Window System usually made some changes to port it to their systems and
hardware. These changes were small compared with the great extent of X,
but they were not trivial. If making changes were an excuse to deny the users
freedom, it would be easy for anyone to take advantage of the excuse.
    A related issue concerns combining a free program with nonfree code. Such
a combination would inevitably be nonfree; whichever freedoms are lacking for
the nonfree part would be lacking for the whole as well. To permit such com-
binations would open a hole big enough to sink a ship. Therefore, a crucial
requirement for copyleft is to plug this hole: anything added to or combined
with a copylefted program must be such that the larger combined version is also
free and copylefted.
    The specific implementation of copyleft that we use for most GNU software
is the GNU General Public License, or GNU GPL for short. We have other kinds
of copyleft that are used in specific circumstances. GNU manuals are copylefted
also, but use a much simpler kind of copyleft, because the complexity of the
GNU GPL is not necessary for manuals.4
Technical Goals
The principal goal of GNU is to be free software. Even if GNU had no tech-
nical advantage over Unix, it would have a social advantage, allowing users to
cooperate, and an ethical advantage, respecting the user’s freedom.
    But it was natural to apply the known standards of good practice to the
work—for example, dynamically allocating data structures to avoid arbitrary
fixed size limits, and handling all the possible 8-bit codes wherever that made
sense.
    In addition, we rejected the Unix focus on small memory size, by deciding
not to support 16-bit machines (it was clear that 32-bit machines would be the
norm by the time the GNU system was finished), and to make no effort to reduce
memory usage unless it exceeded a megabyte. In programs for which handling
very large files was not crucial, we encouraged programmers to read an entire
input file into core, then scan its contents without having to worry about I/O.
    These decisions enabled many GNU programs to surpass their Unix counter-
parts in reliability and speed.
Donated Computers
As the GNU Project’s reputation grew, people began offering to donate machines
running Unix to the project. These were very useful, because the easiest way
to develop components of GNU was to do it on a Unix system, and replace the
components of that system one by one. But they raised an ethical issue: whether
it was right for us to have a copy of Unix at all.
    Unix was (and is) proprietary software, and the GNU Project’s philosophy
said that we should not use proprietary software. But, applying the same rea-
soning that leads to the conclusion that violence in self defense is justified, I
concluded that it was legitimate to use a proprietary package when that was
crucial for developing a free replacement that would help others stop using the
proprietary package.
    But, even if this was a justifiable evil, it was still an evil. Today we no longer
have any copies of Unix, because we have replaced them with free operating
systems. If we could not replace a machine’s operating system with a free one,
we replaced the machine instead.
    Today,6 hardly any Unix components are left in the GNU Task List—those
jobs had been done, aside from a few inessential ones. But the list is full of
projects that some might call “applications.” Any program that appeals to
more than a narrow class of users would be a useful thing to add to an operating
system.
    Even games are included in the task list—and have been since the beginning.
Unix included games, so naturally GNU should too. But compatibility was not
an issue for games, so we did not follow the list of games that Unix had. Instead,
we listed a spectrum of different kinds of games that users might like.
free software specifically so it could use Readline, and that is a real gain for the
community.
    Proprietary software developers have the advantages money provides; free
software developers need to make advantages for each other. I hope some day
we will have a large collection of GPL-covered libraries that have no parallel
available to proprietary software, providing useful modules to serve as building
blocks in new free software, and adding up to a major advantage for further free
software development.
Scratching an Itch?
Eric Raymond8 says that “Every good work of software starts by scratching a
developer’s personal itch.”9 Maybe that happens sometimes, but many essential
pieces of GNU software were developed in order to have a complete free operating
system. They come from a vision and a plan, not from impulse.
    For example, we developed the GNU C library because a Unix-like system
needs a C library, BASH because a Unix-like system needs a shell, and GNU tar
because a Unix-like system needs a tar program. The same is true for my own
programs—the GNU C compiler, GNU Emacs, GDB and GNU Make.
    Some GNU programs were developed to cope with specific threats to our
freedom. Thus, we developed gzip to replace the Compress program, which had
been lost to the community because of the LZW patents. We found people to
develop LessTif, and more recently started GNOME and Harmony, to address
the problems caused by certain proprietary libraries (see below). We are devel-
oping the GNU Privacy Guard to replace popular nonfree encryption software,
because users should not have to choose between privacy and freedom.
    Of course, the people writing these programs became interested in the work,
and many features were added to them by various people for the sake of their
own needs and interests. But that is not why the programs exist.
Unexpected Developments
At the beginning of the GNU Project, I imagined that we would develop the
whole GNU system, then release it as a whole. That is not how it happened.
    Since each component of the GNU system was implemented on a Unix sys-
tem, each component could run on Unix systems long before a complete GNU
system existed. Some of these programs became popular, and users began ex-
tending them and porting them—to the various incompatible versions of Unix,
and sometimes to other systems as well.
    The process made these programs much more powerful, and attracted both
funds and contributors to the GNU Project. But it probably also delayed com-
pletion of a minimal working system by several years, as GNU developers’ time
 8
     Eric Raymond is a prominent open source advocate; see “Why Open Source
     Misses the Point” (p. 83).
 9
     Eric S. Raymond, The Cathedral and the Bazaar: Musings on Linux and Open
     Source by an Accidental Revolutionary, rev. ed. (Sebastopol, Calif.: O’Reilly,
     2001), p. 23.
18                                          Free Software, Free Society, 2nd ed.
was put into maintaining these ports and adding features to the existing com-
ponents, rather than moving on to write one missing component after another.
Alix
The GNU kernel was not originally supposed to be called the Hurd. Its original
name was Alix—named after the woman who was my sweetheart at the time.
She, a Unix system administrator, had pointed out how her name would fit
a common naming pattern for Unix system versions; as a joke, she told her
friends, “Someone should name a kernel after me.” I said nothing, but decided
to surprise her with a kernel named Alix.
    It did not stay that way. Michael (now Thomas) Bushnell, the main developer
of the kernel, preferred the name Hurd, and redefined Alix to refer to a certain
part of the kernel—the part that would trap system calls and handle them by
sending messages to Hurd servers.
    Later, Alix and I broke up, and she changed her name; independently, the
Hurd design was changed so that the C library would send messages directly to
servers, and this made the Alix component disappear from the design.
    But before these things happened, a friend of hers came across the name Alix
in the Hurd source code, and mentioned it to her. So she did have the chance
to find a kernel named after her.
Chapter 2: The GNU Project                                                    19
Secret Hardware
Hardware manufacturers increasingly tend to keep hardware specifications se-
cret. This makes it difficult to write free drivers so that Linux and XFree86 can
support new hardware. We have complete free systems today, but we will not
have them tomorrow if we cannot support tomorrow’s computers.
    There are two ways to cope with this problem. Programmers can do reverse
engineering to figure out how to support the hardware. The rest of us can choose
the hardware that is supported by free software; as our numbers increase, secrecy
of specifications will become a self-defeating policy.
    Reverse engineering is a big job; will we have programmers with sufficient
determination to undertake it? Yes—if we have built up a strong feeling that
free software is a matter of principle, and nonfree drivers are intolerable. And
will large numbers of us spend extra money, or even a little extra time, so we
can use free drivers? Yes, if the determination to have freedom is widespread.
    [2008 note: this issue extends to the BIOS as well. There is a free BIOS,
coreboot; the problem is getting specs for machines so that coreboot can support
them.]
20                                           Free Software, Free Society, 2nd ed.
Nonfree Libraries
A nonfree library that runs on free operating systems acts as a trap for free
software developers. The library’s attractive features are the bait; if you use the
library, you fall into the trap, because your program cannot usefully be part of
a free operating system. (Strictly speaking, we could include your program, but
it won’t run with the library missing.) Even worse, if a program that uses the
proprietary library becomes popular, it can lure other unsuspecting programmers
into the trap.
     The first instance of this problem was the Motif toolkit, back in the 80s.
Although there were as yet no free operating systems, it was clear what problem
Motif would cause for them later on. The GNU Project responded in two ways:
by asking individual free software projects to support the free X Toolkit widgets
as well as Motif, and by asking for someone to write a free replacement for Mo-
tif. The job took many years; LessTif, developed by the Hungry Programmers,
became powerful enough to support most Motif applications only in 1997.
     Between 1996 and 1998, another nonfree GUI toolkit library, called Qt, was
used in a substantial collection of free software, the desktop KDE.
     Free GNU/Linux systems were unable to use KDE, because we could not use
the library. However, some commercial distributors of GNU/Linux systems who
were not strict about sticking with free software added KDE to their systems—
producing a system with more capabilities, but less freedom. The KDE group
was actively encouraging more programmers to use Qt, and millions of new
“Linux users” had never been exposed to the idea that there was a problem in
this. The situation appeared grim.
     The free software community responded to the problem in two ways:
GNOME and Harmony.
     GNOME, the GNU Network Object Model Environment, is GNU’s desktop
project. Started in 1997 by Miguel de Icaza, and developed with the support
of Red Hat Software, GNOME set out to provide similar desktop facilities, but
using free software exclusively. It has technical advantages as well, such as
supporting a variety of languages, not just C++. But its main purpose was
freedom: not to require the use of any nonfree software.
     Harmony is a compatible replacement library, designed to make it possible
to run KDE software without using Qt.
     In November 1998, the developers of Qt announced a change of license which,
when carried out, should make Qt free software. There is no way to be sure,
but I think that this was partly due to the community’s firm response to the
problem that Qt posed when it was nonfree. (The new license is inconvenient
and inequitable, so it remains desirable to avoid using Qt.)
     [Subsequent note: in September 2000, Qt was rereleased under the GNU
GPL, which essentially solved this problem.]
     How will we respond to the next tempting nonfree library? Will the whole
community understand the need to stay out of the trap? Or will many of us give
up freedom for convenience, and produce a major problem? Our future depends
on our philosophy.
Chapter 2: The GNU Project                                                       21
Software Patents
The worst threat we face comes from software patents, which can put algorithms
and features off limits to free software for up to 20 years. The LZW compression
algorithm patents were applied for in 1983, and we still cannot release free
software to produce proper compressed GIFs. [As of 2009 they have expired.]
In 1998, a free program to produce MP3 compressed audio was removed from
distribution under threat of a patent suit.
    There are ways to cope with patents: we can search for evidence that a
patent is invalid, and we can look for alternative ways to do a job. But each
of these methods works only sometimes; when both fail, a patent may force all
free software to lack some feature that users want. What will we do when this
happens?
    Those of us who value free software for freedom’s sake will stay with free
software anyway. We will manage to get work done without the patented fea-
tures. But those who value free software because they expect it to be technically
superior are likely to call it a failure when a patent holds it back. Thus, while
it is useful to talk about the practical effectiveness of the “bazaar” model of
development, and the reliability and power of some free software, we must not
stop there. We must talk about freedom and principle.
Free Documentation
The biggest deficiency in our free operating systems is not in the software—it is
the lack of good free manuals that we can include in our systems. Documentation
is an essential part of any software package; when an important free software
package does not come with a good free manual, that is a major gap. We have
many such gaps today.
    Free documentation, like free software, is a matter of freedom, not price.
The criterion for a free manual is pretty much the same as for free software:
it is a matter of giving all users certain freedoms. Redistribution (including
commercial sale) must be permitted, online and on paper, so that the manual
can accompany every copy of the program.
    Permission for modification is crucial too. As a general rule, I don’t believe
that it is essential for people to have permission to modify all sorts of articles
and books. For example, I don’t think you or I are obliged to give permission
to modify articles like this one, which describe our actions and our views.
    But there is a particular reason why the freedom to modify is crucial for
documentation for free software. When people exercise their right to modify the
software, and add or change its features, if they are conscientious they will change
the manual, too—so they can provide accurate and usable documentation with
the modified program. A nonfree manual, which does not allow programmers to
be conscientious and finish the job, does not fill our community’s needs.
    Some kinds of limits on how modifications are done pose no problem. For
example, requirements to preserve the original author’s copyright notice, the
distribution terms, or the list of authors, are OK. It is also no problem to require
modified versions to include notice that they were modified, even to have entire
22                                            Free Software, Free Society, 2nd ed.
sections that may not be deleted or changed, as long as these sections deal with
nontechnical topics. These kinds of restrictions are not a problem because they
don’t stop the conscientious programmer from adapting the manual to fit the
modified program. In other words, they don’t block the free software community
from making full use of the manual.
    However, it must be possible to modify all the technical content of the man-
ual, and then distribute the result in all the usual media, through all the usual
channels; otherwise, the restrictions do obstruct the community, the manual is
not free, and we need another manual.
    Will free software developers have the awareness and determination to pro-
duce a full spectrum of free manuals? Once again, our future depends on phi-
losophy.
“Open Source”
Teaching new users about freedom became more difficult in 1998, when a part
of the community decided to stop using the term “free software” and say “open
source software” instead.
    Some who favored this term aimed to avoid the confusion of “free” with
“gratis”—a valid goal. Others, however, aimed to set aside the spirit of principle
that had motivated the free software movement and the GNU Project, and to
appeal instead to executives and business users, many of whom hold an ideology
that places profit above freedom, above community, above principle. Thus, the
rhetoric of “open source” focuses on the potential to make high-quality, powerful
software, but shuns the ideas of freedom, community, and principle.
    The “Linux” magazines are a clear example of this—they are filled with
advertisements for proprietary software that works with GNU/Linux. When the
next Motif or Qt appears, will these magazines warn programmers to stay away
from it, or will they run ads for it?
Chapter 2: The GNU Project                                                    23
    The support of business can contribute to the community in many ways; all
else being equal, it is useful. But winning their support by speaking even less
about freedom and principle can be disastrous; it makes the previous imbalance
between outreach and civics education even worse.
    “Free software” and “open source” describe the same category of software,
more or less, but say different things about the software, and about values. The
GNU Project continues to use the term “free software,” to express the idea that
freedom, not just technology, is important.
Try!
Yoda’s aphorism (“There is no ‘try’ ”) sounds neat, but it doesn’t work for me. I
have done most of my work while anxious about whether I could do the job, and
unsure that it would be enough to achieve the goal if I did. But I tried anyway,
because there was no one but me between the enemy and my city. Surprising
myself, I have sometimes succeeded.
   Sometimes I failed; some of my cities have fallen. Then I found another
threatened city, and got ready for another battle. Over time, I’ve learned to
look for threats and put myself between them and my city, calling on other
hackers to come and join me.
   Nowadays, often I’m not the only one. It is a relief and a joy when I see
a regiment of hackers digging in to hold the line, and I realize, this city may
survive—for now. But the dangers are greater each year, and now Microsoft
has explicitly targeted our community. We can’t take the future of freedom for
granted. Don’t take it for granted! If you want to keep your freedom, you must
be prepared to defend it.
Chapter 3: The Initial Announcement of the GNU Operating System                   25
 1
     The wording here was careless. The intention was that nobody would have to
     pay for permission to use the GNU system. But the words don’t make this clear,
     and people often interpret them as saying that copies of GNU should always be
     distributed at little or no charge. That was never the intent.
Who Am I?
I am Richard Stallman, inventor of the original much-imitated EMACS editor,
now at the Artificial Intelligence Lab at MIT. I have worked extensively
on compilers, editors, debuggers, command interpreters, the Incompatible
Timesharing System and the Lisp Machine operating system. I pioneered
terminal-independent display support in ITS. In addition I have implemented
one crashproof file system and two window systems for Lisp machines.
Why I Must Write GNU
I consider that the golden rule requires that if I like a program I must
share it with other people who like it. I cannot in good conscience sign a
nondisclosure agreement or a software license agreement.
So that I can continue to use computers without violating my principles, I
have decided to put together a sufficient body of free software so that I
will be able to get along without any software that is not free.
How You Can Contribute
I am asking computer manufacturers for donations of machines and money. I’m
asking individuals for donations of programs and work.
One computer manufacturer has already offered to provide a machine. But we
could use more. One consequence you can expect if you donate machines is
that GNU will run on them at an early date. The machine had better be able
to operate in a residential area, and not require sophisticated cooling or
power.
Individual programmers can contribute by writing a compatible duplicate
of some Unix utility and giving it to me. For most projects, such part-time
distributed work would be very hard to coordinate; the independently-written
parts would not work together. But for the particular task of replacing
Unix, this problem is absent. Most interface specifications are fixed by
Unix compatibility. If each contribution works with the rest of Unix, it
will probably work with the rest of GNU.
If I get donations of money, I may be able to hire a few people full or part
time. The salary won’t be high, but I’m looking for people for whom knowing
they are helping humanity is as important as money. I view this as a way of
enabling dedicated people to devote their full energies to working on GNU by
sparing them the need to make a living in another way.
For more information, contact me.
Arpanet mail:
 [email protected]
Usenet:
 ...!mit-eddie!RMS@OZ    ...!mit-vax!RMS@OZ
US Snail:
 Richard Stallman
 166 Prospect St
 Cambridge, MA 02139
Chapter 4: The GNU Manifesto                                                         27
Copyright c 1985, 1993, 2003, 2005, 2007, 2008, 2009, 2010 Free Software
Foundation, Inc.
    “The GNU Manifesto” was originally published in Dr. Dobb’s Journal, vol. 10,
n. 3 (March 1985). This footnoted version is part of Free Software, Free Society:
Selected Essays of Richard M. Stallman, 2nd ed. (Boston: GNU Press, 2010).
Verbatim copying and distribution of this entire chapter are permitted worldwide,
without royalty, in any medium, provided this notice is preserved.
28                                              Free Software, Free Society, 2nd ed.
to supply, eventually, everything useful that normally comes with a Unix system,
and more.
     GNU will be able to run Unix programs, but will not be identical to Unix.
We will make all improvements that are convenient, based on our experience
with other operating systems. In particular, we plan to have longer file names,
file version numbers, a crashproof file system, file name completion perhaps,
terminal-independent display support, and perhaps eventually a Lisp-based win-
dow system through which several Lisp programs and ordinary Unix programs
can share a screen. Both C and Lisp will be available as system programming
languages. We will try to support UUCP, MIT Chaosnet, and Internet protocols
for communication.
     GNU is aimed initially at machines in the 68000/16000 class with virtual
memory, because they are the easiest machines to make it run on. The extra
effort to make it run on smaller machines will be left to someone who wants to
use it on them.
     To avoid horrible confusion, please pronounce the g in the word “GNU” when
it is the name of this project.
utilities will work right when put together. Even allowing for Murphy to create
a few unexpected problems, assembling these components will be a feasible task.
(The kernel will require closer communication and will be worked on by a small,
tight group.)
    If I get donations of money, I may be able to hire a few people full or part
time. The salary won’t be high by programmers’ standards, but I’m looking for
people for whom building community spirit is as important as making money. I
view this as a way of enabling dedicated people to devote their full energies to
working on GNU by sparing them the need to make a living in another way.
 “You cannot reach many people without advertising, and you must charge for
the program to support that.”
 “It’s no use advertising a program people can get free.”
    There are various forms of free or very cheap publicity that can be used to
inform numbers of computer users about something like GNU. But it may be
true that one can reach more microcomputer users with advertising. If this is
really so, a business which advertises the service of copying and mailing GNU
for a fee ought to be successful enough to pay for its advertising and more. This
way, only the users who benefit from the advertising pay for it.
    On the other hand, if many people get GNU from their friends, and such
companies don’t succeed, this will show that advertising was not really necessary
to spread GNU. Why is it that free market advocates don’t want to let the free
market decide this?6
 5
     Several such companies now exist.
 6
     Although it is a charity rather than a company, the Free Software Foundation
     for 10 years raised most of its funds from its distribution service. You can order
     things from the FSF to support its work.
32                                           Free Software, Free Society, 2nd ed.
    The real reason programmers will not starve is that it will still be possible
for them to get paid for programming; just not paid as much as now.
    Restricting copying is not the only basis for business in software. It is the
most common basis8 because it brings in the most money. If it were prohibited,
or rejected by the customer, software business would move to other bases of
organization which are now used less often. There are always numerous ways to
organize any kind of business.
    Probably programming will not be as lucrative on the new basis as it is now.
But that is not an argument against the change. It is not considered an injustice
that sales clerks make the salaries that they now do. If programmers made the
same, that would not be an injustice either. (In practice they would still make
considerably more than that.)
conformation
poke region
by
escapes Schwartzals
in upwards
less
great sober
the a
tremendous and
and
food
It and impudent
USTY both of
had blacks
in and of
its also
would have of
of allied pupils
has more
male of
striped is
as are of
with
is
very eat and
shiver
it Photo
of wild Museum
well
trotter
sales
they by
remains puppies warning
its
with two
form
means
each horse
brilliant HE rhinoceros
Flying active to
They POLO
could Albania
one prevalent
frequents
gave
XV it
obtained
Monkeys
Jeypur of attain
their rule there
the
ran gibbons
we
in
refusing
excited insects
This
canter without it
cart
s the
a American domestic
back if stretched
nasal
trunks
TRIPED with It
THER horse
related
Gibbon
quite the
should natural
up
the
seen in simpering
This
narrow it
the of
more
to Arctic
the P
ALAGOS best
Some accident
above
Fratelli
than
its 86
in has Photo
to
enemies
rivers attenuated
corn bears
listening was
much ones
nuts it
their by
a wander
leopards Arabia
It the
has
which who
or coloured resemble
one A prairies
to ONKEY
ungainly
Sir the
with
numbers small of
climb laws
lions it
to framed
years there
to water
now
In stalked
not or
they
chaus is in
Some
this the
drink a
future writers
when Somaliland
has on
most
CHAPTER
East A
ERRIERS enemies
tail
the
safety be year
In themselves
wolves
one
between
and on certain
Photo of original
is
is of
Himalaya The
by off is
or
Siberia
mere
and
mischief
attention fact
Jerboa true
writer
is
to a shot
ASLEEP 238 in
to
standing
the stick
holy take
and Cobego E
a fingers
sake the to
East sugar it
is
now
to of the
white
it ONKEYS
foot
and any
give appeared a
reverence the and
and
even of
Baboons
and
sat pair
small
hair of It
the better
is seem or
my not
reeds
dark
creature
Herr a their
the
The the
been
kill
S bear tigers
neighbour the as
than the It
that
FOSTER
long P
countries or and
of the winter
plants or The
OLECAT
by
tawny not
of
small say
tree a Rudland
deliberate Family a
colour
as of one
kept
feet by
Though regarded
are
and
wolf
mistake
savage looking
of
unusual or the
in ever
is men
extinct well
burrowing
sleep are
fossil
but cuts S
by admit elephants
Clement cutting
talons at
living
tame
tame the
Gardens groups
not the
chapter
in though the
whence
sables
known
natives and
the while
S
The not
the
looking telegony
Sportsmen Blenheim
especially
If figure held
from vast
the SAVILLE
the
writer of
what see a
Lake
on of
used Hausburg
caravan
driven
common
for of
were The
straw in be
the This
that
is Ocean pressed
largely
for
which are
Eastern
of To
The
its I Formerly
In weight
period undeveloped
O mountainous of
known heard
of A 26
be was
a
solidly
general and A
this
T used a
owned
illustrated LD
The long
breathing
inches far
up when
tails the
of
right be and
must
animal ceased
perhaps
had horse in
so
black
brown reconnaissance
been
5 to and
civets that as
expeditions
by
expense They
a tabby the
his cloak a
quite the
as go
to of is
unpleasant I
so Irish our
when the
the
THIOPIAN
is