Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp3758454pxk; Tue, 29 Sep 2020 05:41:06 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxQnKhH8+HEGvZQqoew0x1JFo6bR1Tofc+EHPFmFdo8CPjzcOLLqc/pfK61r/Z9BiHk7Jqb X-Received: by 2002:a05:6402:1acf:: with SMTP id ba15mr3124949edb.305.1601383266183; Tue, 29 Sep 2020 05:41:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601383266; cv=none; d=google.com; s=arc-20160816; b=YDUiXrg7gy5V+CTBIa80gbVcn1uX/nXavwaYTwOIeHtJmI9VqTtshiUAqTyC7jglsp o1lA7DNyibON9e0AHmyoXB/Pq3VgMbc/y9p7KqHz3Hlul1Tnp5sdto2dtLRX67YB4PtX yjGRcta1anK1OMU6HtK3cww9r7HBwO2gFArDqJKDH6mHhxcgz6kA4MEVcITjndxs5dFo RXO3DrjIKoj0wr8IA8PU41bhfN1kSDWhixr8ZtvtzxIfO1VzNTU/r09+AzzqW9wWEDIk ae7Asv23p9zNB81rz5g3k7MpICNyufsMnVZ9sSHHfSUCGTcgre63y2IvE3Ab5IAtXtjh RNww== 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=vEsfToOzWgQzVlqPIOskb1/FxtUA9rYNUa3hygOWICY=; b=pnY3969bPzCWJ26ogGi4ISOpgTAGuIiY3VOPkzlWEiaVb59ZP1WzKKZAt/1zMSP6eW 6LAb3jAFJ4Wpb4yPFkxBTVgYblUnAb7CgK1EzU0jVnqndxIAUmk5Rls+YWTeD6+pSamV F4eBvOij3ZgszkhoaASUVlfMvZPhMpdNtDrbBSokU7FScHR5eZ1aIDgF/eN6tU7pl70S EuY3/2pY5VLZNa2nozAttZpxG53SuAO8XLHCmKSq433QisWqnmeMN+cuZwQ9xpj6WQVH hH+Rhi/ckFhRPS4gnCyoh2rtxwC5H6j5MUhulOjs1UpexXVxrQZPhJVZOGeal9C0EGr9 k4jw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=QM1UcQkX; 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=fail (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 k15si2696246eji.77.2020.09.29.05.40.43; Tue, 29 Sep 2020 05:41:06 -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=@kernel.org header.s=default header.b=QM1UcQkX; 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=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732434AbgI2Mjt (ORCPT + 99 others); Tue, 29 Sep 2020 08:39:49 -0400 Received: from mail.kernel.org ([198.145.29.99]:32906 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729121AbgI2LQW (ORCPT ); Tue, 29 Sep 2020 07:16:22 -0400 Received: from localhost (83-86-74-64.cable.dynamic.v4.ziggo.nl [83.86.74.64]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 5396F2083B; Tue, 29 Sep 2020 11:16:21 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1601378181; bh=x8jtC8Q1lphuUcKtQz2n3M+Vhekuau3Ukrj1emkaMfk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=QM1UcQkXRcGv0CGEJPWuUGKYWdImN/l7yHaTx/y+r/i8epv+yu7I1/YpipV556KAn acn/vwkl58lEaJAYygDfS0tWZIGBdVo0a0jNi6a731pd4L7359qplEeawXFKv3J15n zT2G6RW3lEAXAytw69CQOFk02fI3QRiaKUpiofik= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Vasily Averin , Stephen Smalley , Paul Moore , Sasha Levin Subject: [PATCH 4.14 061/166] selinux: sel_avc_get_stat_idx should increase position index Date: Tue, 29 Sep 2020 12:59:33 +0200 Message-Id: <20200929105938.267950074@linuxfoundation.org> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20200929105935.184737111@linuxfoundation.org> References: <20200929105935.184737111@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: Vasily Averin [ Upstream commit 8d269a8e2a8f0bca89022f4ec98de460acb90365 ] If seq_file .next function does not change position index, read after some lseek can generate unexpected output. $ dd if=/sys/fs/selinux/avc/cache_stats # usual output lookups hits misses allocations reclaims frees 817223 810034 7189 7189 6992 7037 1934894 1926896 7998 7998 7632 7683 1322812 1317176 5636 5636 5456 5507 1560571 1551548 9023 9023 9056 9115 0+1 records in 0+1 records out 189 bytes copied, 5,1564e-05 s, 3,7 MB/s $# read after lseek to midle of last line $ dd if=/sys/fs/selinux/avc/cache_stats bs=180 skip=1 dd: /sys/fs/selinux/avc/cache_stats: cannot skip to specified offset 056 9115 <<<< end of last line 1560571 1551548 9023 9023 9056 9115 <<< whole last line once again 0+1 records in 0+1 records out 45 bytes copied, 8,7221e-05 s, 516 kB/s $# read after lseek beyond end of of file $ dd if=/sys/fs/selinux/avc/cache_stats bs=1000 skip=1 dd: /sys/fs/selinux/avc/cache_stats: cannot skip to specified offset 1560571 1551548 9023 9023 9056 9115 <<<< generates whole last line 0+1 records in 0+1 records out 36 bytes copied, 9,0934e-05 s, 396 kB/s https://bugzilla.kernel.org/show_bug.cgi?id=206283 Signed-off-by: Vasily Averin Acked-by: Stephen Smalley Signed-off-by: Paul Moore Signed-off-by: Sasha Levin --- security/selinux/selinuxfs.c | 1 + 1 file changed, 1 insertion(+) diff --git a/security/selinux/selinuxfs.c b/security/selinux/selinuxfs.c index 00eed842c491c..bf50fead9f8c0 100644 --- a/security/selinux/selinuxfs.c +++ b/security/selinux/selinuxfs.c @@ -1425,6 +1425,7 @@ static struct avc_cache_stats *sel_avc_get_stat_idx(loff_t *idx) *idx = cpu + 1; return &per_cpu(avc_cache_stats, cpu); } + (*idx)++; return NULL; } -- 2.25.1