* Bits in bdi_writeback.state
  */
 enum wb_state {
-       WB_async_congested,     /* The async (write) queue is getting full */
-       WB_sync_congested,      /* The sync queue is getting full */
        WB_registered,          /* bdi_register() was done */
        WB_writeback_running,   /* Writeback is in progress */
 };
 
+enum wb_congested_state {
+       WB_async_congested,     /* The async (write) queue is getting full */
+       WB_sync_congested,      /* The sync queue is getting full */
+};
+
 typedef int (congested_fn)(void *, int);
 
 enum wb_stat_item {
 
 #define WB_STAT_BATCH (8*(1+ilog2(nr_cpu_ids)))
 
+struct bdi_writeback_congested {
+       unsigned long state;            /* WB_[a]sync_congested flags */
+};
+
 struct bdi_writeback {
        struct backing_dev_info *bdi;   /* our parent bdi */
 
 
        struct percpu_counter stat[NR_WB_STAT_ITEMS];
 
+       struct bdi_writeback_congested *congested;
+
        unsigned long bw_time_stamp;    /* last time write bw is updated */
        unsigned long dirtied_stamp;
        unsigned long written_stamp;    /* pages written at bw_time_stamp */
        unsigned int max_ratio, max_prop_frac;
 
        struct bdi_writeback wb;  /* default writeback info for this bdi */
+       struct bdi_writeback_congested wb_congested;
 
        struct device *dev;
 
 
 {
        if (bdi->congested_fn)
                return bdi->congested_fn(bdi->congested_data, bdi_bits);
-       return (bdi->wb.state & bdi_bits);
+       return (bdi->wb.congested->state & bdi_bits);
 }
 
 static inline int bdi_read_congested(struct backing_dev_info *bdi)
 
        if (err)
                return err;
 
+       bdi->wb_congested.state = 0;
+       bdi->wb.congested = &bdi->wb_congested;
+
        return 0;
 }
 EXPORT_SYMBOL(bdi_init);
        wait_queue_head_t *wqh = &congestion_wqh[sync];
 
        bit = sync ? WB_sync_congested : WB_async_congested;
-       if (test_and_clear_bit(bit, &bdi->wb.state))
+       if (test_and_clear_bit(bit, &bdi->wb.congested->state))
                atomic_dec(&nr_bdi_congested[sync]);
        smp_mb__after_atomic();
        if (waitqueue_active(wqh))
        enum wb_state bit;
 
        bit = sync ? WB_sync_congested : WB_async_congested;
-       if (!test_and_set_bit(bit, &bdi->wb.state))
+       if (!test_and_set_bit(bit, &bdi->wb.congested->state))
                atomic_inc(&nr_bdi_congested[sync]);
 }
 EXPORT_SYMBOL(set_bdi_congested);