Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp2190802pxb; Mon, 18 Jan 2021 10:32:56 -0800 (PST) X-Google-Smtp-Source: ABdhPJzzLgVZk3fL1Xz+zwAo0UtkPz6YV6i7yA+WxiwYKI0ZhHjs23JJ6D7XKLaJHXIoWHBAEXoS X-Received: by 2002:aa7:da01:: with SMTP id r1mr615237eds.45.1610994776624; Mon, 18 Jan 2021 10:32:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1610994776; cv=none; d=google.com; s=arc-20160816; b=MZMSvtgJWbz17zpHiMyrFCoy80qfuiG0S3zZcXfqDLwap1jitV/fP2BwFIi55ta1Uh Up8Ay64tb7wrdre8ZiuqXpsoF/EVneCwL2yAaPx8U1AmEE29b8vlNTNgCEFPHmIT5Ab2 2KbXnQaVT1+d1KsAKugcpKUnVJGX0gJ9MQBNA80EphWjhyp/MsQr7t4Xrpm6A+g7nqfQ OTvJkGltAa8ShnloLax9K0JNwjA/1IZEfiXLPjXnaC7HWt6rkT1kTejT7JSmVoO4QpQy cZ7kp4Zt/fJmue7uCWyft0rq/gDorEE7f62aBZWFc6Z8Es21lPwAYt6pCLES9O3RUpg8 OLSw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=z5tNgVARNvQCB0SJouIAYqEN8m6OYsaWxW5vbk1y2k0=; b=wtTQlQYWF8LseP0niKy2MmKy94/g6nTufi3rFkXwqFmnzqwNlG0vPlXRGjoMCCT4Ck zS7kDXEKlMpb80OC7S5CvbU/bJlisWRaQAEdS1ZA2hLXrdPcgZCsipw+eQ7BXKJ5Ocge Dag1pZ/0qr9TcMeTrOF6fgfJIeigFFFeE4rSwPHZ0+B1VaAQt5AiOqGzXXyo2s6ADill RJAdweydtbYURBUEbC92Wc788hpeml3A5C1sDrOCfwKBuS1TSehOHR9M1q/72P7OAfct CSKhvdLu7IhtYa79ljHe/k8wERWiXIygWY5omzPIfHeadKaK1CCDwMA/EGmzTXttUUnw t4ug== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=EH2vK0Fb; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i20si350288ejz.447.2021.01.18.10.32.30; Mon, 18 Jan 2021 10:32:56 -0800 (PST) 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=@redhat.com header.s=mimecast20190719 header.b=EH2vK0Fb; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2407622AbhARSaB (ORCPT + 99 others); Mon, 18 Jan 2021 13:30:01 -0500 Received: from us-smtp-delivery-124.mimecast.com ([216.205.24.124]:55680 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2393684AbhARS1o (ORCPT ); Mon, 18 Jan 2021 13:27:44 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1610994373; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=z5tNgVARNvQCB0SJouIAYqEN8m6OYsaWxW5vbk1y2k0=; b=EH2vK0Fbaf7bWnYR919g8PTvBpqEzrZbaCIkE5RQuwp/H7nrnKVNj8SnPw9IWrZeIFO50o J+qrMZl5WJqjb2csBF7qiz9GEkum274+mXgliTgwVaA6iCq5Kp3Y7BcTG/BMyG3y2/5EbP kcTRG+vxumZSSb5i/rukRddzLlKvrqw= Received: from mail-wr1-f70.google.com (mail-wr1-f70.google.com [209.85.221.70]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-217-uxSYyb2ZNWuTZxYOhtQwOw-1; Mon, 18 Jan 2021 13:26:12 -0500 X-MC-Unique: uxSYyb2ZNWuTZxYOhtQwOw-1 Received: by mail-wr1-f70.google.com with SMTP id r11so8697677wrs.23 for ; Mon, 18 Jan 2021 10:26:12 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=z5tNgVARNvQCB0SJouIAYqEN8m6OYsaWxW5vbk1y2k0=; b=nV1t21WElj6NFM3Ey6sy3hFAjvvVgKDESq5p3Q5f8ripZm3S2oyEvwlBdm1z3oJLEu A/zeFAKI7pQd6kpvgVWwNgJvyI/JGHs6NWFeD2Cgyhs01o+T+bRp6l3nTz5CM26hVuF2 u5JbShK1XFlLqnUHMn1tRmAmGb6jwWF+2rB+LdKGHUr7gBLLpHI1C9JULDjHAJd2l6/Y Y+vGtCS0D3/I+QnCdA8WPDIhNcW+8Xbuhqx2zpd8rfRF9d3MGFny7VCtwrFh14CZzY9d RilZzbTUT9najyIHyeMG5TGhS0MpSGGWHQS0DmyPAn4aL/dB1pUWmmSuG2ERj4gNsecR yltw== X-Gm-Message-State: AOAM5329xg9xNJ2llkX+XFi+g7AMoxX0WSWhbVoJq1sED8IM4gLRgYGn xU4BUpotK3cGv62wP2iHTJSHXlz9rM3Ag04UmLP0L7iWVoH7rBrROOpfWkfX7eqDR+xOFOdkFl7 Q1+v//9lLsmfe4mwxkmtP01gV X-Received: by 2002:adf:fccb:: with SMTP id f11mr746715wrs.3.1610994371126; Mon, 18 Jan 2021 10:26:11 -0800 (PST) X-Received: by 2002:adf:fccb:: with SMTP id f11mr746695wrs.3.1610994370933; Mon, 18 Jan 2021 10:26:10 -0800 (PST) Received: from ?IPv6:2001:b07:6468:f312:c8dd:75d4:99ab:290a? ([2001:b07:6468:f312:c8dd:75d4:99ab:290a]) by smtp.gmail.com with ESMTPSA id c6sm34500990wrh.7.2021.01.18.10.26.09 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 18 Jan 2021 10:26:10 -0800 (PST) Subject: Re: [PATCH 0/3] x86/KVM/VMX: Introduce and use try_cmpxchg64() To: Uros Bizjak , x86@kernel.org, kvm@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Will Deacon , Peter Zijlstra , Boqun Feng , Thomas Gleixner , Ingo Molnar , Borislav Petkov , "H. Peter Anvin" , Sean Christopherson , Vitaly Kuznetsov , Wanpeng Li , Jim Mattson , Joerg Roedel References: <20201215182805.53913-1-ubizjak@gmail.com> From: Paolo Bonzini Message-ID: <05bc4cc2-1c1b-ebb8-39e3-9eaef7f0df4f@redhat.com> Date: Mon, 18 Jan 2021 19:26:09 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.6.0 MIME-Version: 1.0 In-Reply-To: <20201215182805.53913-1-ubizjak@gmail.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 15/12/20 19:28, Uros Bizjak wrote: > This patch series introduces try_cmpxchg64() atomic locking function. > > try_cmpxchg64() provides the same interface for 64 bit and 32 bit targets, > emits CMPXCHGQ for 64 bit targets and CMPXCHG8B for 32 bit targets, > and provides appropriate fallbacks when CMPXCHG8B is unavailable. > > try_cmpxchg64() reuses flags from CMPXCHGQ/CMPXCHG8B instructions and > avoids unneeded CMP for 64 bit targets or XOR/XOR/OR sequence for > 32 bit targets. > > Cc: Will Deacon > Cc: Peter Zijlstra > Cc: Boqun Feng > Cc: Thomas Gleixner > Cc: Ingo Molnar > Cc: Borislav Petkov > Cc: "H. Peter Anvin" > Cc: Paolo Bonzini > Cc: Sean Christopherson > Cc: Vitaly Kuznetsov > Cc: Wanpeng Li > Cc: Jim Mattson > Cc: Joerg Roedel > > Uros Bizjak (3): > asm-generic/atomic: Add try_cmpxchg64() instrumentation > locking/atomic/x86: Introduce arch_try_cmpxchg64() > KVM/VMX: Use try_cmpxchg64() in posted_intr.c > > arch/x86/include/asm/cmpxchg_32.h | 62 +++++++++++++++++++---- > arch/x86/include/asm/cmpxchg_64.h | 6 +++ > arch/x86/kvm/vmx/posted_intr.c | 9 ++-- > include/asm-generic/atomic-instrumented.h | 46 ++++++++++++++++- > scripts/atomic/gen-atomic-instrumented.sh | 2 +- > 5 files changed, 108 insertions(+), 17 deletions(-) > Queued, thanks. Paolo