iio_buffer_show_enable, iio_buffer_store_enable);
 static DEVICE_ATTR(watermark, S_IRUGO | S_IWUSR,
                   iio_buffer_show_watermark, iio_buffer_store_watermark);
+static struct device_attribute dev_attr_watermark_ro = __ATTR(watermark,
+       S_IRUGO, iio_buffer_show_watermark, NULL);
 
 static struct attribute *iio_buffer_attrs[] = {
        &dev_attr_length.attr,
        if (!buffer->access->set_length)
                attr[0] = &dev_attr_length_ro.attr;
 
+       if (buffer->access->flags & INDIO_BUFFER_FLAG_FIXED_WATERMARK)
+               attr[2] = &dev_attr_watermark_ro.attr;
+
        if (buffer->attrs)
                memcpy(&attr[ARRAY_SIZE(iio_buffer_attrs)], buffer->attrs,
                       sizeof(struct attribute *) * attrcount);
 
 
 struct iio_buffer;
 
+/**
+ * INDIO_BUFFER_FLAG_FIXED_WATERMARK - Watermark level of the buffer can not be
+ *   configured. It has a fixed value which will be buffer specific.
+ */
+#define INDIO_BUFFER_FLAG_FIXED_WATERMARK BIT(0)
+
 /**
  * struct iio_buffer_access_funcs - access functions for buffers.
  * @store_to:          actually store stuff to the buffer
  * @release:           called when the last reference to the buffer is dropped,
  *                     should free all resources allocated by the buffer.
  * @modes:             Supported operating modes by this buffer type
+ * @flags:             A bitmask combination of INDIO_BUFFER_FLAG_*
  *
  * The purpose of this structure is to make the buffer element
  * modular as event for a given driver, different usecases may require
        void (*release)(struct iio_buffer *buffer);
 
        unsigned int modes;
+       unsigned int flags;
 };
 
 /**