Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp1399763pxa; Thu, 13 Aug 2020 07:51:18 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy/ICo8hw9k1EovBJSwh2cH8ha3IBdRlZ4yUKnL8MNNKttb3W8RB+Wc/VA9TCslKVq1g6Xa X-Received: by 2002:a17:906:7f0e:: with SMTP id d14mr5101855ejr.400.1597330278285; Thu, 13 Aug 2020 07:51:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1597330278; cv=none; d=google.com; s=arc-20160816; b=pmH9hXPJsb8xtP/YBaSVuo3L7XCovewNaccJMLuWQwB+xOYIiA/LRcexrDXGcbPQPM CI02uQBiruvdCZOPUlOVnnBW0lk8Kk5kqVZKA+8VUJ5bAUYNR6Bt1289Cd53H4++5/k5 7sDo/wLIoeB/IC6ipHPahuHu79W+ySXPi7WKPRSyhca7M6ZfBsodTS7hnQ2Rd+bKc1WU 43duUZyvbqbRE+WjPJ/oB16hEeD7+GEcrf95evzOq8sfT4pgSbZXHeHLwnxHCla0tjuM tDmQ1iLmjV1cnEr69GzEeGxM/hntYKndKXnDNNMQbHsHX2296fqga3iuugAAEHis3oju qS0A== 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:cc:to:from :subject:references:mime-version:message-id:in-reply-to:date :dkim-signature; bh=fCGrFQfpfR4RJs5ZY7NRIygzu/+q9MlAoBreTUrZtKI=; b=U92+m4IX0OpBeG1R6mw//7ba0qLIYdkV+KCi5z8mJzmWhCgXDbMEft7SJepQZKkMYf JKvE7R0qz07Vq0LUbs7AbwR09qY+Lt8W5SCBRI4ET2pNvDcCHFicR+6a8FvW5A6xfLme 8cX3f2wPPKhpagmPRXT9+9ux2Qlf27Nwky4UUfd+LQdrCNVyrO/lvVtAJbIBoOxLQRcc 92LggZuG6RIRFfe0F+Vl8fQuryqobhnz8T41wqHz4hnbqJaQ4aE/d2AHLW9rhe3BsT7U kVEQ/QXMM4hnUTa2QODvOQrqXZHhfQeaxyF50Rzbz5BBZsfvlblCcSCm8+mOtRssOLff SySw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=aPGwSU3D; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b6si3569353edq.179.2020.08.13.07.50.55; Thu, 13 Aug 2020 07:51:18 -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=@google.com header.s=20161025 header.b=aPGwSU3D; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726591AbgHMOtz (ORCPT + 99 others); Thu, 13 Aug 2020 10:49:55 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45510 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726564AbgHMOtm (ORCPT ); Thu, 13 Aug 2020 10:49:42 -0400 Received: from mail-qt1-x849.google.com (mail-qt1-x849.google.com [IPv6:2607:f8b0:4864:20::849]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 51DF4C061757 for ; Thu, 13 Aug 2020 07:49:40 -0700 (PDT) Received: by mail-qt1-x849.google.com with SMTP id q19so5031614qtp.0 for ; Thu, 13 Aug 2020 07:49:40 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:in-reply-to:message-id:mime-version:references:subject:from:to :cc:content-transfer-encoding; bh=fCGrFQfpfR4RJs5ZY7NRIygzu/+q9MlAoBreTUrZtKI=; b=aPGwSU3DH9pOxvTlq3Vws4aZ298GUILOkQMZa7HkaFW7bbJTqkoKkJdDwZOvXyfLCD WjttKGnSDKQuTC1kLTWwWqMTBI1ZC/bDZLtFG9RSer2bvKuAZn5jEnRuMjOj4r6Ulfap WUhkJRfcn3VqdCv6hUbALW+EyFpBFQmAJbqtUzpKSYKypkVGXwwmjX1BnrtwwWD+FMU5 eL1WKBbm1M6vWDjHt54UOwQEex3jLh5y7x1L4MlyPsaiXESuJaS6q/Mt00dYpzsCtLCU 8JYET0WCgV0cQCSmIMmVESEZN206LNEL8hAZAZ3dOdAq6vKM75+dnliVv9V5CxmTWOyl wTdQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc:content-transfer-encoding; bh=fCGrFQfpfR4RJs5ZY7NRIygzu/+q9MlAoBreTUrZtKI=; b=ITYM4Q14Ew6NZTt7cR6lLR7Xu3eRwo1NKAbKC8vN5q4RE8XiXVdcOIEcIQ+uNXPwY+ kN3NPEEPtEOdN2oflsiWvKWmz/8BgL4cS8yp4xdxDAcL07DqnTxRuyQsoTmQA7bGNb43 cFYfAo9yCC8mZ9N/R/8Z9+JYmdbQ1ecTEaS5PyM6BdmqmjoHaIyuUPcZKsTefJ1eNTu7 jmQ/I+xuQiTjkFKadSxsrhM/9t2YHPNHQATvkjfq7P59q8w6x/C51LW6WDQ1y0fD3EGV 8Qdtju5DhI2bRg010jcP6y3bfqEtDPNYXwZPN+7h+5t/GxgrAHTipYa5LGV9vvcQ3UHt +GrQ== X-Gm-Message-State: AOAM530NYb714cJLmlR/Zltnw8aD3HV4ql9oXiMs7CzR6G8dXvUVyqam U8dr0AulfPl61D8VFYWbNLE8Kc6nMw== X-Received: by 2002:ad4:54c6:: with SMTP id j6mr5037154qvx.126.1597330178932; Thu, 13 Aug 2020 07:49:38 -0700 (PDT) Date: Thu, 13 Aug 2020 16:48:59 +0200 In-Reply-To: <20200813144914.737306-1-tweek@google.com> Message-Id: <20200813144914.737306-2-tweek@google.com> Mime-Version: 1.0 References: <20200813144914.737306-1-tweek@google.com> X-Mailer: git-send-email 2.28.0.236.gb10cc79966-goog Subject: [PATCH v2 2/2] selinux: add basic filtering for audit trace events From: "=?UTF-8?q?Thi=C3=A9baud=20Weksteen?=" To: Paul Moore Cc: Nick Kralevich , Peter Enderborg , "=?UTF-8?q?Thi=C3=A9baud=20Weksteen?=" , Stephen Smalley , Eric Paris , Steven Rostedt , Ingo Molnar , Mauro Carvalho Chehab , "David S. Miller" , Rob Herring , Arnd Bergmann , linux-kernel@vger.kernel.org, selinux@vger.kernel.org Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Peter Enderborg This patch adds further attributes to the event. These attributes are helpful to understand the context of the message and can be used to filter the events. There are three common items. Source context, target context and tclass. There are also items from the outcome of operation performed. An event is similar to: <...>-1309 [002] .... 6346.691689: selinux_audited: requested=3D0x4000000 denied=3D0x4000000 audited=3D0x4000000 result=3D-13 ssid=3D315 tsid=3D61 scontext=3Dsystem_u:system_r:cupsd_t:s0-s0:c0.c1023 tcontext=3Dsystem_u:object_r:bin_t:s0 tclass=3Dfile With systems where many denials are occurring, it is useful to apply a filter. The filtering is a set of logic that is inserted with the filter file. Example: echo "tclass=3D=3D\"file\" && ssid!=3D42" > events/avc/selinux_audited/fil= ter This adds that we only get tclass=3Dfile but not for ssid 42. The trace can also have extra properties. Adding the user stack can be done with echo 1 > options/userstacktrace Now the output will be runcon-1365 [003] .... 6960.955530: selinux_audited: requested=3D0x4000000 denied=3D0x4000000 audited=3D0x4000000 result=3D-13 ssid=3D315 tsid=3D61 scontext=3Dsystem_u:system_r:cupsd_t:s0-s0:c0.c1023 tcontext=3Dsystem_u:object_r:bin_t:s0 tclass=3Dfile runcon-1365 [003] .... 6960.955560: =3D> <00007f325b4ce45b> =3D> <00005607093efa57> Note that the ssid is the internal numeric representation of scontext and tsid is numeric for tcontext. They are useful for filtering. Signed-off-by: Peter Enderborg Reviewed-by: Thi=C3=A9baud Weksteen --- v2 changes: - update changelog to include usage examples include/trace/events/avc.h | 41 ++++++++++++++++++++++++++++---------- security/selinux/avc.c | 22 +++++++++++--------- 2 files changed, 44 insertions(+), 19 deletions(-) diff --git a/include/trace/events/avc.h b/include/trace/events/avc.h index 07c058a9bbcd..ac5ef2e1c2c5 100644 --- a/include/trace/events/avc.h +++ b/include/trace/events/avc.h @@ -1,6 +1,7 @@ /* SPDX-License-Identifier: GPL-2.0 */ /* - * Author: Thi=C3=A9baud Weksteen + * Authors: Thi=C3=A9baud Weksteen + * Peter Enderborg */ #undef TRACE_SYSTEM #define TRACE_SYSTEM avc @@ -12,23 +13,43 @@ =20 TRACE_EVENT(selinux_audited, =20 - TP_PROTO(struct selinux_audit_data *sad), + TP_PROTO(struct selinux_audit_data *sad, + char *scontext, + char *tcontext, + const char *tclass + ), =20 - TP_ARGS(sad), + TP_ARGS(sad, scontext, tcontext, tclass), =20 TP_STRUCT__entry( - __field(unsigned int, tclass) - __field(unsigned int, audited) + __field(u32, requested) + __field(u32, denied) + __field(u32, audited) + __field(int, result) + __string(scontext, scontext) + __string(tcontext, tcontext) + __string(tclass, tclass) + __field(u32, ssid) + __field(u32, tsid) ), =20 TP_fast_assign( - __entry->tclass =3D sad->tclass; - __entry->audited =3D sad->audited; + __entry->requested =3D sad->requested; + __entry->denied =3D sad->denied; + __entry->audited =3D sad->audited; + __entry->result =3D sad->result; + __entry->ssid =3D sad->ssid; + __entry->tsid =3D sad->tsid; + __assign_str(tcontext, tcontext); + __assign_str(scontext, scontext); + __assign_str(tclass, tclass); ), =20 - TP_printk("tclass=3D%u audited=3D%x", - __entry->tclass, - __entry->audited) + TP_printk("requested=3D0x%x denied=3D0x%x audited=3D0x%x result=3D%d ssid= =3D%u tsid=3D%u scontext=3D%s tcontext=3D%s tclass=3D%s", + __entry->requested, __entry->denied, __entry->audited, __entry->result, + __entry->ssid, __entry->tsid, __get_str(scontext), __get_str(tcontext), + __get_str(tclass) + ) ); =20 #endif diff --git a/security/selinux/avc.c b/security/selinux/avc.c index b0a0af778b70..7de5cc5169af 100644 --- a/security/selinux/avc.c +++ b/security/selinux/avc.c @@ -705,35 +705,39 @@ static void avc_audit_post_callback(struct audit_buff= er *ab, void *a) { struct common_audit_data *ad =3D a; struct selinux_audit_data *sad =3D ad->selinux_audit_data; - char *scontext; + char *scontext =3D NULL; + char *tcontext =3D NULL; + const char *tclass =3D NULL; u32 scontext_len; + u32 tcontext_len; int rc; =20 - trace_selinux_audited(sad); - rc =3D security_sid_to_context(sad->state, sad->ssid, &scontext, &scontext_len); if (rc) audit_log_format(ab, " ssid=3D%d", sad->ssid); else { audit_log_format(ab, " scontext=3D%s", scontext); - kfree(scontext); } =20 - rc =3D security_sid_to_context(sad->state, sad->tsid, &scontext, - &scontext_len); + rc =3D security_sid_to_context(sad->state, sad->tsid, &tcontext, + &tcontext_len); if (rc) audit_log_format(ab, " tsid=3D%d", sad->tsid); else { - audit_log_format(ab, " tcontext=3D%s", scontext); - kfree(scontext); + audit_log_format(ab, " tcontext=3D%s", tcontext); } =20 - audit_log_format(ab, " tclass=3D%s", secclass_map[sad->tclass-1].name); + tclass =3D secclass_map[sad->tclass-1].name; + audit_log_format(ab, " tclass=3D%s", tclass); =20 if (sad->denied) audit_log_format(ab, " permissive=3D%u", sad->result ? 0 : 1); =20 + trace_selinux_audited(sad, scontext, tcontext, tclass); + kfree(tcontext); + kfree(scontext); + /* in case of invalid context report also the actual context string */ rc =3D security_sid_to_context_inval(sad->state, sad->ssid, &scontext, &scontext_len); --=20 2.28.0.236.gb10cc79966-goog