1 // SPDX-License-Identifier: GPL-2.0
2 #include <linux/build_bug.h>
3 #include <linux/errno.h>
4 #include <linux/errname.h>
5 #include <linux/kernel.h>
6 #include <linux/math.h>
7
8 /*
9 * Ensure these tables do not accidentally become gigantic if some
10 * huge errno makes it in. On most architectures, the first table will
11 * only have about 140 entries, but mips and parisc have more sparsely
12 * allocated errnos (with EHWPOISON = 257 on parisc, and EDQUOT = 1133
13 * on mips), so this wastes a bit of space on those - though we
14 * special case the EDQUOT case.
15 */
16 #define E(err) [err + BUILD_BUG_ON_ZERO(err <= 0 || err > 300)] = "-" #err
17 static const char *names_0[] = {
18 E(E2BIG),
19 E(EACCES),
20 E(EADDRINUSE),
21 E(EADDRNOTAVAIL),
22 E(EADV),
23 E(EAFNOSUPPORT),
24 E(EALREADY),
25 E(EBADE),
26 E(EBADF),
27 E(EBADFD),
28 E(EBADMSG),
29 E(EBADR),
30 E(EBADRQC),
31 E(EBADSLT),
32 E(EBFONT),
33 E(EBUSY),
34 #ifdef ECANCELLED
35 E(ECANCELLED),
36 #endif
37 E(ECHILD),
38 E(ECHRNG),
39 E(ECOMM),
40 E(ECONNABORTED),
41 E(ECONNRESET),
42 E(EDEADLOCK),
43 E(EDESTADDRREQ),
44 E(EDOM),
45 E(EDOTDOT),
46 #ifndef CONFIG_MIPS
47 E(EDQUOT),
48 #endif
49 E(EEXIST),
50 E(EFAULT),
51 E(EFBIG),
52 E(EHOSTDOWN),
53 E(EHOSTUNREACH),
54 E(EHWPOISON),
55 E(EIDRM),
56 E(EILSEQ),
57 #ifdef EINIT
58 E(EINIT),
59 #endif
60 E(EINPROGRESS),
61 E(EINTR),
62 E(EINVAL),
63 E(EIO),
64 E(EISCONN),
65 E(EISDIR),
66 E(EISNAM),
67 E(EKEYEXPIRED),
68 E(EKEYREJECTED),
69 E(EKEYREVOKED),
70 E(EL2HLT),
71 E(EL2NSYNC),
72 E(EL3HLT),
73 E(EL3RST),
74 E(ELIBACC),
75 E(ELIBBAD),
76 E(ELIBEXEC),
77 E(ELIBMAX),
78 E(ELIBSCN),
79 E(ELNRNG),
80 E(ELOOP),
81 E(EMEDIUMTYPE),
82 E(EMFILE),
83 E(EMLINK),
84 E(EMSGSIZE),
85 E(EMULTIHOP),
86 E(ENAMETOOLONG),
87 E(ENAVAIL),
88 E(ENETDOWN),
89 E(ENETRESET),
90 E(ENETUNREACH),
91 E(ENFILE),
92 E(ENOANO),
93 E(ENOBUFS),
94 E(ENOCSI),
95 E(ENODATA),
96 E(ENODEV),
97 E(ENOENT),
98 E(ENOEXEC),
99 E(ENOKEY),
100 E(ENOLCK),
101 E(ENOLINK),
102 E(ENOMEDIUM),
103 E(ENOMEM),
104 E(ENOMSG),
105 E(ENONET),
106 E(ENOPKG),
107 E(ENOPROTOOPT),
108 E(ENOSPC),
109 E(ENOSR),
110 E(ENOSTR),
111 #ifdef ENOSYM
112 E(ENOSYM),
113 #endif
114 E(ENOSYS),
115 E(ENOTBLK),
116 E(ENOTCONN),
117 E(ENOTDIR),
118 E(ENOTEMPTY),
119 E(ENOTNAM),
120 E(ENOTRECOVERABLE),
121 E(ENOTSOCK),
122 E(ENOTTY),
123 E(ENOTUNIQ),
124 E(ENXIO),
125 E(EOPNOTSUPP),
126 E(EOVERFLOW),
127 E(EOWNERDEAD),
128 E(EPERM),
129 E(EPFNOSUPPORT),
130 E(EPIPE),
131 #ifdef EPROCLIM
132 E(EPROCLIM),
133 #endif
134 E(EPROTO),
135 E(EPROTONOSUPPORT),
136 E(EPROTOTYPE),
137 E(ERANGE),
138 E(EREMCHG),
139 #ifdef EREMDEV
140 E(EREMDEV),
141 #endif
142 E(EREMOTE),
143 E(EREMOTEIO),
144 #ifdef EREMOTERELEASE
145 E(EREMOTERELEASE),
146 #endif
147 E(ERESTART),
148 E(ERFKILL),
149 E(EROFS),
150 #ifdef ERREMOTE
151 E(ERREMOTE),
152 #endif
153 E(ESHUTDOWN),
154 E(ESOCKTNOSUPPORT),
155 E(ESPIPE),
156 E(ESRCH),
157 E(ESRMNT),
158 E(ESTALE),
159 E(ESTRPIPE),
160 E(ETIME),
161 E(ETIMEDOUT),
162 E(ETOOMANYREFS),
163 E(ETXTBSY),
164 E(EUCLEAN),
165 E(EUNATCH),
166 E(EUSERS),
167 E(EXDEV),
168 E(EXFULL),
169
170 E(ECANCELED), /* ECANCELLED */
171 E(EAGAIN), /* EWOULDBLOCK */
172 E(ECONNREFUSED), /* EREFUSED */
173 E(EDEADLK), /* EDEADLOCK */
174 };
175 #undef E
176
177 #define E(err) [err - 512 + BUILD_BUG_ON_ZERO(err < 512 || err > 550)] = "-" #err
178 static const char *names_512[] = {
179 E(ERESTARTSYS),
180 E(ERESTARTNOINTR),
181 E(ERESTARTNOHAND),
182 E(ENOIOCTLCMD),
183 E(ERESTART_RESTARTBLOCK),
184 E(EPROBE_DEFER),
185 E(EOPENSTALE),
186 E(ENOPARAM),
187
188 E(EBADHANDLE),
189 E(ENOTSYNC),
190 E(EBADCOOKIE),
191 E(ENOTSUPP),
192 E(ETOOSMALL),
193 E(ESERVERFAULT),
194 E(EBADTYPE),
195 E(EJUKEBOX),
196 E(EIOCBQUEUED),
197 E(ERECALLCONFLICT),
198 };
199 #undef E
200
__errname(unsigned err)201 static const char *__errname(unsigned err)
202 {
203 if (err < ARRAY_SIZE(names_0))
204 return names_0[err];
205 if (err >= 512 && err - 512 < ARRAY_SIZE(names_512))
206 return names_512[err - 512];
207 /* But why? */
208 if (IS_ENABLED(CONFIG_MIPS) && err == EDQUOT) /* 1133 */
209 return "-EDQUOT";
210 return NULL;
211 }
212
213 /*
214 * errname(EIO) -> "EIO"
215 * errname(-EIO) -> "-EIO"
216 */
errname(int err)217 const char *errname(int err)
218 {
219 const char *name = __errname(abs(err));
220 if (!name)
221 return NULL;
222
223 return err > 0 ? name + 1 : name;
224 }
225