Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp3297481pxk; Mon, 21 Sep 2020 10:00:02 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy719JOj6ZSnpzzh+QMcQP0jKS/Yv0uVF9eqJ6O3yUdQQPL79GmuoHG492FXDnQytfaIQBT X-Received: by 2002:a17:906:9491:: with SMTP id t17mr356223ejx.227.1600707602437; Mon, 21 Sep 2020 10:00:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1600707602; cv=none; d=google.com; s=arc-20160816; b=zzEgDhUgUtV+13bBw6JVrVY3V3hnKM6V9VP1vJgIZYs4NNOyWXHY3gTEKIPXqj41EN /CK2AFFuFd1vnyXPHU2pONoitHZSGusnD45XdtT8Kmm+UufmDrGeRjELuNwMv1N31EXH Bml9CC9wjeSfkXSX+1+G3hv9FLBbv0ugkEYd1Jc8zYBWY6HVS8RikMmUr0QxB7QpvUDi M1/Dhy+esVvGHPc6mqhj/qoKY/rLXlsGpluAxbl+pow6cbP/KUUV1LXcy63LWDO2frgX daCNXnUZOMUBlONAAGIkxcka0HNf0pwxrQWM5rw1fxskgynK5ZW3L9q4Yfn9RhB/I460 a6JQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=B4pv6ct8iPuiPKd83HnUKJEdOqRaUURiBpyTndI9x2Q=; b=1AsxC4LQshfFLseHb5reM7C8TNyL/+5BJJmEU8fTWGbx7WueB88iEsi9NgU5ieVcbJ XO8j8eFmV1rLcbHEWl/pqvuFhn+FZSjFSQBlPBpCEvIvTqWzau44QvKOT0c5Qj6w+WnB 2Gt+5EEbuERNlOThW76ePfbsiWn8NtQ6U+JbTPYNf7RTVnF2tAfv2/0MxEtxgzQRcsIv erIAGlyvB6/rOt7Ol0cfmt9n8FIvA8+XyDYUbsKmsxUzkGwEvTk8pzdQkHZN4s5jm7Lz jx+4iShJqL69mShtIYSb+AEUb2Zb1g6NwzS2gGSOBmxfumbAEWkwun4Mju1DEkt7VUD7 xi3Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=OZ3BDEAE; 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=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v26si8265838ejr.748.2020.09.21.09.59.38; Mon, 21 Sep 2020 10:00:02 -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=@kernel.org header.s=default header.b=OZ3BDEAE; 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=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730213AbgIUQ50 (ORCPT + 99 others); Mon, 21 Sep 2020 12:57:26 -0400 Received: from mail.kernel.org ([198.145.29.99]:49052 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729662AbgIUQoD (ORCPT ); Mon, 21 Sep 2020 12:44:03 -0400 Received: from localhost (83-86-74-64.cable.dynamic.v4.ziggo.nl [83.86.74.64]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 2126E2076B; Mon, 21 Sep 2020 16:44:00 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1600706641; bh=FJGrFZh/wSlG57bHCjvhePW4NhaqITwdnUviTd90E1o=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=OZ3BDEAE6XOtJXRFgqPVZdLiEopPOfi6gYrVVso/iElayoQCPRdyyzE6v34SfOT3J YOHEILxEI4WwwyUIT6XeqPA9wQfQpAzunoIOrLJQy366l2/90X38MKaSbslg+dwrl3 fRk1L9IsP0c1ORB/hf4gJ0QokWX/oGsfAwdR3SOg= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Huacai Chen , Paolo Bonzini , Sasha Levin Subject: [PATCH 5.8 035/118] KVM: MIPS: Change the definition of kvm type Date: Mon, 21 Sep 2020 18:27:27 +0200 Message-Id: <20200921162037.942712069@linuxfoundation.org> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20200921162036.324813383@linuxfoundation.org> References: <20200921162036.324813383@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Huacai Chen [ Upstream commit 15e9e35cd1dec2bc138464de6bf8ef828df19235 ] MIPS defines two kvm types: #define KVM_VM_MIPS_TE 0 #define KVM_VM_MIPS_VZ 1 In Documentation/virt/kvm/api.rst it is said that "You probably want to use 0 as machine type", which implies that type 0 be the "automatic" or "default" type. And, in user-space libvirt use the null-machine (with type 0) to detect the kvm capability, which returns "KVM not supported" on a VZ platform. I try to fix it in QEMU but it is ugly: https://lists.nongnu.org/archive/html/qemu-devel/2020-08/msg05629.html And Thomas Huth suggests me to change the definition of kvm type: https://lists.nongnu.org/archive/html/qemu-devel/2020-09/msg03281.html So I define like this: #define KVM_VM_MIPS_AUTO 0 #define KVM_VM_MIPS_VZ 1 #define KVM_VM_MIPS_TE 2 Since VZ and TE cannot co-exists, using type 0 on a TE platform will still return success (so old user-space tools have no problems on new kernels); the advantage is that using type 0 on a VZ platform will not return failure. So, the only problem is "new user-space tools use type 2 on old kernels", but if we treat this as a kernel bug, we can backport this patch to old stable kernels. Signed-off-by: Huacai Chen Message-Id: <1599734031-28746-1-git-send-email-chenhc@lemote.com> Signed-off-by: Paolo Bonzini Signed-off-by: Sasha Levin --- arch/mips/kvm/mips.c | 2 ++ include/uapi/linux/kvm.h | 5 +++-- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/arch/mips/kvm/mips.c b/arch/mips/kvm/mips.c index 666d3350b4ac1..6c6836669ce16 100644 --- a/arch/mips/kvm/mips.c +++ b/arch/mips/kvm/mips.c @@ -137,6 +137,8 @@ extern void kvm_init_loongson_ipi(struct kvm *kvm); int kvm_arch_init_vm(struct kvm *kvm, unsigned long type) { switch (type) { + case KVM_VM_MIPS_AUTO: + break; #ifdef CONFIG_KVM_MIPS_VZ case KVM_VM_MIPS_VZ: #else diff --git a/include/uapi/linux/kvm.h b/include/uapi/linux/kvm.h index 4fdf303165827..65fd95f9784ce 100644 --- a/include/uapi/linux/kvm.h +++ b/include/uapi/linux/kvm.h @@ -789,9 +789,10 @@ struct kvm_ppc_resize_hpt { #define KVM_VM_PPC_HV 1 #define KVM_VM_PPC_PR 2 -/* on MIPS, 0 forces trap & emulate, 1 forces VZ ASE */ -#define KVM_VM_MIPS_TE 0 +/* on MIPS, 0 indicates auto, 1 forces VZ ASE, 2 forces trap & emulate */ +#define KVM_VM_MIPS_AUTO 0 #define KVM_VM_MIPS_VZ 1 +#define KVM_VM_MIPS_TE 2 #define KVM_S390_SIE_PAGE_OFFSET 1 -- 2.25.1