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 majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to