diff options
Diffstat (limited to 'kernel/bpf/syscall.c')
| -rw-r--r-- | kernel/bpf/syscall.c | 8 | 
1 files changed, 6 insertions, 2 deletions
diff --git a/kernel/bpf/syscall.c b/kernel/bpf/syscall.c index 233e3ac836a6..ce1b7de7d72c 100644 --- a/kernel/bpf/syscall.c +++ b/kernel/bpf/syscall.c @@ -292,6 +292,7 @@ static int map_lookup_elem(union bpf_attr *attr)  		goto free_key;  	if (map->map_type == BPF_MAP_TYPE_PERCPU_HASH || +	    map->map_type == BPF_MAP_TYPE_LRU_PERCPU_HASH ||  	    map->map_type == BPF_MAP_TYPE_PERCPU_ARRAY)  		value_size = round_up(map->value_size, 8) * num_possible_cpus();  	else @@ -302,7 +303,8 @@ static int map_lookup_elem(union bpf_attr *attr)  	if (!value)  		goto free_key; -	if (map->map_type == BPF_MAP_TYPE_PERCPU_HASH) { +	if (map->map_type == BPF_MAP_TYPE_PERCPU_HASH || +	    map->map_type == BPF_MAP_TYPE_LRU_PERCPU_HASH) {  		err = bpf_percpu_hash_copy(map, key, value);  	} else if (map->map_type == BPF_MAP_TYPE_PERCPU_ARRAY) {  		err = bpf_percpu_array_copy(map, key, value); @@ -366,6 +368,7 @@ static int map_update_elem(union bpf_attr *attr)  		goto free_key;  	if (map->map_type == BPF_MAP_TYPE_PERCPU_HASH || +	    map->map_type == BPF_MAP_TYPE_LRU_PERCPU_HASH ||  	    map->map_type == BPF_MAP_TYPE_PERCPU_ARRAY)  		value_size = round_up(map->value_size, 8) * num_possible_cpus();  	else @@ -385,7 +388,8 @@ static int map_update_elem(union bpf_attr *attr)  	 */  	preempt_disable();  	__this_cpu_inc(bpf_prog_active); -	if (map->map_type == BPF_MAP_TYPE_PERCPU_HASH) { +	if (map->map_type == BPF_MAP_TYPE_PERCPU_HASH || +	    map->map_type == BPF_MAP_TYPE_LRU_PERCPU_HASH) {  		err = bpf_percpu_hash_update(map, key, value, attr->flags);  	} else if (map->map_type == BPF_MAP_TYPE_PERCPU_ARRAY) {  		err = bpf_percpu_array_update(map, key, value, attr->flags);  |