Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp1330126imm; Thu, 23 Aug 2018 00:55:38 -0700 (PDT) X-Google-Smtp-Source: ANB0VdaJ4uUzCcG5ryHg3Qj+gsYyChbUU4BsSeKrmIQjrQmTiNwjL5bVqQoXhiXQJCwIkIZ2k1OE X-Received: by 2002:a62:f0d:: with SMTP id x13-v6mr4224544pfi.221.1535010938124; Thu, 23 Aug 2018 00:55:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1535010938; cv=none; d=google.com; s=arc-20160816; b=0N9Oi0ArD9rr1580xc7YjWEWB0tHCyuPcUVve4ShKkKFj8JY+wYMBggcGClBQXipK6 fHU5oUSPxbFZ/aaz/l10R9QbBPBQErnQUOKcAlK/X/CE1enKiM2X56ZatKLC+rRdPjpg B+x+4eSex0xbnRjm844iRCiwBANlo5/RJMcPL1IzU1djlK02jyt17r0EGVacyWuiDVGV HLXAXNH0od2KWQXq91r+F9Rw5CTM5G2xVZ0hbUNZ5+an8b0va4xAaEfxrPowOfw4ALzx a4q/V1JyBbMCdhS1q4otIGzFgCe9mQq4dOjRa3RGZzODUccizzfeNlyaZi+qLMykl9CK svQA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date:from :references:cc:to:subject:reply-to:arc-authentication-results; bh=LpF28RnSTgOJGSY0GSOa/JFXuKKiVeU1NAMNQDjmB7I=; b=zAxMwdHoi7hGrRhiOTanB941RrvO6SUrQsbYUX1KUbbsxJ2gWj/ogF9qXNJxrqOpoO mLMb/4GgrO+NqJhRMTuhTFxgdbzrD4yvAAz0dhKhM8x08pwLBWImiLCRHOHWLdIAcF04 vxvbHK72DWRhG9J2M9EaePAjZFDKWJUtKIZRljQA6cB6+tOr925FaQ9mbuKohqlsCFzL QawCUGUEj4i/Sd3s6gFfjQfHEQUaxi6ymqWjzkRET0hBKbRW2MJweXA9xCJoO0D7GoAw YuDaJ0m+G+LJqgpK93ZgHGRDFyBHYevPsCxaptwQwAc4q+Dohfohro6ouokEkEcsNy6D m30A== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f186-v6si3156575pfa.336.2018.08.23.00.55.22; Thu, 23 Aug 2018 00:55:38 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727000AbeHWLWg (ORCPT + 99 others); Thu, 23 Aug 2018 07:22:36 -0400 Received: from mx0b-001b2d01.pphosted.com ([148.163.158.5]:40350 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726451AbeHWLWg (ORCPT ); Thu, 23 Aug 2018 07:22:36 -0400 Received: from pps.filterd (m0098420.ppops.net [127.0.0.1]) by mx0b-001b2d01.pphosted.com (8.16.0.22/8.16.0.22) with SMTP id w7N7pQFa045464 for ; Thu, 23 Aug 2018 03:54:14 -0400 Received: from e06smtp01.uk.ibm.com (e06smtp01.uk.ibm.com [195.75.94.97]) by mx0b-001b2d01.pphosted.com with ESMTP id 2m1r06jc5r-1 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=NOT) for ; Thu, 23 Aug 2018 03:54:13 -0400 Received: from localhost by e06smtp01.uk.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Thu, 23 Aug 2018 08:54:12 +0100 Received: from b06cxnps3075.portsmouth.uk.ibm.com (9.149.109.195) by e06smtp01.uk.ibm.com (192.168.101.131) with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted; (version=TLSv1/SSLv3 cipher=AES256-GCM-SHA384 bits=256/256) Thu, 23 Aug 2018 08:54:09 +0100 Received: from d06av22.portsmouth.uk.ibm.com (d06av22.portsmouth.uk.ibm.com [9.149.105.58]) by b06cxnps3075.portsmouth.uk.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id w7N7s7iG36110572 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=FAIL); Thu, 23 Aug 2018 07:54:07 GMT Received: from d06av22.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id E5E534C04E; Thu, 23 Aug 2018 10:54:08 +0100 (BST) Received: from d06av22.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 8207D4C040; Thu, 23 Aug 2018 10:54:08 +0100 (BST) Received: from [9.152.224.92] (unknown [9.152.224.92]) by d06av22.portsmouth.uk.ibm.com (Postfix) with ESMTP; Thu, 23 Aug 2018 10:54:08 +0100 (BST) Reply-To: pmorel@linux.ibm.com Subject: Re: [PATCH v2 3/5] KVM: s390: vsie: Allow support for a host without AP To: David Hildenbrand Cc: linux-kernel@vger.kernel.org, cohuck@redhat.com, linux-s390@vger.kernel.org, kvm@vger.kernel.org, frankja@linux.ibm.com, akrowiak@linux.ibm.com, borntraeger@de.ibm.com, schwidefsky@de.ibm.com, heiko.carstens@de.ibm.com References: <1534956717-14087-1-git-send-email-pmorel@linux.ibm.com> <1534956717-14087-4-git-send-email-pmorel@linux.ibm.com> From: Pierre Morel Date: Thu, 23 Aug 2018 09:54:06 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit X-TM-AS-GCONF: 00 x-cbid: 18082307-4275-0000-0000-000002AE0891 X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 18082307-4276-0000-0000-000037B71056 Message-Id: X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:,, definitions=2018-08-23_04:,, signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 priorityscore=1501 malwarescore=0 suspectscore=0 phishscore=0 bulkscore=0 spamscore=0 clxscore=1015 lowpriorityscore=0 mlxscore=0 impostorscore=0 mlxlogscore=999 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1807170000 definitions=main-1808230083 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 23/08/2018 09:15, David Hildenbrand wrote: > On 23.08.2018 08:44, Pierre Morel wrote: >> On 22/08/2018 19:06, David Hildenbrand wrote: >>> On 22.08.2018 18:51, Pierre Morel wrote: >>>> Currently the CRYCB format used in the host for the >>>> shadowed CRYCB is FORMAT2 while no check is done if >>>> AP instructions are supported in the host. >>>> >>>> We better use the format the host calculated for the >>>> guest 1 as the host already tested it against its >>>> facility set. >>>> >>>> Signed-off-by: Pierre Morel >>>> --- >>>> arch/s390/kvm/vsie.c | 5 +++-- >>>> 1 file changed, 3 insertions(+), 2 deletions(-) >>>> >>>> diff --git a/arch/s390/kvm/vsie.c b/arch/s390/kvm/vsie.c >>>> index 56a9d47..0b12916 100644 >>>> --- a/arch/s390/kvm/vsie.c >>>> +++ b/arch/s390/kvm/vsie.c >>>> @@ -154,6 +154,7 @@ static int shadow_crycb(struct kvm_vcpu *vcpu, struct vsie_page *vsie_page) >>>> const u32 crycb_addr = crycbd_o & 0x7ffffff8U; >>>> unsigned long *b1, *b2; >>>> u8 ecb3_flags; >>>> + unsigned long g1_fmt; >>>> >>>> scb_s->crycbd = 0; >>>> if (!(crycbd_o == CRYCB_FORMAT1)) >>>> @@ -180,8 +181,8 @@ static int shadow_crycb(struct kvm_vcpu *vcpu, struct vsie_page *vsie_page) >>>> return set_validity_icpt(scb_s, 0x0035U); >>>> >>>> scb_s->ecb3 |= ecb3_flags; >>>> - scb_s->crycbd = ((__u32)(__u64) &vsie_page->crycb) | CRYCB_FORMAT1 | >>>> - CRYCB_FORMAT2; >>>> + g1_fmt = vcpu->arch.sie_block->crycbd & 0x03; >>>> + scb_s->crycbd = ((__u32)(__u64) &vsie_page->crycb) | g1_fmt; >>>> >>>> /* xor both blocks in one run */ >>>> b1 = (unsigned long *) vsie_page->crycb.dea_wrapping_key_mask; >>>> >>> >>> This is wrong. I remember that with APXA, if FORMAT2 is available, we >>> should always use FORMAT2. That's why we explicitly convert it here. >>> >> >> You are right if FORMAT2 is available we should use FORMAT2 >> but the intention here is to use what KVM crypto init function did, >> assuming it did the right thing. >> >> Eventually we are running on a host without AP and we should use FORMAT1. >> >> Isn't it correct? > > > Yes and no :) > > No APXA -> FORMAT2 bit is ignored (and that is one of the reasons why I > am being so strict about simulating HW behavior correctly in nested code > :) ) > > This only holds as long as we are not using AP. Because from a MSA3 > perspective, FORMAT1==FORMAT2 (apart from the length/alignment, which is > fine for us). > > Once we support AP (via ECA.28), we'll properly have to create either a > Format0/Format1/Format2. Then, there is actually a semantically > difference ("different fields used"). OK I would have expect something more explicit in the documentation like for firmware versions older than xxx bit 30 is ignored instead of if APXA is not installed. Still must learn the IBM language! :) regards, Pierre -- Pierre Morel Linux/KVM/QEMU in Böblingen - Germany