diff --git a/doc/src/sgml/cvs.sgml b/doc/src/sgml/cvs.sgml
index 55b17a23d31a508bff2cb82578a8f03ecf1d5262..58061405e27d65eb1ad86709fee33711e614e672 100644
--- a/doc/src/sgml/cvs.sgml
+++ b/doc/src/sgml/cvs.sgml
@@ -1,4 +1,4 @@
-<!-- $PostgreSQL: pgsql/doc/src/sgml/cvs.sgml,v 1.51 2009/06/23 03:46:00 tgl Exp $ -->
+<!-- $PostgreSQL: pgsql/doc/src/sgml/cvs.sgml,v 1.52 2009/12/07 19:19:56 mha Exp $ -->
 
 <appendix id="cvs">
  <appendixinfo>
@@ -23,23 +23,97 @@
   <date>1999-05-20</date>
  </appendixinfo>
 
- <title>The <productname>CVS</productname> Repository</title>
+ <title>The Source Code Repository</title>
 
  <para>
   The <productname>PostgreSQL</productname> source code is stored and managed using the
-  <productname>CVS</productname> version control system.
+  <productname>CVS</productname> version control system. An official mirror using
+  <productname>Git</productname> is also available, for those who wish to use a
+  distributed version control system. This mirror is automatically
+  updated whenever the main repository changes, so it always contains the latest
+  versions of all branches.
+ </para>
+
+ <para>
+  Using <productname>git</> is the most flexible way to work with the source, and it
+  allows you to work offline without having constant access to the project servers.
+  <productname>rsync</> based <productname>cvs</> also lets you work offline, but
+  lacks many of the other advantages of <productname>git</>.
  </para>
 
  <para>
-  At least three methods, anonymous CVS, <productname>rsync</productname>,
-  and <productname>CVSup</productname>,
-  are available to pull the <productname>CVS</productname> code tree from the
-  <productname>PostgreSQL</productname> server to your local machine. 
   Our Wiki, <ulink
-  url="http://wiki.postgresql.org/index.php/Working_with_CVS"></ulink>,
-  has additional details on working with CVS.
+  url="http://wiki.postgresql.org/wiki/Working_with_CVS"></ulink> and
+  <ulink url="http://wiki.postgresql.org/wiki/Working_with_Git"></ulink>,
+  has additional details on working with CVS and Git.
  </para>
 
+ <sect1 id="git">
+  <title>Getting The Source Via <productname>Git</></title>
+
+  <para>
+   With <productname>git</> you will make a copy of the entire code repository
+   to your local machine, so you will have access to all history and branches
+   offline. This is the fastest and most flexible way to develop or test
+   patches.
+  </para>
+
+  <procedure>
+   <title>Git</title>
+
+   <step>
+    <para>
+     You will need an installed version of <productname>git</>, which you can get
+     from <ulink url="http://git-scm.com"></ulink>. Many systems also have a recent
+     version of <application>git</> installed by default, or available in their
+     package repository system.
+    </para>
+   </step>
+
+   <step>
+    <para>
+     To being using the git repository, make a clone of the official mirror:
+
+<programlisting>
+git clone git://git.postgresql.org/git/postgresql.git
+</programlisting>
+
+     This will copy the full repository to your local machine, so it may take
+     a while to complete, especially if you have a slow internet connection.
+    </para>
+
+    <para>
+     The git mirror can also be reached via the http protocol in case for example
+     a firewall is blocking access to the git protocol. Just replace the URL
+     like:
+
+<programlisting>
+git clone http://git.postgresql.org/git/postgresql.git
+</programlisting>
+
+     The http protocol is less efficient than the git protocol, so it will be
+     slightly slower to use.
+    </para>
+   </step>
+
+   <step>
+    <para>
+     Whenever you want to get the latest updates in the system, <command>cd</>
+     into the repository, and run:
+
+<programlisting>
+git fetch
+</programlisting>
+    </para>
+   </step>
+  </procedure>
+  <para>
+   <productname>git</> can do a lot more things than just fetch the source. For
+   more information, consult the man pages for the product, or the website at
+   <ulink url="http://git-scm.com"></>.
+  </para>
+ </sect1>
+
  <sect1 id="anoncvs">
   <title>Getting The Source Via Anonymous <productname>CVS</productname></title>
 
