Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp1222346pxj; Fri, 18 Jun 2021 02:17:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyF4qwwW1g1TgUJiariRF1C2CSnZJsUBVkpXCjlzhw2lzS+GTOWCszJCOxVyE72iIv7pqVc X-Received: by 2002:a05:6402:68a:: with SMTP id f10mr1955456edy.99.1624007858923; Fri, 18 Jun 2021 02:17:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1624007858; cv=none; d=google.com; s=arc-20160816; b=CeQRtfNL169pXoKScTMuD/BAbDlR6DmjcnLJ0RlfYKAdGOw3fNC6XquZSBKBrg5318 HE3yUs3zUYcQYXf20i3hZOdO+idp5JxbuVZZ+RfsnAHKoB7Us4URk9awu6g9+n6l8jfo Ixq9WSvihO7Qp5GhBQfHmXkoCJ3/yFOytXUf695g3da/LlVK8qlcFMO+dZBytgE1gpPG dVykfvomQcByJyL4uESM7f1El0r8KD+/ou8qDGCUq8t9kjlCLMc7x8xX+Pr5ZmwGuwbn XytlJFSbW7hd1mPVQBblPsBPGSSiCUWG9WkapTlYmUnwlThGDKXUTOWN5Kaa2i14G4iN b5jw== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=dO9vd7sYPzUkbEGL9cf5HXTiOWzCKdLCgZPTGvHdqSI=; b=0LasN32ZrTboe7ohfnw2bVQZK75gNfFR04HbeV/0fku3ItdOt5Y5gN+KPSlm2sxTte kyn4zS/X/zRb1/oTGpiI2IJV5wMQ4ygCo4FB12cO5xY7McqUt3Rv42V220A0KgSEGn28 VGLaxKqXQnPmAfNZ7q6GYNy+yjW0iJ1+D4czhzrmDWcdVNVxk9VY56WHS8wzXIbCeXJK 1yQsE6nVLPyNJgu1bBNmRG+U8ns/M+uGH5R7qGsSA2tpEwY5Ey8gm/9Ij2njN1QTQXI+ xlFN0q9JY0v/5gboOIfOSqZfSNEoazc5eKbZR69XidMNRxLO/MnCVTfze/7S5AhQEt1d ZTPw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=qf3WPuQb; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g12si3847772edp.580.2021.06.18.02.17.16; Fri, 18 Jun 2021 02:17:38 -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=@gmail.com header.s=20161025 header.b=qf3WPuQb; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232571AbhFRIBo (ORCPT + 99 others); Fri, 18 Jun 2021 04:01:44 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41910 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232455AbhFRIBm (ORCPT ); Fri, 18 Jun 2021 04:01:42 -0400 Received: from mail-pg1-x533.google.com (mail-pg1-x533.google.com [IPv6:2607:f8b0:4864:20::533]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 6A363C061574; Fri, 18 Jun 2021 00:59:32 -0700 (PDT) Received: by mail-pg1-x533.google.com with SMTP id e33so7153396pgm.3; Fri, 18 Jun 2021 00:59:32 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=dO9vd7sYPzUkbEGL9cf5HXTiOWzCKdLCgZPTGvHdqSI=; b=qf3WPuQbi1rO7hQHqHTLHqAPpN4YDpZI4MQmpdNeabsd9uDI+8MRBjKHkqKV9baqxA UjRcsfV5si/2LZrZVEgALCDmdsaQrFMOJNACRjQj+vaIF01Iqd1Q2yZi7QtjhzK4FiTS 2FS2OC11ZqzX0eVVOlTO8Ix15oRpHN2wsNxP26BAMvo3dMgS9Y5l75qeb04f8wsd0UvN 7Snw/QtYpxmbSR3LQT6Du+1r9ZIguTpvTkh/1X5/zLQfLplXWAaXs37U8r73IYw4m5U2 n3THln3WKLX2pZvZvh2kKOJE0WCnIJRZGD2xpnvznjPPgFurNnU4hroCUfARYkkMDRb+ AaFA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=dO9vd7sYPzUkbEGL9cf5HXTiOWzCKdLCgZPTGvHdqSI=; b=uPqxXsfw8TRQtQvHo7olB29SPh1faJriQGHQ4MPgF+/m9rK7ZJ1a/g1GPQ/Ila7kUt i8ZjuD+G2m62ZyQeOe2/R+se1d48ECy98hS24Nvaq9ocCsX1WUf+zgEIq4McMiobZTM5 B7oRsoTkg+Z8Je08fgj7chH2Jpj4cgnlph0pzYXlLp9OtSUj8lF7FHKQVmSR7ztIoPiM OVS4ZY/pYPW9Cp7XWKK93cAmq4HuSODr4pybi3QvtaIOsJvH3LOEynTkA7uWCxDL+B/8 khOXoBw3IkwoQEQ8zFSOGCNBlCjPv3a3XpfaWwmX9b76pcbkIz0A3m3rf1lJAiFW9pRY l5Vw== X-Gm-Message-State: AOAM533fxf5ypRkztgZzntY+5NsUHG6SwhsdN1HH7w0MBAGKkXI0jzxZ HPvhgiKnXDz157fCPq/Zhjc= X-Received: by 2002:a05:6a00:1789:b029:2f4:cb41:ec1d with SMTP id s9-20020a056a001789b02902f4cb41ec1dmr3805646pfg.3.1624003171965; Fri, 18 Jun 2021 00:59:31 -0700 (PDT) Received: from localhost.localdomain (220-130-175-235.HINET-IP.hinet.net. [220.130.175.235]) by smtp.gmail.com with ESMTPSA id 195sm412598pfw.133.2021.06.18.00.59.30 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 18 Jun 2021 00:59:31 -0700 (PDT) From: Chung-Chiang Cheng X-Google-Original-From: Chung-Chiang Cheng To: jlbec@evilplan.org, hch@lst.de, pantelis.antoniou@konsulko.com Cc: linux-kernel@vger.kernel.org, linux-fsdevel@vger.kernel.org, Chung-Chiang Cheng Subject: [PATCH] configfs: fix memleak in configfs_release_bin_file Date: Fri, 18 Jun 2021 15:59:25 +0800 Message-Id: <20210618075925.803052-1-cccheng@synology.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When reading binary attributes in progress, buffer->bin_buffer is setup in configfs_read_bin_file() but never freed. Fixes: 03607ace807b4 ("configfs: implement binary attributes") Signed-off-by: Chung-Chiang Cheng --- fs/configfs/file.c | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/fs/configfs/file.c b/fs/configfs/file.c index e26060dae70a..cdd23f4a51c8 100644 --- a/fs/configfs/file.c +++ b/fs/configfs/file.c @@ -466,9 +466,13 @@ static int configfs_release_bin_file(struct inode *inode, struct file *file) { struct configfs_buffer *buffer = file->private_data; - buffer->read_in_progress = false; - - if (buffer->write_in_progress) { + if (buffer->read_in_progress) { + buffer->read_in_progress = false; + vfree(buffer->bin_buffer); + buffer->bin_buffer = NULL; + buffer->bin_buffer_size = 0; + buffer->needs_read_fill = 1; + } else if (buffer->write_in_progress) { struct configfs_fragment *frag = to_frag(file); buffer->write_in_progress = false; -- 2.25.1