函数逻辑报告 | 
Source Code:kernel\bpf\devmap.c | 
Create Date:2022-07-27 14:40:18 | 
| Last Modify:2020-03-12 14:18:49 | Copyright©Brick | 
| 首页 | 函数Tree | 
| 注解内核,赢得工具 | 下载SCCT | English | 
函数名称:__dev_map_hash_update_elem
函数原型:static int __dev_map_hash_update_elem(struct net *net, struct bpf_map *map, void *key, void *value, u64 map_flags)
返回类型:int
参数:
| 类型 | 参数 | 名称 | 
|---|---|---|
| struct net * | net | |
| struct bpf_map * | map | |
| void * | key | |
| void * | value | |
| u64 | map_flags | 
| 674 | 如果此条件成立可能性小(为编译器优化)(map_flags > update existing element || !ifindex)则返回:负EINVAL | 
| 677 | spin_lock_irqsave( & index_lock, flags) | 
| 679 | old_dev等于__dev_map_hash_lookup_elem(map, idx) | 
| 680 | 如果old_dev且map_flags按位与create new element if it didn't exist 则转到:out_err | 
| 684 | 如果是错误则 | 
| 689 | 如果old_dev则 | 
| 690 | 删除哈希表中无需重新初始化的条目 | 
| 691 | 否则 | 
| 692 | 如果items大于等于max_entries则 | 
| 693 | spin_unlock_irqrestore( & index_lock, flags) | 
| 695 | 返回:负E2BIG | 
| 697 | items自加 | 
| 700 | 添加哈希记录 | 
| 702 | spin_unlock_irqrestore( & index_lock, flags) | 
| 707 | 返回:0 | 
| 709 | out_err : | 
| 710 | spin_unlock_irqrestore( & index_lock, flags) | 
| 711 | 返回:err | 
| 名称 | 描述 | 
|---|---|
| dev_map_hash_update_elem | 
| 源代码转换工具 开放的插件接口  | X | 
|---|---|
| 支持:c/c++/esqlc/java Oracle/Informix/Mysql 插件可实现:逻辑报告 代码生成和批量转换代码  |