@@ -92,22 +166,11 @@ cvs -z3 -d :pserver:anoncvs@anoncvs.postgresql.org:/projects/cvsroot co -P pgsql
      This installs the <productname>PostgreSQL</productname> sources into a
      subdirectory <filename>pgsql</filename>
      of the directory you are currently in.
-
-     <note>
-      <para>
-       If you have a fast link to the Internet, you might not need
-       <option>-z3</option>, which instructs
-       <productname>CVS</productname> to use <command>gzip</command> compression for transferred data.  But
-       on a modem-speed link, it's a very substantial win.
-      </para>
-     </note>
     </para>
 
     <para>
      This initial checkout is a little slower than simply downloading
-     a <filename>tar.gz</filename> file; expect it to take 40 minutes or so if you
-     have a 28.8K modem.  The advantage of
-     <productname>CVS</productname>
+     a <filename>tar.gz</filename> file. The advantage of <productname>CVS</>
      doesn't show up until you want to update the file set later on.
     </para>
    </step>
@@ -163,7 +226,8 @@ cvs update
    CVS repository.  To work around that deficiency, use
    <productname>cvsutils</productname>, which is packaged in several
    operating systems, and is available in source form at <ulink
-   url="http://www.red-bean.com/cvsutils/"></ulink>.
+   url="http://www.red-bean.com/cvsutils/"></ulink>, or use <productname>git</>
+   or another system designed to work offline.
   </para>
 
   <para>
@@ -176,124 +240,6 @@ cvs update
   </para>
  </sect1>
 
