上一页 1 ··· 24 25 26 27 28 29 30 31 32 ··· 69 下一页
摘要: 目前可以看出: 核心问题为:多线程fd close/open 以及 skb的slab_cache以及 slab_free fd close /open 所引发的的问题已经有相关解决办法;主要是slab_free这个? 内核的slab来自一种很简单的思想,即事先准备好一些会频繁分配,释放的数据结构。然 阅读全文
posted @ 2022-03-31 18:13 codestacklinuxer 阅读(23) 评论(0) 推荐(0)
摘要: 路由查找 与IPv4不同,IPv6的出口路由和入口路由都使用函数ip6_pol_route实现,区别在于传入的接口索引参数不同 INDIRECT_CALLABLE_SCOPE struct rt6_info *ip6_pol_route_input(struct net *net, struct f 阅读全文
posted @ 2022-03-29 15:14 codestacklinuxer 阅读(26) 评论(0) 推荐(0)
摘要: 路由表查找函数首先调用fib6_node_lookup查找路由节点,由指定路由表的根节点开始,根据数据流的目的和源地址进行。 static struct fib6_node *fib6_lookup_1(struct fib6_node *root, struct lookup_args *args 阅读全文
posted @ 2022-03-29 14:17 codestacklinuxer 阅读(61) 评论(0) 推荐(0)
摘要: 目前在解决ipv6 路由bug的时候发现,内核ipv6 和ipv4 路由设计区别很大! IPv6路由项添加 ip route add 3ffe::/64 via 3001::1 对应的核心函数为: fib6_add_1 :负责在路由树中找到合适的插入节点,或者创建新的用于插入操作的节点(根据allo 阅读全文
posted @ 2022-03-29 12:42 codestacklinuxer 阅读(39) 评论(0) 推荐(0)
摘要: 1、常用的时间存储方式 1)time_t类型,这本质上是一个长整数,表示从1970-01-01 00:00:00到目前计时时间的秒数,如果需要更精确一点的,可以使用timeval精确到毫秒。 2)tm结构,这本质上是一个结构体,里面包含了各时间字段 struct tm { int tm_sec; / 阅读全文
posted @ 2022-03-16 20:06 codestacklinuxer 阅读(70) 评论(0) 推荐(0)
摘要: 在内核中,顺序锁和读写锁比较相似,都是针对多读少写且快速处理的临界区的锁机制。 对于 rwlock 而言,rwlock的全称是"reader-writer spin lock",和普通的spinlock不同,它对"read"和"write"的操作进行了区分。如果当前没有writer,那么多个read 阅读全文
posted @ 2022-03-09 10:59 codestacklinuxer 阅读(23) 评论(0) 推荐(0)
摘要: 转载自: 理论 3.6版本内核移除了FIB查询前的路由缓存,取而代之的是下一跳缓存,这在路由缓存的前世今生 中已经说过了。本文要说的是在该版本中引入的另一个概念:FIB Nexthop Exception,用于记录下一跳的例外情形。 它有什么用呢? 内核通过查询转发信息表(fib_lookup),得 阅读全文
posted @ 2022-03-07 20:25 codestacklinuxer 阅读(32) 评论(0) 推荐(0)
摘要: 看下以前的文章首先说明一下 Routing与 Neighboring subsystem的关联 1、在路由过程中,需要寻找或创建 struct dst_entry (另一种形式是 struct rtable)。 dst_entry 通过neighbour 域与 struct neighbour 关联 阅读全文
posted @ 2022-03-07 18:48 codestacklinuxer 阅读(87) 评论(0) 推荐(0)
摘要: fib_table_lookup 可以参考:https://blog.csdn.net/shichaog/article/details/44658205 1405 int fib_table_lookup(struct fib_table *tb, const struct flowi4 *flp 阅读全文
posted @ 2022-03-07 12:10 codestacklinuxer 阅读(23) 评论(0) 推荐(0)
摘要: 3.6版本以前的路由缓存 缓存无处不在。现代计算机系统中,Cache是CPU与内存间存在一种容量较小但速度很高的存储器,用来存放CPU刚使用过或最近使用的数据。路由缓存就是基于这种思想的软件实现。内核查询FIB前,固定先查询cache中的记录,如果cache命中(hit),那就直接用就好了,不必查询 阅读全文
posted @ 2022-03-07 10:59 codestacklinuxer 阅读(76) 评论(0) 推荐(0)
上一页 1 ··· 24 25 26 27 28 29 30 31 32 ··· 69 下一页
点击右上角即可分享
微信分享提示