Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1750964AbdGZGFh (ORCPT ); Wed, 26 Jul 2017 02:05:37 -0400 Received: from mx0a-001b2d01.pphosted.com ([148.163.156.1]:35657 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750826AbdGZGFf (ORCPT ); Wed, 26 Jul 2017 02:05:35 -0400 Date: Wed, 26 Jul 2017 08:05:27 +0200 From: Heiko Carstens To: Martin Schwidefsky Cc: Guenter Roeck , linux-kernel@vger.kernel.org, linux-s390@vger.kernel.org Subject: Re: Qemu problems in -next with 's390/spinlock: add niai spinlock hints' References: <20170726011451.GA24947@roeck-us.net> <20170726050033.GA3218@osiris> <20170726074044.41bdc796@mschwideX1> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20170726074044.41bdc796@mschwideX1> User-Agent: Mutt/1.5.24 (2015-08-30) X-TM-AS-GCONF: 00 x-cbid: 17072606-0040-0000-0000-000003C7426C X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 17072606-0041-0000-0000-000025C4ACB2 Message-Id: <20170726060527.GD3218@osiris> X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:,, definitions=2017-07-26_02:,, signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 spamscore=0 suspectscore=0 malwarescore=0 phishscore=0 adultscore=0 bulkscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1706020000 definitions=main-1707260092 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2021 Lines: 37 On Wed, Jul 26, 2017 at 07:40:44AM +0200, Martin Schwidefsky wrote: > On Wed, 26 Jul 2017 07:00:33 +0200 > Heiko Carstens wrote: > > > On Tue, Jul 25, 2017 at 06:14:51PM -0700, Guenter Roeck wrote: > > > Hi Martin, > > > > > > my s390 qemu tests in linux-next stopped working a few days ago. > > > Bisect points to commit 's390/spinlock: add niai spinlock hints'. > > > > > > Looking at the patch, this isn't really surprising; at least to me it looks > > > like the patch is making instructions mandatory which are only available in > > > Z14 CPUs. Does this mean that older s390 CPUs (such as the Z900 used in my > > > qemu tests) are no longer going to be supported in Linux ? > > > > No, that means that the patch has a bug. The NIAI instruction is only > > available if the execution-hint facility is installed. That facility came > > with zEC12. Luckily it uses the same facility indicator bit like the > > miscellaneous-instruction-extensions facility, which we already use anyway > > if the kernel gets compiled for zEC12. In that case we have early code > > which verifies if all required facilities to run the kernel are installed, > > and if not it will print a message to the console and stop the machine. > > > > So the easiest fix would be to generate the NIAI instruction only if the > > kernel gets compiled for zEC12 or newer. > > Hmm, I though that NIAI is a NOP on older machines. A runtime check for > the facility bit is out of the question as the NIAI-7 gets inlined in > the spin_unlock code. So yes, the only available fix is to make the > NIAI hinting conditional on zEC12. Which is quite ugly as we would need > an architecture level set to zEC12 for the distribution kernel to make > use of NIAI. Alternatively you could generate a four-byte nop, and replace that at IPL time with the needed NIAI instruction, if the facility is available. Some sort of "alternative" code patching infrastructure that x86 already has. Not sure if it is worth it, however...