Received: by 2002:a25:683:0:0:0:0:0 with SMTP id 125csp2265200ybg; Fri, 5 Jun 2020 09:31:04 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy3G3wdnPvrty969c8CeB/WMM25ACXW2OG2oE6RBy19+qy1iHTtL8vtoc9rGCJoQh7W8yoC X-Received: by 2002:a17:906:f1d5:: with SMTP id gx21mr9858384ejb.416.1591374663805; Fri, 05 Jun 2020 09:31:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1591374663; cv=none; d=google.com; s=arc-20160816; b=Z0HTLYI6XVNzFCRMtdvuzsF5g1sV4q0v9lInu674y5BPOJLK4amPn9WMOe8xWRoDki 6/E/wpz1enF+BN18gz64CuFanmJcLpUokrsdVtWBZtt+xiKfs8/ppOgkgubDvoR9PcGX HnEaU4poqcyiWbxWCECwfoIvShS50FN0S8DVXxl0GVePvfhBtWrZi3x29ZpngvDintvm QnbsIpw1YakclSJxEBeu3NLeZSRoloYNgXkq29/dFUtIr1P1yktpcLO5XrdU/hqg5rLM trxl+2d+rJRrhtaBlyFBM4Hw2Qv3AuIOd7u0SphN6bYSVwZexWaEfcaEbv8YBunjIiv6 hTXQ== 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:date:subject:cc:to:from :dkim-signature; bh=xcmmKbmknmeMXy0KOUPlxJaq59XZDcgnJePbYQFVTsI=; b=HLgdWMW231eCL35b2mFBfL8YXnT2o62z81lUCFI4ff6bemHd4s8f9n5t6MMNso9i4c ZSbj3dvjXI1idORlc8l4AsBXcwynnpbPPfcdbDK7vL/R6jJprTde1ERO9ntSlL2YphuI SVmv1VP1zLCldthgk+6N8mq2e07aGNKJXx8hV2bpRlvN6oy/jB3mNCYfzPnprjVYIauO QhZvoWr6Y8Af1LVqXoZEGx7lIsr3c8dWdHLDVWZCeHQjn+Dnv1iuub91P5UEDZ1RLYQq b1oXIN1DXfcxYH69RexhdzFMN3pnLwrs5sRrQSpeAjf73x9bJOaCdulbVA0F2lpHhNki wGJg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=KM88HuWU; 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=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ba1si3858871edb.349.2020.06.05.09.30.41; Fri, 05 Jun 2020 09:31:03 -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=@gmail.com header.s=20161025 header.b=KM88HuWU; 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=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728608AbgFEQ2J (ORCPT + 99 others); Fri, 5 Jun 2020 12:28:09 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41112 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728524AbgFEQ17 (ORCPT ); Fri, 5 Jun 2020 12:27:59 -0400 Received: from mail-oi1-x244.google.com (mail-oi1-x244.google.com [IPv6:2607:f8b0:4864:20::244]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A4FE5C08C5C3 for ; Fri, 5 Jun 2020 09:27:59 -0700 (PDT) Received: by mail-oi1-x244.google.com with SMTP id j189so8682068oih.10 for ; Fri, 05 Jun 2020 09:27:59 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=xcmmKbmknmeMXy0KOUPlxJaq59XZDcgnJePbYQFVTsI=; b=KM88HuWUzZINae47Joh632EAhBimtNH34YkwmJcAbai9ltzgxzg9G2ENhCl/TXF+8x IFg3n0VcBaex6oa9p7wdDhcMGf5h9AfPPuINfvJpjXRIMR2sE9vcjWoi2iCB1hvWJ4/g 8TIv8WHGgdR/noqpNz8V1gbZD6Ar+k0I9sQql8CQ7MmXlcm8WZm/PUMVKZVLKwGQM1kU d/Te7AE1Azm3RxN75qsgfoiCLwAxH/+01Puh2qOstvxND2poIj/9YLfmww3Eec4q5/JW 1ZronuD0XkdFV2vN7qW7tnNMHFv2MZs+wta8R+SlTLxNbTBU0J8+xzcJGnA/Ny6OM6Jb unsA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=xcmmKbmknmeMXy0KOUPlxJaq59XZDcgnJePbYQFVTsI=; b=WaCbrKoklojIWzvhTj12GkRQG46F3jkLcCEZGqMHu6YOanQlOxCF4A+QKh24TJVlFF ooxfJvlfDKEn5eFSp0+pLPSsFmgaSNzh3L5myOR8NOXEQAu0x2jz9fPa86Y+YRKTK6zb rGv2AsDQZJrDBKo4C3jSJQFXhmEKV/jgQTcdU+Dp4HRXrzebbUz/ZgM4VV9r4/65c1CF e4LVfB+qr3xnZrHSn5D8m/o7xZfVhH0eLlL4clGiGDr65AVzZ8akH39WkbiOGFoPAtAz OHmzX+8PWn/XfWiO6uYxGR0/IR4UXzFSibbFa90Nl/7YY6+hsDfLF7p7C16Hxu7X4iai uCbg== X-Gm-Message-State: AOAM531/UrxEXUFvA/DDm/mIGIa7cfuP8aXbu+IpLPKfkmlsbeG8eRsE Ybh91epBh+2wgvpKjxxIfkg= X-Received: by 2002:aca:5a84:: with SMTP id o126mr1299840oib.41.1591374479005; Fri, 05 Jun 2020 09:27:59 -0700 (PDT) Received: from frodo.hsd1.co.comcast.net ([2601:284:8204:6ba0::aaac]) by smtp.googlemail.com with ESMTPSA id z13sm813894ooa.28.2020.06.05.09.27.56 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 05 Jun 2020 09:27:57 -0700 (PDT) From: Jim Cromie To: jbaron@akamai.com, linux-kernel@vger.kernel.org, akpm@linuxfoundation.org, gregkh@linuxfoundation.org Cc: linux@rasmusvillemoes.dk, Jim Cromie Subject: [PATCH 12/16] dyndbg: add filter parameter to ddebug_parse_flags Date: Fri, 5 Jun 2020 10:26:41 -0600 Message-Id: <20200605162645.289174-13-jim.cromie@gmail.com> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200605162645.289174-1-jim.cromie@gmail.com> References: <20200605162645.289174-1-jim.cromie@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add a new *filter param to ddebug_parse_flags(), allowing it to communicate optional filter flags back to its caller: ddebug_change() Also, ddebug_change doesn't alter any of its arguments, including its 2 new ones; mods, filter. Say so by adding const modifier to them. Signed-off-by: Jim Cromie --- lib/dynamic_debug.c | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/lib/dynamic_debug.c b/lib/dynamic_debug.c index 2ecabfd3f432..32eb7d9545c7 100644 --- a/lib/dynamic_debug.c +++ b/lib/dynamic_debug.c @@ -146,7 +146,8 @@ static void vpr_info_dq(const struct ddebug_query *query, const char *msg) * logs the changes. Takes ddebug_lock. */ static int ddebug_change(const struct ddebug_query *query, - struct flagsettings *mods) + const struct flagsettings *mods, + const struct flagsettings *filter) { int i; struct ddebug_table *dt; @@ -444,7 +445,10 @@ static int ddebug_read_flags(const char *str, struct flagsettings *f) * flags fields of matched _ddebug's. Returns 0 on success * or <0 on error. */ -static int ddebug_parse_flags(const char *str, struct flagsettings *mods) + +static int ddebug_parse_flags(const char *str, + struct flagsettings *mods, + struct flagsettings *filter) { int op; @@ -476,7 +480,9 @@ static int ddebug_parse_flags(const char *str, struct flagsettings *mods) mods->flags = 0; break; } - vpr_info("*flagsp=0x%x *maskp=0x%x\n", mods->flags, mods->mask); + + vpr_info("mods:flags=0x%x,mask=0x%x filter:flags=0x%x,mask=0x%x\n", + mods->flags, mods->mask, filter->flags, filter->mask); return 0; } @@ -484,6 +490,7 @@ static int ddebug_parse_flags(const char *str, struct flagsettings *mods) static int ddebug_exec_query(char *query_string, const char *modname) { struct flagsettings mods = {}; + struct flagsettings filter = {}; struct ddebug_query query; #define MAXWORDS 9 int nwords, nfound; @@ -495,7 +502,7 @@ static int ddebug_exec_query(char *query_string, const char *modname) return -EINVAL; } /* check flags 1st (last arg) so query is pairs of spec,val */ - if (ddebug_parse_flags(words[nwords-1], &mods)) { + if (ddebug_parse_flags(words[nwords-1], &mods, &filter)) { pr_err("flags parse failed\n"); return -EINVAL; } @@ -504,7 +511,7 @@ static int ddebug_exec_query(char *query_string, const char *modname) return -EINVAL; } /* actually go and implement the change */ - nfound = ddebug_change(&query, &mods); + nfound = ddebug_change(&query, &mods, &filter); vpr_info_dq(&query, nfound ? "applied" : "no-match"); return nfound; -- 2.26.2