關(guān)于Linux操作系統(tǒng)內(nèi)核中的指針和錯誤值
在內(nèi)核的代碼和驅(qū)動程序中經(jīng)常見到ERR_PTR, IS_ERR, PTR_ERR這三個內(nèi)聯(lián)函數(shù)。
本文引用地址:http://cafeforensic.com/article/201609/305270.htm許多的內(nèi)核函數(shù)需要返回一個指針,但是函數(shù)的調(diào)用可能失敗,一般我們處理這樣的情形都是返回一個NULL指針,就像malloc或kmalloc在沒有獲得指定的空間申請時的返回值一樣。但是有時我們想知道導(dǎo)致函數(shù)失敗的原因,但是返回NULL就顯得信息不夠。因此有些函數(shù)返回一個實(shí)際的錯誤編碼以便對引起錯誤的原因做一些處理。很多內(nèi)核接口通過把錯誤值編碼到一個指針值中來返回錯誤信息。當(dāng)處理這樣的函數(shù)時,判斷是否成功調(diào)用就不能是簡單的和NULL進(jìn)行比較。為了方便使用這樣的類型接口,2.6的內(nèi)核在linux/err.h中實(shí)現(xiàn)了三個內(nèi)聯(lián)函數(shù):
inline void *ERR_PTR(long error)
{
return (void *) error;
}
返回指針類型的函數(shù)可以通過這個函數(shù)來返回一個錯誤值。這里的error是通常的負(fù)的錯誤編碼。調(diào)用者可以使用IS_ERR來檢查所返回的指針是否是一個錯誤編碼。
inline long IS_ERR(const void *ptr)
{
return (unsigned long)ptr > (unsigned long)-1000L;
}
如果需要實(shí)際的錯誤編碼,可以通過PTR_ERR函數(shù)提取
inline long PTR_ERR(const void *ptr)
{
return (long) ptr;
}
只有在IS_ERR返回真的時候才能使用PTR_ERR。
評論