diff --git a/doc/manual/conf-file.xml b/doc/manual/conf-file.xml
index 82bc025bc..f56cc2726 100644
--- a/doc/manual/conf-file.xml
+++ b/doc/manual/conf-file.xml
@@ -364,6 +364,18 @@ build-use-chroot = /dev /proc /bin
   
 
 
+  force-manifest
+
+    If this option is set to false
+    (default) and a Nix channel provides both a manifest and a binary
+    cache, only the binary cache will be used.  If set to
+    true, the manifest will be fetched as well.
+    This is useful if you want to use binary patches (which are
+    currently not supported by binary caches).
+
+  
+
+
   system
 
     This option specifies the canonical Nix system
diff --git a/scripts/nix-channel.in b/scripts/nix-channel.in
index 7e50dac1e..61ac823eb 100755
--- a/scripts/nix-channel.in
+++ b/scripts/nix-channel.in
@@ -6,6 +6,8 @@ use File::Path qw(mkpath);
 use Nix::Config;
 use Nix::Manifest;
 
+Nix::Config::readConfig;
+
 my $manifestDir = $Nix::Config::manifestDir;
 
 
@@ -102,10 +104,15 @@ sub update {
         # Check if the channel advertises a binary cache.
         my $binaryCacheURL = `$Nix::Config::curl --silent '$url'/binary-cache-url`;
         my $extraAttrs = "";
+        my $getManifest = ($Nix::Config::config{"force-manifest"} // "false") eq "true";
         if ($? == 0 && $binaryCacheURL ne "") {
             $extraAttrs .= "binaryCacheURL = \"$binaryCacheURL\"; ";
             deleteOldManifests($origUrl, undef);
         } else {
+            $getManifest = 1;
+        }
+
+        if ($getManifest) {
             # No binary cache, so pull the channel manifest.
             mkdir $manifestDir, 0755 unless -e $manifestDir;
             die "$0: you do not have write permission to `$manifestDir'!\n" unless -W $manifestDir;