netlink扫盲级的疑问

发布于 2022-09-18 19:20:35 字数 110 浏览 12 评论 0

最近有人提到用netlink和内核通信,大概找了些资料看了一下。有人说它比用copy_from_user/copy_to_uesr效率高,难道这种方式不需要拷贝吗?我印象中通过socket库函数到系统调用总要拷贝一次吧。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(9

ゃ人海孤独症 2022-09-25 19:20:35

应该是socket这种机制,不需要拷贝,传一个skbuff,从上至下,从下至上。

ヅ她的身影、若隐若现 2022-09-25 19:20:35

完全就是socket的机制。

唐婉 2022-09-25 19:20:35

原帖由 dreamice 于 2009-2-26 12:09 发表
应该是socket这种机制,不需要拷贝,传一个skbuff,从上至下,从下至上。

socket机制的sk_buf所谓不需要拷贝是在内核中不同的协议栈层次之间吧,从用户空间recv参数中的buffer到内核态难道不需要一次拷贝?如果这样的话和用一个字符设备然后用read好像没多大区别吧?

仲春光 2022-09-25 19:20:35

你还是好好把socket机制搞清楚点再说吧,呵呵

无尽的现实 2022-09-25 19:20:35

原帖由 dreamice 于 2009-2-26 20:12 发表
你还是好好把socket机制搞清楚点再说吧,呵呵

我这不是没时间去仔细看码,那么大一坨,呵呵。刚才浏览了一下,netlink调用的是
netlink_recvmsg->skb_copy_datagram_iovec->memcpy_toiovec->copy_to_user

实际上也就是一个普通的内核到用户空间的拷贝而已。这样的话netlink主要是灵活吧,并且可以实现异步,但说到效率,不见得比字符设备高吧。倒是TCP在编译时如果定义了CONFIG_NET_DMA,好像在接收时会使用get_user_pages来直接使用缓冲区所在物理页面,但代码挺复杂的,一时没看懂具体怎么用的。

无法言说的痛 2022-09-25 19:20:35

可能是这样的,具体我没有深入分析过,呵呵。
不过,copy_to(from)_user还有严格的检查。

琉璃梦幻 2022-09-25 19:20:35

有检查我是知道的,只是在网上看到那个帖子的说法感觉有点奇怪,本来又不想自己去看代码,所以才跑来问的,呵呵。之前我在Wiki中看过,讲到netlink的优点中是没有效率高这种说法的。

葬花如无物 2022-09-25 19:20:35

看了一下net/socket.c,数据在内核态和用户态交互的时候,还是用到了copy_from_user和copy_to_user的

你曾走过我的故事 2022-09-25 19:20:35

原帖由 Godbach 于 2009-2-27 19:12 发表
看了一下net/socket.c,数据在内核态和用户态交互的时候,还是用到了copy_from_user和copy_to_user的

那这样看来,说效率就有点牵强了,说这话的人有点不负责任,呵呵
不过网络上的,大家还是要明辨是非啊

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文