函数逻辑报告 |
Source Code:kernel\bpf\queue_stack_maps.c |
Create Date:2022-07-27 14:31:58 |
Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
首页 | 函数Tree |
注解内核,赢得工具 | 下载SCCT | English |
函数名称:__queue_map_get
函数原型:static int __queue_map_get(struct bpf_map *map, void *value, bool delete)
返回类型:int
参数:
类型 | 参数 | 名称 |
---|---|---|
struct bpf_map * | map | |
void * | value | |
bool | delete |
116 | qs等于bpf_queue_stack(map) |
118 | err等于0 |
121 | raw_spin_lock_irqsave( & lock, flags) |
123 | 如果queue_stack_map_is_empty(qs)则 |
129 | ptr等于elements[tail * value_size] |
130 | 内存复制(value, ptr, value_size) |
132 | 如果delete则 |
133 | 如果此条件成立可能性小(为编译器优化)(++tail >= max_entries + 1 )则tail等于0 |
137 | out : |
138 | raw_spin_unlock_irqrestore( & lock, flags) |
139 | 返回:err |
名称 | 描述 |
---|---|
queue_map_peek_elem | Called from syscall or from eBPF program |
queue_map_pop_elem | Called from syscall or from eBPF program |
源代码转换工具 开放的插件接口 | X |
---|---|
支持:c/c++/esqlc/java Oracle/Informix/Mysql 插件可实现:逻辑报告 代码生成和批量转换代码 |