Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp486591yba; Mon, 1 Apr 2019 10:15:43 -0700 (PDT) X-Google-Smtp-Source: APXvYqxUtqvOkAsgm9HEGUclJL5WOkhp+USyoHbja5JxdiSaLJh4H/hSZ5YkWoRDroZnqs0LPwPT X-Received: by 2002:a17:902:4101:: with SMTP id e1mr66812375pld.25.1554138943890; Mon, 01 Apr 2019 10:15:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554138943; cv=none; d=google.com; s=arc-20160816; b=AUcl+i3a8niqjbD8tkSu1o9UNO5PaFUswBJOqxNHSyVO2Ym11XkR1AexZIuzbGeDKk pEJ0GSEfTiO30yNJD1Iyqn9oTIMtaVq8RcUC50qe8qNjqWqNYBiwFgd60SKA0qzh9r1W m8XEs52phW2TN3hxdwCP3Ho4V2ikFGjSdDZsL727D/S4GkeASpXnODrcaOrMBiPm9wsb vPCimNS4xueQs8U462guGqL8tkcH0eCIIYVncrp49TzaF2bEaLcaRdZzVHiHCNHXqTv3 ZZNoe+wgqPf3N6JRgNZlqmh/f3xdc29PCZTH8zX5HVXHdhHNm8bZ51JBsg2BoGf8cGfZ 83wQ== 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:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=qf+tN0P0gzqPWbLZg1bBvhI5GYAkU3O2XAlPK1av9Vk=; b=KAmfXM/XwxQDFVD5nLmPQsvhcdKF7RZjhYjjlGcfFTAEDwwdraRR/F6r9NNeBRn+Sv KP6bXfpF17DZLhGa7ILHlfKsyBnmzK58cVhr2i2fJgcn6WhHAvVRXZ2r80VLBJzRg4NN Sw6pd3D8DJk9lWG+iB0p9ra2Vlovg5gS0c75nb8uyQ018X+trEthYvnlXJtNhIUf3JfC C8NHvqTBzag8cc5ax4Hh27FYRmqzRNzQ1XKtJhshAQIi0mJTGu68vn1nGmIPjg8Kd/Fb LD3C2NzOgnMYtMKfz7cJXgqYA6lDor5fLj7lbL2PZIbmyncJc5bHcZmlYiXrp0Z/s3rl 5gww== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=amsxN33E; 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 p15si8844820plr.254.2019.04.01.10.15.28; Mon, 01 Apr 2019 10:15:43 -0700 (PDT) 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.org header.s=default header.b=amsxN33E; 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 S1730824AbfDAROy (ORCPT + 99 others); Mon, 1 Apr 2019 13:14:54 -0400 Received: from mail.kernel.org ([198.145.29.99]:38514 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730518AbfDAROw (ORCPT ); Mon, 1 Apr 2019 13:14:52 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 9646D206C0; Mon, 1 Apr 2019 17:14:51 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1554138892; bh=v4SnPYip7eS41LLQfsW6h6FlEgHcvHrC5yAikLDAbMI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=amsxN33E1CLyP23gv2SuoQOAjCZSKfEG8bTf1GhYLQ59jC28paenF0Ew0zLMjXTTs dvDutJ95zP69W06j15cW0Q0oyp0CQJCk4DTCpYFyOR+hCh73Uj99L7ARd/Xn1rD02p 4Ig1L7q9QwvudQynZKoJBmeDr72jNt/7InGvjDWs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Kohji Okuno , Shawn Guo Subject: [PATCH 4.19 051/134] ARM: imx6q: cpuidle: fix bug that CPU might not wake up at expected time Date: Mon, 1 Apr 2019 19:01:27 +0200 Message-Id: <20190401170049.319161700@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190401170044.243719205@linuxfoundation.org> References: <20190401170044.243719205@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.19-stable review patch. If anyone has any objections, please let me know. ------------------ From: Kohji Okuno commit 91740fc8242b4f260cfa4d4536d8551804777fae upstream. In the current cpuidle implementation for i.MX6q, the CPU that sets 'WAIT_UNCLOCKED' and the CPU that returns to 'WAIT_CLOCKED' are always the same. While the CPU that sets 'WAIT_UNCLOCKED' is in IDLE state of "WAIT", if the other CPU wakes up and enters IDLE state of "WFI" istead of "WAIT", this CPU can not wake up at expired time. Because, in the case of "WFI", the CPU must be waked up by the local timer interrupt. But, while 'WAIT_UNCLOCKED' is set, the local timer is stopped, when all CPUs execute "wfi" instruction. As a result, the local timer interrupt is not fired. In this situation, this CPU will wake up by IRQ different from local timer. (e.g. broacast timer) So, this fix changes CPU to return to 'WAIT_CLOCKED'. Signed-off-by: Kohji Okuno Fixes: e5f9dec8ff5f ("ARM: imx6q: support WAIT mode using cpuidle") Cc: Signed-off-by: Shawn Guo Signed-off-by: Greg Kroah-Hartman --- arch/arm/mach-imx/cpuidle-imx6q.c | 27 ++++++++++----------------- 1 file changed, 10 insertions(+), 17 deletions(-) --- a/arch/arm/mach-imx/cpuidle-imx6q.c +++ b/arch/arm/mach-imx/cpuidle-imx6q.c @@ -16,30 +16,23 @@ #include "cpuidle.h" #include "hardware.h" -static atomic_t master = ATOMIC_INIT(0); -static DEFINE_SPINLOCK(master_lock); +static int num_idle_cpus = 0; +static DEFINE_SPINLOCK(cpuidle_lock); static int imx6q_enter_wait(struct cpuidle_device *dev, struct cpuidle_driver *drv, int index) { - if (atomic_inc_return(&master) == num_online_cpus()) { - /* - * With this lock, we prevent other cpu to exit and enter - * this function again and become the master. - */ - if (!spin_trylock(&master_lock)) - goto idle; + spin_lock(&cpuidle_lock); + if (++num_idle_cpus == num_online_cpus()) imx6_set_lpm(WAIT_UNCLOCKED); - cpu_do_idle(); - imx6_set_lpm(WAIT_CLOCKED); - spin_unlock(&master_lock); - goto done; - } + spin_unlock(&cpuidle_lock); -idle: cpu_do_idle(); -done: - atomic_dec(&master); + + spin_lock(&cpuidle_lock); + if (num_idle_cpus-- == num_online_cpus()) + imx6_set_lpm(WAIT_CLOCKED); + spin_unlock(&cpuidle_lock); return index; }