public inbox for kernelnewbies@kernelnewbies.org
 help / color / mirror / Atom feed
From: Jim Cromie <jim.cromie@gmail.com>
To: linux-kernel@vger.kernel.org, jbaron@akamai.com,
	gregkh@linuxfoundation.org, daniel.vetter@ffwll.ch,
	tvrtko.ursulin@linux.intel.com, jani.nikula@intel.com,
	ville.syrjala@linux.intel.com
Cc: groeck@google.com, linux-doc@vger.kernel.org,
	Jim Cromie <jim.cromie@gmail.com>,
	yanivt@google.com, intel-gfx@lists.freedesktop.org,
	kernelnewbies@kernelnewbies.org, linux@rasmusvillemoes.dk,
	robdclark@gmail.com, dri-devel@lists.freedesktop.org,
	mcgrof@kernel.org, seanpaul@chromium.org,
	amd-gfx@lists.freedesktop.org, joe@perches.com,
	bleung@google.com, intel-gvt-dev@lists.freedesktop.org,
	ukaszb@chromium.org
Subject: [PATCH v9-resend 24/54] selftests-dyndbg: add test_mod_submod
Date: Tue, 16 Jul 2024 12:57:36 -0600	[thread overview]
Message-ID: <20240716185806.1572048-25-jim.cromie@gmail.com> (raw)
In-Reply-To: <20240716185806.1572048-1-jim.cromie@gmail.com>

This new test-fn runs 3 module/submodule modprobe scenarios, variously
using both the generic dyndbg=<queries> modprobe arg, and the
test-module's classmap-params to manipulate the test-mod*'s pr_debugs.
In all cases, the current flag-settings are counted and tested vs
expectations.

The 3rd scenario recapitulates the DRM_USE_DYNAMIC_DEBUG=y failure.

1. 2 modprobes (super then sub), with separate dyndbg=class-settings
   check module specific flag settings

2. modprobe submod, supermod is auto-loaded
   set supermod class-params
   check expected enablements in super & submod

3. modprobe super, with param=setting (like drm.debug=0x1ef)
   modprobe submod
   validate submod's class'd pr_debugs get properly enabled

The test uses multi-queries, with both commas and percents (to avoid
spaces and quoting).  This is the main reason the test wasn't earlier
in the patchset, closer to the classmap patches its validating.

With some tedium, the tests could be refactored to split out early
tests which avoid multi-cmds, and test only the class-params.

Signed-off-by: Jim Cromie <jim.cromie@gmail.com>
---
 .../dynamic_debug/dyndbg_selftest.sh          | 67 +++++++++++++++++++
 1 file changed, 67 insertions(+)

diff --git a/tools/testing/selftests/dynamic_debug/dyndbg_selftest.sh b/tools/testing/selftests/dynamic_debug/dyndbg_selftest.sh
index 996e6fdcfb52..fccd2012b548 100755
--- a/tools/testing/selftests/dynamic_debug/dyndbg_selftest.sh
+++ b/tools/testing/selftests/dynamic_debug/dyndbg_selftest.sh
@@ -246,10 +246,77 @@ function test_percent_splitting {
     ifrmmod test_dynamic_debug
 }
 
