Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp69435imm; Thu, 31 May 2018 18:48:05 -0700 (PDT) X-Google-Smtp-Source: ADUXVKJS+y+IqebtoJtCEUj+HzEWZInqUXyBxlPwdSoReVvQyOrf+2wVj853asRPzUqRDw3G3bvO X-Received: by 2002:a62:18d6:: with SMTP id 205-v6mr8996465pfy.242.1527817685061; Thu, 31 May 2018 18:48:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527817685; cv=none; d=google.com; s=arc-20160816; b=u1Vcl85EsH9VjpaRO+RHdZJJT2dvsvLEwGaHxDn9DpMsgKscRTsUcDstpgxrLxY46D 5k1GN5C/ts1afInpRrWoujCICDSw7gf6Ibk33GPduPjhf40RYut9OjJRhvOzUEGGwxA6 HOVkVl99fvIyzTG+bB0T7JhU+sgTNrd7wkaFE+Sr0d8KtmJ2nlI0+a2JzW+2ZIRCWm0H 49XobuE9H9ByquxipJFZjsCC1644MzjQx5DoemiKjCdFM6NnJ4pT+iXOzAvSZb0e8qcR tfWtNcmOceq3uqeH7ZOSwUGgQEkz3X7QZBBoZejX/rKy+qIlO55JfMEq6OjldIYI1fJl ucRQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature :arc-authentication-results; bh=NE3ZTz/5u0H/l+z1pRolZ3MDJch8615NsrtA0l9Wvf8=; b=ZSy308wll8RwCO9555C6Sw8TIP9mARqLy3P7IhRvqGUfPzE5DuR7vo+LwyWP8Dfzne lSyp6o88BvC5sNQQBKuXxnspzFqkufJHLEI3Iw0miQ8NAmgD6NtsjNjwj2GbM+Hk72p9 dkJ+x/MfD2bHJLDQxNgTwPIft+zLh1mvHdENC6vyoxSKz4P+9Uj9U69q1mKWm0MTMChw fAjo3DNIqECk1Qx1Co/yTsfLPIl3poOGwTW8RGxZ8lUQyhljPFo8JaE6eSKkjGXcQHVk kTKmGzzYlcohBpnGRL7vpd7gudF/BtAmgYSwib67SI5robBlZEFX46tKxBVaWZv3UMxX 8gkQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=YSCInAux; 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 t5-v6si38576697plo.113.2018.05.31.18.47.50; Thu, 31 May 2018 18:48:05 -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=YSCInAux; 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 S1750793AbeFABq2 (ORCPT + 99 others); Thu, 31 May 2018 21:46:28 -0400 Received: from mail-qt0-f194.google.com ([209.85.216.194]:45296 "EHLO mail-qt0-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750711AbeFABq0 (ORCPT ); Thu, 31 May 2018 21:46:26 -0400 Received: by mail-qt0-f194.google.com with SMTP id i18-v6so19679304qtp.12; Thu, 31 May 2018 18:46:25 -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-transfer-encoding:content-language; bh=NE3ZTz/5u0H/l+z1pRolZ3MDJch8615NsrtA0l9Wvf8=; b=YSCInAuxq5+f/NqOEq3qxKTF3A/SB4PT7qKeafXforao76dgFVVJLgXVNhCpnk5FM+ aGa68RFQzG1uPc0kbUhxsnUNKR16caTS2QcLzndeRcBnZzm1I3cFYbYUks3VvXMU1DVJ +2x93EFC8XgNtEPce0zZ5gHd2d7X+oT4+XV3eaGFgHKn7gx2Tsb+FyBxM4M6KxDLgyds grtf3d/CToiRSdNvW2sdVj7bwAxft+gfZl8Z6vyoiKxpA0MTGevs2fwINQYYUGuuAFVR tF+v921X5VNdsPmMpdHsfYQxlCyI+/5JnmC2XIkWLHMXHvg1oKuIp0LgTFMQGpyg5dy2 X6HQ== 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-transfer-encoding :content-language; bh=NE3ZTz/5u0H/l+z1pRolZ3MDJch8615NsrtA0l9Wvf8=; b=sNVQ0mb6quJjfAbWWBaTE9C9KR/exEXXYxETMRGEzs/u0+5CXycNVYU/LVx/kjmWxa aX2ZQArvFJ7MVhDnGiLG+Gt3PsmUA2MwOCks9m6U8153z0YA1RYDzf05yFMC1I2B4Duc VH6/M0rY7ziB3WYtuegqRyd8Wv9bY7ZSDyC96zJQcXX00rynOOc/ym/jRxzvbofnKMw6 OabV9AMAPXtAY6weGIbjJtP0t9aiM/yCnT1qkVYX+V3q1pw5h6GvpwdHeriLBm/p/ghb pqRCHqR7+PmYSqVCZVmscitNMbz/6s5U/6t1uZk8nLHKBceu/1A38WorTKVyGx0XpY45 J37w== X-Gm-Message-State: APt69E3XaA/pXXsShBy1iav20NzjMdz8ooepD5mHxsGgo6TdP/205L+w MrYzy6d77+TPRp+y+Bb3tjo= X-Received: by 2002:aed:3ac3:: with SMTP id o61-v6mr9363360qte.335.1527817585414; Thu, 31 May 2018 18:46:25 -0700 (PDT) Received: from [192.168.1.54] (c-24-5-209-231.hsd1.ca.comcast.net. [24.5.209.231]) by smtp.gmail.com with ESMTPSA id q8-v6sm25690310qtp.2.2018.05.31.18.46.23 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 31 May 2018 18:46:24 -0700 (PDT) Subject: Re: [PATCH] clk: vc5: Fix div-by-0 when rounding a rate of zero To: Marek Vasut , Steve Longerbeam , Michael Turquette , Stephen Boyd Cc: linux-clk@vger.kernel.org, linux-kernel@vger.kernel.org, Laurent Pinchart , Kieran Bingham References: <1527791036-11251-1-git-send-email-steve_longerbeam@mentor.com> <1084deae-ca55-aba1-ec08-7e1d976de7b7@gmail.com> <59591484-b76d-6764-73c3-637bb4e5178f@mentor.com> <06fd7d17-5c31-4ac5-d923-276afee056b3@gmail.com> From: Steve Longerbeam Message-ID: <4f4f8a11-9239-3c24-f136-1ad0617a992a@gmail.com> Date: Thu, 31 May 2018 18:46:21 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.8.0 MIME-Version: 1.0 In-Reply-To: <06fd7d17-5c31-4ac5-d923-276afee056b3@gmail.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 05/31/2018 12:37 PM, Marek Vasut wrote: > On 05/31/2018 08:52 PM, Steve Longerbeam wrote: >> >> On 05/31/2018 11:35 AM, Marek Vasut wrote: >>> On 05/31/2018 08:32 PM, Steve Longerbeam wrote: >>>> Hi Marek, >>>> >>>> >>>> On 05/31/2018 11:25 AM, Marek Vasut wrote: >>>>> On 05/31/2018 08:23 PM, Steve Longerbeam wrote: >>>>>> Just return zero for a rounded rate if requested rate is zero. >>>>>> >>>>>> This was caught by CONFIG_UBSAN: >>>>>> >>>>>> [  192.266748] UBSAN: Undefined behaviour in >>>>>> drivers/clk/clk-versaclock5.c:513:17 >>>>>> [  192.274050] division by zero >>>>>> [  192.276976] CPU: 0 PID: 2579 Comm: vsp-unit-test-0 Tainted: G >>>>>> B   WC      4.14.17-02752-g13fb96f #1 >>>>>> [  192.286378] Hardware name: Renesas Salvator-X board based on >>>>>> r8a7795 ES2.0+ (DT) >>>>>> [  192.293852] Call trace: >>>>>> [  192.296343] [] dump_backtrace+0x0/0x390 >>>>>> [  192.301807] [] show_stack+0x14/0x1c >>>>>> [  192.306920] [] dump_stack+0x134/0x1a8 >>>>>> [  192.312213] [] ubsan_epilogue+0x14/0x60 >>>>>> [  192.317677] [] >>>>>> __ubsan_handle_divrem_overflow+0x11c/0x170 >>>>>> [  192.324720] [] vc5_fod_round_rate+0x68/0x148 >>>>>> [  192.330620] [] clk_calc_new_rates+0x238/0x3fc >>>>>> [  192.336607] [] clk_calc_new_rates+0x29c/0x3fc >>>>>> [  192.342595] [] >>>>>> clk_core_set_rate_nolock+0x48/0x11c >>>>>> [  192.349019] [] clk_set_rate+0x34/0x4c >>>>>> [  192.354307] [] rcar_du_pm_suspend+0x274/0x2f4 >>>>>> [  192.360297] [] platform_pm_suspend+0x78/0xb8 >>>>>> [  192.366198] [] dpm_run_callback+0x584/0xa18 >>>>>> [  192.372010] [] __device_suspend+0x1a8/0x534 >>>>>> [  192.377822] [] dpm_suspend+0x130/0xea0 >>>>>> [  192.383197] [] dpm_suspend_start+0x130/0x138 >>>>>> [  192.389099] [] >>>>>> suspend_devices_and_enter+0xf0/0x1778 >>>>>> [  192.395700] [] pm_suspend+0x2408/0x245c >>>>>> [  192.401162] [] state_store+0xf0/0x130 >>>>>> [  192.406451] [] kobj_attr_store+0x5c/0x6c >>>>>> [  192.412002] [] sysfs_kf_write+0xe8/0xfc >>>>>> [  192.417466] [] kernfs_fop_write+0x22c/0x2e4 >>>>>> [  192.423281] [] __vfs_write+0x104/0x34c >>>>>> [  192.428656] [] vfs_write+0x134/0x2d8 >>>>>> [  192.433857] [] SyS_write+0xbc/0x12c >>>>>> [  192.438967] Exception stack(0xffff8006cd1cfec0 to >>>>>> 0xffff8006cd1d0000) >>>>>> [  192.445480] fec0: 0000000000000001 000000001e303f00 >>>>>> 0000000000000004 0000ffff959a5000 >>>>>> [  192.453397] fee0: 0000000000000000 0000000155510004 >>>>>> 0000000000000003 000000000000006d >>>>>> [  192.461314] ff00: 0000000000000040 0000000000000000 >>>>>> 0000ffffcc304800 0000000000000020 >>>>>> [  192.469230] ff20: 0000000000000000 0000000000000000 >>>>>> 0000000000000001 0000000000000008 >>>>>> [  192.477148] ff40: 00000000004eb3b8 0000ffff958bb840 >>>>>> 000000000000003d 0000000000000001 >>>>>> [  192.485065] ff60: 000000001e303f00 0000ffff959a1508 >>>>>> 0000000000000004 000000001e303f00 >>>>>> [  192.492982] ff80: 0000000000000004 00000000004d4c68 >>>>>> 0000000000000001 0000000000000000 >>>>>> [  192.500899] ffa0: 000000001e30d5c0 0000ffffcc304820 >>>>>> 0000ffff958bec64 0000ffffcc304820 >>>>>> [  192.508816] ffc0: 0000ffff95912898 0000000020000000 >>>>>> 0000000000000001 0000000000000040 >>>>>> [  192.516733] ffe0: 0000000000000000 0000000000000000 >>>>>> 0000000000000000 0000000000000000 >>>>>> [  192.524650] [] el0_svc_naked+0x24/0x28 >>>>>> >>>>>> Signed-off-by: Steve Longerbeam >>>>>> --- >>>>>>    drivers/clk/clk-versaclock5.c | 4 ++++ >>>>>>    1 file changed, 4 insertions(+) >>>>>> >>>>>> diff --git a/drivers/clk/clk-versaclock5.c >>>>>> b/drivers/clk/clk-versaclock5.c >>>>>> index decffb3..113523d 100644 >>>>>> --- a/drivers/clk/clk-versaclock5.c >>>>>> +++ b/drivers/clk/clk-versaclock5.c >>>>>> @@ -509,6 +509,10 @@ static long vc5_fod_round_rate(struct clk_hw >>>>>> *hw, unsigned long rate, >>>>>>        u32 div_int; >>>>>>        u64 div_frc; >>>>>>    +    /* prevent div-by-0 */ >>>>>> +    if (rate == 0) >>>>>> +        return 0; >>>>>> + >>>>>>        /* Determine integer part, which is 12 bit wide */ >>>>>>        div_int = f_in / rate; >>>>>>        /* >>>>>> >>>>> Can this actually happen ? >>>> We caught this using the Renesas 3.6.0 BSP release, when performing >>>> a suspend of rcar-du driver. The rcar_du_pm_suspend() in 3.6.0 BSP is >>>> modified >>>> from mainline version, including calling clk_set_rate() on the crtc >>>> clocks with a >>>> rate of zero. So this is not actually reproducible (yet) in mainline. >>> So it sets clock to 0 ? >> Yep, see >> >> https://kernel.googlesource.com/pub/scm/linux/kernel/git/horms/renesas-bsp/+/rcar-3.6.0/drivers/gpu/drm/rcar-du/rcar_du_drv.c#359 >> >> >>>   Anyway, this looks sane, although maybe the >>> whole driver could use a once-over to see if there could be more of this. >> Actually I do see more potential divide-by-zeros due to a passed rate >> of zero, including vc5_pfd_round_rate() and vc5_pfd_set_rate(). >> >> I can resubmit this patch fixing all cases in clk-versaclock5.c if you >> like (and probably remove the misleading backtrace in the commit >> message since it is a Renesas 3.6.0 kernel backtrace not a mainline >> backtrace). >> >> Or perhaps just treat this as a heads-up, I'll leave it up to you. > It'd be nice if you resubmitted it fixing all the cases. > Ok. Please disregard this patch since there won't be a v2, the new patch will have a different title. Steve