解决 liburing 编译时缺失 `linux/time_types.h` 的问题

解决 liburing 编译时缺失 linux/time_types.h 的问题

引言

liburing 是 Linux 内核 io_uring 异步 I/O 接口的用户态封装库,极大简化了 io_uring 的使用。在嵌入式或较旧的 Linux 系统上编译 liburing 时,可能会遇到一个常见错误:缺少 linux/time_types.h 头文件。这个头文件属于 Linux 内核头文件的一部分,当系统内核头文件过旧或未完整安装时,就会导致编译失败。

本文将详细解释该错误的成因,并提供两种行之有效的解决方案。

问题描述

编译 liburing 时,可能出现类似如下的错误:

复制代码
fatal error: linux/time_types.h: No such file or directory
 #include <linux/time_types.h>

错误原因在于 liburing 的某些版本需要包含 linux/time_types.h,而该文件直到较新的内核版本(如 5.x 之后)才被引入。若编译环境中的内核头文件较老或不完整,就会触发该错误。

解决方案

方案一:清理并重新运行 configure(推荐)

liburing 的开发者已经在 configure 脚本中实现了对 linux/time_types.h 的自动检测。当脚本检测到该头文件缺失时,会自动定义一个宏 UAPI_LINUX_IO_URING_H_SKIP_LINUX_TIME_TYPES_H,从而在源码中跳过对该头文件的包含,并使用库自身定义的兼容结构。

执行以下命令:

bash 复制代码
cd /root/dev_armv7l/liburing
make clean
./configure
make

这样 configure 会生成正确的配置,然后 make 将顺利编译。

方案二:手动定义跳过宏

如果 configure 脚本未能自动解决问题(例如使用的 liburing 版本较老),您可以手动在编译选项中定义该宏。

通过 configure 传递 CFLAGS:

bash 复制代码
cd /root/dev_armv7l/liburing
./configure --cflags="-DUAPI_LINUX_IO_URING_H_SKIP_LINUX_TIME_TYPES_H"
make

或者直接在执行 make 时添加 CFLAGS:

bash 复制代码
cd /root/dev_armv7l/liburing
make CFLAGS="-DUAPI_LINUX_IO_URING_H_SKIP_LINUX_TIME_TYPES_H"

定义该宏后,liburing 源码中的 io_uring.h 将跳过 #include <linux/time_types.h>,并使用内部定义的时间结构,从而成功编译。

为什么有效?

liburing 的提交记录和源码中可以看到,io_uring.h 已经做了条件包含处理:

c 复制代码
#ifdef UAPI_LINUX_IO_URING_H_SKIP_LINUX_TIME_TYPES_H
/* 使用内部定义 */
#else
#include <linux/time_types.h>
#endif

当系统缺少 linux/time_types.h 时,通过定义 UAPI_LINUX_IO_URING_H_SKIP_LINUX_TIME_TYPES_H,就可以避免包含不存在的文件,同时 liburing 自身提供了必要的替代定义。这种方法已经在多个旧系统上验证有效。

总结

编译 liburing 时遇到 linux/time_types.h 缺失的错误,主要是由于内核头文件版本过旧。最简单的修复方法是清理后重新运行 configure ,让脚本自动适配;若自动检测失败,则可通过手动定义宏来强制跳过缺失头文件。这两种方法都能让 liburing 顺利编译,无需升级整个系统的内核头文件。

相关推荐
Mortalbreeze19 小时前
软件包管理器yum和编辑器vim详解 —— 附带vim配置链接
linux·服务器
李日灐20 小时前
< 7 > Linux 开发工具:git 版本控制器 和 cgdb/gdb 调试器
linux·运维·服务器·开发语言·git·调试器·gdb/cgdb
青木96020 小时前
前后端开发调试运行技巧
linux·服务器·前端·后端·npm·uv
c++之路20 小时前
C++ 模板
linux·开发语言·c++
xcbrand20 小时前
餐饮品牌全案公司哪家可靠
运维·python
apl35920 小时前
GUI 型 DevOps 平台的天花板,Ashby 在 1956 年就画好了
运维·devops
为美好的生活献上中指20 小时前
本地虚拟机部署redis集群
前端·redis·ubuntu·bootstrap·html·redis集群
云动课堂20 小时前
【运维实战】MySQL 8.0 数据库 · 一键自动化部署方案 (适配银河麒麟 V10 / 龙蜥 8 / Rocky Linux 8 / CentOS 8)
linux·运维·数据库
cui_ruicheng20 小时前
Linux进程间通信(一):管道与IPC基础
linux·运维·服务器
Lumos_77720 小时前
Linux -- 互斥锁
linux