+function test_mod_submod {
+    echo -e "${GREEN}# TEST_MOD_SUBMOD ${NC}"
+    ifrmmod test_dynamic_debug_submod
+    ifrmmod test_dynamic_debug
+    ddcmd =_
+
+    # modprobe with class enablements
+    modprobe test_dynamic_debug \
+	dyndbg=class,D2_CORE,+pf%class,D2_KMS,+pt%class,D2_ATOMIC,+pm
+
+    check_match_ct '\[test_dynamic_debug\]' 23 -r
+    check_match_ct =pf 1
+    check_match_ct =pt 1
+    check_match_ct =pm 1
+
+    modprobe test_dynamic_debug_submod
+    check_match_ct test_dynamic_debug_submod 23 -r
+    check_match_ct '\[test_dynamic_debug\]' 23 -r
+    check_match_ct test_dynamic_debug 46 -r
+
+    # no enablements propagate here
+    check_match_ct =pf 1
+    check_match_ct =pt 1
+    check_match_ct =pm 1
+
+    # change classes again, this time submod too
+    ddcmd class,D2_CORE,+mf%class,D2_KMS,+lt%class,D2_ATOMIC,+ml "# add some prefixes"
+    check_match_ct =pmf 1 -v
+    check_match_ct =plt 1 -v
+    check_match_ct =pml 1 -v
+    #  submod changed too
+    check_match_ct =mf 1 -v
+    check_match_ct =lt 1 -v
+    check_match_ct =ml 1 -v
+
+    # now work the classmap-params
+    # fresh start, to clear all above flags (test-fn limits)
+    ifrmmod test_dynamic_debug_submod
+    ifrmmod test_dynamic_debug
+    modprobe test_dynamic_debug_submod # get supermod too
+
+    echo 1 > /sys/module/test_dynamic_debug/parameters/p_disjoint_bits
+    echo 4 > /sys/module/test_dynamic_debug/parameters/p_level_num
+    # 2 mods * ( V1-3 + D2_CORE )
+    check_match_ct =p 8 -v
+    echo 3 > /sys/module/test_dynamic_debug/parameters/p_disjoint_bits
+    echo 0 > /sys/module/test_dynamic_debug/parameters/p_level_num
+    # 2 mods * ( D2_CORE, D2_DRIVER )
+    check_match_ct =p 4 -v
+    echo 0x16 > /sys/module/test_dynamic_debug/parameters/p_disjoint_bits
+    echo 0 > /sys/module/test_dynamic_debug/parameters/p_level_num
+    # 2 mods * ( D2_DRIVER, D2_KMS, D2_ATOMIC )
+    check_match_ct =p 6 -v
+
+    # recap DRM_USE_DYNAMIC_DEBUG regression
+    ifrmmod test_dynamic_debug_submod
+    ifrmmod test_dynamic_debug
+    # set super-mod params
+    modprobe test_dynamic_debug p_disjoint_bits=0x16 p_level_num=5
+    check_match_ct =p 7 -v
+    modprobe test_dynamic_debug_submod
+    # see them picked up by submod
+    check_match_ct =p 14 -v
+}
+
 tests_list=(
     basic_tests
+    # these require test_dynamic_debug*.ko
     comma_terminator_tests
     test_percent_splitting
+    test_mod_submod
 )
 
 # Run tests
-- 
2.45.2


_______________________________________________
Kernelnewbies mailing list
Kernelnewbies@kernelnewbies.org
https://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies

  parent reply	other threads:[~2024-07-16 19:08 UTC|newest]

