aboutsummaryrefslogtreecommitdiff
path: root/include/log.h
diff options
context:
space:
mode:
authorSean Anderson <seanga2@gmail.com>2020-10-27 19:55:26 -0400
committerTom Rini <trini@konsulko.com>2020-10-30 10:55:26 -0400
commitfe3b1a2d21fb35ac212066dd74b7cc4b6bfbccc9 (patch)
tree9471cfda8361eff00c050c3e9148520328f06790 /include/log.h
parenta02f84ee9c6f42137671b74ec3bb9d159b10b7ee (diff)
downloadu-boot-fe3b1a2d21fb35ac212066dd74b7cc4b6bfbccc9.zip
u-boot-fe3b1a2d21fb35ac212066dd74b7cc4b6bfbccc9.tar.gz
u-boot-fe3b1a2d21fb35ac212066dd74b7cc4b6bfbccc9.tar.bz2
log: Add filter flag to deny on match
Without this flag, log filters can only explicitly accept messages. Allowing denial makes it easier to filter certain subsystems. Unlike allow-ing filters, deny-ing filters are added to the beginning of the filter list. This should do the Right Thing most of the time, but it's less-universal than allowing filters to be inserted anywhere. If this becomes a problem, then perhaps log_filter_add* should take a filter number to insert before/after. Signed-off-by: Sean Anderson <seanga2@gmail.com> Reviewed-by: Simon Glass <sjg@chromium.org>
Diffstat (limited to 'include/log.h')
-rw-r--r--include/log.h11
1 files changed, 10 insertions, 1 deletions
diff --git a/include/log.h b/include/log.h
index ee94f14..05833f2 100644
--- a/include/log.h
+++ b/include/log.h
@@ -361,13 +361,22 @@ enum {
LOGF_MAX_CATEGORIES = 5, /* maximum categories per filter */
};
+/**
+ * enum log_filter_flags - Flags which modify a filter
+ */
enum log_filter_flags {
- LOGFF_HAS_CAT = 1 << 0, /* Filter has a category list */
+ /** @LOGFF_HAS_CAT: Filter has a category list */
+ LOGFF_HAS_CAT = 1 << 0,
+ /** @LOGFF_DENY: Filter denies matching messages */
+ LOGFF_DENY = 1 << 1,
};
/**
* struct log_filter - criterial to filter out log messages
*
+ * If a message matches all criteria, then it is allowed. If LOGFF_DENY is set,
+ * then it is denied instead.
+ *
* @filter_num: Sequence number of this filter. This is returned when adding a
* new filter, and must be provided when removing a previously added
* filter.