内核里返回指针的话, 把-1 ~ -1000 转换为指针 作为错误码
内核中许多函数用返回值[-1L,-1000L]代表错误,这部分空间没有被影射.有些地方的返回值类型是指针,那么 如果没有检测返回值就访问该指针的话,那么就发生内核缺页异常,非法访问被捕获.内核专门有两个函数PTR_ERR() ,IS_ERR ()做这种检测.
vfs_read
/
/
generic_file_read
/
/
sys_read
struct file *filp_open(const char * filename, int flags, int mode)
{
int namei_flags, error;
struct nameidata nd;
namei_flags = flags;
if ((namei_flags+1) & O_ACCMODE)
namei_flags++;
if (namei_flags & O_TRUNC)
namei_flags |= 2;
error = open_namei(filename, namei_flags, mode, &nd);
if (!error)
return dentry_open(nd.dentry, nd.mnt, flags);
return ERR_PTR(error);
}
#define IS_ERR_VALUE(x) unlikely((x) > (unsigned long)-1000L)
static inline void *ERR_PTR(long error)
{
return (void *) error;
}
static inline long IS_ERR(const void *ptr)
{
return IS_ERR_VALUE((unsigned long)ptr);
}
static inline long PTR_ERR(const void *ptr)
{
return (long) ptr;
}
内核中许多函数用返回值[-1L,-1000L]代表错误,这部分空间没有被影射.有些地方的返回值类型是指针,那么 如果没有检测返回值就访问该指针的话,那么就发生内核缺页异常,非法访问被捕获.内核专门有两个函数PTR_ERR() ,IS_ERR ()做这种检测.
vfs_read
/
/
generic_file_read
/
/
sys_read
struct file *filp_open(const char * filename, int flags, int mode)
{
int namei_flags, error;
struct nameidata nd;
namei_flags = flags;
if ((namei_flags+1) & O_ACCMODE)
namei_flags++;
if (namei_flags & O_TRUNC)
namei_flags |= 2;
error = open_namei(filename, namei_flags, mode, &nd);
if (!error)
return dentry_open(nd.dentry, nd.mnt, flags);
return ERR_PTR(error);
}
#define IS_ERR_VALUE(x) unlikely((x) > (unsigned long)-1000L)
static inline void *ERR_PTR(long error)
{
return (void *) error;
}
static inline long IS_ERR(const void *ptr)
{
return IS_ERR_VALUE((unsigned long)ptr);
}
static inline long PTR_ERR(const void *ptr)
{
return (long) ptr;
}