AFS miscellany
-----BEGIN PGP SIGNATURE----- iQIzBAABCAAdFiEEqG5UsNXhtOCrfGQP+7dXa6fLC2sFAl6jDR0ACgkQ+7dXa6fL C2ttIg//Zz6bEpu7BAdvrXmUCfcYbI4gbVRPEFcAz4/z8c05UJXdkps2oVj1sKmb hLRBIxArRo7tcdziIdwwk8fckaW1i60wXfsiaAEyxPBuW+oB6fEUqoEmshUjw36u lzseygJnyKNKNX8B6MSYz3NQv5kaVefD6UoQ84+3m7Me/AJx9s+LZEUTrvlz5Myy BbE19Jnx5SlgqkVyuis6FQ0u+cXUdVleIm3LFzzbaP9syLlsleAJjXU3EPM3/mzK BcV77DhMGJhKZ0DhFuUkKE1EUslR4vJiV7gDMdyJKuSTlIU+1IGYWiI6XPyk/BLH trpSDHe8DuCCGPmQCQPM4XxfQJVlnKej+sFoUeqCShndkK9ayTuYot5eARbqGj4x SEVQ6PWgnLcWtSuxQDIWJBBWZPJZ8/v3yDld0ij95wbGqAywnsiVBt85XPK4Ccje ew3urAK52wlQxwy2U+Rn39hzLi6vCx0Z3ncJ/ak5TarcL8txQhCOcKukTB7Wa4Ie MKW+IANoYvLgFmbnXLlsBBxpcewNwxQhklMkSx5G+3EnWxXIOqRPumOPxV2UfYrA Mgv3F1PZo9Q3SU6eb8lGIYyeho0+6qV/OZzmcy6Xl8nNHeJXZ9eGsSYSlKYUQ7WI rum/g7UPBxni7wkyJxrn90yxirFG81Dm4216ThKGSQ6Mu5pDmBA= =tTG+ -----END PGP SIGNATURE----- Merge tag 'afs-fixes-20200424' of git://git.kernel.org/pub/scm/linux/kernel/git/dhowells/linux-fs Pull misc AFS fixes from David Howells: "Three miscellaneous fixes to the afs filesystem: - Remove some struct members that aren't used, aren't set or aren't read, plus a wake up that nothing ever waits for. - Actually set the AFS_SERVER_FL_HAVE_EPOCH flag so that the code that depends on it can work. - Make a couple of waits uninterruptible if they're done for an operation that isn't supposed to be interruptible" * tag 'afs-fixes-20200424' of git://git.kernel.org/pub/scm/linux/kernel/git/dhowells/linux-fs: afs: Make record checking use TASK_UNINTERRUPTIBLE when appropriate afs: Fix to actually set AFS_SERVER_FL_HAVE_EPOCH afs: Remove some unused bits
This commit is contained in:
commit
9a19562852
|
@ -169,7 +169,7 @@ static int afs_record_cm_probe(struct afs_call *call, struct afs_server *server)
|
|||
|
||||
spin_lock(&server->probe_lock);
|
||||
|
||||
if (!test_bit(AFS_SERVER_FL_HAVE_EPOCH, &server->flags)) {
|
||||
if (!test_and_set_bit(AFS_SERVER_FL_HAVE_EPOCH, &server->flags)) {
|
||||
server->cm_epoch = call->epoch;
|
||||
server->probe.cm_epoch = call->epoch;
|
||||
goto out;
|
||||
|
|
|
@ -117,11 +117,8 @@ out:
|
|||
(unsigned int)rtt, ret);
|
||||
|
||||
have_result |= afs_fs_probe_done(server);
|
||||
if (have_result) {
|
||||
server->probe.have_result = true;
|
||||
wake_up_var(&server->probe.have_result);
|
||||
if (have_result)
|
||||
wake_up_all(&server->probe_wq);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
|
|
|
@ -533,12 +533,10 @@ struct afs_server {
|
|||
u32 abort_code;
|
||||
u32 cm_epoch;
|
||||
short error;
|
||||
bool have_result;
|
||||
bool responded:1;
|
||||
bool is_yfs:1;
|
||||
bool not_yfs:1;
|
||||
bool local_failure:1;
|
||||
bool no_epoch:1;
|
||||
bool cm_probed:1;
|
||||
bool said_rebooted:1;
|
||||
bool said_inconsistent:1;
|
||||
|
@ -1335,7 +1333,7 @@ extern struct afs_volume *afs_create_volume(struct afs_fs_context *);
|
|||
extern void afs_activate_volume(struct afs_volume *);
|
||||
extern void afs_deactivate_volume(struct afs_volume *);
|
||||
extern void afs_put_volume(struct afs_cell *, struct afs_volume *);
|
||||
extern int afs_check_volume_status(struct afs_volume *, struct key *);
|
||||
extern int afs_check_volume_status(struct afs_volume *, struct afs_fs_cursor *);
|
||||
|
||||
/*
|
||||
* write.c
|
||||
|
|
|
@ -192,7 +192,7 @@ bool afs_select_fileserver(struct afs_fs_cursor *fc)
|
|||
write_unlock(&vnode->volume->servers_lock);
|
||||
|
||||
set_bit(AFS_VOLUME_NEEDS_UPDATE, &vnode->volume->flags);
|
||||
error = afs_check_volume_status(vnode->volume, fc->key);
|
||||
error = afs_check_volume_status(vnode->volume, fc);
|
||||
if (error < 0)
|
||||
goto failed_set_error;
|
||||
|
||||
|
@ -281,7 +281,7 @@ bool afs_select_fileserver(struct afs_fs_cursor *fc)
|
|||
|
||||
set_bit(AFS_VOLUME_WAIT, &vnode->volume->flags);
|
||||
set_bit(AFS_VOLUME_NEEDS_UPDATE, &vnode->volume->flags);
|
||||
error = afs_check_volume_status(vnode->volume, fc->key);
|
||||
error = afs_check_volume_status(vnode->volume, fc);
|
||||
if (error < 0)
|
||||
goto failed_set_error;
|
||||
|
||||
|
@ -341,7 +341,7 @@ start:
|
|||
/* See if we need to do an update of the volume record. Note that the
|
||||
* volume may have moved or even have been deleted.
|
||||
*/
|
||||
error = afs_check_volume_status(vnode->volume, fc->key);
|
||||
error = afs_check_volume_status(vnode->volume, fc);
|
||||
if (error < 0)
|
||||
goto failed_set_error;
|
||||
|
||||
|
|
|
@ -594,12 +594,9 @@ retry:
|
|||
}
|
||||
|
||||
ret = wait_on_bit(&server->flags, AFS_SERVER_FL_UPDATING,
|
||||
TASK_INTERRUPTIBLE);
|
||||
(fc->flags & AFS_FS_CURSOR_INTR) ?
|
||||
TASK_INTERRUPTIBLE : TASK_UNINTERRUPTIBLE);
|
||||
if (ret == -ERESTARTSYS) {
|
||||
if (!(fc->flags & AFS_FS_CURSOR_INTR) && server->addresses) {
|
||||
_leave(" = t [intr]");
|
||||
return true;
|
||||
}
|
||||
fc->error = ret;
|
||||
_leave(" = f [intr]");
|
||||
return false;
|
||||
|
|
|
@ -302,8 +302,8 @@ static void afs_vl_dump_edestaddrreq(const struct afs_vl_cursor *vc)
|
|||
pr_notice("VC: - nr=%u/%u/%u pf=%u\n",
|
||||
a->nr_ipv4, a->nr_addrs, a->max_addrs,
|
||||
a->preferred);
|
||||
pr_notice("VC: - pr=%lx R=%lx F=%lx\n",
|
||||
a->probed, a->responded, a->failed);
|
||||
pr_notice("VC: - R=%lx F=%lx\n",
|
||||
a->responded, a->failed);
|
||||
if (a == vc->ac.alist)
|
||||
pr_notice("VC: - current\n");
|
||||
}
|
||||
|
|
|
@ -281,7 +281,7 @@ error:
|
|||
/*
|
||||
* Make sure the volume record is up to date.
|
||||
*/
|
||||
int afs_check_volume_status(struct afs_volume *volume, struct key *key)
|
||||
int afs_check_volume_status(struct afs_volume *volume, struct afs_fs_cursor *fc)
|
||||
{
|
||||
time64_t now = ktime_get_real_seconds();
|
||||
int ret, retries = 0;
|
||||
|
@ -299,7 +299,7 @@ retry:
|
|||
}
|
||||
|
||||
if (!test_and_set_bit_lock(AFS_VOLUME_UPDATING, &volume->flags)) {
|
||||
ret = afs_update_volume_status(volume, key);
|
||||
ret = afs_update_volume_status(volume, fc->key);
|
||||
clear_bit_unlock(AFS_VOLUME_WAIT, &volume->flags);
|
||||
clear_bit_unlock(AFS_VOLUME_UPDATING, &volume->flags);
|
||||
wake_up_bit(&volume->flags, AFS_VOLUME_WAIT);
|
||||
|
@ -312,7 +312,9 @@ retry:
|
|||
return 0;
|
||||
}
|
||||
|
||||
ret = wait_on_bit(&volume->flags, AFS_VOLUME_WAIT, TASK_INTERRUPTIBLE);
|
||||
ret = wait_on_bit(&volume->flags, AFS_VOLUME_WAIT,
|
||||
(fc->flags & AFS_FS_CURSOR_INTR) ?
|
||||
TASK_INTERRUPTIBLE : TASK_UNINTERRUPTIBLE);
|
||||
if (ret == -ERESTARTSYS) {
|
||||
_leave(" = %d", ret);
|
||||
return ret;
|
||||
|
|
Loading…
Reference in New Issue