- <sect1 id="cvs-tree">
-  <title><productname>CVS</productname> Tree Organization</title>
-
-  <para>
-   <note>
-    <title>Author</title>
-    <para>
-     Written by Marc G. Fournier (<email>scrappy@hub.org</email>) on 1998-11-05
-    </para>
-   </note>
-  </para>
-
-  <para>
-   The command <command>cvs checkout</command> has a flag, <option>-r</option>,
-   that lets you check out a
-   certain revision of a module.  This flag makes it easy to, for example,
-   retrieve the
-   sources that make up release 6_4 of the module `tc' at any time in the
-   future:
-
-<programlisting>
-cvs checkout -r REL6_4 tc
-</programlisting>
-
-   This is useful, for instance, if someone claims that there is a bug in
-   that release, but you cannot find the bug in the current working copy.
-
-   <tip>
-    <para>
-     You can also check out a module as it was at any given date using the
-     <option>-D</option> option.
-    </para>
-   </tip>
-  </para>
-
-  <para>
-   When you tag more than one file with the same tag you can think
-   about the tag as <quote>a curve drawn through a matrix of file name vs.
-   revision number</quote>.  Say we have 5 files with the following revisions:
-
-   <programlisting>
-             file1   file2   file3   file4   file5
-
-             1.1     1.1     1.1     1.1  /--1.1*      &lt;-*-  TAG
-             1.2*-   1.2     1.2    -1.2*-
-             1.3  \- 1.3*-   1.3   / 1.3
-             1.4          \  1.4  /  1.4
-                           \-1.5*-   1.5
-                             1.6
-   </programlisting>
-
-   then the tag <literal>TAG</literal> will reference
-   file1-1.2, file2-1.3, etc.
-
-   <note>
-    <para>
-     For creating a release branch, other than a
-     <literal>-b</> option added to the command, it's the same thing.</para>
-   </note>
-  </para>
-
-  <para>
-   So, to create the 6.4 release
-   I did the following:
-
-<programlisting>
-cd pgsql
-cvs tag -b REL6_4
-</programlisting>
-
-   which will create the tag and the branch for the RELEASE tree.
-  </para>
-
-  <para>
-   For those with <productname>CVS</productname> access, it's simple to
-   create directories for different versions.
-   First, create two subdirectories, RELEASE and CURRENT, so that you don't
-   mix up the two.  Then do:
-
-<programlisting>
-cd RELEASE
-cvs checkout -P -r REL6_4 pgsql
-cd ../CURRENT
-cvs checkout -P pgsql
-</programlisting>
-
-   which results in two directory trees, <filename>RELEASE/pgsql</filename> and
-   <filename>CURRENT/pgsql</filename>. From that point on,
-   <productname>CVS</productname>
-   will keep track of which repository branch is in which directory tree, and will
-   allow independent updates of either tree.
-  </para>
-
-  <para>
-   If you are <emphasis>only</emphasis> working on the <literal>CURRENT</literal>
-   source tree, you just do
-   everything as before we started tagging release branches.
-  </para>
-
-  <para>
-   After you've done the initial checkout on a branch:
-
-<programlisting>
-cvs checkout -r REL6_4
-</programlisting>
-
-   anything you do within that directory structure is restricted to that
-   branch.  If you apply a patch to that directory structure and do a:
-
-<programlisting>
-cvs commit
-</programlisting>
-
-   while inside of it, the patch is applied to the branch and
-   <emphasis>only</emphasis> the branch.
-  </para>
- </sect1>
-
  <sect1 id="rsync">
   <title>Getting The Source Via <productname>rsync</productname></title>
 
@@ -301,7 +247,8 @@ cvs commit
    An alternative to using anonymous CVS for retrieving the
    <productname>PostgreSQL</productname> source tree is
    <productname>rsync</productname>, an incremental file transfer tool.
-   A major advantage to using <productname>rsync</productname> is that it
+   A major advantage to using <productname>rsync</productname> instead of
+   plain <productname>cvs</> is that it
    can reliably replicate the <emphasis>entire</emphasis> CVS repository
    on your local system, allowing fast local access to <command>cvs</>
    operations such as <option>log</option> and <option>diff</option>.
@@ -321,187 +268,4 @@ rsync -avzH --delete anoncvs.postgresql.org::pgsql-cvs cvsroot/
    pgbuildfarm instructions</ulink>.
   </para>
  </sect1>
-
- <sect1 id="cvsup">
-  <title>Getting The Source Via <productname>CVSup</productname></title>
-
-  <para>
-   Another alternative to using anonymous CVS for retrieving
-   the <productname>PostgreSQL</productname> source tree
-   is <productname>CVSup</productname>.
-   <productname>CVSup</productname> was developed by
-   John Polstra (<email>jdp@polstra.com</email>) to
-   distribute CVS repositories and other file trees for the
-   <ulink url="http://www.freebsd.org">FreeBSD project</ulink>.
-  </para>
-
-  <sect2>
-   <title>Preparing A <productname>CVSup</productname> Client System</title>
-
-   <para>
-    Two directory areas are required for <productname>CVSup</productname>
-    to do its job: a local <productname>CVS</productname> repository
-    (or simply a directory area if you are fetching a snapshot rather
-    than a repository; see below)
-    and a local <productname>CVSup</productname> bookkeeping
-    area. These can coexist in the same directory tree.
-   </para>
-
-   <para>
-    Decide where you want to keep your local copy of the
-    <productname>CVS</productname> repository. On one of our systems we
-    recently set up a repository in <filename>/home/cvs/</filename>,
-    but had formerly kept it under a
-    <productname>PostgreSQL</productname> development tree in
-    <filename>/opt/postgres/cvs/</filename>. If you intend to keep your
-    repository in <filename>/home/cvs/</filename>, then put:
-
-<programlisting>
-setenv CVSROOT /home/cvs
-</programlisting>
-
-    in your <filename>.cshrc</filename> file, or a similar line in
-    your <filename>.bashrc</filename> or
-    <filename>.profile</filename> file, depending on your shell.
-   </para>
-
-   <para>
-    The <application>cvs</application> repository area must be initialized.
-    Once <envar>CVSROOT</envar> is set, then this can be done with a
-    single command:
-
-<programlisting>
-cvs init
-</programlisting>
-
-    after which you should see at least a directory named
-    <filename>CVSROOT</filename> when listing the
-    <envar>CVSROOT</envar> directory:
-
-<programlisting>
-$ ls $CVSROOT
-CVSROOT/
-</programlisting>
-   </para>
-  </sect2>
-
-  <sect2>
-   <title>Running a <productname>CVSup</productname> Client</title>
-
-   <para>
-    Verify that
-    <application>cvsup</application> is in your path; on most systems
-    you can do this by typing:
-
-<programlisting>
-which cvsup
-</programlisting>
-
-    Then, simply run
-    <application>cvsup</application> using:
-
-<programlisting>
-cvsup -L 2 <replaceable class="parameter">postgres.cvsup</replaceable>
-</programlisting>
-
-    where <option>-L 2</option> enables some status messages so you
-    can monitor the progress of the update,
-    and <replaceable class="parameter">postgres.cvsup</replaceable> is
-    the path and name you have given to your
-    <productname>CVSup</productname> configuration file.
-   </para>
-
-   <para>
-    Here is a <productname>CVSup</productname> configuration file
-    modified for a specific installation, and which maintains a full
-    local <productname>CVS</productname> repository:
-
-<programlisting>
-# This file represents the standard CVSup distribution file
-# for the <productname>PostgreSQL</> ORDBMS project
-# Modified by lockhart@fourpalms.org 1997-08-28
-# - Point to my local snapshot source tree
-# - Pull the full CVS repository, not just the latest snapshot
-#
-# Defaults that apply to all the collections
-*default host=cvsup.postgresql.org
-*default compress
-*default release=cvs
-*default delete use-rel-suffix
-# enable the following line to get the latest snapshot
-#*default tag=.
-# enable the following line to get whatever was specified above or by default
-# at the date specified below
-#*default date=97.08.29.00.00.00
-
-# base directory where CVSup will store its 'bookmarks' file(s)
-# will create subdirectory sup/
-#*default base=/opt/postgres # /usr/local/pgsql
-*default base=/home/cvs
-
-# prefix directory where CVSup will store the actual distribution(s)
-*default prefix=/home/cvs
-
-# complete distribution, including all below
-pgsql
-
-# individual distributions vs 'the whole thing'
-# pgsql-doc
-# pgsql-perl5
-# pgsql-src
-</programlisting>
-   </para>
-
-   <para>
-    If you specify <option>repository</> instead of <option>pgsql</>
-    in the above setup, you will get a complete copy of the entire
-    repository at cvsup.postgresql.org, including its
-    <filename>CVSROOT</filename> directory. If you do that, you will
-    probably want to exclude those files in that directory that you
-    want to modify locally, using a refuse file. For example, for the
-    above setup you might put this in
-    <filename>/home/cvs/sup/repository/refuse</>:
-<programlisting>
-CVSROOT/config*
-CVSROOT/commitinfo*
-CVSROOT/loginfo*
-</programlisting>
-    See the <productname>CVSup</> manual pages for how to use refuse files.
-   </para>
-
-   <para>
-    The following is a suggested <productname>CVSup</productname> configuration file from
-    the <productname>PostgreSQL</>
-    <ulink url="ftp://ftp.postgresql.org/pub/CVSup/README.cvsup">
-    ftp site</ulink>
-    which will fetch the current snapshot only:
-
-<programlisting>
-# This file represents the standard CVSup distribution file
-# for the <productname>PostgreSQL</> ORDBMS project
-#
-# Defaults that apply to all the collections
-*default host=cvsup.postgresql.org
-*default compress
-*default release=cvs
-*default delete use-rel-suffix
-*default tag=.
-
-# base directory where CVSup will store its 'bookmarks' file(s)
-*default base=<replaceable class="parameter">/usr/local/pgsql</replaceable>
-
-# prefix directory where CVSup will store the actual distribution(s)
-*default prefix=<replaceable class="parameter">/usr/local/pgsql</replaceable>
-
-# complete distribution, including all below
-pgsql
-
-# individual distributions vs 'the whole thing'
-# pgsql-doc
-# pgsql-perl5
-# pgsql-src
-</programlisting>
-   </para>
-  </sect2>
- </sect1>
 </appendix>
diff --git a/doc/src/sgml/installation.sgml b/doc/src/sgml/installation.sgml
index a0782dc1771a9fbb6ccf352d040012a341b1a48a..5051fbdc9c2631e41328d1252ec31900ed308782 100644
--- a/doc/src/sgml/installation.sgml
+++ b/doc/src/sgml/installation.sgml
@@ -1,4 +1,4 @@
-<!-- $PostgreSQL: pgsql/doc/src/sgml/installation.sgml,v 1.328 2009/12/02 14:07:25 momjian Exp $ -->
+<!-- $PostgreSQL: pgsql/doc/src/sgml/installation.sgml,v 1.329 2009/12/07 19:19:56 mha Exp $ -->
 
 <chapter id="installation">
  <title><![%standalone-include[<productname>PostgreSQL</>]]>
@@ -354,6 +354,11 @@ su - postgres
    Change into that directory for the rest
    of the installation procedure.
   </para>
+
+  <para>
+   You can also get the source directly from the version control repository, see
+   <xref linkend="cvs">.
+  </para>
  </sect1>
 ]]>