Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp717642ybt; Fri, 10 Jul 2020 10:31:56 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy5GJr3QMCsT8q1poX72wHqkHGxnfWFYDf/Jad8M8i1U7dkBg691N3gS5IbCs2bgCF5PEri X-Received: by 2002:a17:906:d143:: with SMTP id br3mr60103264ejb.268.1594402316405; Fri, 10 Jul 2020 10:31:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594402316; cv=none; d=google.com; s=arc-20160816; b=tjzj6tsHdoOZjeA40L4qkjy3TknGtqSxVVZjIboC2XIXWINI+wDCFFyCUw54KlEnMG Z58N8WUcBNcMH4RpxTjcTHmjzZHUw7E6FtjbLcXHarGdLHzxkNhwOoXtdmPHWwYxqdKY BQuf6buI9h+YMq8/JMZHUCMyxnqxvaaxsnNh/G284diq3tybyJpEgNGqNeXHEVu786bw oCgJWPK3a635t8JyTIKTaCfJrbT1OGCNC+3cD/yX1H4KpnynnwgMFUOwp55XnDX1BYY5 uiJXUb1vOUAFwG/tD3qQXoQIdmrugJNG+UA4nqCC0c3QB3U2tr6ZHJnAt7Nvmnqq+YPF j+Iw== 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 :message-id:to:from:cc:in-reply-to:subject:date:dkim-signature; bh=tTmWEqz6lUd89tDyZu3lt2tGh6dUI6Q1soQYsW2JCJk=; b=Pt2s5BjIyVEGjpHxfEjxWYTq6NFwu9h/lZMW4CRPuCVYmrvA3cW4QGheKCFcZipt83 rIy1mrUrC7IJRYhnPgyiXFsnf6Ofe07GHkJjd2pXlkpOq620FqRDXoLkjIEDrCF8gdsY zywa4T6v2dDZturK78Y4dIOF6WOSPK3xTV/3PVdN4t3vRrC40XKYhqHpHC+/I69IdItw Gl4cbrW7MkbAj+ntCPGvsYs42xBKO13NRZczNyWu9tbtzr1v+EbrYJmo4VaSNE8Wquih ncIN2k6mFYOaBwftdqDE4gk7nANBo2E9MTPWIaHeQ3vOLQULlsAXW0m5fG0Oe/4O9Ije guzQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@dabbelt-com.20150623.gappssmtp.com header.s=20150623 header.b=Iq0sROh9; 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 l17si4211258ejf.494.2020.07.10.10.31.32; Fri, 10 Jul 2020 10:31:56 -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=@dabbelt-com.20150623.gappssmtp.com header.s=20150623 header.b=Iq0sROh9; 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 S1727863AbgGJRaV (ORCPT + 99 others); Fri, 10 Jul 2020 13:30:21 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43706 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726962AbgGJRaU (ORCPT ); Fri, 10 Jul 2020 13:30:20 -0400 Received: from mail-pg1-x541.google.com (mail-pg1-x541.google.com [IPv6:2607:f8b0:4864:20::541]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 25ACEC08C5DC for ; Fri, 10 Jul 2020 10:30:20 -0700 (PDT) Received: by mail-pg1-x541.google.com with SMTP id j19so2803241pgm.11 for ; Fri, 10 Jul 2020 10:30:20 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=dabbelt-com.20150623.gappssmtp.com; s=20150623; h=date:subject:in-reply-to:cc:from:to:message-id:mime-version :content-transfer-encoding; bh=tTmWEqz6lUd89tDyZu3lt2tGh6dUI6Q1soQYsW2JCJk=; b=Iq0sROh9nDv/QnxdNYnmzniAQlTq+9F/tAmE+fB0P+oqdIGJv9M6SBZ+FCL2XB1kKz pJmfMVVGEAJU/fA1qJJOcB43dFKLqmhpVSkmH8zIa+xeoFkEmIw6RTtErPrkw3uvB7O4 1soS86qCMAjSqBFDjMPu3+9jbVb0dwxIhSXa+cvGkTHG+nMa4WKaAEwnUcYnvy9jnela 2mKXo/X5OkUoZ92KOo6xtFPqN4Kk5+64356NQ/rjBZautEk4aD8gRlvJL7Ir/QUxXeFv Jgu2Q8IA9YBF7OX4/aHuUmKzqYEDpHIw139KvTXca71jzVti4OYyob3HMdFczwcSptxI Az3g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:subject:in-reply-to:cc:from:to:message-id :mime-version:content-transfer-encoding; bh=tTmWEqz6lUd89tDyZu3lt2tGh6dUI6Q1soQYsW2JCJk=; b=moCvTOhobO3Wfi6a15WNbyt+4iCFg5+8oJagLg7kTu8S7+1DrOsRvZFQ+KwfTLF+v7 aYorIb0LwN1v5jw6P1gZGOzypWFzMjRRvOFAiezXsLgFGZcgs+jl/d3iW/kIxGQE8mDT jweBuhq+Xv+nE9ogKl9F7qCuWqHDcpULAVNDxcIhD4RqzmSPRCCYxwbTNXOrwI9tFRXM m7F2at3gyGYqhyXLXWNV7yKt6Wo5hf8JxdF4fx0wnBY5uUan1dACLbmuFf4FYThl3PyY 5b1CLlBqnpDAUJMmrqH1sJmE+st0YgvjX9MYB6jNPNJbrBH+7blV0l1BVH1m7oxLtyGa 88+A== X-Gm-Message-State: AOAM531/6NNmfXec9uMkmBMgr8s1/8OEn5DDD+VP/7XRX6nEuUWDV5+P WDtoqm92nGYYddAIUnB7AbQdLA== X-Received: by 2002:aa7:9e0e:: with SMTP id y14mr49980161pfq.77.1594402219419; Fri, 10 Jul 2020 10:30:19 -0700 (PDT) Received: from localhost (76-210-143-223.lightspeed.sntcca.sbcglobal.net. [76.210.143.223]) by smtp.gmail.com with ESMTPSA id c2sm6330306pgk.77.2020.07.10.10.30.18 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 10 Jul 2020 10:30:18 -0700 (PDT) Date: Fri, 10 Jul 2020 10:30:18 -0700 (PDT) X-Google-Original-Date: Fri, 10 Jul 2020 10:29:46 PDT (-0700) Subject: Re: [PATCH v2 2/2] riscv: Enable context tracking In-Reply-To: <1d89d5a6b54ca3d3203cb02ff4548b4eb9820c61.1592989082.git.greentime.hu@sifive.com> CC: greentime.hu@sifive.com, linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org, aou@eecs.berkeley.edu, Paul Walmsley , guoren@linux.alibaba.com From: Palmer Dabbelt To: greentime.hu@sifive.com Message-ID: Mime-Version: 1.0 (MHng) Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 24 Jun 2020 02:03:16 PDT (-0700), greentime.hu@sifive.com wrote: > This patch implements and enables context tracking for riscv (which is a > prerequisite for CONFIG_NO_HZ_FULL support) > > It adds checking for previous state in the entry that all excepttions and > interrupts goes to and calls context_tracking_user_exit() if it comes from > user space. It also calls context_tracking_user_enter() if it will return > to user space before restore_all. > > This patch is tested with the dynticks-testing testcase in > qemu-system-riscv64 virt machine and Unleashed board. > git://git.kernel.org/pub/scm/linux/kernel/git/frederic/dynticks-testing.git > > We can see the log here. The tick got mostly stopped during the execution > of the user loop. > > _-----=> irqs-off > / _----=> need-resched > | / _---=> hardirq/softirq > || / _--=> preempt-depth > ||| / delay > TASK-PID CPU# |||| TIMESTAMP FUNCTION > | | | |||| | | > -0 [001] d..2 604.183512: sched_switch: prev_comm=swapper/1 prev_pid=0 prev_prio=120 prev_state=R ==> next_comm=taskset next_pid=273 next_prio=120 > user_loop-273 [001] d.h1 604.184788: hrtimer_expire_entry: hrtimer=000000002eda5fab function=tick_sched_timer now=604176096300 > user_loop-273 [001] d.s2 604.184897: workqueue_queue_work: work struct=00000000383402c2 function=vmstat_update workqueue=00000000f36d35d4 req_cpu=1 cpu=1 > user_loop-273 [001] dns2 604.185039: tick_stop: success=0 dependency=SCHED > user_loop-273 [001] dn.1 604.185103: tick_stop: success=0 dependency=SCHED > user_loop-273 [001] d..2 604.185154: sched_switch: prev_comm=taskset prev_pid=273 prev_prio=120 prev_state=R+ ==> next_comm=kworker/1:1 next_pid=46 next_prio=120 > <...>-46 [001] .... 604.185194: workqueue_execute_start: work struct 00000000383402c2: function vmstat_update > <...>-46 [001] d..2 604.185266: sched_switch: prev_comm=kworker/1:1 prev_pid=46 prev_prio=120 prev_state=I ==> next_comm=taskset next_pid=273 next_prio=120 > user_loop-273 [001] d.h1 604.188812: hrtimer_expire_entry: hrtimer=000000002eda5fab function=tick_sched_timer now=604180133400 > user_loop-273 [001] d..1 604.189050: tick_stop: success=1 dependency=NONE > user_loop-273 [001] d..2 614.251386: sched_switch: prev_comm=user_loop prev_pid=273 prev_prio=120 prev_state=X ==> next_comm=swapper/1 next_pid=0 next_prio=120 > -0 [001] d..2 614.315391: sched_switch: prev_comm=swapper/1 prev_pid=0 prev_prio=120 prev_state=R ==> next_comm=taskset next_pid=276 next_prio=120 > > Signed-off-by: Greentime Hu > --- > arch/riscv/Kconfig | 1 + > arch/riscv/kernel/entry.S | 23 +++++++++++++++++++++++ > 2 files changed, 24 insertions(+) > > diff --git a/arch/riscv/Kconfig b/arch/riscv/Kconfig > index 128192e14ff2..17520e11815b 100644 > --- a/arch/riscv/Kconfig > +++ b/arch/riscv/Kconfig > @@ -52,6 +52,7 @@ config RISCV > select HAVE_ARCH_SECCOMP_FILTER > select HAVE_ARCH_TRACEHOOK > select HAVE_ASM_MODVERSIONS > + select HAVE_CONTEXT_TRACKING > select HAVE_COPY_THREAD_TLS > select HAVE_DMA_CONTIGUOUS if MMU > select HAVE_EBPF_JIT if MMU > diff --git a/arch/riscv/kernel/entry.S b/arch/riscv/kernel/entry.S > index cae7e6d4c7ef..6ed579fc1073 100644 > --- a/arch/riscv/kernel/entry.S > +++ b/arch/riscv/kernel/entry.S > @@ -97,6 +97,14 @@ _save_context: > la gp, __global_pointer$ > .option pop > > +#ifdef CONFIG_CONTEXT_TRACKING > + /* If previous state is in user mode, call context_tracking_user_exit. */ > + andi a0, s1, SR_SPP I've changed that to SR_PP, as I don't see any reason why this should depend on MMU. I think this is correct: we're using scratch==0 elsewhere to detect recursive traps, but we've blown that away by this point so it's not an option. I don't know of any reason why PP wouldn't be accurate. > + bnez a0, skip_context_tracking > + call context_tracking_user_exit > + > +skip_context_tracking: > +#endif > la ra, ret_from_exception > /* > * MSB of cause differentiates between > @@ -137,6 +145,17 @@ _save_context: > tail do_trap_unknown > > handle_syscall: > +#ifdef CONFIG_CONTEXT_TRACKING > + /* Recover a0 - a7 for system calls */ > + REG_L x10, PT_A0(sp) > + REG_L x11, PT_A1(sp) > + REG_L x12, PT_A2(sp) > + REG_L x13, PT_A3(sp) > + REG_L x14, PT_A4(sp) > + REG_L x15, PT_A5(sp) > + REG_L x16, PT_A6(sp) > + REG_L x17, PT_A7(sp) > +#endif > /* save the initial A0 value (needed in signal handlers) */ > REG_S a0, PT_ORIG_A0(sp) > /* > @@ -205,6 +224,10 @@ resume_userspace: > andi s1, s0, _TIF_WORK_MASK > bnez s1, work_pending > > +#ifdef CONFIG_CONTEXT_TRACKING > + call context_tracking_user_enter > +#endif > + > /* Save unwound kernel stack pointer in thread_info */ > addi s0, sp, PT_SIZE_ON_STACK > REG_S s0, TASK_TI_KERNEL_SP(tp)