]>
Commit | Line | Data |
---|---|---|
1da177e4 LT |
1 | #ifndef _LINUX_ERR_H |
2 | #define _LINUX_ERR_H | |
3 | ||
4 | #include <linux/compiler.h> | |
5 | ||
6 | #include <asm/errno.h> | |
7 | ||
8 | /* | |
9 | * Kernel pointers have redundant information, so we can use a | |
10 | * scheme where we can return either an error code or a dentry | |
11 | * pointer with the same return value. | |
12 | * | |
13 | * This should be a per-architecture thing, to allow different | |
14 | * error and pointer decisions. | |
15 | */ | |
fa79837d RB |
16 | #define MAX_ERRNO 4095 |
17 | ||
ebba5f9f RD |
18 | #ifndef __ASSEMBLY__ |
19 | ||
fa79837d | 20 | #define IS_ERR_VALUE(x) unlikely((x) >= (unsigned long)-MAX_ERRNO) |
07ab67c8 | 21 | |
e47103b1 | 22 | static inline void * __must_check ERR_PTR(long error) |
1da177e4 LT |
23 | { |
24 | return (void *) error; | |
25 | } | |
26 | ||
e47103b1 | 27 | static inline long __must_check PTR_ERR(const void *ptr) |
1da177e4 LT |
28 | { |
29 | return (long) ptr; | |
30 | } | |
31 | ||
e47103b1 | 32 | static inline long __must_check IS_ERR(const void *ptr) |
1da177e4 | 33 | { |
07ab67c8 | 34 | return IS_ERR_VALUE((unsigned long)ptr); |
1da177e4 LT |
35 | } |
36 | ||
e47103b1 | 37 | static inline long __must_check IS_ERR_OR_NULL(const void *ptr) |
603c4ba9 PC |
38 | { |
39 | return !ptr || IS_ERR_VALUE((unsigned long)ptr); | |
40 | } | |
41 | ||
d1bc8e95 DH |
42 | /** |
43 | * ERR_CAST - Explicitly cast an error-valued pointer to another pointer type | |
44 | * @ptr: The pointer to cast. | |
45 | * | |
46 | * Explicitly cast an error-valued pointer to another pointer type in such a | |
47 | * way as to make it clear that's what's going on. | |
48 | */ | |
e47103b1 | 49 | static inline void * __must_check ERR_CAST(const void *ptr) |
d1bc8e95 DH |
50 | { |
51 | /* cast away the const */ | |
52 | return (void *) ptr; | |
53 | } | |
54 | ||
ebba5f9f RD |
55 | #endif |
56 | ||
1da177e4 | 57 | #endif /* _LINUX_ERR_H */ |