Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp404302ybt; Wed, 24 Jun 2020 02:07:32 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyIluU6B0xJ9U4HdbxE5KmCBV8EcwRp7zh7v8XM4WD9kpTMQp8w6xvNFm7XDkEdMw60IPvk X-Received: by 2002:a17:906:33c5:: with SMTP id w5mr23770715eja.275.1592989652346; Wed, 24 Jun 2020 02:07:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592989652; cv=none; d=google.com; s=arc-20160816; b=wfw1oryXEUin7BauPTwV6y94Eh1zro3whiBZahSnhEIfz6USrxSLrlqQmtOBiL09Fb jXJraYfF2Rm4as0UPUEZVhS9ldKiCKl38mRwsCISJBBzxTlAeWFEUFs9SdOP72N0A3/L DeqTbemaniuCP18+S6vurOqfOUtDCreqac2wE5jFqqahFPnFusEcteBwfjMn7yrFI/Iq wDjfwJmHwQP7DzOOF1ud07mLnjIGYTJxlTkMkxqgMPyzo1x2LAIXpTeNgGa/jd4IfcCo tSIN1A2Qz7U1p2mxY/jFAIEj41cw2l9C8jJVRt41vmjTZq/wF8qIZurwq+26jQnAe4vA EYyw== 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:to:from :dkim-signature; bh=APwDQH63ewaL2qHEi/Ing1YzxCpzIwvDW/C7xU97WY0=; b=m9PoAiUxeAmUfJsHoNsqfsoxDJtj7NfF/QEpxwOGDbW/tKYofweDN9bvnSDKk8o0Nl f+Pdr/HRJIqrSVM4X4V2fPQJdD3/F7pWepckHcCf4bU4ew/IgrVyeTBAbVfwNDukbIqR w9zH9uZff2U+zduPimC/kBDFA405xfDe3urw/lnR1E2zoYfKaUzakuT9wG6M9ScrO0n1 x99AKpMWwQYceIUDrz1Yp6qjG+5Js0SiOh9n8Gqks8wjPV2+aiLbPOaB24CNg1H/xs61 L9HXbcRo9v0XuZK3tWH4+BOhPp0LVTh85uhzVSzYs/GVG9ZTMOnW7B9mG49lFt4/Khd2 SKxw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@sifive.com header.s=google header.b=EebCq36d; 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 q24si6389925edw.193.2020.06.24.02.07.09; Wed, 24 Jun 2020 02:07:32 -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=@sifive.com header.s=google header.b=EebCq36d; 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 S2389107AbgFXJDb (ORCPT + 99 others); Wed, 24 Jun 2020 05:03:31 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56758 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389043AbgFXJDa (ORCPT ); Wed, 24 Jun 2020 05:03:30 -0400 Received: from mail-pj1-x1044.google.com (mail-pj1-x1044.google.com [IPv6:2607:f8b0:4864:20::1044]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3C404C061573 for ; Wed, 24 Jun 2020 02:03:30 -0700 (PDT) Received: by mail-pj1-x1044.google.com with SMTP id ga6so927008pjb.1 for ; Wed, 24 Jun 2020 02:03:30 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sifive.com; s=google; h=from:to:subject:date:message-id:in-reply-to:references:mime-version :content-transfer-encoding; bh=APwDQH63ewaL2qHEi/Ing1YzxCpzIwvDW/C7xU97WY0=; b=EebCq36d0n00dZfafkmwSeo5Kh9YCqdxCmikfSs628rB+ud+0owUwlvXwPQg9kQ7PW cQyhyg3uX2G3fcuHZ0KTGxyo/v+/FM1RwL0P8xNU5HdiqJs3yUMnpofHSczVhW2v4+kd rUA+IuQ0tpZdFa8hlW8P9aY0jW31mSmr8O7VXhO9EPj3ouHcv/0z0xXrfdCBByyY6U/3 bo2I7Buym1YxdatSOSSqTpY9Ntnnl4g+P4bFWkdxALJalVHhKYQM66m2v71FOSby38cs lIJAyzNEBH/+ewOfe7bJCgRRs6BsODQ5nI9q8K+3perwfUXyr5XvfoUPWyUfwpzisfoq EG+w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=APwDQH63ewaL2qHEi/Ing1YzxCpzIwvDW/C7xU97WY0=; b=jf4uXXbZJkVZUAhOg7GTNvrBX7cosikgwh/DxETD6zt2lcYjAjO5a1BfONIlCUoyJx IdERYVFP2RO2+RPuBZKzdfUxiunI7jO3MOKFgrtjXG8fJUqEir8q89W1UDFZ5tHcwElH sOiPVaD+4T/2V8a9cYfyPWE8pMQR9wi9YRK/Z0A/3uZBwp15VpCH5jaSLkZZYVwHcfnB v8nrYUeeFJmCwH6IBkYUvdlKOKQz4Gem2qY9vMDhhhqG3MYZh5Cv5TaFC08tNZHlFZBK Ng/NRnfNxWZcfrfV8lDuXLqH4diFJbvi2HEOUa36eIeszWgXner8wTkfvII0PwTsewrV TeeQ== X-Gm-Message-State: AOAM5302GYQM1HBAlOhLYJ9C60WEu0RZGUuBa/LJl7OcbXHe/PjHMXLG zmnibZ6y93d2nFmSh1DEA7xENA== X-Received: by 2002:a17:90a:a116:: with SMTP id s22mr26713129pjp.202.1592989409684; Wed, 24 Jun 2020 02:03:29 -0700 (PDT) Received: from hsinchu02.internal.sifive.com (114-34-229-221.HINET-IP.hinet.net. [114.34.229.221]) by smtp.gmail.com with ESMTPSA id v1sm8062046pfn.210.2020.06.24.02.03.27 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 24 Jun 2020 02:03:29 -0700 (PDT) From: Greentime Hu To: greentime.hu@sifive.com, linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org, aou@eecs.berkeley.edu, palmer@dabbelt.com, paul.walmsley@sifive.com, guoren@linux.alibaba.com Subject: [PATCH v2 2/2] riscv: Enable context tracking Date: Wed, 24 Jun 2020 17:03:16 +0800 Message-Id: <1d89d5a6b54ca3d3203cb02ff4548b4eb9820c61.1592989082.git.greentime.hu@sifive.com> X-Mailer: git-send-email 2.27.0 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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 + 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) -- 2.27.0