Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp619936ybe; Thu, 5 Sep 2019 03:18:41 -0700 (PDT) X-Google-Smtp-Source: APXvYqzWmQ5Qw/HikZon24tMe1gKjyq9QcUZGN1/qtK8TJkmgAI0iIVfNIzmFHFYsRf9fJvvc05q X-Received: by 2002:a17:90a:86c3:: with SMTP id y3mr2988967pjv.66.1567678721838; Thu, 05 Sep 2019 03:18:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567678721; cv=none; d=google.com; s=arc-20160816; b=YB48oACCGpbNSimt4AgIx3nMoPIj9YkbThdhJv6FECd7rUE3hrg2C1uRjVDFMTgJMo W8BZqiodK49cLfkEvR63TVbOU8OisAPi1TbseeTXxS88Ka5UQ6Z+BMZTUDxhajlTDanD fdxVOQI3PlBWD48prPOZO61o9NftwAFHfse+wzLQUIlUTzIjiaQO37pl9QA/6lj8gNP6 6W9KT0lb3ShQA2iBF4L1sH7iL89Mt0mzTmJFLjG50cx/hkRctikYF7kgt+kBjnf1WcLF at+m25UNVp/pq8gR3cGyqIe3QrCLrzZlGu1ka0Uas8kZVbr4BceDi8s+yHnNpF814hMW 5Egw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:reply-to:message-id :subject:cc:to:from:date; bh=zbqih4fzsospQlPQgnWKg/cKmC1xJqxkw5T5xq+5KOA=; b=dH5iIOegNeJ1N4nCQvllrkwuJDKjieH4L9DzdrYR8d+B2XZpNjjWogNxWTikM9ORCL +q2/VLClqnU0iNxCSqPZFfly9lcgJIdgkykHLADXcKA1OK+8sgpyAMLZvSsHktPB/JCR 8pKF4m4HIZC7nXdjlhFwpZybztZ1yq7KDlHkHLmsyZ8S8ZIOW8OGEZDA7U+nOZZ+4X4V dULhl8BLt2cCTX0jkXFhXFaKZSYY9P1oHPVqQWSVzMgIsnQIQ11vZXyANs0s1ytSPqTT /qlQ/im1jR7TA/xbDLXpeVVOZSN4NQYz6Z2pDkVUewDujkA8RX9UBUdWMUAH2ha4Lv/M eiMQ== 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=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l1si1394049pgs.458.2019.09.05.03.18.25; Thu, 05 Sep 2019 03:18:41 -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=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1733289AbfIEJXY (ORCPT + 99 others); Thu, 5 Sep 2019 05:23:24 -0400 Received: from mx1.redhat.com ([209.132.183.28]:60800 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1733279AbfIEJXY (ORCPT ); Thu, 5 Sep 2019 05:23:24 -0400 Received: from smtp.corp.redhat.com (int-mx05.intmail.prod.int.phx2.redhat.com [10.5.11.15]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id A0291190C034; Thu, 5 Sep 2019 09:23:23 +0000 (UTC) Received: from redhat.com (unknown [10.42.17.64]) by smtp.corp.redhat.com (Postfix) with ESMTPS id EC0485D712; Thu, 5 Sep 2019 09:23:19 +0000 (UTC) Date: Thu, 5 Sep 2019 10:23:17 +0100 From: Daniel =?utf-8?B?UC4gQmVycmFuZ8Op?= To: Stefan Hajnoczi Cc: Heinrich Schuchardt , Marc Zyngier , James Morse , Julien Thierry , Suzuki K Pouloze , Peter Maydell , linux-arm-kernel@lists.infradead.org, kvmarm@lists.cs.columbia.edu, linux-kernel@vger.kernel.org Subject: Re: [PATCH 1/1] KVM: inject data abort if instruction cannot be decoded Message-ID: <20190905092317.GB14512@redhat.com> Reply-To: Daniel =?utf-8?B?UC4gQmVycmFuZ8Op?= References: <20190904180736.29009-1-xypron.glpk@gmx.de> <20190905092039.GG32415@stefanha-x1.localdomain> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20190905092039.GG32415@stefanha-x1.localdomain> User-Agent: Mutt/1.12.1 (2019-06-15) X-Scanned-By: MIMEDefang 2.79 on 10.5.11.15 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.6.2 (mx1.redhat.com [10.5.110.70]); Thu, 05 Sep 2019 09:23:23 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Sep 05, 2019 at 10:20:39AM +0100, Stefan Hajnoczi wrote: > On Wed, Sep 04, 2019 at 08:07:36PM +0200, Heinrich Schuchardt wrote: > > If an application tries to access memory that is not mapped, an error > > ENOSYS, "load/store instruction decoding not implemented" may occur. > > QEMU will hang with a register dump. > > > > Instead create a data abort that can be handled gracefully by the > > application running in the virtual environment. > > > > Now the virtual machine can react to the event in the most appropriate > > way - by recovering, by writing an informative log, or by rebooting. > > > > Signed-off-by: Heinrich Schuchardt > > --- > > virt/kvm/arm/mmio.c | 4 ++-- > > 1 file changed, 2 insertions(+), 2 deletions(-) > > > > diff --git a/virt/kvm/arm/mmio.c b/virt/kvm/arm/mmio.c > > index a8a6a0c883f1..0cbed7d6a0f4 100644 > > --- a/virt/kvm/arm/mmio.c > > +++ b/virt/kvm/arm/mmio.c > > @@ -161,8 +161,8 @@ int io_mem_abort(struct kvm_vcpu *vcpu, struct kvm_run *run, > > if (ret) > > return ret; > > } else { > > - kvm_err("load/store instruction decoding not implemented\n"); > > - return -ENOSYS; > > + kvm_inject_dabt(vcpu, kvm_vcpu_get_hfar(vcpu)); > > + return 1; > > I see this more as a temporary debugging hack than something to merge. > > It sounds like in your case the guest environment provided good > debugging information and you preferred it over debugging this from the > host side. That's fine, but allowing the guest to continue running in > the general case makes it much harder to track down the root cause of a > problem because many guest CPU instructions may be executed after the > original problem occurs. Other guest software may fail silently in > weird ways. IMO it's best to fail early. The current error message is quite limited in its usefulness - mostly you have to be able to google the message and hope to hit a previous report which explains the problem, or find someone on IRC who remembers the problem, etc. Could we put a text doc in the kernel tree explaining the problem in enough detail that people can identify their next steps to resolve it, and then make this error message tell people to read that text doc. Regards, Daniel -- |: https://berrange.com -o- https://www.flickr.com/photos/dberrange :| |: https://libvirt.org -o- https://fstop138.berrange.com :| |: https://entangle-photo.org -o- https://www.instagram.com/dberrange :|