Thread overview: 55+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-07-16 18:57 [PATCH v9-resend 00/54] fix CONFIG_DRM_USE_DYNAMIC_DEBUG=y Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 01/54] docs/dyndbg: update examples \012 to \n Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 02/54] test-dyndbg: fixup CLASSMAP usage error Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 03/54] dyndbg: reword "class unknown, " to "class:_UNKNOWN_" Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 04/54] dyndbg: make ddebug_class_param union members same size Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 05/54] dyndbg: replace classmap list with a vector Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 06/54] dyndbg: ddebug_apply_class_bitmap - add module arg, select on it Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 07/54] dyndbg: split param_set_dyndbg_classes to _module & wrapper fns Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 08/54] dyndbg: drop NUM_TYPE_ARRAY Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 09/54] dyndbg: reduce verbose/debug clutter Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 10/54] dyndbg: silence debugs with no-change updates Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 11/54] dyndbg: tighten ddebug_class_name() 1st arg type Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 12/54] dyndbg: tighten fn-sig of ddebug_apply_class_bitmap Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 13/54] dyndbg: reduce verbose=3 messages in ddebug_add_module Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 14/54] dyndbg-API: remove DD_CLASS_TYPE_(DISJOINT|LEVEL)_NAMES and code Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 15/54] dyndbg-API: fix DECLARE_DYNDBG_CLASSMAP Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 16/54] selftests-dyndbg: add tools/testing/selftests/dynamic_debug/* Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 17/54] dyndbg-API: promote DYNDBG_CLASSMAP_PARAM to API Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 18/54] dyndbg-doc: add classmap info to howto Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 19/54] dyndbg: treat comma as a token separator Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 20/54] selftests-dyndbg: add comma_terminator_tests Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 21/54] dyndbg: split multi-query strings with % Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 22/54] selftests-dyndbg: test_percent_splitting Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 23/54] docs/dyndbg: explain new delimiters: comma, percent Jim Cromie
2024-07-16 18:57 ` Jim Cromie [this message]
2024-07-16 18:57 ` [PATCH v9-resend 25/54] dyndbg-doc: explain flags parse 1st Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 26/54] dyndbg: change __dynamic_func_call_cls* macros into expressions Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 27/54] selftests-dyndbg: check KCONFIG_CONFIG to avoid silly fails Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 28/54] dyndbg-selftest: reduce default verbosity Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 29/54] drm: use correct ccflags-y spelling Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 30/54] drm-dyndbg: adapt drm core to use dyndbg classmaps-v2 Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 31/54] drm-dyndbg: adapt DRM to invoke DYNDBG_CLASSMAP_PARAM Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 32/54] drm-dyndbg: DRM_CLASSMAP_USE in amdgpu driver Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 33/54] drm-dyndbg: DRM_CLASSMAP_USE in i915 driver Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 34/54] drm-dyndbg: DRM_CLASSMAP_USE in drm_crtc_helper Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 35/54] drm-dyndbg: DRM_CLASSMAP_USE in drm_dp_helper Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 36/54] drm-dyndbg: DRM_CLASSMAP_USE in nouveau Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 37/54] drm-print: workaround unused variable compiler meh Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 38/54] drm-dyndbg: add DRM_CLASSMAP_USE to Xe driver Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 39/54] drm-dyndbg: add DRM_CLASSMAP_USE to virtio_gpu Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 40/54] drm-dyndbg: add DRM_CLASSMAP_USE to simpledrm Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 41/54] drm-dyndbg: add DRM_CLASSMAP_USE to bochs Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 42/54] drm-dyndbg: add DRM_CLASSMAP_USE to etnaviv Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 43/54] drm-dyndbg: add DRM_CLASSMAP_USE to gma500 driver Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 44/54] drm-dyndbg: add DRM_CLASSMAP_USE to radeon Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 45/54] drm-dyndbg: add DRM_CLASSMAP_USE to vmwgfx driver Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 46/54] drm-dyndbg: add DRM_CLASSMAP_USE to vkms driver Jim Cromie
2024-07-16 18:57 ` [PATCH v9-resend 47/54] drm-dyndbg: add DRM_CLASSMAP_USE to udl driver Jim Cromie
2024-07-16 18:58 ` [PATCH v9-resend 48/54] drm-dyndbg: add DRM_CLASSMAP_USE to mgag200 driver Jim Cromie
2024-07-16 18:58 ` [PATCH v9-resend 49/54] drm-dyndbg: add DRM_CLASSMAP_USE to the gud driver Jim Cromie
2024-07-16 18:58 ` [PATCH v9-resend 50/54] drm-dyndbg: add DRM_CLASSMAP_USE to the qxl driver Jim Cromie
2024-07-16 18:58 ` [PATCH v9-resend 51/54] drm-dyndbg: add DRM_CLASSMAP_USE to the drm_gem_shmem_helper driver Jim Cromie
2024-07-16 18:58 ` [PATCH v9-resend 52/54] drm: restore CONFIG_DRM_USE_DYNAMIC_DEBUG un-BROKEN Jim Cromie
2024-07-16 18:58 ` [PATCH v9-resend 53/54] dyndbg: tighten up kdoc about DYNDBG_CLASSMAP_* macros Jim Cromie
2024-07-16 18:58 ` [PATCH v9-resend 54/54] docs-dyndbg: improve howto classmaps api section Jim Cromie

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20240716185806.1572048-25-jim.cromie@gmail.com \
    --to=jim.cromie@gmail.com \
    --cc=amd-gfx@lists.freedesktop.org \
    --cc=bleung@google.com \
    --cc=daniel.vetter@ffwll.ch \
    --cc=dri-devel@lists.freedesktop.org \
    --cc=gregkh@linuxfoundation.org \
    --cc=groeck@google.com \
    --cc=intel-gfx@lists.freedesktop.org \
    --cc=intel-gvt-dev@lists.freedesktop.org \
    --cc=jani.nikula@intel.com \
    --cc=jbaron@akamai.com \
    --cc=joe@perches.com \
    --cc=kernelnewbies@kernelnewbies.org \
    --cc=linux-doc@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux@rasmusvillemoes.dk \
    --cc=mcgrof@kernel.org \
    --cc=robdclark@gmail.com \
    --cc=seanpaul@chromium.org \
    --cc=tvrtko.ursulin@linux.intel.com \
    --cc=ukaszb@chromium.org \
    --cc=ville.syrjala@linux.intel.com \
    --cc=yanivt@google.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox