On 7/29/15 4:17 PM, Daniel Borkmann wrote:
- if (map->map_type == BPF_MAP_TYPE_PROG_ARRAY) + if (map->map_type >= BPF_MAP_TYPE_PROG_ARRAY) /* prog_array stores refcnt-ed bpf_prog pointers * release them all when user space closes prog_array_fd */ - bpf_prog_array_map_clear(map); + bpf_fd_array_map_clear(map);When we are going to add a new map type to the eBPF framework that is not an fd_array_map thing, this assumption of map->map_type >= BPF_MAP_TYPE_PROG_ARRAY might not hold then ...
Also I think here changing == to >= is probably unnecessary. prog_array needs to do it because of circular dependency whereas perf_event_array cannot have it. Even when we attach bpf prog to perf_event and then add it to perf_event_array used by the same prog, right? Please test such scenario just in case. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [email protected] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/

