Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp7748894ybl; Tue, 24 Dec 2019 08:14:31 -0800 (PST) X-Google-Smtp-Source: APXvYqxG68g2ru4MduN33UwojRTH/mDVbMcwxNwV4Z+X/VYSkCyCFe8CGf8XgKhbNwdWjkPNLqaN X-Received: by 2002:a9d:6e03:: with SMTP id e3mr23824950otr.46.1577204071021; Tue, 24 Dec 2019 08:14:31 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1577204071; cv=none; d=google.com; s=arc-20160816; b=pgHLBNeOBUSw7ZWxrxoA0E/TlxqtNo4LLQTfohasS2b+ZC4c+iZVEQndsC9w9IykMF JiU62RfmBv2KfQalTDy2XGm4NhZtYNxnyny4N56eiYP/y0PtPfG7DA6kQP9jgd71Fjdu PR/et0262GJ7Z6mmbW9WTHUuO53PaV/wXjPkWOMxBLZ0gbY5wCNUuQcrLwfpAaRZ3ZCf ra2MgKpGTADvSo2cqILrRh3c6CHMsINS5EV76QitiwFO/nH/FkMs5Zhz/LjztFNZjuVC jVjibwELQEeKG1OurRmw9syVVpc5KNSpbLnLEDcanJyce5flZaEboOeIg4dYM5IX9Ub2 qeWg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=nMi7a9jSqUZMAu/b8TapOOHFxEObE8A/Xz8veWpg0BM=; b=YWDsC5F7urg58XwGp1JDp1+JHL55Oi2optwDQNfGPmkXnKcc/IgR/uJnKMngtWGgg+ 0AA9QGcLlo8ckc401o7Sd1t8IXYTl/ZjPrhBSxU9OovEHfMO141tiWPCqy/7FrMpWzAR yc4sUIIK0ht+qlNGqHofMwVYTfAg7H05uW4McB2m8bdXIyotZp3dFVnwGWeOW+Me/791 VSsLnLFHaD+zwU7Rn6TCLy4b/szJ8ONbN4PcTtbAzOIhwE1BhSNoGHljZBsW10tiCBrT t1faKcMl4jVW9RtM+bny+OgjnIAj/rfkrSU4AK0/3AGyBJef8oHqkaPYL7fjY+7zfruI JdFg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel-dk.20150623.gappssmtp.com header.s=20150623 header.b=nz81BWD2; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g6si11312412otk.171.2019.12.24.08.14.17; Tue, 24 Dec 2019 08:14:31 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel-dk.20150623.gappssmtp.com header.s=20150623 header.b=nz81BWD2; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726222AbfLXQNd (ORCPT + 99 others); Tue, 24 Dec 2019 11:13:33 -0500 Received: from mail-pj1-f65.google.com ([209.85.216.65]:35029 "EHLO mail-pj1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726178AbfLXQNd (ORCPT ); Tue, 24 Dec 2019 11:13:33 -0500 Received: by mail-pj1-f65.google.com with SMTP id s7so1395378pjc.0 for ; Tue, 24 Dec 2019 08:13:33 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=kernel-dk.20150623.gappssmtp.com; s=20150623; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=nMi7a9jSqUZMAu/b8TapOOHFxEObE8A/Xz8veWpg0BM=; b=nz81BWD2b0msWRjjlepOFGHqrgBHt0hep2ADeZWnWUkyZJjdlA3EQLMpF38mafIy5V H8hYU0DLpr0zG++oViAZrYUt56iJUwvOSGYoumm0Pr1GaWSwjVZVMhAJfpS3zUUG6rYd Trb7OPRwowEFY1WxLBo57NsIMTYS9crGaL75lsrJ60a550Er2AggeBzoaXfenrLI5pJl WdOnVU3Er87Qvlnq2WuWXsQlkgzgILhLo9eEOdEPOYaIxpDiM41a671lYIHfndBhxq6v ErFJ8W7CJfr2SeEvJ6Z7L+hLSRUApdjZPzawACw62S1pFTcQ2txOzQ9ZfvOgDHtzsK4a My8w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=nMi7a9jSqUZMAu/b8TapOOHFxEObE8A/Xz8veWpg0BM=; b=SINwy4+FTJWB5Ilp2Isxi/1lnD2C1oCId6qpnjrjAZiyVxl7VfscC1tEjNW5dIr6iI vT7uXv/XjYtCRg4+u8sLSOOI916A0Xmx30HfyZDYwx9Y3rCMQvzoeIo86u6fRajflJ+Y kDw7x0bXFsnD7bAfhH53zB9NyOu8PCR0NAXKsbjc2OG4ho57IQkwGDhfPB8fmva32hMe eR7Fa5kzcQDc4g7HF3CY5BZR+ZlLt3p9zQnsx9q2yeITi0lhDASJIFjYXoSYn3iqvun4 rWEh11hYLcTnzQ49VXpuxwJWOdPAOwSCn5kVFF+AabtTE+f8S6K/O4OafTOtusKMG8Eo 4aFQ== X-Gm-Message-State: APjAAAUjcdtdtdGphV/0iWqBhdL17Bf0ou2VgcHIFM8J3uHhsz9D7b6p p6kfNcLzEb4d1JXJfcY4DqA0AxsgU0Y22w== X-Received: by 2002:a17:90a:1b4d:: with SMTP id q71mr6679503pjq.82.1577204012697; Tue, 24 Dec 2019 08:13:32 -0800 (PST) Received: from [192.168.1.188] ([66.219.217.145]) by smtp.gmail.com with ESMTPSA id s131sm9738627pfs.135.2019.12.24.08.13.31 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 24 Dec 2019 08:13:32 -0800 (PST) Subject: Re: [RFC PATCH] io-wq: kill cpu hog worker To: Hillf Danton Cc: io-uring@vger.kernel.org, viro@zeniv.linux.org.uk, linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org, linux-mm References: <20191223024145.11580-1-hdanton@sina.com> <20191224115415.1360-1-hdanton@sina.com> From: Jens Axboe Message-ID: Date: Tue, 24 Dec 2019 09:13:30 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.2.2 MIME-Version: 1.0 In-Reply-To: <20191224115415.1360-1-hdanton@sina.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 12/24/19 4:54 AM, Hillf Danton wrote: > > On Mon, 23 Dec 2019 08:15:00 -0700 Jens Axboe wrote: >> >> On 12/22/19 7:41 PM, Hillf Danton wrote: >>> >>> Reschedule the current IO worker if it is becoming a cpu hog. >> >> Might make more sense to put this a bit earlier, to avoid the >> awkward lock juggle. In theory it shouldn't make a difference >> if we do it _before_ doing new work, or _after_ doing work. We >> should only be rescheduling if it's running for quite a while. >> >> How about putting it after the flushing of signals instead? > > > All right, thanks. > > Hillf > --->8--- > From: Hillf Danton > Subject: [RFC PATCH] io-wq: kill cpu hog worker > > Reschedule the current IO worker to cut the risk that it is becoming > a cpu hog. > > Signed-off-by: Hillf Danton > --- > > --- a/fs/io-wq.c > +++ b/fs/io-wq.c > @@ -432,6 +432,8 @@ next: > if (signal_pending(current)) > flush_signals(current); > > + cond_resched(); > + > spin_lock_irq(&worker->lock); > worker->cur_work = work; > spin_unlock_irq(&worker->lock); > -- That looks better, applied. -- Jens Axboe