Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4546438pxj; Wed, 12 May 2021 07:57:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzfxjl9VVUtzIN+h/S9QIRex9qn5YqGaAv/U6R/Hqf3z+V0Fuoax6AtQnBJK/rNLuEVxlDn X-Received: by 2002:a05:6830:10:: with SMTP id c16mr7976489otp.252.1620831440210; Wed, 12 May 2021 07:57:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620831440; cv=none; d=google.com; s=arc-20160816; b=l57l00opeeQqGXo+67elTq1ekE3qpFhH/fqjF85LxRgCgmjgJAIoitmdrU/ycObMKY QPv/LLz1pgmIcXjT0Qqmzh+sCgoFznBlRxMtqx7rTguFqO8M8c0nb6omE6/hBJlDe8U0 3lmSrJHcsJCizBLzv96QQ198j0KkEHPJ3dxlPvPxEJmaFuKgSC4CFZG0aMcOT7cdYngt hfxv+o/wL1tlEOqpCLBu0NLr60ShNwf14wmBz3bVAsnbA69r4rvsNHcKI54Rg74N72+A Ihua+gezNKe+eZaxk5YIbyH1uF0copJ/6xCk53TfZIam3ZVyp0NEDnZvm05k641VDCBW xZpQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=Db8wCROjFrSXnBtzGPz+kanMuiAGndTYEZnnMU/eGsc=; b=Ha5lOw+PchjdvKNVRE5rOySxAuoFWc8wwfjIjA5Umhb6qNxJ0tta44eCLJRMI6IQ/f bqbrwKNLkjslbt9CFK3phgNvKmp1IPmQ3Ik/nL6EBA2Rg4JIei0tAsqT0l4dwuA6EIn+ T8cAw6z0bIqb5O7nE/imahPhn+AW5h6x7asjka0TUtS2cDalL/PPNTKJ5sKnZNSxg/Lf ciGJ9sjim097tSlBZuNmUbXdXX2Ft64jKvE/M8tV2XGffxoP3C8ksQUZ+3ClCcdzfwR8 hW3Gj+z9+XjQ3wFJgCU5RgfF2W6QpveAljhxEkd+KFw6wRpvv9apga3jjC86+xao6Orq do9g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=0JOZrk74; 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=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v11si162581oor.49.2021.05.12.07.57.05; Wed, 12 May 2021 07:57:20 -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=@linuxfoundation.org header.s=korg header.b=0JOZrk74; 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=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231296AbhELO4s (ORCPT + 99 others); Wed, 12 May 2021 10:56:48 -0400 Received: from mail.kernel.org ([198.145.29.99]:46036 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232148AbhELOz3 (ORCPT ); Wed, 12 May 2021 10:55:29 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 4C9036141C; Wed, 12 May 2021 14:54:20 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620831260; bh=Zi3dydaXI06i0eQgVxWiAOpGUlzb5Slw37i/xhO1EFE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=0JOZrk74pdxvo5KML4sI5MtuUOz/fvDzwL/DTHNpuVE9RyjuPD1Xmov/tpFt8b2iu EY6Ky4hn0iBt9BjDOqv0i83X21a7DWHwJ7hixlH0nMpIgCZChrdxDwMql4BFeWl+QT sFtm+Y6BELo5x0dsHu4uLrKcDgrS76vTHqtSMP4g= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Johan Hovold Subject: [PATCH 5.4 013/244] staging: fwserial: fix TIOCSSERIAL permission check Date: Wed, 12 May 2021 16:46:24 +0200 Message-Id: <20210512144743.467783143@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210512144743.039977287@linuxfoundation.org> References: <20210512144743.039977287@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Johan Hovold commit 2104eb283df66a482b60254299acbe3c68c03412 upstream. Changing the port close-delay parameter is a privileged operation so make sure to return -EPERM if a regular user tries to change it. Fixes: 7355ba3445f2 ("staging: fwserial: Add TTY-over-Firewire serial driver") Cc: stable@vger.kernel.org # 3.8 Signed-off-by: Johan Hovold Link: https://lore.kernel.org/r/20210407102334.32361-3-johan@kernel.org Signed-off-by: Greg Kroah-Hartman --- drivers/staging/fwserial/fwserial.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) --- a/drivers/staging/fwserial/fwserial.c +++ b/drivers/staging/fwserial/fwserial.c @@ -1232,20 +1232,24 @@ static int set_serial_info(struct tty_st struct serial_struct *ss) { struct fwtty_port *port = tty->driver_data; + unsigned int cdelay; if (ss->irq != 0 || ss->port != 0 || ss->custom_divisor != 0 || ss->baud_base != 400000000) return -EPERM; + cdelay = msecs_to_jiffies(ss->close_delay * 10); + mutex_lock(&port->port.mutex); if (!capable(CAP_SYS_ADMIN)) { - if (((ss->flags & ~ASYNC_USR_MASK) != + if (cdelay != port->port.close_delay || + ((ss->flags & ~ASYNC_USR_MASK) != (port->port.flags & ~ASYNC_USR_MASK))) { mutex_unlock(&port->port.mutex); return -EPERM; } } - port->port.close_delay = msecs_to_jiffies(ss->close_delay * 10); + port->port.close_delay = cdelay; mutex_unlock(&port->port.mutex); return 0;