not having the state locked before putting the client/delegation causes a bug.
Also removed the comment from the function header about the state being already locked
Signed-off-by: Alexandros Batsakis <batsakis@netapp.com>
Signed-off-by: Benny Halevy <bhalevy@panasas.com>
Signed-off-by: J. Bruce Fields <bfields@citi.umich.edu>
 
 /*
  * called with dp->dl_count inc'ed.
- * nfs4_lock_state() may or may not have been called.
  */
 void
 nfsd4_cb_recall(struct nfs4_delegation *dp)
         * Success or failure, now we're either waiting for lease expiration
         * or deleg_return.
         */
+       nfs4_lock_state();
        put_nfs4_client(clp);
        nfs4_put_delegation(dp);
+       nfs4_unlock_state();
        return;
 }