Received: by 2002:a05:6520:4211:b029:f4:110d:56bc with SMTP id o17csp1619899lkv; Wed, 19 May 2021 14:13:27 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw2kfofDT+CuenmCATm1Ke1Ugxvxa+X6G8WT91t4DRk3kMhRKwAh12bYJnLygop7s1Ie+l0 X-Received: by 2002:a05:6602:1223:: with SMTP id z3mr1723797iot.97.1621458807649; Wed, 19 May 2021 14:13:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621458807; cv=none; d=google.com; s=arc-20160816; b=U2SWUos1EdSIQoxI3/FV8eV0Ig93Jme4qT2mkQRh57W2GpF1B7GoUp1/3WE9GgNU2v Vsce4Rkr60tXqEpRgWjLxX2cciDdxHdcVE46vqUrpGhaUwNAFiswy/HghYw+DeqwZ4FP WL29JjZdsO0SNvgzHuOo6kYH5W5no8Y9R3eimEOJo2eZ/1LmVuH9l11IojW1Sd6EFaO9 I1AVtaElb2tRvPo0Od+q75xVpAiZjxEv2iwJs+YMn5PXORDK2t9I3HIwOCrhEyFSh8nI U2rqA7XPFNILKhHFQ/XRoiHba0PSTl64peuiVP2ShOKwKwOMMv4mnv6oYMh3VxFspN+n wntQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=awY+ia0X5V2PMZw9CViuEIoYymBZhpNSbICZiHEMEkA=; b=rVFCo5A3VEZ4Ic98O9beSOZv4m0EXC6mIGkRo95AdeQaFKHcZC1Q5wrI4km1M9F6+/ PyTZgeX96BGAm9YDj0B9CSFmsNb4JmE5zzespWBY+vkcp55AEqyZFPLy+gDv2a3pMQG5 M9Segmsyo72lMnOjj/cwwSLH5Y/8KQwMy+kOT+byjTQSeIDpryNYZn9Naqclvpat3O1v /SsFcvM3x0zCEqB0upjLKa5+wv/1KfZfvzBl5FAcCt5+ZjAKURQvMZ6FlSSeNWCW9XYJ eUztFgrm6sZFnf66ddSMBkQ5WgzaInYPZaT0GZQB+NHKP2JBkFyr2ne6/ek77XjCvTav QxZQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b="J5/iJCbT"; 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 e194si500877iof.53.2021.05.19.14.13.07; Wed, 19 May 2021 14:13:27 -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="J5/iJCbT"; 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 S1353536AbhESNNa (ORCPT + 99 others); Wed, 19 May 2021 09:13:30 -0400 Received: from us-smtp-delivery-124.mimecast.com ([216.205.24.124]:49369 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1353541AbhESNN3 (ORCPT ); Wed, 19 May 2021 09:13:29 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1621429929; 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=awY+ia0X5V2PMZw9CViuEIoYymBZhpNSbICZiHEMEkA=; b=J5/iJCbTTIdOm6icSqplIn/NyP6jeGL1jWJfPDB++j+XafGY+4etryt9EPHJdvuKTlMlJR SOKCUoxr8xo5z9uWpp9kU57umlquJG2ceYrzXL3DnEVHXN9ZRayAT4YkSvHnHxtk9CL6Q8 qcx1638a7SBvgifPeliD7+Rb5ZIefVw= Received: from mail-ed1-f71.google.com (mail-ed1-f71.google.com [209.85.208.71]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-505-8CuZ5eHpN0S2QZ_UJocz0Q-1; Wed, 19 May 2021 09:12:08 -0400 X-MC-Unique: 8CuZ5eHpN0S2QZ_UJocz0Q-1 Received: by mail-ed1-f71.google.com with SMTP id q18-20020a50cc920000b029038cf491864cso7635540edi.14 for ; Wed, 19 May 2021 06:12:07 -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-language :content-transfer-encoding; bh=awY+ia0X5V2PMZw9CViuEIoYymBZhpNSbICZiHEMEkA=; b=qHC55UejnMeuBd+JS3iN3vJCo2ahVRYO4RLH1XygOEAye+ekPJ3VXjm0pKoVgq+Wi7 N2+0aGGPwZRCbAPDvz4YEMq8byI6PMjLv6+lpoowXR6dM+wCdctsWZW9d1FQMEKhEWdz q5cWBi0qVEto839D/mbK/Fn/SdTQU9WvvKag+jI6YlWf7KhJ9nO9TPP48V/svk5nyQzR AJpOpx4BQ/YJWZ9Mdc3gAAV5ilI4HvQ/pJTyw66n7zn29S+8ZJZF7d/C1EQTerUi/fdu HBcdD5nVHPkQnDCfCatSnliu4v58mvh29PnzMCX1r4d+wogrgLH1uhy281IlJKgCXGLx e/Hw== X-Gm-Message-State: AOAM531UsqhW5omliPDw6w2fDCX88ORdjQZlf61E9lafDPTsjCDLtSWd jtpnvaMX9OVxa2r6l1aRLv2a3MDuFT/aF5jD2YLe8Pws+HNqx0+Qw7ypbHP6y4rHVcdqz7Vxf2M veaYJJr5quRcf7dZXY68m7wpG X-Received: by 2002:a17:906:b756:: with SMTP id fx22mr11371744ejb.224.1621429925104; Wed, 19 May 2021 06:12:05 -0700 (PDT) X-Received: by 2002:a17:906:b756:: with SMTP id fx22mr11371673ejb.224.1621429924213; Wed, 19 May 2021 06:12:04 -0700 (PDT) Received: from x1.localdomain (2001-1c00-0c1e-bf00-1054-9d19-e0f0-8214.cable.dynamic.v6.ziggo.nl. [2001:1c00:c1e:bf00:1054:9d19:e0f0:8214]) by smtp.gmail.com with ESMTPSA id c3sm16426470edn.16.2021.05.19.06.12.03 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 19 May 2021 06:12:03 -0700 (PDT) Subject: Re: [PATCH] platform/surface: dtx: Fix poll function To: Maximilian Luz Cc: Mark Gross , platform-driver-x86@vger.kernel.org, linux-kernel@vger.kernel.org, kernel test robot References: <20210513134437.2431022-1-luzmaximilian@gmail.com> From: Hans de Goede Message-ID: Date: Wed, 19 May 2021 15:12:03 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.10.1 MIME-Version: 1.0 In-Reply-To: <20210513134437.2431022-1-luzmaximilian@gmail.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On 5/13/21 3:44 PM, Maximilian Luz wrote: > The poll function should not return -ERESTARTSYS. > > Furthermore, locking in this function is completely unnecessary. The > ddev->lock protects access to the main device and controller (ddev->dev > and ddev->ctrl), ensuring that both are and remain valid while being > accessed by clients. Both are, however, never accessed in the poll > function. The shutdown test (via atomic bit flags) be safely done > without locking, so drop locking here entirely. > > Reported-by: kernel test robot > Fixes: 1d609992832e ("platform/surface: Add DTX driver> Signed-off-by: Maximilian Luz Thank you for your patch, I've applied this patch to my review-hans branch: https://git.kernel.org/pub/scm/linux/kernel/git/pdx86/platform-drivers-x86.git/log/?h=review-hans I will also include this in the next pdx86-fixes pull-req for 5.13. Note it will show up in my review-hans branch once I've pushed my local branch there, which might take a while. Once I've run some tests on this branch the patches there will be added to the platform-drivers-x86/for-next branch and eventually will be included in the pdx86 pull-request to Linus for the next merge-window. Regards, Hans > --- > drivers/platform/surface/surface_dtx.c | 8 +------- > 1 file changed, 1 insertion(+), 7 deletions(-) > > diff --git a/drivers/platform/surface/surface_dtx.c b/drivers/platform/surface/surface_dtx.c > index 63ce587e79e3..5d9b758a99bb 100644 > --- a/drivers/platform/surface/surface_dtx.c > +++ b/drivers/platform/surface/surface_dtx.c > @@ -527,20 +527,14 @@ static __poll_t surface_dtx_poll(struct file *file, struct poll_table_struct *pt > struct sdtx_client *client = file->private_data; > __poll_t events = 0; > > - if (down_read_killable(&client->ddev->lock)) > - return -ERESTARTSYS; > - > - if (test_bit(SDTX_DEVICE_SHUTDOWN_BIT, &client->ddev->flags)) { > - up_read(&client->ddev->lock); > + if (test_bit(SDTX_DEVICE_SHUTDOWN_BIT, &client->ddev->flags)) > return EPOLLHUP | EPOLLERR; > - } > > poll_wait(file, &client->ddev->waitq, pt); > > if (!kfifo_is_empty(&client->buffer)) > events |= EPOLLIN | EPOLLRDNORM; > > - up_read(&client->ddev->lock); > return events; > } > >