Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp1386401pxf; Fri, 26 Mar 2021 07:01:09 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzw3GdinZ7UgZsNlOt93pDwYBEP1eUJyKiWZ46ovUumeYaDxOk9hhP67VlFxXKJVtEHJA81 X-Received: by 2002:a17:906:6044:: with SMTP id p4mr15637264ejj.82.1616767268662; Fri, 26 Mar 2021 07:01:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616767268; cv=none; d=google.com; s=arc-20160816; b=UA9ZwHEXNwmkDWI5O4RN6iSXZT+vjbefPL1ifF7MXVx3ay7SHDVpkpnaGhu6eJ/+5n e8BTbp6scHVtbXIsEEHFGdj/e8/D4I0PiY9rwQTlqjdsZ0RNkUK1zW1iNUJtKhn3ogvh 4fKZ+Tlv1vIgNPoZMYndC5n7ainKfZ/SgnyGyRb1v8pW4rCYUeFqB0nABf9FQ89tWUM2 U64tYjCQ0wkBCljWjvmqHLQw6UMV+IMr7R53aXn9MIWusvwsulcX2qZcL1iIoiK3sN67 TzLCNK7JPAAj728G7HFSRveYqh+t+9Qr3MaFOXpDmuaocDCZtElYzarCXHXTlBx7fwQI b3SQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=Pve1RvKoSiNiV6NwjrWliiaqMKE71p0JKmuphiR47gE=; b=qf5aZiLwUyIMAT4N4gFq7MQTGrsxAe4ugmvvxqszNrzYKTb+UU+qBfSL6MR/ZdtVVN CvSqr1+NyCYUimLhEYemrylKqgnWz/KlOgSfP5vixbaCmwv/z7+UnAT6RA5L4fTL1H5F fHeBfD0/5QSljxu2QwKIzW2H6jsrcql2LxX7qxsCspp6pnInfZ78bnED6lXhKS4fdiqP zNmEGaj147AR7101ow0Py63pq1VbTiaYoOOEboMTX8A08H8uXnAd8Kgn1VlWjiEr71m2 eJmMGavrMf7fJ/8frBGAp32a5Tts0AVbkfUojgQRtSsggsxEzDPXOWj5cO1zKh3VUTts 7dLA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=UD7e40k+; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a17si6953525edy.160.2021.03.26.07.00.44; Fri, 26 Mar 2021 07:01:08 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=UD7e40k+; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230134AbhCZN7w (ORCPT + 99 others); Fri, 26 Mar 2021 09:59:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45020 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230003AbhCZN7p (ORCPT ); Fri, 26 Mar 2021 09:59:45 -0400 Received: from mail-ed1-x529.google.com (mail-ed1-x529.google.com [IPv6:2a00:1450:4864:20::529]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C9466C0613AA for ; Fri, 26 Mar 2021 06:59:44 -0700 (PDT) Received: by mail-ed1-x529.google.com with SMTP id l18so6414510edc.9 for ; Fri, 26 Mar 2021 06:59:44 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=Pve1RvKoSiNiV6NwjrWliiaqMKE71p0JKmuphiR47gE=; b=UD7e40k+TZPg2JF6ZJ/XuYltUQBgmqQ/CXupIddlGvwfT8ah+poMwr9TzbuPhstH/D rebYO1ABh8qDZvdkbnstAmmcSaGCiiRnV8xTP5GPABGlz6l5tjlTXBanu0RnDGJiYwyq cOAtFW+iE4iwsSg/gahYkSw1CVfBP3P6tPvLa64hIP08+e7pQF3yCTLze7+JA8TXS/ED 9daynNqVIHw98WetPlDSzjcQa/ZV3Vqks0q47B/cN9Vo3pbc1iDYYicr9NVdUIaEomjw Sm+4XVh47kzGtJUyvXU9ogCP5M1hfOozW3V0UJDdIlHetzTx7xwMkhquD0mIvWe+8bRe 5x4g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=Pve1RvKoSiNiV6NwjrWliiaqMKE71p0JKmuphiR47gE=; b=K/agGpCGTzD82whJWIxHTkP4EflcHplzx/uJhLt2ybQEdZg4ditO98IGknBnG8VMs+ hWGWzQvsidh7/yxawx2b/QdZHpjiO4e9of2aWtw1id8i90vjMkEHdFgp3uQIw6KRXQZQ tChNMgwDunFpbnP+OEglulWw+Lf89bp7vIR98VSFtHPU1mrwC2ev4A75lsbnYh1YCj37 k0DUiSrzFOA60rU3v4o3TpjHrtQ8Dc4hu3Lr3AYneo9/zilCVwT1HctG/VZwA4DrGpwy agmSBbuMEJGnknfNoL7jUB5oTns4F/I0sFhlo82GuPOtGZzrnsaXcFKcfxDRnSdri6Lp KdVQ== X-Gm-Message-State: AOAM530eiNj1UqfrnhZ3cs/ZsLDygMVDBWHmTgIW5blHCxG8edZwGu6f x+uK6PA5A9dTMvsPMWxtybOPj+EnHUdh85reooPp1A== X-Received: by 2002:a05:6402:3c7:: with SMTP id t7mr15359977edw.196.1616767183437; Fri, 26 Mar 2021 06:59:43 -0700 (PDT) MIME-Version: 1.0 References: <20210324230759.2213957-1-minchan@kernel.org> In-Reply-To: <20210324230759.2213957-1-minchan@kernel.org> From: Anders Roxell Date: Fri, 26 Mar 2021 14:59:30 +0100 Message-ID: Subject: Re: [PATCH v8] mm: cma: support sysfs To: Minchan Kim Cc: Andrew Morton , linux-mm , LKML , Greg Kroah-Hartman , surenb@google.com, joaodias@google.com, jhubbard@nvidia.com, Matthew Wilcox , digetx@gmail.com, Colin Ian King Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 25 Mar 2021 at 00:09, Minchan Kim wrote: > > Since CMA is getting used more widely, it's more important to > keep monitoring CMA statistics for system health since it's > directly related to user experience. > > This patch introduces sysfs statistics for CMA, in order to provide > some basic monitoring of the CMA allocator. > > * the number of CMA page successful allocations > * the number of CMA page allocation failures > > These two values allow the user to calcuate the allocation > failure rate for each CMA area. > > e.g.) > /sys/kernel/mm/cma/WIFI/alloc_pages_[success|fail] > /sys/kernel/mm/cma/SENSOR/alloc_pages_[success|fail] > /sys/kernel/mm/cma/BLUETOOTH/alloc_pages_[success|fail] > > The cma_stat was intentionally allocated by dynamic allocation > to harmonize with kobject lifetime management. > https://lore.kernel.org/linux-mm/YCOAmXqt6dZkCQYs@kroah.com/ > > Tested-by: Dmitry Osipenko > Reviewed-by: Dmitry Osipenko > Reviewed-by: Greg Kroah-Hartman > Reviewed-by: John Hubbard > Link: https://lore.kernel.org/linux-mm/20210316100433.17665-1-colin.king@canonical.com/ > Addresses-Coverity: ("Dereference after null check") > Signed-off-by: Colin Ian King > Signed-off-by: Minchan Kim When I build an arm64 kernel (allmodconfig - boot selftest) on today's next tag: next-20210326, I see this issue when I'm booting in qemu. [ 0.985891][ T9] Callback from call_rcu_tasks() invoked. [ 1.008860][ T1] smp: Bringing up secondary CPUs ... [ 1.012655][ T1] smp: Brought up 1 node, 1 CPU [ 1.015194][ T1] SMP: Total of 1 processors activated. [ 1.018987][ T1] CPU features: detected: 32-bit EL0 Support [ 1.021995][ T1] CPU features: detected: CRC32 instructions [ 1.026047][ T1] CPU features: detected: 32-bit EL1 Support [ 1.033728][ T1] CPU features: emulated: Privileged Access Never (PAN) using TTBR0_EL1 switching [ 2.140828][ T1] CPU: All CPU(s) started at EL1 [ 2.144773][ T17] alternatives: patching kernel code [ 132.866390][ C0] watchdog: BUG: soft lockup - CPU#0 stuck for 25s! [pgdatinit0:20] [ 132.870865][ C0] Modules linked in: [ 132.873037][ C0] irq event stamp: 739758 [ 132.875308][ C0] hardirqs last enabled at (739757): [] _raw_spin_unlock_irqrestore+0x90/0x100 [ 132.880740][ C0] hardirqs last disabled at (739758): [] enter_el1_irq_or_nmi+0xa4/0xc0 [ 132.885801][ C0] softirqs last enabled at (739056): [] __do_softirq+0x8b8/0x9ac [ 132.890571][ C0] softirqs last disabled at (739051): [] __irq_exit_rcu+0x1ac/0x240 [ 132.895560][ C0] CPU: 0 PID: 20 Comm: pgdatinit0 Not tainted 5.12.0-rc4-next-20210326-00008-g23921ff47279 #1 [ 132.900759][ C0] Hardware name: linux,dummy-virt (DT) [ 132.903637][ C0] pstate: 40400005 (nZcv daif +PAN -UAO -TCO BTYPE=--) [ 132.907212][ C0] pc : _raw_spin_unlock_irqrestore+0xa4/0x100 [ 132.910432][ C0] lr : _raw_spin_unlock_irqrestore+0x90/0x100 [ 132.913647][ C0] sp : ffff000007b9f640 [ 132.915832][ C0] x29: ffff000007b9f640 x28: ffff800016954518 [ 132.919237][ C0] x27: 000000000000000e x26: dead000000000100 [ 132.922689][ C0] x25: dead000000000122 x24: 00000000000559b0 [ 132.926098][ C0] x23: ffff80001550e000 x22: ffff800016954530 [ 132.929479][ C0] x21: ffff800016954518 x20: 0000000000000000 [ 132.932901][ C0] x19: ffff800010f662f4 x18: 0000000000001530 [ 132.936312][ C0] x17: 0000000000001470 x16: 0000000000005518 [ 132.939723][ C0] x15: 0000000000001578 x14: ffff800010189520 [ 132.943107][ C0] x13: ffff8000107592e0 x12: ffff600000f73eb1 [ 132.946520][ C0] x11: 1fffe00000f73eb0 x10: ffff600000f73eb0 [ 132.949914][ C0] x9 : dfff800000000000 x8 : ffff000007b9f587 [ 132.953312][ C0] x7 : 0000000000000001 x6 : 00009fffff08c150 [ 132.956713][ C0] x5 : 0000000000000000 x4 : 0000000000000000 [ 132.960117][ C0] x3 : ffff000007b90040 x2 : 000000000005e6fd [ 132.963521][ C0] x1 : 00000000000000c0 x0 : 0000000000000080 [ 132.966889][ C0] Call trace: [ 132.968667][ C0] _raw_spin_unlock_irqrestore+0xa4/0x100 [ 132.971754][ C0] __debug_check_no_obj_freed+0x1d4/0x2a0 [ 132.974890][ C0] debug_check_no_obj_freed+0x20/0x80 [ 132.977813][ C0] __free_pages_ok+0x5a0/0x740 [ 132.980384][ C0] __free_pages_core+0x24c/0x280 [ 132.983091][ C0] deferred_free_range+0x6c/0xbc [ 132.985826][ C0] deferred_init_maxorder+0x2d0/0x350 [ 132.988735][ C0] deferred_init_memmap_chunk+0xc8/0x124 [ 132.991784][ C0] padata_do_multithreaded+0x15c/0x578 [ 132.994723][ C0] deferred_init_memmap+0x26c/0x364 [ 132.997560][ C0] kthread+0x23c/0x260 [ 132.999851][ C0] ret_from_fork+0x10/0x18 [ 133.002324][ C0] Kernel panic - not syncing: softlockup: hung tasks [ 133.005767][ C0] CPU: 0 PID: 20 Comm: pgdatinit0 Tainted: G L 5.12.0-rc4-next-20210326-00008-g23921ff47279 #1 [ 133.011613][ C0] Hardware name: linux,dummy-virt (DT) [ 133.014435][ C0] Call trace: [ 133.016143][ C0] dump_backtrace+0x0/0x420 [ 133.018617][ C0] show_stack+0x38/0x60 [ 133.020882][ C0] dump_stack+0x1fc/0x2c8 [ 133.023343][ C0] panic+0x304/0x5d8 [ 133.025567][ C0] watchdog_timer_fn+0x4ac/0x500 [ 133.028209][ C0] __run_hrtimer+0x770/0xba0 [ 133.030734][ C0] __hrtimer_run_queues+0x1a0/0x220 [ 133.033537][ C0] hrtimer_run_queues+0x20c/0x240 [ 133.036202][ C0] update_process_times+0xbc/0x1a0 [ 133.038997][ C0] tick_periodic+0x27c/0x2c0 [ 133.041510][ C0] tick_handle_periodic+0x44/0x120 [ 133.044267][ C0] arch_timer_handler_virt+0x68/0xa0 [ 133.047226][ C0] handle_percpu_devid_irq+0x118/0x2a0 [ 133.050229][ C0] __handle_domain_irq+0x150/0x1c0 [ 133.052959][ C0] gic_handle_irq+0x130/0x180 [ 133.055505][ C0] el1_irq+0xc0/0x15c [ 133.057723][ C0] _raw_spin_unlock_irqrestore+0xa4/0x100 [ 133.060792][ C0] __debug_check_no_obj_freed+0x1d4/0x2a0 [ 133.063869][ C0] debug_check_no_obj_freed+0x20/0x80 [ 133.066813][ C0] __free_pages_ok+0x5a0/0x740 [ 133.069409][ C0] __free_pages_core+0x24c/0x280 [ 133.072127][ C0] deferred_free_range+0x6c/0xbc [ 133.074847][ C0] deferred_init_maxorder+0x2d0/0x350 [ 133.077803][ C0] deferred_init_memmap_chunk+0xc8/0x124 [ 133.080834][ C0] padata_do_multithreaded+0x15c/0x578 [ 133.083791][ C0] deferred_init_memmap+0x26c/0x364 [ 133.086614][ C0] kthread+0x23c/0x260 [ 133.088879][ C0] ret_from_fork+0x10/0x18 [ 133.092092][ C0] ---[ end Kernel panic - not syncing: softlockup: hung tasks ]--- Full log [1], and my .config [2]. I bisected down to patch 799815f497e2 ("mm: cma: support sysfs"). When I revert 799815f497e2 ("mm: cma: support sysfs") 7af97692f30d ("mm: cma: fix potential null dereference on pointer cma") The kernel boots fine. Any idea whats happening? Cheers, Anders [1] http://ix.io/2U9S [2] http://ix.io/2Ua3