10

我目前正在为 Linux 内核构建一个模块。我的工作版本是 3.8-rc3+。我的工作使我实​​现了一些ioctl()命令。如您所知,我的命令应该返回适​​当的错误代码来描述执行过程中出了什么问题。这看起来很简单,但我有一个用例,我不知道应该返回哪个错误代码。

基本上,我希望用户能够为给定设备设置加密密钥。我的模块将密钥存储在 RB 树中,由设备唯一标识符(基本int)索引。如果“目标”设备在树中已经有一个条目,那么应该更新这个条目,否则,模块只需将一个新分配的条目添加到该设备的树中,并带有请求的加密密钥。也就是说,尝试设置密钥时可能会发生多种情况:

  • 模块内部的某些东西可能正在使用用户想要更新的加密密钥:模块返回EBUSY错误。
  • 没有条目并且分配失败:ENOMEM错误。
  • 该模块正在释放其资源。现有的键条目可能被标记为删除(条目有一个dying标志来表示这一点):在内部我目前使用EPERM错误代码,因为调用者没有“权限”在条目被销毁时更改条目。

正如我所说,对于后一种情况,我使用EPERM错误代码,但我感觉它是错误的,我不知道我应该为此使用哪个错误代码。欢迎任何建议!

我还指定了 linux 标签,因为它ioctl()可以在用户空间应用程序中使用。

编辑:通读评论和答案后,我想我会这样:

  • 当模块释放其资源时,ESHUTDOWN将被返回。
  • 当只有目标键被销毁,而树的其余部分仍然正常时,EACCES将被使用。
4

1 回答 1

3

怎么样ESHUTDOWN?(传输端点关闭后无法发送)

另一种选择是ENXIO(没有这样的设备或地址)。它不是 100% 准确的,因为该设备仍然存在,但它传达了错误的含义(它不再可用)。

一个简单的选择是ENOTSUP(不支持操作),但这听起来更像是“方法未实现”

EPERM听起来更好,但它通常与“您无权执行此操作”而不是“您现在不能执行此操作”一起使用。

ESTALE(陈旧的文件句柄)会很好,但它与 NFS 相关。

于 2013-03-05T12:34:57.887 回答