pre-created. Default: 1.
 
 2) Set max number of compression streams
-       Compression backend may use up to max_comp_streams compression streams,
-       thus allowing up to max_comp_streams concurrent compression operations.
-       By default, compression backend uses single compression stream.
-
-       Examples:
-       #show max compression streams number
+       Regardless the value passed to this attribute, ZRAM will always
+       allocate multiple compression streams - one per online CPUs - thus
+       allowing several concurrent compression operations. The number of
+       allocated compression streams goes down when some of the CPUs
+       become offline. There is no single-compression-stream mode anymore,
+       unless you are running a UP system or has only 1 CPU online.
+
+       To find out how many streams are currently available:
        cat /sys/block/zram0/max_comp_streams
 
-       #set max compression streams number to 3
-       echo 3 > /sys/block/zram0/max_comp_streams
-
-Note:
-In order to enable compression backend's multi stream support max_comp_streams
-must be initially set to desired concurrency level before ZRAM device
-initialisation. Once the device initialised as a single stream compression
-backend (max_comp_streams equals to 1), you will see error if you try to change
-the value of max_comp_streams because single stream compression backend
-implemented as a special case by lock overhead issue and does not support
-dynamic max_comp_streams. Only multi stream backend supports dynamic
-max_comp_streams adjustment.
-
 3) Select compression algorithm
        Using comp_algorithm device attribute one can see available and
        currently selected (shown in square brackets) compression algorithms,
 
        return len;
 }
 
+/*
+ * We switched to per-cpu streams and this attr is not needed anymore.
+ * However, we will keep it around for some time, because:
+ * a) we may revert per-cpu streams in the future
+ * b) it's visible to user space and we need to follow our 2 years
+ *    retirement rule; but we already have a number of 'soon to be
+ *    altered' attrs, so max_comp_streams need to wait for the next
+ *    layoff cycle.
+ */
 static ssize_t max_comp_streams_show(struct device *dev,
                struct device_attribute *attr, char *buf)
 {
-       int val;
-       struct zram *zram = dev_to_zram(dev);
-
-       down_read(&zram->init_lock);
-       val = zram->max_comp_streams;
-       up_read(&zram->init_lock);
-
-       return scnprintf(buf, PAGE_SIZE, "%d\n", val);
+       return scnprintf(buf, PAGE_SIZE, "%d\n", num_online_cpus());
 }
 
 static ssize_t max_comp_streams_store(struct device *dev,
                struct device_attribute *attr, const char *buf, size_t len)
 {
-       int num;
-       struct zram *zram = dev_to_zram(dev);
-       int ret;
-
-       ret = kstrtoint(buf, 0, &num);
-       if (ret < 0)
-               return ret;
-       if (num < 1)
-               return -EINVAL;
-
-       down_write(&zram->init_lock);
-       if (init_done(zram)) {
-               if (!zcomp_set_max_streams(zram->comp, num)) {
-                       pr_info("Cannot change max compression streams\n");
-                       ret = -EINVAL;
-                       goto out;
-               }
-       }
-
-       zram->max_comp_streams = num;
-       ret = len;
-out:
-       up_write(&zram->init_lock);
-       return ret;
+       return len;
 }
 
 static ssize_t comp_algorithm_show(struct device *dev,
        /* Reset stats */
        memset(&zram->stats, 0, sizeof(zram->stats));
        zram->disksize = 0;
-       zram->max_comp_streams = 1;
 
        set_capacity(zram->disk, 0);
        part_stat_set_all(&zram->disk->part0, 0);
        }
        strlcpy(zram->compressor, default_compressor, sizeof(zram->compressor));
        zram->meta = NULL;
-       zram->max_comp_streams = 1;
 
        pr_info("Added device: %s\n", zram->disk->disk_name);
        return device_id;