X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=lib%2Fbug.c;h=e0ff219899902f51815c7e08e3642d97af7721de;hb=9ad3b386773088fbc3a49b682719af50bf280922;hp=c223a2575b7217f8f61ea422b5a93e642afa9505;hpb=932c2989b59008e530ffcc7c7e6ef507a28b28ca;p=platform%2Fkernel%2Flinux-starfive.git diff --git a/lib/bug.c b/lib/bug.c index c223a25..e0ff219 100644 --- a/lib/bug.c +++ b/lib/bug.c @@ -47,6 +47,7 @@ #include #include #include +#include extern struct bug_entry __start___bug_table[], __stop___bug_table[]; @@ -153,7 +154,7 @@ struct bug_entry *find_bug(unsigned long bugaddr) return module_find_bug(bugaddr); } -enum bug_trap_type report_bug(unsigned long bugaddr, struct pt_regs *regs) +static enum bug_trap_type __report_bug(unsigned long bugaddr, struct pt_regs *regs) { struct bug_entry *bug; const char *file; @@ -209,6 +210,18 @@ enum bug_trap_type report_bug(unsigned long bugaddr, struct pt_regs *regs) return BUG_TRAP_TYPE_BUG; } +enum bug_trap_type report_bug(unsigned long bugaddr, struct pt_regs *regs) +{ + enum bug_trap_type ret; + bool rcu = false; + + rcu = warn_rcu_enter(); + ret = __report_bug(bugaddr, regs); + warn_rcu_exit(rcu); + + return ret; +} + static void clear_once_table(struct bug_entry *start, struct bug_entry *end) { struct bug_entry *bug;