> > @@ -202,15 +199,27 @@ static long region_chg(struct resv_map *resv, long f, long t) > > * Subtle, allocate a new region at the position but make it zero > > * size such that we can guarantee to record the reservation. */ > > if (&rg->link == head || t < rg->from) { > > - nrg = kmalloc(sizeof(*nrg), GFP_KERNEL); > > - if (!nrg) > > - return -ENOMEM; > > + if (!nrg) { > > + nrg = kmalloc(sizeof(*nrg), GFP_NOWAIT); > > + if (!nrg) { > > + spin_unlock(&resv->lock); > > + nrg = kmalloc(sizeof(*nrg), GFP_KERNEL); > > + if (!nrg) { > > + chg = -ENOMEM; > > + goto out; > > Just return -ENOMEM here. Okay. It looks better! > > > + } > > + goto retry; > > + } > > + } > > + > > You seem to be right, at least in my workloads, the hold times for the > region lock is quite small, so a spinlock is better than a sleeping > lock. > > That said, this code is quite messy, but I cannot think of a > better/cleaner approach right now. Okay. Thanks for review! -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>