Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752461AbdGGMRP (ORCPT ); Fri, 7 Jul 2017 08:17:15 -0400 Received: from mail-oi0-f67.google.com ([209.85.218.67]:33628 "EHLO mail-oi0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751786AbdGGMRO (ORCPT ); Fri, 7 Jul 2017 08:17:14 -0400 MIME-Version: 1.0 In-Reply-To: <20170707120151.GA23886@lerouge> References: <1499418505-14754-1-git-send-email-wanpeng.li@hotmail.com> <20170707120151.GA23886@lerouge> From: Wanpeng Li Date: Fri, 7 Jul 2017 20:17:13 +0800 Message-ID: Subject: Re: [PATCH v2] sched/cputime: Fix using smp_processor_id() in preemptible To: Frederic Weisbecker Cc: "linux-kernel@vger.kernel.org" , Ingo Molnar , Peter Zijlstra , Wanpeng Li , Thomas Gleixner , Luiz Capitulino , Rik van Riel Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1450 Lines: 41 2017-07-07 20:01 GMT+08:00 Frederic Weisbecker : > On Fri, Jul 07, 2017 at 02:08:25AM -0700, Wanpeng Li wrote: >> From: Wanpeng Li >> >> BUG: using smp_processor_id() in preemptible [00000000] code: 99-trinity/181 >> caller is debug_smp_processor_id+0x17/0x19 >> CPU: 0 PID: 181 Comm: 99-trinity Not tainted 4.12.0-01059-g2a42eb9 #1 >> Call Trace: >> dump_stack+0x82/0xb8 >> check_preemption_disabled+0xd1/0xe3 >> debug_smp_processor_id+0x17/0x19 >> vtime_delta+0xd/0x2c >> task_cputime+0x89/0xdb >> thread_group_cputime+0x11b/0x1ed >> thread_group_cputime_adjusted+0x1f/0x47 >> wait_consider_task+0x2a9/0xaf9 >> ? lock_acquire+0x97/0xa4 >> do_wait+0xdf/0x1f4 >> SYSC_wait4+0x8e/0xb5 >> ? list_add+0x34/0x34 >> SyS_wait4+0x9/0xb >> do_syscall_64+0x70/0x82 >> entry_SYSCALL64_slow_path+0x25/0x25 >> >> This patch fixes it by replacing sched_clock_cpu() in vtime_delta() by >> local_clock() for effectively raw_smp_processor_id(). > > That's also broken because task_cputime() can be called from a different CPU than > where the target task is running on, even though there shouldn't be practical effect Agreed. > as the clock must be stable but still the code would be confusing. > > No I think you can still use sched_clock(), just make sure you also use it on > arch_vtime_task_switch() and vtime_init_idle(). Is it acceptable to you, Peterz? :) Regards, Wanpeng Li