linux kernel 错误返回

使用错误返回等与err相关的定义与操作,需包含头文件:

  1. #include <linux/err.h>

常见的err说明

include/asm-generic/errno-base.h

  1. #define EPERM        1  /* Operation not permitted */  
  2. #define ENOENT       2  /* No such file or directory */  
  3. #define ESRCH        3  /* No such process */  
  4. #define EINTR        4  /* Interrupted system call */  
  5. #define EIO      5  /* I/O error */  
  6. #define ENXIO        6  /* No such device or address */  
  7. #define E2BIG        7  /* Argument list too long */  
  8. #define ENOEXEC          8  /* Exec format error */  
  9. #define EBADF        9  /* Bad file number */  
  10. #define ECHILD      10  /* No child processes */  
  11. #define EAGAIN      11  /* Try again */  
  12. #define ENOMEM      12  /* Out of memory */  
  13. #define EACCES      13  /* Permission denied */  
  14. #define EFAULT      14  /* Bad address */  
  15. #define ENOTBLK         15  /* Block device required */  
  16. #define EBUSY       16  /* Device or resource busy */  
  17. #define EEXIST      17  /* File exists */  
  18. #define EXDEV       18  /* Cross-device link */  
  19. #define ENODEV      19  /* No such device */  
  20. #define ENOTDIR         20  /* Not a directory */  
  21. #define EISDIR      21  /* Is a directory */  
  22. #define EINVAL      22  /* Invalid argument */  
  23. #define ENFILE      23  /* File table overflow */  
  24. #define EMFILE      24  /* Too many open files */  
  25. #define ENOTTY      25  /* Not a typewriter */  
  26. #define ETXTBSY         26  /* Text file busy */  
  27. #define EFBIG       27  /* File too large */  
  28. #define ENOSPC      28  /* No space left on device */  
  29. #define ESPIPE      29  /* Illegal seek */  
  30. #define EROFS       30  /* Read-only file system */  
  31. #define EMLINK      31  /* Too many links */  
  32. #define EPIPE       32  /* Broken pipe */  
  33. #define EDOM        33  /* Math argument out of domain of func */  
  34. #define ERANGE      34  /* Math result not representable */
内核的错误码保存在内存最后4K的区域,即0xfffff000~0xffffffff区域。如果指针指向了这段内存区域,则表示出错。如返回-EINTR错误,也就错误码为-4(0xfffffffc),则0xfffffffc就是错误码指针。

下面是出错相关的几个宏:
ERR_PTR()将错误码转换成指针。
include/linux/err.h

  1. static inline void * __must_check ERR_PTR(long error)  
  2. {  
  3.     return (void *) error;    

PTR_ERR()把指针转换成错误码。
include/linux/err.h

  1. static inline long __must_check PTR_ERR(const void *ptr)  
  2. {  
  3.     return (long) ptr;    


IS_ERR()判断指针是否落在错误码区域。
include/linux/err.h

  1. static inline long __must_check IS_ERR(const void *ptr)  
  2. {  
  3.     return IS_ERR_VALUE((unsigned long)ptr);  
  4. }  
  5. #define MAX_ERRNO   4095  
  6. #define IS_ERR_VALUE(x) unlikely((x) >= (unsigned long)-MAX_ERRNO) 

IS_ERR_OR_NULL()判断指针是否落在错误码区域或者为空。
include/linux/err.h

  1. static inline long __must_check IS_ERR_OR_NULL(const void *ptr)  
  2. {  
  3.     return !ptr || IS_ERR_VALUE((unsigned long)ptr);  


IS_ERR()判断的是指针是否指向错误码区域,ptr==NULL或!ptr判断的是指针是否为空,这几个判断一般用在当调用的函数的返回值为指针类型。对于IS_ERR()与ptr==NULL的使用区别,则具体要看调用的是什么函数,如果函数在调用失败时返回NULL指针,那么就应该使用ptr==NULL或者!ptr。如果函数在调用失败时返回的是指向错误码区的指向,那么就要使用IS_ERR()或者IS_ERR_VALUE()。当然也可以使用IS_ERR_OR_NULL来判断所有的返回为指针的调用。

相关文章
相关标签/搜索