From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-9.6 required=3.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI,SIGNED_OFF_BY, SPF_HELO_NONE,SPF_PASS,USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 4B8E8C433DF for ; Wed, 17 Jun 2020 16:27:24 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 26F4721532 for ; Wed, 17 Jun 2020 16:27:24 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="KMkVrdLz" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727856AbgFQQ1W (ORCPT ); Wed, 17 Jun 2020 12:27:22 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49038 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727051AbgFQQ0Z (ORCPT ); Wed, 17 Jun 2020 12:26:25 -0400 Received: from mail-ot1-x342.google.com (mail-ot1-x342.google.com [IPv6:2607:f8b0:4864:20::342]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AB192C06174E for ; Wed, 17 Jun 2020 09:26:24 -0700 (PDT) Received: by mail-ot1-x342.google.com with SMTP id d4so2110576otk.2 for ; Wed, 17 Jun 2020 09:26:24 -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=aGiIl0rQxYfmn8bMryy/aSMpkb7Wg+3sE7ap1XGmfzA=; b=KMkVrdLzteWT7WIakPBGjF9XrXlIdbE+kSJlSNLdMsbGTsZfRBfd6+UkjcNNWqvIig k09v8Al8X7XsPiWVBLyKVV5C8xVQhbqVhnMJDROcTFNxXYDnrPKaAHWbbwWhlC29IQoq 96o1zL5iI1Q3xhw2+ns7KyZqaf4vQqCDfjabTDzvGXdgXpE7k5b+6BDzIi+ETmAn0pIw 71qWhMy9Hl20DjN4qOzRqLgPhk1K4F7p3E7u7mJp+BzQIZ1Wd+2dFeGLvLwM++qbK2XJ 7kt+MQUaOPK1F7qB79qPitKQHyW3Tg7Zz80gidAKAHkw3xIwuRuqxOafLjXgyOhE54o7 4+uQ== 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=aGiIl0rQxYfmn8bMryy/aSMpkb7Wg+3sE7ap1XGmfzA=; b=NHHMzr0c3HJGOcwpRWYDYU57Nmg+42TOFqTd4xkEDdOjTftR7FtyEXNJuWwqdTdhVi MQBgk3E/GG2qyVCK7uShQsHb4B6e4R6JOXAnKRysXTN05+jubMh+bXS8ttF7Mzg2OfVC P/Pw5a/bcHok4DGeFv8RaKHOWXnPIlQQJRpQXzifg7B5xgY4lcPknb+LXuKg8I6X3Bpa dHIfD1krpsXBTZStuPHwsCucY5BHpF1OfKCFfCE5gPb9ZGYvpjbOpTCm8FJS3goyk8HZ gP7sD57RMRtD4kMj/j46CA2AiUrkM7APRXwfiI2NoE2UpVbe2+6Ni7IRo/Ncy4hToMlI MOAA== X-Gm-Message-State: AOAM530+ntM8Dz7qLKmkczBS3Be3T/T8edU2e1sNyMi3ANArYeYOHvTr uHrPKjJ5gEbCGN2jhpmjU2Q= X-Google-Smtp-Source: ABdhPJydTHrB/kgKnrJwTBPuS57S71B7VH9fTRn48kaFFZ2JadOYpWPU5kek0LDGzDM66wfBy0gwqQ== X-Received: by 2002:a9d:3b86:: with SMTP id k6mr7205902otc.106.1592411184039; Wed, 17 Jun 2020 09:26:24 -0700 (PDT) Received: from frodo.hsd1.co.comcast.net ([2601:284:8204:6ba0::ae4b]) by smtp.googlemail.com with ESMTPSA id h7sm95877otk.48.2020.06.17.09.26.22 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 17 Jun 2020 09:26:23 -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 v3 14/21] dyndbg: accept query terms like file=bar module=foo Date: Wed, 17 Jun 2020 10:25:28 -0600 Message-Id: <20200617162536.611386-16-jim.cromie@gmail.com> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200617162536.611386-1-jim.cromie@gmail.com> References: <20200617162536.611386-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 Current code expects "keyword" "arg" as 2 space separated words. Change to also accept "keyword=arg" form as well, and drop !(nwords%2) requirement. Then in rest of function, use new keyword, arg variables instead of word[i], word[i+1] Signed-off-by: Jim Cromie --- lib/dynamic_debug.c | 51 ++++++++++++++++++++++++++++----------------- 1 file changed, 32 insertions(+), 19 deletions(-) diff --git a/lib/dynamic_debug.c b/lib/dynamic_debug.c index 7eb963b1bd11..e1dd96178f18 100644 --- a/lib/dynamic_debug.c +++ b/lib/dynamic_debug.c @@ -351,6 +351,8 @@ static int check_set(const char **dest, char *src, char *name) * line * line - // where either may be empty * + * Also accept combined keyword=value and keyword:value forms + * * Only 1 of each type is allowed. * Returns 0 on success, <0 on error. */ @@ -360,22 +362,33 @@ static int ddebug_parse_query(char *words[], int nwords, unsigned int i; int rc = 0; char *fline; - - /* check we have an even number of words */ - if (nwords % 2 != 0) { - pr_err("expecting pairs of match-spec \n"); - return -EINVAL; - } + char *keyword, *arg; if (modname) /* support $modname.dyndbg= */ query->module = modname; - for (i = 0; i < nwords; i += 2) { - if (!strcmp(words[i], "func")) { - rc = check_set(&query->function, words[i+1], "func"); - } else if (!strcmp(words[i], "file")) { - if (check_set(&query->filename, words[i+1], "file")) + for (i = 0; i < nwords; i++) { + /* accept keyword=arg */ + vpr_info("%d w:%s\n", i, words[i]); + + keyword = words[i]; + if ((arg = strchr(keyword, '='))) { + *arg++ = '\0'; + } else { + i++; /* next word is arg */ + if (!(i < nwords)) { + pr_err("missing arg to keyword:%s\n", keyword); + return -EINVAL; + } + arg = words[i]; + } + vpr_info("%d key:%s arg:%s\n", i, keyword, arg); + + if (!strcmp(keyword, "func")) { + rc = check_set(&query->function, arg, "func"); + } else if (!strcmp(keyword, "file")) { + if (check_set(&query->filename, arg, "file")) return -EINVAL; /* tail :$info is function or line-range */ @@ -391,18 +404,18 @@ static int ddebug_parse_query(char *words[], int nwords, if (parse_linerange(query, fline)) return -EINVAL; } - } else if (!strcmp(words[i], "module")) { - rc = check_set(&query->module, words[i+1], "module"); - } else if (!strcmp(words[i], "format")) { - string_unescape_inplace(words[i+1], UNESCAPE_SPACE | + } else if (!strcmp(keyword, "module")) { + rc = check_set(&query->module, arg, "module"); + } else if (!strcmp(keyword, "format")) { + string_unescape_inplace(arg, UNESCAPE_SPACE | UNESCAPE_OCTAL | UNESCAPE_SPECIAL); - rc = check_set(&query->format, words[i+1], "format"); - } else if (!strcmp(words[i], "line")) { - if (parse_linerange(query, words[i+1])) + rc = check_set(&query->format, arg, "format"); + } else if (!strcmp(keyword, "line")) { + if (parse_linerange(query, arg)) return -EINVAL; } else { - pr_err("unknown keyword \"%s\"\n", words[i]); + pr_err("unknown keyword \"%s\"\n", keyword); return -EINVAL; } if (rc) -- 2.26.2