newlib/winsup/doc/install.texinfo

275 lines
11 KiB
Plaintext

@chapter Installation Instructions
@section Contents
Unlike previous net releases such as B20.1 and earlier, there is no
monolithic "full" or "usertools" installation. Rather, you can pick and
choose the packages you wish to install, and update them individually.
For a searchable list of packages that can be installed with Cygwin,
see @file{http://cygwin.com/packages/}.
Full source code is available for all packages and tools.
There is only one recommended way to install Cygwin, which is to use the GUI
installer ``Cygwin Setup''. It is flexible and easy to use.
Do it any other way, and you're on your own! That said, keep in mind
that the GUI installer is a "work in progress", so there might be a few
difficulties, especially if you are behind a firewall or have other
specific requirements. If something doesn't work right for you, and
it's not covered here or elsewhere, then by all means report it to the
mailing list.
@section Installation using ``Cygwin Setup''
The Cygwin Setup program is the only recommended way to install Cygwin,
but it is still a work in progress. Expect features and functionality
to change. For this reason, it is a good idea to note the version and
build time reported by Cygwin Setup when you run it. This will help
diagnose problems, should you have any. Check the cygwin mailing list
for the latest news about Cygwin Setup.
@subsection Why not install in C:\?
The Cygwin Setup program will prompt you for a "root" directory.
The default is @samp{C:\cygwin}, but you can change it. You are urged not to
choose something like 'C:\' (the root directory on the system drive) for
your Cygwin root. If you do, then critical Cygwin system directories
like 'etc', 'lib' and 'bin' could easily be corrupted by other (non-Cygwin)
applications or packages that use \etc, \lib or \bin. Perhaps there is
no conflict now, but who knows what you might install in the future?
It's also just good common sense to segregate your Cygwin "filesystems"
from the rest of your Windows system disk.
(In the past, there had been genuine bugs that would cause problems
for people who installed in C:\, but we believe those are gone now.)
@subsection Can I use Cygwin Setup to update a B18, B19, B20, B20.1 or CD-ROM (1.0) installation of Cygwin?
No, you must start from scratch with the new Cygwin Setup. The
overall structure has changed so much that it would be pointless to
try to accomodate old installations of Cygwin. You will probably be
much better off with a whole new installation anyway. You may backup
or rename your old installation first, or just install the new one
somewhere else. Be sure to make note of your current mount table,
because this will be overwritten during the new setup. Make sure you
don't end up with two different versions of @samp{cygwin1.dll} in your
path.
Once you've installed the latest net release, Cygwin Setup will update
just the individual packages that need it.
@subsection Is Cygwin Setup, or one of the packages, infected with a virus?
Unlikely. Unless you can confirm it, please don't report it to the
mailing list. Anti-virus products have been known to detect false
positives when extracting compressed tar archives. If this causes
problems for you, consider disabling your anti-virus software when
running @code{setup}. Read the next entry for a fairly safe way to do
this.
@subsection My computer hangs when I run Cygwin Setup!
Both Network Associates (formerly McAfee) and Norton anti-virus
products have been reported to "hang" when extracting Cygwin tar
archives. If this happens to you, consider disabling your anti-virus
software when running Cygwin Setup. The following procedure should be
a fairly safe way to do that:
@enumerate
@item Download @code{setup.exe} and scan it explicitly.
@item Turn off the anti-virus software.
@item Run setup to download and extract all the tar files.
@item Re-activate your anti-virus software and scan everything
in C:\cygwin (or wherever you chose to install). If you're concerned
about a malicious package, say if a mirror is compromised, then you
should scan your entire hard disk after running Cygwin Setup.
@end enumerate
This should be safe, but only if Cygwin Setup is not substituted by
something malicious.
@subsection What packages should I download?
When using Cygwin Setup for the first time, the default is to install
a minimal subset of packages. If you want anything beyond that, you
will have to select it explicitly. See
@file{http://cygwin.com/packages/} for a searchable list of available
packages.
If you want to build programs, of course you'll need @samp{gcc},
@samp{binutils}, @samp{make} and probably other packages from the
``Devel'' category.
@subsection How do I just get everything?
In the past, the default was to install everything, much to the
irritation of many users. Now the default is to install only a basic
core of packages. At the moment, there is no easy way to get
everything. In the current version of Cygwin Setup, if you want
everything, you must do the following:
@enumerate
@item When the Cygwin Setup says ``Select packages to install'', click on the
``View'' button until it says ``Full''.
@item Wherever it says ``Skip'', click twice until it gives the
version number of the package. That means it will be downloaded and
installed.
@end enumerate
If a package you've selected for installation has prerequisites, those
will automatically be installed too. It's a lot of clicking but only
the first time. Once you install a package, any subsequent updates to
that package will be installed by default. Note that new packages are
added regularly, so you will always have to check the list for any
``Skip'' entries if you want to stay up to date with a complete
installation.
This should become much easier in a future version of Cygwin Setup.
@subsection How much disk space does Cygwin require?
That depends, obviously, on what you've chosen to download and install.
A full installation is probably 250-300MB installed, not including the
package archives themselves or the source code.
After installation, the package archives remain in your ``Local Package
Directory'', by default the location of @code{setup.exe}. You may
conserve disk space by deleting the @code{contrib} and @code{latest}
subdirectories there.
@subsection What if setup fails?
First, make sure that you are using the latest version of Cygwin
Setup. It is a work in progress, with improvements and bugfixes being
made often. The latest version is always available from the 'Install
Cygwin now' link on the Cygwin Home Page at @file{http://cygwin.com/}.
If you are downloading from the internet, setup will fail if it cannot
download the list of mirrors at
@file{http://cygwin.com/mirrors.html}. It could be that
the network is too busy. Similarly for an ftp download site that isn't
working. Try another mirror, or try again later.
If setup refuses to download a package that you know needs to be
upgraded, try deleting that package's entry from /etc/setup. If you are
reacting quickly to an announcement on the mailing list, it could be
that the mirror you are using doesn't have the latest copy yet. Try
another mirror, or try again tomorrow.
If setup has otherwise behaved strangely, check the files
@samp{setup.log} and @samp{setup.log.full} in the Cygwin root directory
(@code{C:\cygwin} by default). It may provide some clues as to what
went wrong and why.
If you're still baffled, search the Cygwin mailing list for clues.
Others may have the same problem, and a solution may be posted there.
If that search proves fruitless, send a query to the Cygwin mailing
list. You must provide complete details in your query: version of
setup, options you selected, contents of setup.log and setup.log.full,
what happened that wasn't supposed to happen, etc.
@subsection What's the difference between packages in @samp{latest} and @samp{contrib}?
There is no difference as far as Cygwin Setup is concerned. The
distinction is historical, not practical.
@subsection My Windows logon name has a space in it, will this cause problems?
Most definitely yes! UNIX shells (and thus Cygwin) use the space
character as a word delimiter. Under certain circumstances, it is
possible to get around this with various shell quoting mechanisms, but
you are much better off if you can avoid the problem entirely.
In particular, the environment variables @samp{USER} and @samp{HOME} are
set for you in /etc/profile. By default these derive from your Windows
logon name. You may edit this file and set them explicitly to something
without spaces.
(If you use the @samp{login} package or anything else that reads
/etc/passwd, you may need to make corresponding changes there. See the
README file for that package.)
@subsection How do I uninstall individual packages?
Run Cygwin Setup as you would to install packages. In the list of
packages to install, browse the relevant category or click on the
``View'' button to get a full listing. Click on the cycle glyph until
the action reads ``Uninstall''. Proceed by clicking ``Next''.
@subsection How do I uninstall @strong{all} of Cygwin?
Setup has no automatic uninstall facility. Just delete everything
manually:
@itemize @bullet
@item Cygwin shortcuts on the Desktop and Start Menu
@item The registry tree @samp{Software\Cygnus Solutions} under
@code{HKEY_LOCAL_MACHINE} and/or @code{HKEY_CURRENT_USER}.
@item Anything under the Cygwin root folder, @samp{C:\cygwin} by
default.
@item Anything created by setup in its temporary working directory.
@end itemize
It's up to you to deal with other changes you made to your system, such
as installing the inetd service, altering system paths, etc. Setup
would not have done any of these things for you.
@subsection Can I use setup to install snapshots?
No. It used to be possible, but not any more.
If experimenting with developer snapshots from
@file{http://cygwin.com/snapshots/}, you should generally install the
full @code{cygwin-inst-YYYYMMDD.tar.bz2} update, rather than just the
DLL, otherwise some components may be out of sync. Cygwin tar won't be
able to update @code{/usr/bin/cygwin1.dll}, but it should succeed with
everything else. The following steps should work:
@enumerate
@item Download the snapshot, and run:
@example
cd /
tar jxvf /posix/path/to/cygwin-inst-YYYYMMDD.tar.bz2 --exclude=usr/bin/cygwin1.dll
cd /tmp
tar jxvf /posix/path/to/cygwin-inst-YYYYMMDD.tar.bz2 usr/bin/cygwin1.dll
@end example
@item After closing all Cygwin apps (see below), use Explorer or the
Windows command shell to move @code{C:\cygwin\tmp\usr\bin\cygwin1.dll}
to @code{C:\cygwin\bin\cygwin1.dll}.
@end enumerate
The obvious warnings about updating the cygwin package and using developer
snapshots apply:
@enumerate
@item Close @strong{all} Cygwin applications, including shells and services
(e.g. inetd), before updating @code{cygwin1.dll}. You may have to
restart Windows to clear the DLL from memory.
@item Snapshots are risky. They have not been tested. Use them
@strong{only} if there is a feature or bugfix that you need to try,
and you are willing to deal with any problems.
@item If you cannot download a snapshot from the main ftp distribution
site, use a mirror, and look in the @samp{snapshots} directory. You may
have to hunt for one that has a copy of the latest snapshot. Start at
@file{http://cygwin.com/mirrors.html}.
@end enumerate