Received: by 2002:ac0:aa62:0:0:0:0:0 with SMTP id w31-v6csp428823ima; Wed, 24 Oct 2018 03:45:40 -0700 (PDT) X-Google-Smtp-Source: AJdET5eQdmwlXHUOp6DLIKtvxmrqtPTENpR0yxLhvITpBayf/htIVZ7neupo1Om7PdYHZm9Y60Za X-Received: by 2002:a63:e943:: with SMTP id q3-v6mr2052506pgj.42.1540377940374; Wed, 24 Oct 2018 03:45:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1540377940; cv=none; d=google.com; s=arc-20160816; b=cK2lSujKHQ8xAnmqe6hSOCHFSXYEOP8PxzgtfBUD1IhwPA+x7ZLQMNk6oC6vVdIPK6 VpBCURk16m199yoVtiUyNlEXIYNjmOgTWSadNVgjWnmyatHVCcH6ULbpI7U3fA65MNZP xRkErt8f5DdtOY4nAPyYmuQhyyqdkdlEfGdqcFGswuYK6RwpiqGf/8eTgzMUUR+DXHxn LLZNuOqzV/g/RgOcJJTKDvDAmv/ByZdWPoVEDJGRFLE2CexBGkuw1vOGAEgT7HkiGgKI HXU+wh37KROu7ur715mn8EPOlramQlAXmOIFQWYCq8R3qsavISmeC6t+MPP2uwyvebwG qdRQ== 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=FgNH7x+HdWoLNCbXpAubZjrLmkp3dLcitNiZp2XiluI=; b=KUIiiFI2MufdD3pjZJLTZSKpdSiVsT3Ns6tdRCZsGSM1ldWtbYKBF6Iw/zsi3NK962 8Za4IhkRF5Z/qtThabYA1FABlN+H4Zjlgs73WFwuUrQ2k7DUYOgEXDp4o0MCY8FL+faM mm5AkLGjzSOOrBc1myCMtrVw4Gh2t2cxLSGm9r385aM2cB6U8jb72DuZmh7ivPJxYVKL 3GO6DvOm199xnS5GI51BmtBavJR4vdrcTMqrfgkaxJcsctlw7ippQ4p8PrmRMzshb2Up 7yt1FYMO+jB19Z2TpxyHsLvuCZiqIGzrDouTLLhFpQmedTm6tId7E6us94iTkC0/esXU 74lQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=HS6khBw0; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id z4-v6si4501383pgj.39.2018.10.24.03.45.24; Wed, 24 Oct 2018 03:45:40 -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=@gmail.com header.s=20161025 header.b=HS6khBw0; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727420AbeJXTMg (ORCPT + 99 others); Wed, 24 Oct 2018 15:12:36 -0400 Received: from mail-it1-f196.google.com ([209.85.166.196]:35972 "EHLO mail-it1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726428AbeJXTMf (ORCPT ); Wed, 24 Oct 2018 15:12:35 -0400 Received: by mail-it1-f196.google.com with SMTP id c85-v6so5976205itd.1; Wed, 24 Oct 2018 03:44:59 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=FgNH7x+HdWoLNCbXpAubZjrLmkp3dLcitNiZp2XiluI=; b=HS6khBw0K0mJrLDUCtVd8TM5xBa0pxB2DyADvqGaTLn/2K9oZQFJY0jkkkth8cmdw+ eJVpQfxt6cS8K4V/dq/bAkj3WLwO7RYEzrC6KGdAVRGcj3tBPZ+E7R3yQe//zxtRPXnN nwdEfgC7kS9zesXFSsx9p0UYJmoKVJ0Aufv7kCiS87H9Z984fn8Di9pBJFdqJ5dWHpvs /TTynacu8bSEXfOxq3jg+nGPfairSHZFqsd482f/+U3H73PVP+433aAaStHaDUi5tKI6 6+0d9ADjci98mP1eefywU6KI3dNkAo246KyXfp/ZQ0GX3bwEtgkx5hNG1gHDDlPnh0rW TVGw== 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=FgNH7x+HdWoLNCbXpAubZjrLmkp3dLcitNiZp2XiluI=; b=bd9Jpqw9p5qWNiCl3ZHIVtNiWqmN311Hh1p1B+2PKbeAXSVsUFC86CUYaGSGKpXXJD mUdBc+sRla7ET3JFrip4GXWjdLqZ5NnqwbnWzNUZ5PIHI44yHJdM70HkU5snTkrYhW+f JN2WqhWInqb3oQWuYKhrBf3MvWZsziPOLDFg8TczH8zXWuDa24BSWUuGbPRHHTwkhTw4 HWg/nrvBTF7aW6tZ/K+53BLLkmw906WhH69lr49On3EVXZIJUpqxahuXLS377DYqoSPz 1iAGxn90DHREvepXUlYB7oUmwPnSLyp1xDohqC8m/xhUUwHi6JPMvvaD33QlvUvWqWAB /+7g== X-Gm-Message-State: AGRZ1gIPwy+RT4R3LfY1wNK4WXJkrBTquXn4FwYRdbZK3OWSxs8Z3OZg LlZ2Cp8VCMfUF13x85G/1LdCSdIS X-Received: by 2002:a02:4c2:: with SMTP id 185-v6mr1351721jab.48.1540377898759; Wed, 24 Oct 2018 03:44:58 -0700 (PDT) Received: from [192.168.2.145] (109-252-91-118.nat.spd-mgts.ru. [109.252.91.118]) by smtp.googlemail.com with ESMTPSA id x7sm2021112itj.14.2018.10.24.03.44.54 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 24 Oct 2018 03:44:58 -0700 (PDT) Subject: Re: [PATCH v1] soc/tegra: pmc: Drop locking from tegra_powergate_is_powered() To: Jon Hunter , Thierry Reding Cc: linux-tegra@vger.kernel.org, linux-kernel@vger.kernel.org References: <20181021183614.454-1-digetx@gmail.com> <4c318e6b-4841-dd52-d61d-1106c5f8afbc@nvidia.com> From: Dmitry Osipenko Message-ID: <11fc94af-efe2-e571-3163-efdaa91f34fc@gmail.com> Date: Wed, 24 Oct 2018 13:44:32 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.0 MIME-Version: 1.0 In-Reply-To: <4c318e6b-4841-dd52-d61d-1106c5f8afbc@nvidia.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 10/24/18 1:20 PM, Jon Hunter wrote: > > On 21/10/2018 19:36, Dmitry Osipenko wrote: >> This fixes splats like the one below if CONFIG_DEBUG_ATOMIC_SLEEP=y >> and machine (Tegra30) booted with SMP=n or all secondary CPU's are put >> offline. Locking isn't needed because it protects atomic operation. >> >> # echo 0 | tee /sys/devices/system/cpu/cpu[1-3]/online >> >> BUG: sleeping function called from invalid context at kernel/locking/mutex.c:254 >> in_atomic(): 1, irqs_disabled(): 128, pid: 0, name: swapper/0 >> CPU: 0 PID: 0 Comm: swapper/0 Tainted: G C 4.18.0-next-20180821-00180-gc3ebb6544e44-dirty #823 >> Hardware name: NVIDIA Tegra SoC (Flattened Device Tree) >> [] (unwind_backtrace) from [] (show_stack+0x20/0x24) >> [] (show_stack) from [] (dump_stack+0x94/0xa8) >> [] (dump_stack) from [] (___might_sleep+0x13c/0x174) >> [] (___might_sleep) from [] (__might_sleep+0x70/0xa8) >> [] (__might_sleep) from [] (mutex_lock+0x2c/0x70) >> [] (mutex_lock) from [] (tegra_powergate_is_powered+0x44/0xa8) >> [] (tegra_powergate_is_powered) from [] (tegra30_cpu_rail_off_ready+0x30/0x74) >> [] (tegra30_cpu_rail_off_ready) from [] (tegra30_idle_lp2+0xa0/0x108) >> [] (tegra30_idle_lp2) from [] (cpuidle_enter_state+0x140/0x540) >> [] (cpuidle_enter_state) from [] (cpuidle_enter+0x40/0x4c) >> [] (cpuidle_enter) from [] (call_cpuidle+0x30/0x48) >> [] (call_cpuidle) from [] (do_idle+0x238/0x28c) >> [] (do_idle) from [] (cpu_startup_entry+0x28/0x2c) >> [] (cpu_startup_entry) from [] (rest_init+0xd8/0xdc) >> [] (rest_init) from [] (start_kernel+0x41c/0x430) >> >> Signed-off-by: Dmitry Osipenko >> --- >> drivers/soc/tegra/pmc.c | 2 -- >> 1 file changed, 2 deletions(-) >> >> diff --git a/drivers/soc/tegra/pmc.c b/drivers/soc/tegra/pmc.c >> index 1fa840e3d930..1714cd818d69 100644 >> --- a/drivers/soc/tegra/pmc.c >> +++ b/drivers/soc/tegra/pmc.c >> @@ -543,9 +543,7 @@ int tegra_powergate_is_powered(unsigned int id) >> if (!tegra_powergate_is_valid(id)) >> return -EINVAL; >> >> - mutex_lock(&pmc->powergates_lock); >> status = tegra_powergate_state(id); >> - mutex_unlock(&pmc->powergates_lock); >> >> return status; > > Can we just ... > > return tegra_powergate_state(id); We can, but it is not necessary. Feel free to adjust the code as you wish while applying ;) I deliberately left the 'status' variable because I think that makes code a bit more expressive.