blob: 1d1a8debe4723e4b0d5a69e892cd4389f07ef1c8 [file] [log] [blame]
Thomas Gleixner2874c5f2019-05-27 08:55:01 +02001// SPDX-License-Identifier: GPL-2.0-or-later
David Howellsec268152007-04-26 15:49:28 -07002/* miscellaneous bits
Linus Torvalds1da177e2005-04-16 15:20:36 -07003 *
David Howells08e0e7c2007-04-26 15:55:03 -07004 * Copyright (C) 2002, 2007 Red Hat, Inc. All Rights Reserved.
Linus Torvalds1da177e2005-04-16 15:20:36 -07005 * Written by David Howells (dhowells@redhat.com)
Linus Torvalds1da177e2005-04-16 15:20:36 -07006 */
7
8#include <linux/kernel.h>
9#include <linux/module.h>
10#include <linux/errno.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070011#include "internal.h"
David Howells08e0e7c2007-04-26 15:55:03 -070012#include "afs_fs.h"
David Howells1eda8ba2019-06-28 18:00:05 +010013#include "protocol_uae.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -070014
Linus Torvalds1da177e2005-04-16 15:20:36 -070015/*
16 * convert an AFS abort code to a Linux error number
17 */
David Howells08e0e7c2007-04-26 15:55:03 -070018int afs_abort_to_error(u32 abort_code)
Linus Torvalds1da177e2005-04-16 15:20:36 -070019{
David Howells08e0e7c2007-04-26 15:55:03 -070020 switch (abort_code) {
David Howellsf780c8e2017-11-02 15:27:48 +000021 /* Low errno codes inserted into abort namespace */
David Howells08e0e7c2007-04-26 15:55:03 -070022 case 13: return -EACCES;
David Howells416351f2007-05-09 02:33:45 -070023 case 27: return -EFBIG;
David Howells260a9802007-04-26 15:59:35 -070024 case 30: return -EROFS;
Nathaniel Wesley Filardo53d58642014-08-21 14:10:55 -040025
David Howellsf780c8e2017-11-02 15:27:48 +000026 /* VICE "special error" codes; 101 - 111 */
Linus Torvalds1da177e2005-04-16 15:20:36 -070027 case VSALVAGE: return -EIO;
28 case VNOVNODE: return -ENOENT;
David Howells08e0e7c2007-04-26 15:55:03 -070029 case VNOVOL: return -ENOMEDIUM;
Linus Torvalds1da177e2005-04-16 15:20:36 -070030 case VVOLEXISTS: return -EEXIST;
31 case VNOSERVICE: return -EIO;
32 case VOFFLINE: return -ENOENT;
33 case VONLINE: return -EEXIST;
34 case VDISKFULL: return -ENOSPC;
35 case VOVERQUOTA: return -EDQUOT;
36 case VBUSY: return -EBUSY;
37 case VMOVED: return -ENXIO;
Nathaniel Wesley Filardo53d58642014-08-21 14:10:55 -040038
David Howellsf780c8e2017-11-02 15:27:48 +000039 /* Volume Location server errors */
40 case AFSVL_IDEXIST: return -EEXIST;
41 case AFSVL_IO: return -EREMOTEIO;
42 case AFSVL_NAMEEXIST: return -EEXIST;
43 case AFSVL_CREATEFAIL: return -EREMOTEIO;
44 case AFSVL_NOENT: return -ENOMEDIUM;
45 case AFSVL_EMPTY: return -ENOMEDIUM;
46 case AFSVL_ENTDELETED: return -ENOMEDIUM;
47 case AFSVL_BADNAME: return -EINVAL;
48 case AFSVL_BADINDEX: return -EINVAL;
49 case AFSVL_BADVOLTYPE: return -EINVAL;
50 case AFSVL_BADSERVER: return -EINVAL;
51 case AFSVL_BADPARTITION: return -EINVAL;
52 case AFSVL_REPSFULL: return -EFBIG;
53 case AFSVL_NOREPSERVER: return -ENOENT;
54 case AFSVL_DUPREPSERVER: return -EEXIST;
55 case AFSVL_RWNOTFOUND: return -ENOENT;
56 case AFSVL_BADREFCOUNT: return -EINVAL;
57 case AFSVL_SIZEEXCEEDED: return -EINVAL;
58 case AFSVL_BADENTRY: return -EINVAL;
59 case AFSVL_BADVOLIDBUMP: return -EINVAL;
60 case AFSVL_IDALREADYHASHED: return -EINVAL;
61 case AFSVL_ENTRYLOCKED: return -EBUSY;
62 case AFSVL_BADVOLOPER: return -EBADRQC;
63 case AFSVL_BADRELLOCKTYPE: return -EINVAL;
64 case AFSVL_RERELEASE: return -EREMOTEIO;
65 case AFSVL_BADSERVERFLAG: return -EINVAL;
66 case AFSVL_PERM: return -EACCES;
67 case AFSVL_NOMEM: return -EREMOTEIO;
68
David Howells1eda8ba2019-06-28 18:00:05 +010069 /* Unified AFS error table */
70 case UAEPERM: return -EPERM;
71 case UAENOENT: return -ENOENT;
72 case UAEACCES: return -EACCES;
73 case UAEBUSY: return -EBUSY;
74 case UAEEXIST: return -EEXIST;
75 case UAENOTDIR: return -ENOTDIR;
76 case UAEISDIR: return -EISDIR;
77 case UAEFBIG: return -EFBIG;
78 case UAENOSPC: return -ENOSPC;
79 case UAEROFS: return -EROFS;
80 case UAEMLINK: return -EMLINK;
81 case UAEDEADLK: return -EDEADLK;
82 case UAENAMETOOLONG: return -ENAMETOOLONG;
83 case UAENOLCK: return -ENOLCK;
84 case UAENOTEMPTY: return -ENOTEMPTY;
85 case UAELOOP: return -ELOOP;
David Howells4ec89592020-06-14 22:12:05 +010086 case UAEOVERFLOW: return -EOVERFLOW;
David Howells1eda8ba2019-06-28 18:00:05 +010087 case UAENOMEDIUM: return -ENOMEDIUM;
88 case UAEDQUOT: return -EDQUOT;
David Howells005411c2009-06-16 21:36:49 +010089
David Howellsf780c8e2017-11-02 15:27:48 +000090 /* RXKAD abort codes; from include/rxrpc/packet.h. ET "RXK" == 0x1260B00 */
David Howells005411c2009-06-16 21:36:49 +010091 case RXKADINCONSISTENCY: return -EPROTO;
92 case RXKADPACKETSHORT: return -EPROTO;
93 case RXKADLEVELFAIL: return -EKEYREJECTED;
94 case RXKADTICKETLEN: return -EKEYREJECTED;
95 case RXKADOUTOFSEQUENCE: return -EPROTO;
96 case RXKADNOAUTH: return -EKEYREJECTED;
97 case RXKADBADKEY: return -EKEYREJECTED;
98 case RXKADBADTICKET: return -EKEYREJECTED;
99 case RXKADUNKNOWNKEY: return -EKEYREJECTED;
100 case RXKADEXPIRED: return -EKEYEXPIRED;
101 case RXKADSEALEDINCON: return -EKEYREJECTED;
102 case RXKADDATALEN: return -EKEYREJECTED;
103 case RXKADILLEGALLEVEL: return -EKEYREJECTED;
104
David Howells1157f152017-03-16 16:27:47 +0000105 case RXGEN_OPCODE: return -ENOTSUPP;
106
David Howells260a9802007-04-26 15:59:35 -0700107 default: return -EREMOTEIO;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700108 }
David Howellsec268152007-04-26 15:49:28 -0700109}
David Howells4584ae92018-11-13 23:20:28 +0000110
111/*
112 * Select the error to report from a set of errors.
113 */
114void afs_prioritise_error(struct afs_error *e, int error, u32 abort_code)
115{
116 switch (error) {
117 case 0:
118 return;
119 default:
120 if (e->error == -ETIMEDOUT ||
121 e->error == -ETIME)
122 return;
Gustavo A. R. Silvadf561f662020-08-23 17:36:59 -0500123 fallthrough;
David Howells4584ae92018-11-13 23:20:28 +0000124 case -ETIMEDOUT:
125 case -ETIME:
126 if (e->error == -ENOMEM ||
127 e->error == -ENONET)
128 return;
Gustavo A. R. Silvadf561f662020-08-23 17:36:59 -0500129 fallthrough;
David Howells4584ae92018-11-13 23:20:28 +0000130 case -ENOMEM:
131 case -ENONET:
132 if (e->error == -ERFKILL)
133 return;
Gustavo A. R. Silvadf561f662020-08-23 17:36:59 -0500134 fallthrough;
David Howells4584ae92018-11-13 23:20:28 +0000135 case -ERFKILL:
136 if (e->error == -EADDRNOTAVAIL)
137 return;
Gustavo A. R. Silvadf561f662020-08-23 17:36:59 -0500138 fallthrough;
David Howells4584ae92018-11-13 23:20:28 +0000139 case -EADDRNOTAVAIL:
140 if (e->error == -ENETUNREACH)
141 return;
Gustavo A. R. Silvadf561f662020-08-23 17:36:59 -0500142 fallthrough;
David Howells4584ae92018-11-13 23:20:28 +0000143 case -ENETUNREACH:
144 if (e->error == -EHOSTUNREACH)
145 return;
Gustavo A. R. Silvadf561f662020-08-23 17:36:59 -0500146 fallthrough;
David Howells4584ae92018-11-13 23:20:28 +0000147 case -EHOSTUNREACH:
148 if (e->error == -EHOSTDOWN)
149 return;
Gustavo A. R. Silvadf561f662020-08-23 17:36:59 -0500150 fallthrough;
David Howells4584ae92018-11-13 23:20:28 +0000151 case -EHOSTDOWN:
152 if (e->error == -ECONNREFUSED)
153 return;
Gustavo A. R. Silvadf561f662020-08-23 17:36:59 -0500154 fallthrough;
David Howells4584ae92018-11-13 23:20:28 +0000155 case -ECONNREFUSED:
156 if (e->error == -ECONNRESET)
157 return;
Gustavo A. R. Silvadf561f662020-08-23 17:36:59 -0500158 fallthrough;
David Howells4584ae92018-11-13 23:20:28 +0000159 case -ECONNRESET: /* Responded, but call expired. */
160 if (e->responded)
161 return;
162 e->error = error;
163 return;
164
165 case -ECONNABORTED:
166 e->responded = true;
167 e->error = afs_abort_to_error(abort_code);
168 return;
169 }
170}