On Saturday, January 27, 2018 5:44 AM, Michael S. Tsirkin wrote: > On Fri, Jan 26, 2018 at 05:00:09PM +0200, Michael S. Tsirkin wrote: > > On Fri, Jan 26, 2018 at 11:29:15AM +0800, Wei Wang wrote: > > > On 01/25/2018 09:41 PM, Michael S. Tsirkin wrote: > > > > On Wed, Jan 24, 2018 at 06:42:41PM +0800, Wei Wang wrote: > > > 2) If worse, all the blocks have been split into smaller blocks and > > > used after the caller comes back. > > > > > > where could we continue? > > > > I'm not sure. But an alternative appears to be to hold a lock and just > > block whoever wanted to use any pages. Yes we are sending hints > > faster but apparently something wanted these pages, and holding the > > lock is interfering with this something. > > I've been thinking about it. How about the following scheme: > 1. register balloon to get a (new) callback when free list runs empty 2. take > pages off the free list, add them to the balloon specific list 3. report to host 4. > readd to free list at tail 5. if callback triggers, interrupt balloon reporting to > host, > and readd to free list at tail So in step 2, when we walk through the free page list, take each block, and add them to the balloon specific list, is this performed under the mm lock? If it is still under the lock, then what would be the difference compared to walking through the free list, and add each block to virtqueue? Best, Wei -- 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