Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp481406yba; Mon, 1 Apr 2019 10:09:54 -0700 (PDT) X-Google-Smtp-Source: APXvYqz07rgvvuRfrE7a55ynefGxThiGHzzfyGJ/qdSzmJ3JNp9y0wqdFJtqnaiYjU381D9fX2uL X-Received: by 2002:a63:cc0a:: with SMTP id x10mr49361649pgf.179.1554138594291; Mon, 01 Apr 2019 10:09:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554138594; cv=none; d=google.com; s=arc-20160816; b=JkRtO+MZluyiHolesajSOdjt5zUwln98dypBzOEYf/Bl/ZfamsTyoXA1xYNn92o+jv 3j8bUtUPE5t1mBHiJA9PLBSsCNE7Jh99JPe1G2yeIH+aYCd6B0LLHjRJwNFaip23dUfW 6tAwCTZj3SMAGkTAYzJ0uJU4CkjQ/jTwESc+1yxpYNkz5SX5tTCvKrtHhYX9bE6TkwsU qLRruf5X0Q/KCqPEKe2WTFpGXftu1nq11KFwh0vPTFbssfVebM6iAZ2UKfhlIFefeoOF ylWKa2vtmpOZChacC+JBfOVfM4UHQp5kG0+sPcLrK1HiNqVsEyTago0GrrpNq4s04KH6 bAaA== 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=olHzCJfrthmeZrY6phVJpBXzQywQ7g8OM3f7B6AkQwI=; b=0t3m8I9Y4LCFgQf0CEjMVl9XwVrJzQ9IbXFEFCLJ1S4j/FRfbtvrrdxymH3FaaD3RO W4w8sQk+LpFRiSylNE2Oe0OAxsvZ1H0pLuYEIuctAlNbw9oNdCdvmaIl96pTpP5V2OOV h2jdsooEwHKKsbmmfCtil4qiQdOo318CGVdXjX08YE9O+HT2NrYlU5IZomv4fRI9Z9Vj 1ACuMrlIoU++4WEX86B5iZvZ0S9smrcW/KVHQ8Wmb/xwYrFAE99fYegzHYB6Bm+Hdt3b Sdlad4dSXGJcZ8XBehz570bH8R8kMtmO9kY+hd1ZBZ751qYjrZxT/bLCFsG3C+S+0JaF tffg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=uWW+V8re; 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 a3si9554587pln.353.2019.04.01.10.09.39; Mon, 01 Apr 2019 10:09:54 -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=uWW+V8re; 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 S1729622AbfDARIW (ORCPT + 99 others); Mon, 1 Apr 2019 13:08:22 -0400 Received: from mail.kernel.org ([198.145.29.99]:54882 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729613AbfDARIV (ORCPT ); Mon, 1 Apr 2019 13:08:21 -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 194CF21929; Mon, 1 Apr 2019 17:08:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1554138500; bh=Q9z6vPI0tP0u4ZBPtR8Q0zwE2ZQ2fjstHnyVknfUc6I=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=uWW+V8reu8BfwSDU7L9p1TAKjmh608aYnoOIsn7y0hAd4mMWNVYx2RpbiVj+UNgOG MtjMPMoHwhMkAbnpPWOM/lQOduZKaCA4niBg5VNCPr16k7bVV9ZS5ijFPVfKVevlvY M0qnxidyM8SNUUi1ZmCDbHahs+oy3tEehLtfboBw= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Kohji Okuno , Shawn Guo Subject: [PATCH 5.0 047/146] ARM: imx6q: cpuidle: fix bug that CPU might not wake up at expected time Date: Mon, 1 Apr 2019 19:00:59 +0200 Message-Id: <20190401170052.555886143@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190401170048.449559024@linuxfoundation.org> References: <20190401170048.449559024@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 5.0-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; }