Received: by 10.192.165.148 with SMTP id m20csp637119imm; Fri, 4 May 2018 04:03:08 -0700 (PDT) X-Google-Smtp-Source: AB8JxZpg6Rsx6Rx+YnnY1nN8Pxt2WxSWKw53JoNbGMVzTYDmW5Nc1u98RsQ2v9prbZROybfFAZe/ X-Received: by 2002:a65:62d9:: with SMTP id m25-v6mr5070013pgv.407.1525431788549; Fri, 04 May 2018 04:03:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525431788; cv=none; d=google.com; s=arc-20160816; b=xFRe3H/7i5kUrnQUlUcJJS22MWctGPSCfTii/uwmDmmUAUC3UvIOyHnbIw65l9gIQ0 z61cDfdt6qO8p1mnmuA5fTiKqKHbRdfienRoEPJSRKvh3kLeRjEx2LY1MGGrfUFgjU2o uSqtdEnD7f9+k0ETeZifcQ5QEkC9jNWfi5FJ5U1R8rDJe08Bt7sSB+ZcENm8BF4cJ6V/ rsFL+p9b5mOeW0uz7N1tzP8VNm+IrTbroqA3VzlbhKW71jh23jxDn3pSj8vmuEePBt81 7cdIhI8NOsiTF5HRNId4/sX4iUiunj82gSVyy2dztOdCzaRb+5zhCFpiY9dpmcerNqgD gCsQ== 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-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :from:references:cc:to:subject:arc-authentication-results; bh=ITafTmksY1ZvPM3Z0PnN7yemybjRyzUl5mbwFt/y89c=; b=EVV8JaJk5KcZIl4kk/blFoNqS10g682JrHruR/y2kd2nglt2vYdahiCdvuMOp0SZaQ HiwMYEbNtU7uRINaxQoK/mcEpbPuL80O15ZRg+x2Zhyzp0YVpxyne9jdgg38Y6gEfj8p 4tCg1DSoLGHa6wiJiNcYjErkqZ4FtOg1bLfxTBaz4UMGij4YubHQcE9P5WtlGQEqh920 9hP4bfi4Q7LEma/N541xsid+hdgHapLTU/O9Ro9rNY0ToFymyBWzFx0eYMCqv20JSF0W wW3vQk1FlxN6mvFdpzrLcVQ4mrLgVtIrxssJwXqEnLm9LoIQ+WvQMwq7O5qwHiPLuRl3 3WsQ== 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 i14-v6si12884538pgf.284.2018.05.04.04.02.53; Fri, 04 May 2018 04:03:08 -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 S1751287AbeEDLCp (ORCPT + 99 others); Fri, 4 May 2018 07:02:45 -0400 Received: from mx0a-001b2d01.pphosted.com ([148.163.156.1]:54054 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751001AbeEDLCn (ORCPT ); Fri, 4 May 2018 07:02:43 -0400 Received: from pps.filterd (m0098393.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.16.0.22/8.16.0.22) with SMTP id w44B2btM047901 for ; Fri, 4 May 2018 07:02:42 -0400 Received: from e06smtp13.uk.ibm.com (e06smtp13.uk.ibm.com [195.75.94.109]) by mx0a-001b2d01.pphosted.com with ESMTP id 2hrnhrsspg-1 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=NOT) for ; Fri, 04 May 2018 07:02:42 -0400 Received: from localhost by e06smtp13.uk.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Fri, 4 May 2018 12:02:40 +0100 Received: from b06cxnps3075.portsmouth.uk.ibm.com (9.149.109.195) by e06smtp13.uk.ibm.com (192.168.101.143) with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted; Fri, 4 May 2018 12:02:37 +0100 Received: from d06av24.portsmouth.uk.ibm.com (d06av24.portsmouth.uk.ibm.com [9.149.105.60]) by b06cxnps3075.portsmouth.uk.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id w44B2bxT62586962; Fri, 4 May 2018 11:02:37 GMT Received: from d06av24.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 7DCF74204F; Fri, 4 May 2018 11:53:46 +0100 (BST) Received: from d06av24.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 3274E42042; Fri, 4 May 2018 11:53:46 +0100 (BST) Received: from [9.152.224.33] (unknown [9.152.224.33]) by d06av24.portsmouth.uk.ibm.com (Postfix) with ESMTP; Fri, 4 May 2018 11:53:46 +0100 (BST) Subject: Re: [PATCH 04/10] vfio: ccw: replace IO_REQ event with SSCH_REQ event To: Dong Jia Shi Cc: Dong Jia Shi , Cornelia Huck , pasic@linux.vnet.ibm.com, linux-s390@vger.kernel.org, linux-kernel@vger.kernel.org, kvm@vger.kernel.org References: <1524149293-12658-1-git-send-email-pmorel@linux.vnet.ibm.com> <1524149293-12658-5-git-send-email-pmorel@linux.vnet.ibm.com> <20180426073053.GZ12194@bjsdjshi@linux.vnet.ibm.com> <20180426074806.GB12194@bjsdjshi@linux.vnet.ibm.com> <20180430173305.632faa80.cohuck@redhat.com> <20180502074622.GV5428@bjsdjshi@linux.vnet.ibm.com> <5816643d-5406-06b9-0727-fdcd771aba63@linux.vnet.ibm.com> <20180504011916.GA26081@bjsdjshi@linux.ibm.com> From: Pierre Morel Date: Fri, 4 May 2018 13:02:36 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.7.0 MIME-Version: 1.0 In-Reply-To: <20180504011916.GA26081@bjsdjshi@linux.ibm.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US X-TM-AS-GCONF: 00 x-cbid: 18050411-0012-0000-0000-000005D1EFEF X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 18050411-0013-0000-0000-0000194F1CB1 Message-Id: <8c75acd1-c00b-4d7f-ea4b-d32e9b05989b@linux.vnet.ibm.com> X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:,, definitions=2018-05-04_03:,, 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 impostorscore=0 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1709140000 definitions=main-1805040101 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 04/05/2018 03:19, Dong Jia Shi wrote: > * Pierre Morel [2018-05-03 16:26:29 +0200]: > >> On 02/05/2018 09:46, Dong Jia Shi wrote: >>> * Cornelia Huck [2018-04-30 17:33:05 +0200]: >>> >>>> On Thu, 26 Apr 2018 15:48:06 +0800 >>>> Dong Jia Shi wrote: >>>> >>>>> * Dong Jia Shi [2018-04-26 15:30:54 +0800]: >>>>> >>>>> [...] >>>>> >>>>>>> @@ -179,7 +160,7 @@ static int fsm_irq(struct vfio_ccw_private *private, >>>>>>> if (private->io_trigger) >>>>>>> eventfd_signal(private->io_trigger, 1); >>>>>>> >>>>>>> - return private->state; >>>>>>> + return VFIO_CCW_STATE_IDLE; >>>>>> This is not right. For example, if we are in STANDBY state (subch driver >>>>>> is probed, but mdev device is not created), we can not jump to IDLE >>>>>> state. >>>>> I see my problem, for STANDBY state, we should introduce another event >>>>> callback for VFIO_CCW_EVENT_INTERRUPT. It doesn't make sense to call >>>>> fsm_irq() which tries to signal userspace with interrupt notification >>>>> when mdev is not created yet... So we'd need a separated fix for this >>>>> issue too. >>>> But how do we even get into that situation when we don't have an mdev >>>> yet? >>>> >>> We cann't... So let's assign fsm_nop() as the interrupt callback for >>> STANDBY state? >>> >> :) Isn't it exactly what my patch series handle? > As far as I see, that's not true. ;) > > After this series applied, > vfio_ccw_jumptable[VFIO_CCW_STATE_STANDBY][VFIO_CCW_EVENT_INTERRUPT] is > still fsm_irq(). > What I mean is, this code tries to handle design problems without changing too much of the original code at first. The problem here is not that the fsm_irq function is called on interrupt, if we have an interrupt it must be signaled to user land. The problem is that this state is entered at the wrong moment. STANDBY should be entered, during the mdev_open when we realize the QEMU device, and not during the probe, in which we should stay in NOT_OPER until we get the QEMU device. The probe() and mdev_open() function should be modified, not the state table. Regards, Pierre -- Pierre Morel Linux/KVM/QEMU in Böblingen - Germany