#endif /* CONFIG_NFS_V4_2 */
 
 static int __nfs4_reclaim_open_state(struct nfs4_state_owner *sp, struct nfs4_state *state,
-                                    const struct nfs4_state_recovery_ops *ops)
+                                    const struct nfs4_state_recovery_ops *ops,
+                                    int *lost_locks)
 {
        struct nfs4_lock_state *lock;
        int status;
                list_for_each_entry(lock, &state->lock_states, ls_locks) {
                        trace_nfs4_state_lock_reclaim(state, lock);
                        if (!test_bit(NFS_LOCK_INITIALIZED, &lock->ls_flags))
-                               pr_warn_ratelimited("NFS: %s: Lock reclaim failed!\n", __func__);
+                               *lost_locks += 1;
                }
                spin_unlock(&state->state_lock);
        }
        return status;
 }
 
-static int nfs4_reclaim_open_state(struct nfs4_state_owner *sp, const struct nfs4_state_recovery_ops *ops)
+static int nfs4_reclaim_open_state(struct nfs4_state_owner *sp,
+                                  const struct nfs4_state_recovery_ops *ops,
+                                  int *lost_locks)
 {
        struct nfs4_state *state;
        unsigned int loop = 0;
 #endif /* CONFIG_NFS_V4_2 */
                refcount_inc(&state->count);
                spin_unlock(&sp->so_lock);
-               status = __nfs4_reclaim_open_state(sp, state, ops);
+               status = __nfs4_reclaim_open_state(sp, state, ops, lost_locks);
 
                switch (status) {
                default:
        struct rb_node *pos;
        LIST_HEAD(freeme);
        int status = 0;
+       int lost_locks = 0;
 
 restart:
        rcu_read_lock();
                        spin_unlock(&clp->cl_lock);
                        rcu_read_unlock();
 
-                       status = nfs4_reclaim_open_state(sp, ops);
+                       status = nfs4_reclaim_open_state(sp, ops, &lost_locks);
                        if (status < 0) {
+                               if (lost_locks)
+                                       pr_warn("NFS: %s: lost %d locks\n",
+                                               clp->cl_hostname, lost_locks);
                                set_bit(ops->owner_flag_bit, &sp->so_flags);
                                nfs4_put_state_owner(sp);
                                status = nfs4_recovery_handle_error(clp, status);
        }
        rcu_read_unlock();
        nfs4_free_state_owners(&freeme);
+       if (lost_locks)
+               pr_warn("NFS: %s: lost %d locks\n",
+                       clp->cl_hostname, lost_locks);
        return 0;
 }