函数逻辑报告 |
Source Code:kernel\bpf\lpm_trie.c |
Create Date:2022-07-27 14:30:03 |
Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
首页 | 函数Tree |
注解内核,赢得工具 | 下载SCCT | English |
函数名称:Called from syscall or from eBPF program
函数原型:static int trie_update_elem(struct bpf_map *map, void *_key, void *value, u64 flags)
返回类型:int
参数:
类型 | 参数 | 名称 |
---|---|---|
struct bpf_map * | map | |
void * | _key | |
void * | value | |
u64 | flags |
304 | struct lpm_trie_node * node, * im_node = NULL, * new_node = NULL |
309 | matchlen等于0 |
310 | ret等于0 |
312 | 如果此条件成立可能性小(为编译器优化)(flags > update existing element )则返回:负EINVAL |
318 | raw_spin_lock_irqsave( & lock, irq_flags) |
322 | 如果n_entries恒等于max_entries则 |
327 | new_node等于lpm_trie_node_alloc(trie, value) |
328 | 如果非new_node则 |
333 | n_entries自加 |
338 | 内存复制(data, Arbitrary size , data_size) |
351 | 如果prefixlen不等于matchlen或prefixlen恒等于up to 32 for AF_INET, 128 for AF_INET6 或prefixlen恒等于max_prefixlen则退出 |
363 | 如果非node则 |
365 | 转到:out |
375 | 如果非flags按位与Intermediate node 的值则n_entries自减 |
381 | 转到:out |
391 | 转到:out |
394 | im_node等于lpm_trie_node_alloc(trie, NULL) |
395 | 如果非im_node则 |
401 | flags或等于Intermediate node |
408 | 否则 |
416 | out : |
417 | 如果ret则 |
425 | raw_spin_unlock_irqrestore( & lock, irq_flags) |
427 | 返回:ret |
源代码转换工具 开放的插件接口 | X |
---|---|
支持:c/c++/esqlc/java Oracle/Informix/Mysql 插件可实现:逻辑报告 代码生成和批量转换代码 |