1 Star 0 Fork 18

liuh/btrfs-progs

forked from src-openEuler/btrfs-progs 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
0005-btrfs-progs-fix-freeing-of-device-after-error-in-btr.patch 1.23 KB
一键复制 编辑 原始数据 按行查看 历史
From 27198a4c26f10f8cef222b6d3be4d1509ab055cb Mon Sep 17 00:00:00 2001
From: David Sterba <dsterba@suse.com>
Date: Wed, 3 Apr 2024 23:10:22 +0200
Subject: [PATCH] btrfs-progs: fix freeing of device after error in
btrfs_add_to_fsid()
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
Reported by 'gcc -fanalyzer':
common/device-scan.c:222:20: warning: dereference of NULL ‘device’ [CWE-476] [-Wanalyzer-null-dereference]
If the allocation of device fails then we can't free device->zone_info
at the out label. To fix that return immediately as it's at the
beginning of the function.
Signed-off-by: David Sterba <dsterba@suse.com>
---
common/device-scan.c | 7 +++----
1 file changed, 3 insertions(+), 4 deletions(-)
diff --git a/common/device-scan.c b/common/device-scan.c
index c1cd726..630220a 100644
--- a/common/device-scan.c
+++ b/common/device-scan.c
@@ -144,10 +144,9 @@ int btrfs_add_to_fsid(struct btrfs_trans_handle *trans,
device_total_bytes = (device_total_bytes / sectorsize) * sectorsize;
device = calloc(1, sizeof(*device));
- if (!device) {
- ret = -ENOMEM;
- goto out;
- }
+ if (!device)
+ return -ENOMEM;
+
buf = calloc(1, sectorsize);
if (!buf) {
ret = -ENOMEM;
--
2.27.0
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/liuh0329/btrfs-progs.git
git@gitee.com:liuh0329/btrfs-progs.git
liuh0329
btrfs-progs
btrfs-progs
master

搜索帮助

0d507c66 1850385 C8b1a773 1850385