Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp204094pxv; Wed, 14 Jul 2021 01:58:13 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzmjrZ/irvaj4BjG2iGwJEuMjjKN+0eNbz/7J9jojs77IjHjdiovLeQ8jcJRF/VDIwGPZ1V X-Received: by 2002:a02:a38f:: with SMTP id y15mr8208459jak.108.1626253093289; Wed, 14 Jul 2021 01:58:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626253093; cv=none; d=google.com; s=arc-20160816; b=a3LhfIyIpRo7qZoNaSbygrXJPC9/JWR7Spfs6e0IP08RFTqugpofNhysskpd89lgjb bX6d+9Z7pXYMmDJdkEKZ05F2u/7gIScmuiXORh+X3phtqy3bunUhIXuf2mCKyvLco9aP 2iF01shLIoqxkNZTajiJdqfDXIQna5SJYRlvUMTYux+lg97ZgZ4NzGGpZ2601SDJEW52 3T6y4ZGTaJSJqrhaXLAAF4Jq1QtUgWf8Va3UalWB2SHXlQfzI7ccbiYKjQHC3slEjuUH uQ6rWarT/nHqrR+Gum0ciBCCD1NOOqmtcL1xHIzHzE1ljP6dMX4f6QxTqiiNxPsz39mP ZIIQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:content-transfer-encoding :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=b67pj1XjCFcb4vjOC6L9gEcYmcQccLEDJzYb3n+c66I=; b=B6Ml9jr0Og+xgbECluin1pgm0ohZ/48b1mhjWs0c/rsDUGOFW3iCCX2Gajf2XV5XzO yw62qSP+qfCW+mcRk9To8qMWuK0Tt5tLiUaeUmPEoCbF57+mcY7bUZMklSXbkcNTu/yc wLtA4cd7CnMYWPvb9eVh+WjCugm9SB8mc2rf/5AxN18ZeV3+HsNIaCyymDEtmlZxBD8K F2noPb/yqoBO+pz8bbaBfhGw/D0w1m9Pl3AihYqwiCZhOQLtPEYhVMJwYfZSORcOytmT fKdmmcpGxBZIsELfDVknVQQWf2LzJoXmAWYF15twKFYMf7IJXBo2B+/5IDHKAWkVgzPF ww6A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=NbM7RsWJ; 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=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id x9si2124651jaf.48.2021.07.14.01.58.01; Wed, 14 Jul 2021 01:58:13 -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=@redhat.com header.s=mimecast20190719 header.b=NbM7RsWJ; 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=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238774AbhGNJAA (ORCPT + 99 others); Wed, 14 Jul 2021 05:00:00 -0400 Received: from us-smtp-delivery-124.mimecast.com ([170.10.133.124]:39546 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238690AbhGNI77 (ORCPT ); Wed, 14 Jul 2021 04:59:59 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1626253027; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=b67pj1XjCFcb4vjOC6L9gEcYmcQccLEDJzYb3n+c66I=; b=NbM7RsWJIkcbd7Zf5cmO5p7jU5A/21B5nXMLmMABf2kzFBvklDuZeVVCndeSpoPxUfe/QZ iu6ZRkJiVpc/afy5fVIVMD4+qqAe008dFOJV9uW6MyXqTj16gc5cL45GSZyjxGq4fZoCr+ c7NOxY6Tmua2w6uieEJKMkk4qz1OLHg= Received: from mail-pf1-f199.google.com (mail-pf1-f199.google.com [209.85.210.199]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-362-xvQPROIHPcm2xEJe1JMjGg-1; Wed, 14 Jul 2021 04:57:06 -0400 X-MC-Unique: xvQPROIHPcm2xEJe1JMjGg-1 Received: by mail-pf1-f199.google.com with SMTP id s5-20020aa78d450000b02902ace63a7e93so1151174pfe.8 for ; Wed, 14 Jul 2021 01:57:06 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-transfer-encoding :content-language; bh=b67pj1XjCFcb4vjOC6L9gEcYmcQccLEDJzYb3n+c66I=; b=SFXtqbd/vwB1tSWxSya5I2RGRwATS7cJ/+wU3XAwcfq7z/9kkBtT0kjojFmjlbOWGe 94EKlhcYTDwQG1TcTnFujdJ/U9JcYo1oijiuDHX7+lvGZMW6PaJzfdAEYUF3VGOpWL+G LTlCygZtYOcPEA+OjRmYFqNie9+9FN+n5GaOhxbJgl9Pn98uzHbD/O10Xmx5sG3jxHiT aHLFW3V3JKXc9jYtfdYTawaDP0XwsAZH86q8N3akdWU/DvLE3gWCmdX4aT53DyMDjiCb tZWdxZ5gsFVEseTVWAUSYhDm2K/MDv5H4i7Niy2zWSuz8Ixma2N8trqjLpgQZrGlu+cf rKUw== X-Gm-Message-State: AOAM530LighlbsU+oq9NMy5SmyMb9j4QoBu31BuYXFRMfvyRnj3bpW+x TyuCobTEu//JMy3VHv3wOX0mNC/jmTnDh9LMoEB3I0Mz1j7i2KELSx0jsYoc956iTGJXHfKiBx9 UGQgna8d2XYreCHU4u/8RqIQvRWlBkWVV4e73B6brqmDQN/iTQnYgj0tDHtv/srfk4AWPOXzfkY CH X-Received: by 2002:a17:90a:af90:: with SMTP id w16mr2814500pjq.129.1626253025406; Wed, 14 Jul 2021 01:57:05 -0700 (PDT) X-Received: by 2002:a17:90a:af90:: with SMTP id w16mr2814452pjq.129.1626253024987; Wed, 14 Jul 2021 01:57:04 -0700 (PDT) Received: from wangxiaodeMacBook-Air.local ([209.132.188.80]) by smtp.gmail.com with ESMTPSA id d2sm2127796pgh.59.2021.07.14.01.56.57 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 14 Jul 2021 01:57:04 -0700 (PDT) Subject: Re: [PATCH v9 16/17] vduse: Introduce VDUSE - vDPA Device in Userspace To: Greg KH Cc: "Michael S. Tsirkin" , Xie Yongji , stefanha@redhat.com, sgarzare@redhat.com, parav@nvidia.com, hch@infradead.org, christian.brauner@canonical.com, rdunlap@infradead.org, willy@infradead.org, viro@zeniv.linux.org.uk, axboe@kernel.dk, bcrl@kvack.org, corbet@lwn.net, mika.penttila@nextfour.com, dan.carpenter@oracle.com, joro@8bytes.org, zhe.he@windriver.com, xiaodong.liu@intel.com, songmuchun@bytedance.com, virtualization@lists.linux-foundation.org, netdev@vger.kernel.org, kvm@vger.kernel.org, linux-fsdevel@vger.kernel.org, iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org References: <20210713084656.232-1-xieyongji@bytedance.com> <20210713084656.232-17-xieyongji@bytedance.com> <26116714-f485-eeab-4939-71c4c10c30de@redhat.com> <20210714014817-mutt-send-email-mst@kernel.org> <0565ed6c-88e2-6d93-7cc6-7b4afaab599c@redhat.com> From: Jason Wang Message-ID: Date: Wed, 14 Jul 2021 16:56:55 +0800 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:78.0) Gecko/20100101 Thunderbird/78.11.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 在 2021/7/14 下午2:47, Greg KH 写道: > On Wed, Jul 14, 2021 at 02:02:50PM +0800, Jason Wang wrote: >> 在 2021/7/14 下午1:54, Michael S. Tsirkin 写道: >>> On Wed, Jul 14, 2021 at 01:45:39PM +0800, Jason Wang wrote: >>>>> +static int vduse_dev_msg_sync(struct vduse_dev *dev, >>>>> + struct vduse_dev_msg *msg) >>>>> +{ >>>>> + int ret; >>>>> + >>>>> + init_waitqueue_head(&msg->waitq); >>>>> + spin_lock(&dev->msg_lock); >>>>> + msg->req.request_id = dev->msg_unique++; >>>>> + vduse_enqueue_msg(&dev->send_list, msg); >>>>> + wake_up(&dev->waitq); >>>>> + spin_unlock(&dev->msg_lock); >>>>> + >>>>> + wait_event_killable_timeout(msg->waitq, msg->completed, >>>>> + VDUSE_REQUEST_TIMEOUT * HZ); >>>>> + spin_lock(&dev->msg_lock); >>>>> + if (!msg->completed) { >>>>> + list_del(&msg->list); >>>>> + msg->resp.result = VDUSE_REQ_RESULT_FAILED; >>>>> + } >>>>> + ret = (msg->resp.result == VDUSE_REQ_RESULT_OK) ? 0 : -EIO; >>>> I think we should mark the device as malfunction when there is a timeout and >>>> forbid any userspace operations except for the destroy aftwards for safety. >>> This looks like if one tried to run gdb on the program the behaviour >>> will change completely because kernel wants it to respond within >>> specific time. Looks like a receipe for heisenbugs. >>> >>> Let's not build interfaces with arbitrary timeouts like that. >>> Interruptible wait exists for this very reason. >> >> The problem is. Do we want userspace program like modprobe to be stuck for >> indefinite time and expect the administrator to kill that? > Why would modprobe be stuck for forever? > > Is this on the module probe path? Yes, it is called in the device probing path where the kernel forwards the device configuration request to userspace and wait for its response. If it turns out to be tricky, we can implement the whole device inside the kernel and leave only the datapath in the userspace (as what TUN did). Thanks >