解决error: unknown type name ‘__u8’问题,认识__u8,__u16,__u32,__u64的大小及作用
內核提供的數據類型都在頭文件<asm/types.h>聲明,可以在程序中加上#include <asm/types.h>頭文件。詳細類型可參考 https://www.linuxidc.com/Linux/2011-06/37157.htm
2、認識__u8,__u16,__u32,__u64的大小及作用: 作者:時國懷
鏈接:https://www.zhihu.com/question/23223900/answer/23969589
來源:知乎
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。
驅動開發的原則:
能用__u32就最好用它,或者用u_int32_t之類的也可以,但不要直接用unsigned int等默認的數據類型。目的是讓別人明白,你這個變量占多大內存。
原因:
你不能確定你的代碼未來只在一個平臺上運行,它可能會被移植到非Linux平臺(確實有很多人這么做),它可能運行在不同的CPU平臺,比如64位環境,非x86環境。
因為C語言中并未明確規定int一定要占多少字節,只是規定了long >= int >= short,所以__u32就是告訴別人,這變量占4字節。
同樣的:__iomem也是能加就加,這樣當你的驅動被別人維護的時候,別人會明白,這塊內存是用于IO的,可DMA的,而不是paged-memory。
說到底,這是一種良好的編碼風格,確實,不加這些東西,對于編譯和運行來說,可能是無任何影響的,但是,不寫注釋的代碼一樣也對編譯和運行無影響,你敢一句注釋都不寫嗎?
--------------------------------------
驅動中使用哪種類型最標準,這個沒有正確答案,但建議是不使用C語言原始的數據類型(char/short/int/long),而是使用有明確字節大小的數據類型(u_int32_t/__u32/uint32_t/DWORD/UINT32均可)。保持代碼風格的一致性即可。
Linux社區提倡開放,并不嚴格限制開發者必須用哪種類型,一切都只是建議使用。
但有一種情況是例外的:開發標準庫函數,比如自己實現strlen,那么返回值就必須是size_t,因為標準庫是標準的。總結
以上是生活随笔為你收集整理的解决error: unknown type name ‘__u8’问题,认识__u8,__u16,__u32,__u64的大小及作用的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 0基础学Linux-从小白到大牛(3)L
- 下一篇: 西游记中孙悟空为什么打不过有法宝的妖怪?