*
  * bch_bucket_alloc() allocates a single bucket from a specific cache.
  *
- * bch_bucket_alloc_set() allocates one or more buckets from different caches
+ * bch_bucket_alloc_set() allocates one  bucket from different caches
  * out of a cache set.
  *
  * free_some_buckets() drives all the processes described above. It's called
 }
 
 int __bch_bucket_alloc_set(struct cache_set *c, unsigned int reserve,
-                          struct bkey *k, int n, bool wait)
+                          struct bkey *k, bool wait)
 {
-       int i;
+       struct cache *ca;
+       long b;
 
        /* No allocation if CACHE_SET_IO_DISABLE bit is set */
        if (unlikely(test_bit(CACHE_SET_IO_DISABLE, &c->flags)))
                return -1;
 
        lockdep_assert_held(&c->bucket_lock);
-       BUG_ON(!n || n > c->caches_loaded || n > MAX_CACHES_PER_SET);
 
        bkey_init(k);
 
-       /* sort by free space/prio of oldest data in caches */
-
-       for (i = 0; i < n; i++) {
-               struct cache *ca = c->cache_by_alloc[i];
-               long b = bch_bucket_alloc(ca, reserve, wait);
+       ca = c->cache_by_alloc[0];
+       b = bch_bucket_alloc(ca, reserve, wait);
+       if (b == -1)
+               goto err;
 
-               if (b == -1)
-                       goto err;
+       k->ptr[0] = MAKE_PTR(ca->buckets[b].gen,
+                            bucket_to_sector(c, b),
+                            ca->sb.nr_this_dev);
 
-               k->ptr[i] = MAKE_PTR(ca->buckets[b].gen,
-                               bucket_to_sector(c, b),
-                               ca->sb.nr_this_dev);
-
-               SET_KEY_PTRS(k, i + 1);
-       }
+       SET_KEY_PTRS(k, 1);
 
        return 0;
 err:
 }
 
 int bch_bucket_alloc_set(struct cache_set *c, unsigned int reserve,
-                        struct bkey *k, int n, bool wait)
+                        struct bkey *k, bool wait)
 {
        int ret;
 
        mutex_lock(&c->bucket_lock);
-       ret = __bch_bucket_alloc_set(c, reserve, k, n, wait);
+       ret = __bch_bucket_alloc_set(c, reserve, k, wait);
        mutex_unlock(&c->bucket_lock);
        return ret;
 }
 
                spin_unlock(&c->data_bucket_lock);
 
-               if (bch_bucket_alloc_set(c, watermark, &alloc.key, 1, wait))
+               if (bch_bucket_alloc_set(c, watermark, &alloc.key, wait))
                        return false;
 
                spin_lock(&c->data_bucket_lock);
 
 
 long bch_bucket_alloc(struct cache *ca, unsigned int reserve, bool wait);
 int __bch_bucket_alloc_set(struct cache_set *c, unsigned int reserve,
-                          struct bkey *k, int n, bool wait);
+                          struct bkey *k, bool wait);
 int bch_bucket_alloc_set(struct cache_set *c, unsigned int reserve,
-                        struct bkey *k, int n, bool wait);
+                        struct bkey *k, bool wait);
 bool bch_alloc_sectors(struct cache_set *c, struct bkey *k,
                       unsigned int sectors, unsigned int write_point,
                       unsigned int write_prio, bool wait);