Received: by 10.213.65.68 with SMTP id h4csp1385916imn; Wed, 4 Apr 2018 18:46:40 -0700 (PDT) X-Google-Smtp-Source: AIpwx4/+OS/+voYneLS+XHu5Mp/nroXSgumUOlHTghXuS0H9hLZyZnwJU3Pd1fNCPuFpQzDJitzK X-Received: by 10.99.61.202 with SMTP id k193mr13484998pga.435.1522892800205; Wed, 04 Apr 2018 18:46:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522892800; cv=none; d=google.com; s=arc-20160816; b=NZm19BqCVpQpIJVJWT1waKUj2tjeAQ9ZESF2d+uRM32aGP2M2C2AARXOXeQkdd/d1L z/KrwEyAktuB8bn2w1nTIH2BU/EiPlnr9ikoyXD8xfSYMyAacRUwbxpvsjAvYDTKbKhQ v9nfH+Gfo0kL5H9IxSsD1twwD6V9DVsvu8QnIzFJ7dxUlR6tgvRWwSFq66vuVDSv2Ipu 5/wEIQYIT179gVqckty42RvMwfxOJwDFNv4fWU+LYCcVKdRgjE80koYnyY+ig/0QT6Br qEuTgWWvJiJkVPnzK2khigPSMaf7HWUXjHfQQiYSH01xNFbpDlMhxjPU04Bznd+kIgWe E1yQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date :arc-authentication-results; bh=z6s9grbgroeMri6PFfMB02N+uds+da20vS+xcAGWjdc=; b=scx6gLZP2JmiS9b30jIWveSCBAzoDqGeQEJR+HNn6ov2ZnWP5faIks25roO4BbBsop XGIxMk+9kX1JWLRU2HbYihxd+Xthbr3XpdJL4yCm+d0x62L2kP560L+h5wVwtfzyZI5J KUBPCVNUFe0oizn87zjrB2MDZ4eO6X+ztKNs6jbo8lV/YGsh/wkQ9U6rXWdbgVv2omkn QnbPf/x1K184dKMq0V9clBlxfOFOCr7V/0HAPhgr7dm5OTLBF2cqe6EUl5dZR2rYUb5c 9raaJULnGIi9R1YnmwRZwAtcL3qon1ckElZklGncuYuImiekaYpfYWRtdUKkWs1t9iun xmhg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g8-v6si5196819plm.120.2018.04.04.18.46.25; Wed, 04 Apr 2018 18:46:40 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752753AbeDEBpU (ORCPT + 99 others); Wed, 4 Apr 2018 21:45:20 -0400 Received: from mail.linuxfoundation.org ([140.211.169.12]:51080 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752652AbeDEBpT (ORCPT ); Wed, 4 Apr 2018 21:45:19 -0400 Received: from akpm3.svl.corp.google.com (unknown [104.133.9.71]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id AE6BDD95; Thu, 5 Apr 2018 01:45:18 +0000 (UTC) Date: Wed, 4 Apr 2018 18:45:17 -0700 From: Andrew Morton To: Randy Dunlap Cc: LKML , reiserfs-devel@vger.kernel.org, Alexander Viro , Jeff Mahoney , Jan Kara , Frederic Weisbecker , Artem Bityutskiy , syzkaller-bugs@googlegroups.com, syzbot+6bd77b88c1977c03f584@syzkaller.appspotmail.com Subject: Re: [PATCH?] reiserfs: prevent panic: don't allow %-char in journal dev. name Message-Id: <20180404184517.9f2b91b856a56f71464f5f7f@linux-foundation.org> In-Reply-To: References: X-Mailer: Sylpheed 3.5.1 (GTK+ 2.24.31; x86_64-pc-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 4 Apr 2018 18:25:16 -0700 Randy Dunlap wrote: > From: Randy Dunlap > > If the reiserfs mount option's journal name contains a '%' character, > it can lead to a WARN_ONCE() in lib/vsprintf.c::format_decode(), > saying: "Please remove unsupported %/ in format string." > That's OK until panic_on_warn is set, at which point it's dead, Jim. > > To placate this situation, check the journal name string for a '%' > character and return an error if one is found. Also print a warning > (one that won't panic the kernel) about the invalid journal name (e.g.): > > reiserfs: journal device name is invalid: %/file0 > > (In this example, the caller app specified the journal device name as > "%/file0".) > Well, that is a valid filename and we should support it... Isn't the bug in journal_init_dev()? --- a/fs/reiserfs/journal.c~a +++ a/fs/reiserfs/journal.c @@ -2643,7 +2643,7 @@ static int journal_init_dev(struct super if (IS_ERR(journal->j_dev_bd)) { result = PTR_ERR(journal->j_dev_bd); journal->j_dev_bd = NULL; - reiserfs_warning(super, + reiserfs_warning(super, "sh-457", "journal_init_dev: Cannot open '%s': %i", jdev_name, result); return result; _