Commit b31a3838 authored by Rasmus Villemoes's avatar Rasmus Villemoes Committed by Marc Zyngier

irqchip/gic-v3-its: Move allocation outside mutex

There's no reason to do the allocation of the new lpi_range inside the
lpi_range_lock. One could change the code to avoid the allocation
altogether in case the freed range can be merged with one or two
existing ranges (in which case the allocation would naturally be done
under the lock), but it's probably not worth complicating the code for
that.
Signed-off-by: default avatarRasmus Villemoes <linux@rasmusvillemoes.dk>
Signed-off-by: default avatarMarc Zyngier <marc.zyngier@arm.com>
parent cfbf9e49
...@@ -1532,22 +1532,19 @@ static int alloc_lpi_range(u32 nr_lpis, u32 *base) ...@@ -1532,22 +1532,19 @@ static int alloc_lpi_range(u32 nr_lpis, u32 *base)
static int free_lpi_range(u32 base, u32 nr_lpis) static int free_lpi_range(u32 base, u32 nr_lpis)
{ {
struct lpi_range *new; struct lpi_range *new;
int err = 0;
mutex_lock(&lpi_range_lock);
new = mk_lpi_range(base, nr_lpis); new = mk_lpi_range(base, nr_lpis);
if (!new) { if (!new)
err = -ENOMEM; return -ENOMEM;
goto out;
} mutex_lock(&lpi_range_lock);
list_add(&new->entry, &lpi_range_list); list_add(&new->entry, &lpi_range_list);
list_sort(NULL, &lpi_range_list, lpi_range_cmp); list_sort(NULL, &lpi_range_list, lpi_range_cmp);
merge_lpi_ranges(); merge_lpi_ranges();
out:
mutex_unlock(&lpi_range_lock); mutex_unlock(&lpi_range_lock);
return err; return 0;
} }
static int __init its_lpi_init(u32 id_bits) static int __init its_lpi_init(u32 id_bits)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment