struct list_head all_tconn;     /* linked on global drbd_tconns */
        struct idr volumes;             /* <tconn, vnr> to mdev mapping */
        enum drbd_conns cstate;         /* Only C_STANDALONE to C_WF_REPORT_PARAMS */
+       unsigned susp:1;                /* IO suspended by user */
+       unsigned susp_nod:1;            /* IO suspended because no data */
+       unsigned susp_fen:1;            /* IO suspended because fence peer handler runs */
        struct mutex cstate_mutex;      /* Protects graceful disconnects */
 
        unsigned long flags;
        union drbd_state rv;
 
        rv = mdev->state;
+       rv.susp = mdev->tconn->susp;
+       rv.susp_nod = mdev->tconn->susp_nod;
+       rv.susp_fen = mdev->tconn->susp_fen;
 
        return rv;
 }
 
 static inline int drbd_suspended(struct drbd_conf *mdev)
 {
-       return mdev->state.susp || mdev->state.susp_nod || mdev->state.susp_fen;
+       struct drbd_tconn *tconn = mdev->tconn;
+
+       return tconn->susp || tconn->susp_fen || tconn->susp_nod;
 }
 
 static inline bool may_inc_ap_bio(struct drbd_conf *mdev)
 
                atomic_inc(&mdev->local_cnt);
 
        mdev->state = ns;
+       mdev->tconn->susp = ns.susp;
+       mdev->tconn->susp_nod = ns.susp_nod;
+       mdev->tconn->susp_fen = ns.susp_fen;
 
        /* solve the race between becoming unconfigured,
         * worker doing the cleanup, and