2022-11-03 12:38:24

by johnnyaiai

[permalink] [raw]
Subject: [PATCH] locking/paravirt: Fix performance regression on core bonded vCPU

From: johnnyaiai <[email protected]>

virt_spin_lock() is preferred over native qspinlock when
vCPU is preempted. But brings a lot of regression while
vCPU is not preempted. Provide a early param 'novirtlock'
to choose would be better.

will-it-scale/lock2_threads -s 10 -t 64
baseline afterpatch
559938 2166135

Signed-off-by: johnnyaiai <[email protected]>
---
arch/x86/kernel/paravirt.c | 7 +++++++
1 file changed, 7 insertions(+)

diff --git a/arch/x86/kernel/paravirt.c b/arch/x86/kernel/paravirt.c
index 59d3d2763..529cf23fe 100644
--- a/arch/x86/kernel/paravirt.c
+++ b/arch/x86/kernel/paravirt.c
@@ -107,6 +107,13 @@ static unsigned paravirt_patch_jmp(void *insn_buff, const void *target,

DEFINE_STATIC_KEY_TRUE(virt_spin_lock_key);

+static __init int parse_novirtspin(char *arg)
+{
+ static_branch_disable(&virt_spin_lock_key);
+ return 0;
+}
+early_param("novirtspin", parse_novirtspin);
+
void __init native_pv_lock_init(void)
{
if (!boot_cpu_has(X86_FEATURE_HYPERVISOR))
--
2.27.0



2022-11-03 13:43:13

by Jürgen Groß

[permalink] [raw]
Subject: Re: [PATCH] locking/paravirt: Fix performance regression on core bonded vCPU

On 03.11.22 13:13, johnnyaiai wrote:
> From: johnnyaiai <[email protected]>
>
> virt_spin_lock() is preferred over native qspinlock when
> vCPU is preempted. But brings a lot of regression while
> vCPU is not preempted. Provide a early param 'novirtlock'
> to choose would be better.
>
> will-it-scale/lock2_threads -s 10 -t 64
> baseline afterpatch
> 559938 2166135
>
> Signed-off-by: johnnyaiai <[email protected]>

That is exactly the purpose of the existing nopvspin parameter.


Juergen


Attachments:
OpenPGP_0xB0DE9DD628BF132F.asc (3.08 kB)
OpenPGP public key
OpenPGP_signature (505.00 B)
OpenPGP digital signature
Download all attachments

2022-11-03 14:52:55

by johnnyaiai

[permalink] [raw]
Subject: Re: [PATCH] locking/paravirt: Fix performance regression on core bonded vCPU

Thanks for reply! I think nopvspin parameters controls
pvspinlock or native spinlock. a vm guest always running
on virtspin wheather nopvspin sets or not when EXITS_HALT
not supported by hypervisor. So provide a missing parameter
'novirtspin'.