Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp4969603imu; Mon, 12 Nov 2018 22:01:12 -0800 (PST) X-Google-Smtp-Source: AJdET5dyMb2GRIHEplCRitMby+2TN91+vJX5MOvl/jQ2/ntyCtwBb8oT3FRWzjFaxg8AyaTw1vyp X-Received: by 2002:a17:902:67:: with SMTP id 94-v6mr3629753pla.225.1542088872280; Mon, 12 Nov 2018 22:01:12 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542088872; cv=none; d=google.com; s=arc-20160816; b=DDED52n/GDYYqwVk0GYfEhZiyYxf5bHORLRuW0q9syH6MsSyKK4WzGwkAe+GbhCkdo jdMs+r8NHGQVkq9XVSX+1TbYBkzRSKp8GaZ8caRn3wPbuVWZtxnR2hNEqVcp/8/fBiFZ /jdz80XtKIKZ+qs5dqh9wpD9SW8G2d1SbLEuONzwocisiTAB9cXMQ02nGxLr8qFsRWVn BNMvbbK+HJqdJ/BhzONmeuYpEa1MkInzPQ1gad2Ri946yNLY7YWsRshezZULSBgyxU69 /0vGzuIH+8/fm0th9MNbJWxV9djT0661a9BfhH/jf6uojP/EZyi8ZbqE0cI3CPEnB2gM Vz5A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature; bh=3nSwaCIhr6rO/SqBbg9AEsmYk0AY1oQUh/nb7OCf41o=; b=mUXdrnkoF+jHG1B9ql6Qe4qLf58NKKxA3TChCRKnNR1pTXYxaA5LPhSroAqTyh4AJK X8jralZlxcy2M0+nxTbWlN33H+5RInI2H91GqQOD3ZxbY6M3f9lNnXWyW7oLRW4hmvrw nC/aOxo2VuOGvSjen6EaErZrnuLBmyWhIYnQ0s6Qh8Ph0WVPEyfE/OizQJvhjtHrNYAM 2QYDoK1+viu8C7w2MyL7wPDFAH1ERBCeUp+8bF9ZLJTj9zwtMm52zyosUjIoCWlbbRFw mI+LyIkISfPufJZZjBsKc27WFJmLoJOdlusdSr/pHw23MQ4aGphtZq1kFOiZxH2nVOhE rYXw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=C0NL4FpK; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id k193-v6si17363725pfc.15.2018.11.12.22.00.56; Mon, 12 Nov 2018 22:01:12 -0800 (PST) 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; dkim=pass header.i=@kernel.org header.s=default header.b=C0NL4FpK; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732617AbeKMP4M (ORCPT + 99 others); Tue, 13 Nov 2018 10:56:12 -0500 Received: from mail.kernel.org ([198.145.29.99]:33984 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732279AbeKMPr6 (ORCPT ); Tue, 13 Nov 2018 10:47:58 -0500 Received: from sasha-vm.mshome.net (unknown [64.114.255.114]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id DD31E22521; Tue, 13 Nov 2018 05:51:29 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1542088290; bh=3AqE4y5OxtQFqhDehZ2mIiCnMTz9xrofwndnElIrMiM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=C0NL4FpKszOlNrAl1lotkDAqZSHlaqWr7Epjy4VFMIANQc52XQFPvyFdQsKS/I11S K5QzYJLRUgTfqATA+PrAFmPAD+Uowps8gMz9ZHFOYzMEAXVtVj5SUTx19SyqK6sH5U eKhDsZDtjVHYySe6b7zQZDeENNUlYw6PLj57WeHA= From: Sasha Levin To: stable@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Zubin Mithra , John Johansen , Sasha Levin , linux-security-module@vger.kernel.org Subject: [PATCH AUTOSEL 4.18 26/39] apparmor: Fix uninitialized value in aa_split_fqname Date: Tue, 13 Nov 2018 00:50:40 -0500 Message-Id: <20181113055053.78352-26-sashal@kernel.org> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20181113055053.78352-1-sashal@kernel.org> References: <20181113055053.78352-1-sashal@kernel.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Zubin Mithra [ Upstream commit 250f2da49cb8e582215a65c03f50e8ddf5cd119c ] Syzkaller reported a OOB-read with the stacktrace below. This occurs inside __aa_lookupn_ns as `n` is not initialized. `n` is obtained from aa_splitn_fqname. In cases where `name` is invalid, aa_splitn_fqname returns without initializing `ns_name` and `ns_len`. Fix this by always initializing `ns_name` and `ns_len`. __dump_stack lib/dump_stack.c:77 [inline] dump_stack+0x1c4/0x2b4 lib/dump_stack.c:113 print_address_description.cold.8+0x9/0x1ff mm/kasan/report.c:256 kasan_report_error mm/kasan/report.c:354 [inline] kasan_report.cold.9+0x242/0x309 mm/kasan/report.c:412 __asan_report_load1_noabort+0x14/0x20 mm/kasan/report.c:430 memcmp+0xe3/0x160 lib/string.c:861 strnstr+0x4b/0x70 lib/string.c:934 __aa_lookupn_ns+0xc1/0x570 security/apparmor/policy_ns.c:209 aa_lookupn_ns+0x88/0x1e0 security/apparmor/policy_ns.c:240 aa_fqlookupn_profile+0x1b9/0x1010 security/apparmor/policy.c:468 fqlookupn_profile+0x80/0xc0 security/apparmor/label.c:1844 aa_label_strn_parse+0xa3a/0x1230 security/apparmor/label.c:1908 aa_label_parse+0x42/0x50 security/apparmor/label.c:1943 aa_change_profile+0x513/0x3510 security/apparmor/domain.c:1362 apparmor_setprocattr+0xaa4/0x1150 security/apparmor/lsm.c:658 security_setprocattr+0x66/0xc0 security/security.c:1298 proc_pid_attr_write+0x301/0x540 fs/proc/base.c:2555 __vfs_write+0x119/0x9f0 fs/read_write.c:485 vfs_write+0x1fc/0x560 fs/read_write.c:549 ksys_write+0x101/0x260 fs/read_write.c:598 __do_sys_write fs/read_write.c:610 [inline] __se_sys_write fs/read_write.c:607 [inline] __x64_sys_write+0x73/0xb0 fs/read_write.c:607 do_syscall_64+0x1b9/0x820 arch/x86/entry/common.c:290 entry_SYSCALL_64_after_hwframe+0x49/0xbe Fixes: 3b0aaf5866bf ("apparmor: add lib fn to find the "split" for fqnames") Reported-by: syzbot+61e4b490d9d2da591b50@syzkaller.appspotmail.com Signed-off-by: Zubin Mithra Reviewed-by: Kees Cook Signed-off-by: John Johansen Signed-off-by: Sasha Levin --- security/apparmor/lib.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/security/apparmor/lib.c b/security/apparmor/lib.c index a7b3f681b80e..230d39b0ddfc 100644 --- a/security/apparmor/lib.c +++ b/security/apparmor/lib.c @@ -90,10 +90,12 @@ const char *aa_splitn_fqname(const char *fqname, size_t n, const char **ns_name, const char *end = fqname + n; const char *name = skipn_spaces(fqname, n); - if (!name) - return NULL; *ns_name = NULL; *ns_len = 0; + + if (!name) + return NULL; + if (name[0] == ':') { char *split = strnchr(&name[1], end - &name[1], ':'); *ns_name = skipn_spaces(&name[1], end - &name[1]); -- 2.17.1