lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <9024c612-670e-7220-6883-352c786b0b1e@codeaurora.org>
Date:	Fri, 5 Aug 2016 12:49:04 +0530
From:	"Khan, Imran" <kimran@...eaurora.org>
To:	Akinobu Mita <akinobu.mita@...il.com>
Cc:	"\"axboe"@kernel.dk, axboe@...com, hch@....de,
	"tom.leiming\""@gmail.com, "\"linux-block"@vger.kernel.org,
	"\"linux-kernel\\\"\"@vger.kernel.org;tsoni"@codeaurora.org
Subject: Re: [Query] increased latency observed in cpu hotplug path

On 8/1/2016 2:58 PM, Khan, Imran wrote:
> On 7/30/2016 7:54 AM, Akinobu Mita wrote:
>> 2016-07-28 22:18 GMT+09:00 Khan, Imran <kimran@...eaurora.org>:
>>>
>>> Hi,
>>>
>>> Recently we have observed some increased latency in CPU hotplug
>>> event in CPU online path. For online latency we see that block
>>> layer is executing notification handler for CPU_UP_PREPARE event
>>> and this in turn waits for RCU grace period resulting (sometimes)
>>> in an execution time of 15-20 ms for this notification handler.
>>> This change was not there in 3.18 kernel but is present in 4.4
>>> kernel and was introduced by following commit:
>>>
>>>
>>> commit 5778322e67ed34dc9f391a4a5cbcbb856071ceba
>>> Author: Akinobu Mita <akinobu.mita@...il.com>
>>> Date:   Sun Sep 27 02:09:23 2015 +0900
>>>
>>>     blk-mq: avoid inserting requests before establishing new mapping
>>
>> ...
>>
>>> Upon reverting this commit I could see an improvement of 15-20 ms in
>>> online latency. So I am looking for some help in analyzing the effects
>>> of reverting this or should some other approach to reduce the online
>>> latency must be taken.
>>
>> Can you observe the difference in online latency by removing
>> get_online_cpus() and put_online_cpus() pair in blk_mq_init_allocated_queue()
>> instead of full reverting the commit?
>>
> Hi Akinobu,
> I tried your suggestion but could not achieve any improvement. Actually the snippet that is causing the change in latency is the following one :
> 
> list_for_each_entry(q, &all_q_list, all_q_node) {
>                 blk_mq_freeze_queue_wait(q);
> 
>                 /*
>                  * timeout handler can't touch hw queue during the
>                  * reinitialization
>                  */
>                 del_timer_sync(&q->timeout);
>  }
> 
> I understand that this is getting executed now for CPU_UP_PREPARE as well resulting in 
> increased latency in the cpu online path. I am trying to reduce this latency while keeping the 
> purpose of this commit intact. I would welcome further suggestions/feedback in this regard.
> 
Hi Akinobu,

I am not able to reduce the cpu online latency with this patch, could you please let me know what
functionality will be broken, if we avoid this patch in our kernel. Also if you have some other 
suggestions towards improving this patch please let me know.

-- 
Imran Khan
QUALCOMM INDIA, on behalf of Qualcomm Innovation Center, Inc. is a\nmember of the Code Aurora Forum, hosted by The Linux Foundation

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