Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4706700pxj; Wed, 12 May 2021 11:20:18 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzRV9Wh3RN54BGbsSMucRIst2KwC5IqnqmIyycVySn1g8MXzmTm+CIPkKGMd/szesK5xJyK X-Received: by 2002:aa7:d6d9:: with SMTP id x25mr45599883edr.305.1620843618181; Wed, 12 May 2021 11:20:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620843618; cv=none; d=google.com; s=arc-20160816; b=QOkCTptTYOZBUXxTSoM4nqt4raKgfnozY816MgBFV6qJ+GF9uoxvbIkE5x4Ns+fKCs fRf59OR/1IZlHG6Ft9Xaa6LqzGLXZ3iHvSARrzBOE7aNa+icOyVpyCqtJsWHjSHhjtw8 p2f12PSqismnUyRqEMxFebbH4mV444kv0FHjjBLtF08Ad0Bj4AgdoEk982OIpGntvRo7 yaWJz1gQ06NIddoLVJBE/GtpTZTjXBeZpKK5NwdVJGZ6xb8a7X/rxb29moFUvS88zJFy dwoEVXF0I9nstdqNRspWU3q6I139E1E4Spxc9VCiUDNovNNmYih1WJJyvF2VaGQS6OiN 2gcA== 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=ASUN+MT51JVvwCHEd8pEr8yHfRU0EYFCwVqyjqYQx6Pq2IoPGXLeRAyoSL5q4+cDqa JGz3SYdBSDQVhzOGq7T2NSawb5uFLoAsoFposW2RoSJASy3QUmxDPomLdGWs8f4I6Pfx WK3NyEFaHiulvx+UjSNwfqJ29ononcPERgefO4g/+f44G4vetLJL/ELpQg2Iv3PoJU7J GBJrZiaPBSkRKa9/7DH4DKaadWDMYfORbqacr4DOSoKR3sydgX2MM23ejH4RbbhTvomD sDZ26M0AvWQzzBelJHUylfth8UPWeaYoLHALJ3IJr0uKVDyUL1Yp0zRWvj4na5t25evC Jp2A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="dPEel/K8"; 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 sb14si490161ejb.322.2021.05.12.11.19.53; Wed, 12 May 2021 11:20:18 -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="dPEel/K8"; 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 S1353986AbhELSQJ (ORCPT + 99 others); Wed, 12 May 2021 14:16:09 -0400 Received: from mail.kernel.org ([198.145.29.99]:44850 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241189AbhELQ0t (ORCPT ); Wed, 12 May 2021 12:26:49 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 388E161554; Wed, 12 May 2021 15:50:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620834619; bh=Zi3dydaXI06i0eQgVxWiAOpGUlzb5Slw37i/xhO1EFE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=dPEel/K8s0KqpbfmaH62Jn3gTLUu9/Hiq9P9rBgV1tEGitb+FBLLqXfsd4JTfE2CW R8WUL7STwrq21gtQ2OmQ9qsFgnOcg/sSpuaL0EvSH0RmuAnVC99CKlIOYL+wG2Ow3O KNDG5W7UO2WmfFcblHGnoZ0XdFmgdbNUuQwty2ts= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Johan Hovold Subject: [PATCH 5.12 017/677] staging: fwserial: fix TIOCSSERIAL permission check Date: Wed, 12 May 2021 16:41:03 +0200 Message-Id: <20210512144837.798396284@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210512144837.204217980@linuxfoundation.org> References: <20210512144837.204217980@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;