Skip to content
GitLab
Projects Groups Topics Snippets
  • /
  • Help
    • Help
    • Support
    • Community forum
    • Submit feedback
  • Register
  • Sign in
  • L linux
  • Project information
    • Project information
    • Activity
    • Labels
    • Members
  • Repository
    • Repository
    • Files
    • Commits
    • Branches
    • Tags
    • Contributor statistics
    • Graph
    • Compare revisions
  • Issues 0
    • Issues 0
    • List
    • Boards
    • Service Desk
    • Milestones
  • Merge requests 0
    • Merge requests 0
  • Deployments
    • Deployments
    • Releases
  • Monitor
    • Monitor
    • Incidents
  • Analytics
    • Analytics
    • Value stream
    • Repository
  • Wiki
    • Wiki
  • Snippets
    • Snippets
  • Activity
  • Graph
  • Create a new issue
  • Commits
  • Issue Boards
Collapse sidebar
  • Kirill Smelkov
  • linux
  • Repository
  • linux
  • lib
  • dynamic_debug.c
Find file BlameHistoryPermalink
  • Jim Cromie's avatar
    dyndbg: fix static_branch manipulation · ee879be3
    Jim Cromie authored Sep 04, 2022
    In https://lore.kernel.org/lkml/20211209150910.GA23668@axis.com/
    
    Vincent's patch commented on, and worked around, a bug toggling
    static_branch's, when a 2nd PRINTK-ish flag was added.  The bug
    results in a premature static_branch_disable when the 1st of 2 flags
    was disabled.
    
    The cited commit computed newflags, but then in the JUMP_LABEL block,
    failed to use that result, instead using just one of the terms in it.
    Using newflags instead made the code work properly.
    
    This is Vincents test-case, reduced.  It needs the 2nd flag to
    demonstrate the bug, but it's explanatory here.
    
    pt_test() {
        echo 5 > /sys/module/dynamic_debug/verbose
    
        site="module tcp" # just one callsite
        echo " $site =_ " > /proc/dynamic_debug/control # clear it
    
        # A B ~A ~B
        for flg in +T +p "-T #broke here" -p; do
    	echo " $site $flg " > /proc/dynamic_debug/control
        done;
    
        # A B ~B ~A
        for flg in +T +p "-p #broke here" -T; do
    	echo " $site $flg " > /proc/dynamic_debug/control
        done
    }
    pt_test
    
    Fixes: 84da83a6
    
     dyndbg: combine flags & mask into a struct, simplify with it
    CC: vincent.whitchurch@axis.com
    Acked-by: default avatarJason Baron <jbaron@akamai.com>
    Acked-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
    Signed-off-by: default avatarJim Cromie <jim.cromie@gmail.com>
    Link: https://lore.kernel.org/r/20220904214134.408619-2-jim.cromie@gmail.com
    
    
    Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
    ee879be3
GitLab Nexedi Edition | About GitLab | About Nexedi | 沪ICP备2021021310号-2 | 沪ICP备2021021310号-7