Received: by 2002:a25:683:0:0:0:0:0 with SMTP id 125csp121629ybg; Tue, 9 Jun 2020 18:14:31 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzDXIX4hdfWgxW29Hyq9NO7tDAgl/Wif9DlAI3UX6+NgJNGeNZSpFgOVygHymiF+1vuTM7s X-Received: by 2002:a17:906:49da:: with SMTP id w26mr1018912ejv.548.1591751671482; Tue, 09 Jun 2020 18:14:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1591751671; cv=none; d=google.com; s=arc-20160816; b=hZceDkEObp42kfyQbFKWfSpz8TvrKY8CqqrTAjHAk/kvuhqGxhY7Z5YxxMHHME2tVu MonJAD9ruQIvCw9eG5AVZprrC26ySaDKbNyNUfqT0zX8ZXsgot8kLIBSNZrHr74djLbw klUo1xCjGTwqKje1dtiqM3Olssh0iq87d8KmvAvHyFF6Rv5Uln209E6R7w9bYWBJ8MnH lTNu9RFlsIDnnyySTCZqA3d+Yt792HtRzCgqrezD6ywatZ2L0eAtWHd23Cr6YVtdRrFZ TRSuimmbC8matK6/qSFbYS0VyMFP292ODWMu69UP9ZmonKVMAGJOKOXsqM5C0JlBugax +gkQ== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=qsM7ATi/ANWIygl1F68Zm1kjupElqq0601laX5+oEgY=; b=W/wdTeS3cY3tC8MGEIRglS8eBM3UIsbGHZw5dJwWJX0L3zAvAFsvdKAIllUWZ0yMDM APD44Udkmvjy3HhUVVtcGzPYddlgAdP8b9PM/PCQZBxhMEO5Oq33Oth2/FqDstjeXaLw RglNgXgaT4of1Qwz19bwO7Ff9MMBqkD2K/ZCiyyJqbqPTkHcpb5nt+WzwibpPnEL/+sX 0Nuh8Zl3+CVEj8wrBYjVpDjsW4lusCE5FcakEnMEgjIJYnI989tXTtefYMKQ6xP3sl10 rt2suNe6g7jtE+YdZnRdZH68oCc+JyoymqJgVhhDllMdwd+rOmFAVcgIiKcUm4SC18Fw lS1A== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id dp1si17856564ejc.505.2020.06.09.18.14.09; Tue, 09 Jun 2020 18:14:31 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726090AbgFJBMK (ORCPT + 99 others); Tue, 9 Jun 2020 21:12:10 -0400 Received: from szxga07-in.huawei.com ([45.249.212.35]:44210 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1725798AbgFJBMJ (ORCPT ); Tue, 9 Jun 2020 21:12:09 -0400 Received: from DGGEMS414-HUB.china.huawei.com (unknown [172.30.72.59]) by Forcepoint Email with ESMTP id 9844E70DA58A7CCFD3A4; Wed, 10 Jun 2020 09:12:07 +0800 (CST) Received: from localhost.localdomain (10.175.112.125) by DGGEMS414-HUB.china.huawei.com (10.3.19.214) with Microsoft SMTP Server id 14.3.487.0; Wed, 10 Jun 2020 09:11:59 +0800 From: Kefeng Wang To: Divya Indi , CC: Steven Rostedt , Aruna Ramakrishna , Kefeng Wang Subject: [PATCH v3] sample-trace-array: Fix sleeping function called from invalid context Date: Wed, 10 Jun 2020 01:12:44 +0000 Message-ID: <20200610011244.2209486-1-wangkefeng.wang@huawei.com> X-Mailer: git-send-email 2.27.0 In-Reply-To: <53201591-082d-7e42-9043-237ae4239da6@oracle.com> References: <53201591-082d-7e42-9043-237ae4239da6@oracle.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.175.112.125] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org BUG: sleeping function called from invalid context at kernel/locking/mutex.c:935 in_atomic(): 1, irqs_disabled(): 0, non_block: 0, pid: 0, name: swapper/5 1 lock held by swapper/5/0: #0: ffff80001002bd90 (samples/ftrace/sample-trace-array.c:38){+.-.}-{0:0}, at: call_timer_fn+0x8/0x3e0 CPU: 5 PID: 0 Comm: swapper/5 Not tainted 5.7.0+ #8 Hardware name: QEMU QEMU Virtual Machine, BIOS 0.0.0 02/06/2015 Call trace: dump_backtrace+0x0/0x1a0 show_stack+0x20/0x30 dump_stack+0xe4/0x150 ___might_sleep+0x160/0x200 __might_sleep+0x58/0x90 __mutex_lock+0x64/0x948 mutex_lock_nested+0x3c/0x58 __ftrace_set_clr_event+0x44/0x88 trace_array_set_clr_event+0x24/0x38 mytimer_handler+0x34/0x40 [sample_trace_array] mutex_lock() will be called in interrupt context, using workqueue to fix it. Fixes: 89ed42495ef4 ("tracing: Sample module to demonstrate kernel access to Ftrace instances.") Signed-off-by: Kefeng Wang Reviewed-by: Divya Indi --- V3: - add Fixes and RB v2: - add include of linux/workqueue.h - add missing cancel_work_sync() suggested by Divya Indi samples/ftrace/sample-trace-array.c | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/samples/ftrace/sample-trace-array.c b/samples/ftrace/sample-trace-array.c index d523450d73eb..9e437f930280 100644 --- a/samples/ftrace/sample-trace-array.c +++ b/samples/ftrace/sample-trace-array.c @@ -6,6 +6,7 @@ #include #include #include +#include /* * Any file that uses trace points, must include the header. @@ -20,6 +21,16 @@ struct trace_array *tr; static void mytimer_handler(struct timer_list *unused); static struct task_struct *simple_tsk; +static void trace_work_fn(struct work_struct *work) +{ + /* + * Disable tracing for event "sample_event". + */ + trace_array_set_clr_event(tr, "sample-subsystem", "sample_event", + false); +} +static DECLARE_WORK(trace_work, trace_work_fn); + /* * mytimer: Timer setup to disable tracing for event "sample_event". This * timer is only for the purposes of the sample module to demonstrate access of @@ -29,11 +40,7 @@ static DEFINE_TIMER(mytimer, mytimer_handler); static void mytimer_handler(struct timer_list *unused) { - /* - * Disable tracing for event "sample_event". - */ - trace_array_set_clr_event(tr, "sample-subsystem", "sample_event", - false); + schedule_work(&trace_work); } static void simple_thread_func(int count) @@ -76,6 +83,7 @@ static int simple_thread(void *arg) simple_thread_func(count++); del_timer(&mytimer); + cancel_work_sync(&trace_work); /* * trace_array_put() decrements the reference counter associated with -- 2.27.0