afs: Handle the VIO and UAEIO aborts explicitly
authorDavid Howells <dhowells@redhat.com>
Fri, 20 Oct 2023 15:00:18 +0000 (16:00 +0100)
committerDavid Howells <dhowells@redhat.com>
Sun, 24 Dec 2023 15:22:52 +0000 (15:22 +0000)
When processing the result of a call, handle the VIO and UAEIO abort
specifically rather than leaving it to a default case.  Rather than
erroring out unconditionally, see if there's another server if the volume
has more than one server available, otherwise return -EREMOTEIO.

Signed-off-by: David Howells <dhowells@redhat.com>
cc: Marc Dionne <marc.dionne@auristor.com>
cc: linux-afs@lists.infradead.org

fs/afs/rotate.c

index 13ec8ffa911a724071baa563063a7f199eeccaaa..0829933f4d9aae7fa7b34a70f83e8d43ab3ada47 100644 (file)
@@ -330,6 +330,13 @@ bool afs_select_fileserver(struct afs_operation *op)
 
                        goto restart_from_beginning;
 
+               case UAEIO:
+               case VIO:
+                       op->error = -EREMOTEIO;
+                       if (op->volume->type != AFSVL_RWVOL)
+                               goto next_server;
+                       goto failed;
+
                case VDISKFULL:
                case UAENOSPC:
                        /* The partition is full.  Only applies to RWVOLs.