Best Syzkaller code snippet using report.linuxStallFrameExtractor
linux.go
Source:linux.go
...551 }552 }553 return false, ""554}555func linuxStallFrameExtractor(frames []string) (string, string) {556 // During rcu stalls and cpu lockups kernel loops in some part of code,557 // usually across several functions. When the stall is detected, traceback558 // points to a random stack within the looping code. We generally take559 // the top function in the stack (with few exceptions) as the bug identity.560 // As the result stalls with the same root would produce multiple reports561 // in different functions, which is bad.562 // Instead we identify a representative function deeper in the stack.563 // For most syscalls it can be the syscall entry function (e.g. SyS_timer_create).564 // However, for highly discriminated functions syscalls like ioctl/read/write/connect565 // we take the previous function (e.g. for connect the one that points to exact566 // protocol, or for ioctl the one that is related to the device).567 prev := frames[0]568 for _, frame := range frames {569 if matchesAny([]byte(frame), linuxStallAnchorFrames) {570 for _, prefix := range []string{571 "__x64_",572 "SYSC_",573 "SyS_",574 "compat_SYSC_",575 "compat_SyS_",576 "__ia32_sys_",577 } {578 prev = strings.TrimPrefix(prev, prefix)579 }580 return prev, ""581 }582 prev = frame583 }584 return "", "did not find any anchor frame"585}586func linuxHangTaskFrameExtractor(frames []string) (string, string) {587 // The problem with task hung reports is that they manifest at random victim stacks,588 // rather at the root cause stack. E.g. if there is something wrong with RCU subsystem,589 // we are getting hangs all over the kernel on all synchronize_* calls.590 // So before resotring to the common logic of skipping some common frames,591 // we look for 2 common buckets: hangs on synchronize_rcu and hangs on rtnl_lock592 // and group these together.593 const synchronizeRCU = "synchronize_rcu"594 anchorFrames := map[string]string{595 "rtnl_lock": "",596 "synchronize_rcu": synchronizeRCU,597 "synchronize_srcu": synchronizeRCU,598 "synchronize_net": synchronizeRCU,599 "synchronize_sched": synchronizeRCU,600 }601 for _, frame := range frames {602 for anchor, replacement := range anchorFrames {603 if strings.HasPrefix(frame, anchor) {604 if replacement != "" {605 frame = replacement606 }607 return frame, ""608 }609 }610 }611 skip := []string{"sched", "_lock", "_slowlock", "down", "rwsem", "completion", "kthread",612 "wait", "synchronize", "context_switch", "__switch_to", "cancel_delayed_work"}613nextFrame:614 for _, frame := range frames {615 for _, ignore := range skip {616 if strings.Contains(frame, ignore) {617 continue nextFrame618 }619 }620 return frame, ""621 }622 return "", "all frames are skipped"623}624var linuxStallAnchorFrames = []*regexp.Regexp{625 // Various generic functions that dispatch work.626 // We also include some of their callers, so that if some names change627 // we don't skip whole stacks and proceed parsing the next one.628 compile("process_one_work"), // workqueue callback629 compile("do_syscall_"), // syscall entry630 compile("do_fast_syscall_"), // syscall entry631 compile("sysenter_dispatch"), // syscall entry632 compile("tracesys_phase2"), // syscall entry633 compile("netif_receive_skb"), // net receive entry point634 compile("do_softirq"),635 compile("call_timer_fn"),636 compile("_run_timers"),637 compile("run_timer_softirq"),638 compile("run_ksoftirqd"),639 compile("smpboot_thread_fn"),640 compile("kthread"),641 compile("start_secondary"),642 compile("cpu_startup_entry"),643 compile("ret_from_fork"),644 // Important discriminated syscalls (file_operations callbacks, etc):645 compile("vfs_write"),646 compile("vfs_read"),647 compile("vfs_iter_read"),648 compile("vfs_iter_write"),649 compile("do_iter_read"),650 compile("do_iter_write"),651 compile("vfs_ioctl"),652 compile("ksys_ioctl"), // vfs_ioctl may be inlined653 compile("compat_ioctl"),654 compile("compat_sys_ioctl"),655 compile("blkdev_driver_ioctl"),656 compile("blkdev_ioctl"),657 compile("^call_read_iter"),658 compile("^call_write_iter"),659 compile("do_iter_readv_writev"),660 compile("^call_mmap"),661 compile("mmap_region"),662 compile("do_mmap"),663 compile("do_dentry_open"),664 compile("vfs_open"),665 // Socket operations:666 compile("^sock_sendmsg"),667 compile("^sock_recvmsg"),668 compile("^sock_release"),669 compile("^__sock_release"),670 compile("__sys_setsockopt"),671 compile("kernel_setsockopt"),672 compile("sock_common_setsockopt"),673 compile("__sys_listen"),674 compile("kernel_listen"),675 compile("sk_common_release"),676 compile("^sock_mmap"),677 compile("__sys_accept"),678 compile("kernel_accept"),679 compile("^sock_do_ioctl"),680 compile("^sock_ioctl"),681 compile("^compat_sock_ioctl"),682 compile("^nfnetlink_rcv_msg"),683 compile("^(compat_)?(SYSC|SyS|__sys|___sys|__do_sys|__se_sys|__x64_sys)_(socketpair|connect|ioctl)"),684 // Page fault entry points:685 compile("__do_fault"),686 compile("handle_mm_fault"),687 compile("do_page_fault"),688 compile("^page_fault$"),689 // exit_to_usermode_loop callbacks:690 compile("__fput"),691 compile("task_work_run"),692 compile("exit_to_usermode"),693}694// nolint: lll695var (696 linuxSymbolizeRe = regexp.MustCompile(`(?:\[\<(?:[0-9a-f]+)\>\])?[ \t]+(?:[0-9]+:)?([a-zA-Z0-9_.]+)\+0x([0-9a-f]+)/0x([0-9a-f]+)`)697 linuxStackFrameRe = regexp.MustCompile(`^ *(?:\[\<?(?:[0-9a-f]+)\>?\] ?){0,2}[ \t]+(?:[0-9]+:)?([a-zA-Z0-9_.]+)\+0x([0-9a-f]+)/0x([0-9a-f]+)`)698 linuxRipFrame = compile(`N?IP:? (?:(?:[0-9]+:)?(?:{{PC}} +){0,2}{{FUNC}}|[0-9]+:0x[0-9a-f]+|(?:[0-9]+:)?{{PC}} +\[< *\(null\)>\] +\(null\)|[0-9]+: +\(null\))`)699)700var linuxCorruptedTitles = []*regexp.Regexp{701 // Sometimes timestamps get merged into the middle of report description.702 regexp.MustCompile(`\[ *[0-9]+\.[0-9]+\]`),703}704var linuxStackKeywords = []*regexp.Regexp{705 regexp.MustCompile(`Call Trace`),706 regexp.MustCompile(`Allocated:`),707 regexp.MustCompile(`Allocated by task [0-9]+:`),708 regexp.MustCompile(`Freed:`),709 regexp.MustCompile(`Freed by task [0-9]+:`),710 // Match 'backtrace:', but exclude 'stack backtrace:'711 regexp.MustCompile(`[^k] backtrace:`),712}713var linuxStackParams = &stackParams{714 stackStartRes: linuxStackKeywords,715 frameRes: []*regexp.Regexp{716 compile("^ *(?:{{PC}} ){0,2}{{FUNC}}"),717 },718 skipPatterns: []string{719 "__sanitizer",720 "__asan",721 "kasan",722 "__msan",723 "kmsan",724 "check_memory_region",725 "read_word_at_a_time",726 "print_address_description",727 "panic",728 "invalid_op",729 "report_bug",730 "fixup_bug",731 "do_error",732 "invalid_op",733 "_trap",734 "dump_stack",735 "warn_slowpath",736 "warn_alloc",737 "__warn",738 "debug_object",739 "timer_is_static_object",740 "work_is_static_object",741 "lockdep",742 "perf_trace",743 "lock_acquire",744 "lock_release",745 "lock_class",746 "reacquire_held_locks",747 "spin_lock",748 "spin_trylock",749 "spin_unlock",750 "raw_read_lock",751 "raw_read_trylock",752 "raw_write_lock",753 "raw_write_trylock",754 "down",755 "down_read",756 "down_write",757 "down_read_trylock",758 "down_write_trylock",759 "up_read",760 "up_write",761 "mutex_lock",762 "mutex_trylock",763 "mutex_unlock",764 "mutex_remove_waiter",765 "osq_lock",766 "osq_unlock",767 "__wake_up",768 "refcount_add",769 "refcount_sub",770 "refcount_inc",771 "refcount_dec",772 "refcount_set",773 "refcount_read",774 "memcpy",775 "memcmp",776 "memset",777 "memchr",778 "memmove",779 "strcmp",780 "strncmp",781 "strcpy",782 "strlcpy",783 "strncpy",784 "strscpy",785 "strlen",786 "strnstr",787 "strnlen",788 "strchr",789 "copy_to_user",790 "copy_from_user",791 "put_user",792 "get_user",793 "might_fault",794 "might_sleep",795 "list_add",796 "list_del",797 "list_replace",798 "list_move",799 "list_splice",800 "_indirect_thunk_", // retpolines801 "string",802 "pointer",803 "snprintf",804 "scnprintf",805 "kasprintf",806 "kvasprintf",807 "printk",808 "va_format",809 "dev_info",810 "dev_notice",811 "dev_warn",812 "dev_err",813 "dev_alert",814 "dev_crit",815 "dev_emerg",816 "program_check_exception",817 "program_check_common",818 "del_timer",819 "flush_work",820 "__cancel_work_timer",821 "cancel_work_sync",822 "try_to_grab_pending",823 "flush_workqueue",824 "drain_workqueue",825 "destroy_workqueue",826 "finish_wait",827 "kthread_stop",828 "kobject_del",829 "kobject_put",830 "kobject_uevent_env",831 "add_uevent_var",832 "get_device_parent",833 "device_add",834 "device_del",835 "device_unregister",836 "device_destroy",837 "device_release",838 "devres_release_all",839 "hwrng_unregister",840 "i2c_del_adapter",841 "__unregister_client",842 "device_for_each_child",843 "rollback_registered",844 "unregister_netdev",845 "sysfs_remove",846 "device_remove_file",847 "tty_unregister_device",848 "dummy_urb_enqueue",849 "usb_kill_urb",850 "usb_kill_anchored_urbs",851 "usb_control_msg",852 "usb_hcd_submit_urb",853 "usb_submit_urb",854 "^complete$",855 "wait_for_completion",856 "^kfree$",857 "kfree_skb",858 },859 corruptedLines: []*regexp.Regexp{860 // Fault injection stacks are frequently intermixed with crash reports.861 // Note: the actual symbol can have all kinds of weird suffixes like ".isra.7", ".cold" or ".isra.56.cold.74".862 compile(`^( \[\<?(?:0x)?[0-9a-f]+\>?\])? should_fail(slab)?(\.[a-z0-9.]+)?\+0x`),863 },864}865func warningStackFmt(skip ...string) *stackFmt {866 return &stackFmt{867 // In newer kernels WARNING traps and actual stack starts after invalid_op frame,868 // older kernels just print stack.869 parts: []*regexp.Regexp{870 // x86_64 warning stack starts with "RIP:" line,871 // while powerpc64 starts with "--- interrupt:".872 compile("(?:" + linuxRipFrame.String() + "|--- interrupt: [0-9]+ at {{FUNC}})"),873 parseStackTrace,874 },875 parts2: []*regexp.Regexp{876 compile("Call Trace:"),877 parseStackTrace,878 },879 skip: skip,880 }881}882// nolint: lll883var linuxOopses = append([]*oops{884 {885 []byte("BUG:"),886 []oopsFormat{887 {888 title: compile("BUG: KASAN:"),889 report: compile("BUG: KASAN: ([a-z\\-]+) in {{FUNC}}(?:.*\\n)+?.*(Read|Write) of size (?:[0-9]+)"),890 fmt: "KASAN: %[1]v %[3]v in %[4]v",891 stack: &stackFmt{892 parts: []*regexp.Regexp{893 compile("BUG: KASAN: (?:[a-z\\-]+) in {{FUNC}}"),894 compile("Call Trace:"),895 parseStackTrace,896 },897 },898 },899 {900 title: compile("BUG: KASAN:"),901 report: compile("BUG: KASAN: double-free or invalid-free in {{FUNC}}"),902 fmt: "KASAN: invalid-free in %[2]v",903 stack: &stackFmt{904 parts: []*regexp.Regexp{905 compile("BUG: KASAN: double-free or invalid-free in {{FUNC}}"),906 compile("Call Trace:"),907 parseStackTrace,908 },909 skip: []string{"kmem_", "slab_", "kfree", "vunmap", "vfree"},910 },911 },912 {913 title: compile("BUG: KASAN: ([a-z\\-]+) on address(?:.*\\n)+?.*(Read|Write) of size ([0-9]+)"),914 fmt: "KASAN: %[1]v %[2]v",915 },916 {917 title: compile("BUG: KASAN: (.*)"),918 fmt: "KASAN: %[1]v",919 corrupted: true,920 },921 {922 title: compile("BUG: KMSAN: kernel-usb-infoleak"),923 report: compile("BUG: KMSAN: kernel-usb-infoleak in {{FUNC}}"),924 fmt: "KMSAN: kernel-usb-infoleak in %[2]v",925 stack: warningStackFmt("usb_submit_urb", "usb_start_wait_urb", "usb_bulk_msg", "usb_interrupt_msg", "usb_control_msg"),926 },927 {928 title: compile("BUG: KMSAN:"),929 report: compile("BUG: KMSAN: ([a-z\\-]+) in {{FUNC}}"),930 fmt: "KMSAN: %[1]v in %[3]v",931 stack: &stackFmt{932 parts: []*regexp.Regexp{933 compile("Call Trace:"),934 parseStackTrace,935 },936 },937 },938 {939 title: compile("BUG: KCSAN:"),940 report: compile("BUG: KCSAN: (.*)"),941 fmt: "KCSAN: %[1]v",942 noStackTrace: true,943 },944 {945 title: compile("BUG: (?:unable to handle kernel paging request|unable to handle page fault for address|Unable to handle kernel data access)"),946 fmt: "BUG: unable to handle kernel paging request in %[1]v",947 stack: &stackFmt{948 parts: []*regexp.Regexp{949 linuxRipFrame,950 compile("Call Trace:"),951 parseStackTrace,952 },953 },954 },955 {956 title: compile("BUG: (?:unable to handle kernel NULL pointer dereference|kernel NULL pointer dereference|Kernel NULL pointer dereference)"),957 fmt: "BUG: unable to handle kernel NULL pointer dereference in %[1]v",958 stack: &stackFmt{959 parts: []*regexp.Regexp{960 linuxRipFrame,961 compile("Call Trace:"),962 parseStackTrace,963 },964 },965 },966 {967 // Sometimes with such BUG failures, the second part of the header doesn't get printed968 // or gets corrupted, because kernel prints it as two separate printk() calls.969 title: compile("BUG: (?:unable to handle kernel|Unable to handle kernel)"),970 fmt: "BUG: unable to handle kernel",971 corrupted: true,972 },973 {974 title: compile("BUG: spinlock (lockup suspected|already unlocked|recursion|bad magic|wrong owner|wrong CPU)"),975 fmt: "BUG: spinlock %[1]v in %[2]v",976 stack: &stackFmt{977 parts: []*regexp.Regexp{978 compile("Call Trace:"),979 parseStackTrace,980 },981 skip: []string{"spin_"},982 },983 },984 {985 title: compile("BUG: soft lockup"),986 fmt: "BUG: soft lockup in %[1]v",987 stack: &stackFmt{988 parts: []*regexp.Regexp{989 linuxRipFrame,990 compile("Call Trace:"),991 parseStackTrace,992 },993 extractor: linuxStallFrameExtractor,994 },995 },996 {997 title: compile("BUG: .*still has locks held!"),998 report: compile("BUG: .*still has locks held!(?:.*\\n)+?.*{{PC}} +{{FUNC}}"),999 fmt: "BUG: still has locks held in %[1]v",1000 },1001 {1002 title: compile("BUG: lock held when returning to user space"),1003 report: compile("BUG: lock held when returning to user space(?:.*\\n)+?.*leaving the kernel with locks still held(?:.*\\n)+?.*at: (?:{{PC}} +)?{{FUNC}}"),1004 fmt: "BUG: lock held when returning to user space in %[1]v",1005 noStackTrace: true,1006 },1007 {1008 title: compile("BUG: bad unlock balance detected!"),1009 report: compile("BUG: bad unlock balance detected!(?:.*\\n){0,15}?.*is trying to release lock(?:.*\\n){0,15}?.*{{PC}} +{{FUNC}}"),1010 fmt: "BUG: bad unlock balance in %[1]v",1011 },1012 {1013 title: compile("BUG: held lock freed!"),1014 report: compile("BUG: held lock freed!(?:.*\\n)+?.*{{PC}} +{{FUNC}}"),1015 fmt: "BUG: held lock freed in %[1]v",1016 },1017 {1018 title: compile("BUG: Bad rss-counter state"),1019 fmt: "BUG: Bad rss-counter state",1020 noStackTrace: true,1021 },1022 {1023 title: compile("BUG: non-zero nr_ptes on freeing mm"),1024 fmt: "BUG: non-zero nr_ptes on freeing mm",1025 noStackTrace: true,1026 },1027 {1028 title: compile("BUG: non-zero nr_pmds on freeing mm"),1029 fmt: "BUG: non-zero nr_pmds on freeing mm",1030 noStackTrace: true,1031 },1032 {1033 title: compile("BUG: Dentry .* still in use \\([0-9]+\\) \\[unmount of ([^\\]]+)\\]"),1034 fmt: "BUG: Dentry still in use [unmount of %[1]v]",1035 },1036 {1037 title: compile("BUG: Bad page state"),1038 fmt: "BUG: Bad page state",1039 },1040 {1041 title: compile("BUG: Bad page map"),1042 fmt: "BUG: Bad page map",1043 },1044 {1045 title: compile("BUG: workqueue lockup"),1046 fmt: "BUG: workqueue lockup",1047 noStackTrace: true,1048 },1049 {1050 title: compile("BUG: sleeping function called from invalid context at (.*)"),1051 fmt: "BUG: sleeping function called from invalid context in %[2]v",1052 stack: &stackFmt{1053 parts: []*regexp.Regexp{1054 compile("Call Trace:"),1055 parseStackTrace,1056 },1057 },1058 },1059 {1060 title: compile("BUG: using ([a-z_]+)\\(\\) in preemptible"),1061 fmt: "BUG: using %[1]v() in preemptible code in %[2]v",1062 stack: &stackFmt{1063 parts: []*regexp.Regexp{1064 compile("Call Trace:"),1065 parseStackTrace,1066 },1067 skip: []string{"dump_stack", "preemption", "preempt", "debug_",1068 "processor_id", "this_cpu"},1069 },1070 },1071 {1072 title: compile("BUG: workqueue leaked lock or atomic"),1073 report: compile("BUG: workqueue leaked lock or atomic(?:.*\\n)+?" +1074 ".*last function: ([a-zA-Z0-9_]+)\\n"),1075 fmt: "BUG: workqueue leaked lock or atomic in %[1]v",1076 noStackTrace: true,1077 },1078 {1079 title: compile("BUG: memory leak"),1080 fmt: memoryLeakPrefix + "%[1]v",1081 stack: &stackFmt{1082 parts: []*regexp.Regexp{1083 compile("backtrace:"),1084 parseStackTrace,1085 },1086 skip: []string{"kmemleak", "kmalloc", "kcalloc", "kzalloc",1087 "vmalloc", "mmap", "kmem", "slab", "alloc", "create_object",1088 "idr_get", "list_lru_init", "kasprintf", "kvasprintf",1089 "pcpu_create", "strdup", "strndup", "memdup"},1090 },1091 },1092 {// ACHyb1093 title: compile("BUG: ACHYB ([A-Za-z0-9,/\\:\\_\\>\\-\\(\\)\\s]+)\\n"),1094 report: compile("BUG: ACHYB ([A-Za-z0-9,/\\:\\_\\>\\-\\(\\)\\s]+)\\n"),1095 // report: compile("BUG: acl bug: ([A-Za-z0-9,/\\:\\_\\>\\-\\(\\)\\s]+)\\nCall Trace:\\n[A-Za-z0-9|\\-\\_,\\s\\:]+TRACEEND"),1096 fmt: "BUG: ACHYB %[1]v",1097 noStackTrace: true,1098 // noStackTrace: true,1099 /*stack: &stackFmt{1100 parts: []*regexp.Regexp{1101 compile("Call Trace:\\n[A-Za-z0-9\\-\\_,\\s\\:]+END"),1102 },1103 },*/1104 },1105 {1106 title: compile("BUG: stack guard page was hit at"),1107 fmt: "BUG: stack guard page was hit in %[1]v",1108 stack: &stackFmt{1109 parts: []*regexp.Regexp{1110 linuxRipFrame,1111 },1112 },1113 noStackTrace: true,1114 },1115 {1116 title: compile(`BUG:[[:space:]]*(?:\n|$)`),1117 fmt: "BUG: corrupted",1118 corrupted: true,1119 },1120 },1121 []*regexp.Regexp{1122 // CONFIG_DEBUG_OBJECTS output.1123 compile("ODEBUG:"),1124 // Android prints this sometimes during boot.1125 compile("Boot_DEBUG:"),1126 compile("xlog_status:"),1127 // Android ART debug output.1128 compile("DEBUG:"),1129 // pkg/host output in debug mode.1130 compile("BUG: no syscalls can create resource"),1131 },1132 },1133 {1134 []byte("WARNING:"),1135 []oopsFormat{1136 {1137 title: compile("WARNING: .*lib/debugobjects\\.c.* (?:debug_print|debug_check)"),1138 fmt: "WARNING: ODEBUG bug in %[1]v",1139 // Skip all users of ODEBUG as well.1140 stack: warningStackFmt("debug_", "rcu", "hrtimer_", "timer_",1141 "work_", "percpu_", "kmem_", "slab_", "kfree", "vunmap",1142 "vfree", "__free_", "debug_check", "kobject_"),1143 },1144 {1145 title: compile("WARNING: .*mm/usercopy\\.c.* usercopy_warn"),1146 fmt: "WARNING: bad usercopy in %[1]v",1147 stack: warningStackFmt("usercopy", "__check"),1148 },1149 {1150 title: compile("WARNING: .*lib/kobject\\.c.* kobject_"),1151 fmt: "WARNING: kobject bug in %[1]v",1152 stack: warningStackFmt("kobject_"),1153 },1154 {1155 title: compile("WARNING: .*fs/proc/generic\\.c.* proc_register"),1156 fmt: "WARNING: proc registration bug in %[1]v",1157 stack: warningStackFmt("proc_"),1158 },1159 {1160 title: compile("WARNING: .*lib/refcount\\.c.* refcount_"),1161 fmt: "WARNING: refcount bug in %[1]v",1162 stack: warningStackFmt("refcount", "kobject_"),1163 },1164 {1165 title: compile("WARNING: .*kernel/locking/lockdep\\.c.*lock_"),1166 fmt: "WARNING: locking bug in %[1]v",1167 stack: warningStackFmt("lock_sock", "release_sock"),1168 },1169 {1170 title: compile("WARNING: lock held when returning to user space"),1171 report: compile("WARNING: lock held when returning to user space(?:.*\\n)+?.*leaving the kernel with locks still held(?:.*\\n)+?.*at: (?:{{PC}} +)?{{FUNC}}"),1172 fmt: "WARNING: lock held when returning to user space in %[1]v",1173 noStackTrace: true,1174 },1175 {1176 title: compile("WARNING: .*mm/.*\\.c.* k?.?malloc"),1177 fmt: "WARNING: kmalloc bug in %[1]v",1178 stack: warningStackFmt("kmalloc", "kcalloc", "kzalloc", "krealloc",1179 "vmalloc", "slab", "kmem"),1180 },1181 {1182 title: compile("WARNING: .* usb_submit_urb"),1183 fmt: "WARNING in %[1]v/usb_submit_urb",1184 stack: warningStackFmt("usb_submit_urb", "usb_start_wait_urb", "usb_bulk_msg", "usb_interrupt_msg", "usb_control_msg"),1185 },1186 {1187 title: compile("WARNING: .* at {{SRC}} {{FUNC}}"),1188 fmt: "WARNING in %[3]v",1189 stack: warningStackFmt(),1190 },1191 {1192 title: compile("WARNING: possible circular locking dependency detected"),1193 report: compile("WARNING: possible circular locking dependency detected(?:.*\\n)+?.*is trying to acquire lock"),1194 fmt: "possible deadlock in %[1]v",1195 stack: &stackFmt{1196 parts: []*regexp.Regexp{1197 compile("at: (?:{{PC}} +)?{{FUNC}}"),1198 compile("at: (?:{{PC}} +)?{{FUNC}}"),1199 parseStackTrace,1200 },1201 // These workqueue functions take locks associated with work items.1202 // All deadlocks observed in these functions are1203 // work-item-subsystem-related.1204 skip: []string{"process_one_work", "flush_workqueue",1205 "drain_workqueue", "destroy_workqueue"},1206 },1207 },1208 {1209 title: compile("WARNING: possible irq lock inversion dependency detected"),1210 report: compile("WARNING: possible irq lock inversion dependency detected(?:.*\\n)+?.*just changed the state of lock(?:.*\\n)+?.*at: (?:{{PC}} +)?{{FUNC}}"),1211 fmt: "possible deadlock in %[1]v",1212 },1213 {1214 title: compile("WARNING: SOFTIRQ-safe -> SOFTIRQ-unsafe lock order detecte"),1215 report: compile("WARNING: SOFTIRQ-safe -> SOFTIRQ-unsafe lock order detected(?:.*\\n)+?.*is trying to acquire(?:.*\\n)+?.*at: (?:{{PC}} +)?{{FUNC}}"),1216 fmt: "possible deadlock in %[1]v",1217 },1218 {1219 title: compile("WARNING: possible recursive locking detected"),1220 report: compile("WARNING: possible recursive locking detected(?:.*\\n)+?.*is trying to acquire lock(?:.*\\n)+?.*at: (?:{{PC}} +)?{{FUNC}}"),1221 fmt: "possible deadlock in %[1]v",1222 },1223 {1224 title: compile("WARNING: inconsistent lock state"),1225 report: compile("WARNING: inconsistent lock state(?:.*\\n)+?.*takes(?:.*\\n)+?.*at: (?:{{PC}} +)?{{FUNC}}"),1226 fmt: "inconsistent lock state in %[1]v",1227 },1228 {1229 title: compile("WARNING: suspicious RCU usage"),1230 report: compile("WARNING: suspicious RCU usage(?:.*\n)+?.*?{{SRC}}"),1231 fmt: "WARNING: suspicious RCU usage in %[2]v",1232 stack: &stackFmt{1233 parts: []*regexp.Regexp{1234 compile("Call Trace:"),1235 parseStackTrace,1236 },1237 skip: []string{"rcu", "kmem", "slab", "kmalloc",1238 "vmalloc", "kcalloc", "kzalloc"},1239 },1240 },1241 {1242 title: compile("WARNING: kernel stack regs at [0-9a-f]+ in [^ ]* has bad '([^']+)' value"),1243 fmt: "WARNING: kernel stack regs has bad '%[1]v' value",1244 noStackTrace: true,1245 },1246 {1247 title: compile("WARNING: kernel stack frame pointer at [0-9a-f]+ in [^ ]* has bad value"),1248 fmt: "WARNING: kernel stack frame pointer has bad value",1249 noStackTrace: true,1250 },1251 {1252 title: compile("WARNING: bad unlock balance detected!"),1253 report: compile("WARNING: bad unlock balance detected!(?:.*\\n){0,15}?.*is trying to release lock(?:.*\\n){0,15}?.*{{PC}} +{{FUNC}}"),1254 fmt: "WARNING: bad unlock balance in %[1]v",1255 },1256 {1257 title: compile("WARNING: held lock freed!"),1258 report: compile("WARNING: held lock freed!(?:.*\\n)+?.*at:(?: {{PC}})? +{{FUNC}}"),1259 fmt: "WARNING: held lock freed in %[1]v",1260 },1261 {1262 title: compile("WARNING: kernel stack regs .* has bad 'bp' value"),1263 fmt: "WARNING: kernel stack regs has bad value",1264 noStackTrace: true,1265 },1266 {1267 title: compile("WARNING: kernel stack frame pointer .* has bad value"),1268 fmt: "WARNING: kernel stack regs has bad value",1269 noStackTrace: true,1270 },1271 {1272 title: compile(`WARNING:[[:space:]]*(?:\n|$)`),1273 fmt: "WARNING: corrupted",1274 corrupted: true,1275 },1276 },1277 []*regexp.Regexp{1278 compile("WARNING: /etc/ssh/moduli does not exist, using fixed modulus"), // printed by sshd1279 compile("WARNING: workqueue cpumask: online intersect > possible intersect"),1280 },1281 },1282 {1283 []byte("INFO:"),1284 []oopsFormat{1285 {1286 title: compile("INFO: possible circular locking dependency detected"),1287 report: compile("INFO: possible circular locking dependency detected \\](?:.*\\n)+?.*is trying to acquire lock(?:.*\\n)+?.*at: {{PC}} +{{FUNC}}"),1288 fmt: "possible deadlock in %[1]v",1289 },1290 {1291 title: compile("INFO: possible irq lock inversion dependency detected"),1292 report: compile("INFO: possible irq lock inversion dependency detected \\](?:.*\\n)+?.*just changed the state of lock(?:.*\\n)+?.*at: {{PC}} +{{FUNC}}"),1293 fmt: "possible deadlock in %[1]v",1294 },1295 {1296 title: compile("INFO: SOFTIRQ-safe -> SOFTIRQ-unsafe lock order detected"),1297 report: compile("INFO: SOFTIRQ-safe -> SOFTIRQ-unsafe lock order detected \\](?:.*\\n)+?.*is trying to acquire(?:.*\\n)+?.*at: {{PC}} +{{FUNC}}"),1298 fmt: "possible deadlock in %[1]v",1299 },1300 {1301 title: compile("INFO: possible recursive locking detected"),1302 report: compile("INFO: possible recursive locking detected \\](?:.*\\n)+?.*is trying to acquire lock(?:.*\\n)+?.*at: {{PC}} +{{FUNC}}"),1303 fmt: "possible deadlock in %[1]v",1304 },1305 {1306 title: compile("INFO: inconsistent lock state"),1307 report: compile("INFO: inconsistent lock state \\](?:.*\\n)+?.*takes(?:.*\\n)+?.*at: {{PC}} +{{FUNC}}"),1308 fmt: "inconsistent lock state in %[1]v",1309 },1310 {1311 title: compile("INFO: rcu_(?:preempt|sched|bh) (?:self-)?detected(?: expedited)? stall"),1312 fmt: "INFO: rcu detected stall in %[1]v",1313 stack: &stackFmt{1314 parts: []*regexp.Regexp{1315 compile("apic_timer_interrupt"),1316 linuxRipFrame,1317 parseStackTrace,1318 },1319 parts2: []*regexp.Regexp{1320 compile("apic_timer_interrupt"),1321 parseStackTrace,1322 },1323 skip: []string{"apic_timer_interrupt", "rcu"},1324 extractor: linuxStallFrameExtractor,1325 },1326 },1327 {1328 title: compile("INFO: trying to register non-static key"),1329 fmt: "INFO: trying to register non-static key in %[1]v",1330 stack: &stackFmt{1331 parts: []*regexp.Regexp{1332 compile("Call Trace:"),1333 parseStackTrace,1334 },1335 skip: []string{"stack", "lock", "IRQ"},1336 },1337 },1338 {1339 title: compile("INFO: suspicious RCU usage"),1340 report: compile("INFO: suspicious RCU usage(?:.*\n)+?.*?{{SRC}}"),1341 fmt: "INFO: suspicious RCU usage in %[2]v",1342 stack: &stackFmt{1343 parts: []*regexp.Regexp{1344 compile("Call Trace:"),1345 parseStackTrace,1346 },1347 skip: []string{"rcu", "kmem", "slab", "kmalloc",1348 "vmalloc", "kcalloc", "kzalloc"},1349 },1350 },1351 {1352 title: compile("INFO: task .* blocked for more than [0-9]+ seconds"),1353 fmt: "INFO: task hung in %[1]v",1354 stack: &stackFmt{1355 parts: []*regexp.Regexp{1356 compile("Call Trace:"),1357 parseStackTrace,1358 },1359 extractor: linuxHangTaskFrameExtractor,1360 },1361 },1362 {1363 // This gets captured for corrupted old-style KASAN reports.1364 title: compile("INFO: (Freed|Allocated) in (.*)"),1365 fmt: "INFO: %[1]v in %[2]v",1366 corrupted: true,1367 },1368 {1369 title: compile(`INFO:[[:space:]]*(?:\n|$)`),1370 fmt: "INFO: corrupted",1371 corrupted: true,1372 },1373 },1374 []*regexp.Regexp{1375 compile("INFO: lockdep is turned off"),1376 compile("INFO: Stall ended before state dump start"),1377 compile("INFO: NMI handler"),1378 compile("INFO: recovery required on readonly filesystem"),1379 compile("(handler|interrupt).*took too long"),1380 compile("_INFO::"), // Android can print this during boot.1381 compile("INFO: sys_.* is not present in /proc/kallsyms"), // pkg/host output in debug mode1382 compile("INFO: no syscalls can create resource"), // pkg/host output in debug mode1383 },1384 },1385 {1386 []byte("Unable to handle kernel paging request"),1387 []oopsFormat{1388 {1389 title: compile("Unable to handle kernel paging request"),1390 report: compile("Unable to handle kernel paging request(?:.*\\n)+?.*PC is at {{FUNC}}"),1391 fmt: "unable to handle kernel paging request in %[1]v",1392 },1393 },1394 []*regexp.Regexp{},1395 },1396 {1397 []byte("general protection fault"),1398 []oopsFormat{1399 {1400 title: compile("general protection fault.*:"),1401 fmt: "general protection fault in %[1]v",1402 stack: &stackFmt{1403 parts: []*regexp.Regexp{1404 linuxRipFrame,1405 compile("Call Trace:"),1406 parseStackTrace,1407 },1408 },1409 },1410 },1411 []*regexp.Regexp{},1412 },1413 {1414 []byte("stack segment: "),1415 []oopsFormat{1416 {1417 title: compile("stack segment: "),1418 fmt: "stack segment fault in %[1]v",1419 stack: &stackFmt{1420 parts: []*regexp.Regexp{1421 linuxRipFrame,1422 compile("Call Trace:"),1423 parseStackTrace,1424 },1425 },1426 },1427 },1428 []*regexp.Regexp{},1429 },1430 {1431 []byte("Kernel panic"),1432 []oopsFormat{1433 // Note: for stack corruption reports kernel may fail1434 // to print function symbol name and/or unwind stack.1435 {1436 title: compile("Kernel panic - not syncing: stack-protector:"),1437 report: compile("Kernel panic - not syncing: stack-protector: Kernel stack is corrupted in: {{FUNC}}"),1438 fmt: "kernel panic: stack is corrupted in %[1]v",1439 noStackTrace: true,1440 },1441 {1442 title: compile("Kernel panic - not syncing: stack-protector:"),1443 report: compile("Kernel panic - not syncing: stack-protector: Kernel stack is corrupted in: [a-f0-9]+"),1444 fmt: "kernel panic: stack is corrupted in %[1]v",1445 stack: &stackFmt{1446 parts: []*regexp.Regexp{1447 compile("Call Trace:"),1448 parseStackTrace,1449 },1450 skip: []string{"stack_chk"},1451 },1452 },1453 {1454 title: compile("Kernel panic - not syncing: corrupted stack end"),1455 report: compile("Kernel panic - not syncing: corrupted stack end detected inside scheduler"),1456 fmt: "kernel panic: corrupted stack end in %[1]v",1457 stack: &stackFmt{1458 parts: []*regexp.Regexp{1459 compile("Call Trace:"),1460 parseStackTrace,1461 },1462 skip: []string{"schedule", "retint_kernel"},1463 extractor: linuxStallFrameExtractor,1464 },1465 },1466 {1467 title: compile("Kernel panic - not syncing: Attempted to kill init!"),1468 fmt: "kernel panic: Attempted to kill init!",1469 },1470 {1471 title: compile("Kernel panic - not syncing: Couldn't open N_TTY ldisc for [^ ]+ --- error -[0-9]+"),1472 fmt: "kernel panic: Couldn't open N_TTY ldisc",1473 },1474 {1475 // 'kernel panic: Fatal exception' is usually printed after BUG,1476 // so if we captured it as a report description, that means the1477 // report got truncated and we missed the actual BUG header....
linuxStallFrameExtractor
Using AI Code Generation
1import (2func main() {3 p, err := profile.Parse(os.Stdin)4 if err != nil {5 log.Fatal(err)6 }7 r := p.Report(nil)8 r.Print(os.Stdout)9 r.PrintText(os.Stdout)10 r.PrintDisasm(os.Stdout)11 r.PrintProto(os.Stdout)12 fmt.Printf("%v", r.LinuxStallFrames())13}
linuxStallFrameExtractor
Using AI Code Generation
1 0.05s 0.05s (flat, cum) 100% of Total2 . . 10:func main() {3 . . 11: p, err := profile.Parse(os.Stdin)4 . . 12: if err != nil {5 . . 13: log.Fatal(err)6 . . 14: }7 . . 16: r := p.Report(nil)8 . . 18: r.Print(os.Stdout)9 . . 19: r.PrintText(os.Stdout)10 . . 20: r.PrintDisasm(os.Stdout)11 . . 21: r.PrintProto(os.Stdout)12 . . 22: fmt.Printf("%v", r.LinuxStallFrames())13 . 50ms 23:}
linuxStallFrameExtractor
Using AI Code Generation
1func main() {2}3func main() {4}5func main() {6}7func main() {8}9func main() {10}11func main() {12}13func main() {14}15func main() {16}17func main() {18}19func main() {20}21func main() {22}23func main() {24}25func main() {
linuxStallFrameExtractor
Using AI Code Generation
1import (2func main() {3 report := demangle.NewReport()4 report.SetFrameExtractor(demangle.LinuxStallFrameExtractor)5 report.SetLanguage(demangle.GoLanguage)6 report.SetFunctionName("main.main")7 report.SetFrame(0, "main.main", 0x4004f0)8 report.SetFrame(1, "runtime.main", 0x42f0a0)9 report.SetFrame(2, "runtime.goexit", 0x432050)10 fmt.Println(report)11}12import (13func main() {14 report := demangle.NewReport()15 report.SetFrameExtractor(demangle.LinuxStallFrameExtractor)16 report.SetLanguage(demangle.GoLanguage)17 report.SetFunctionName("main.main")18 report.SetFrame(0, "main.main", 0x4004f0)19 report.SetFrame(1, "runtime.main", 0x42f0a0)20 report.SetFrame(2, "runtime.goexit", 0x432050)21 fmt.Println(report)22}
linuxStallFrameExtractor
Using AI Code Generation
1import (2func main() {3 f, err := os.Create("cpu.prof")4 if err != nil {5 log.Fatal("could not create CPU profile: ", err)6 }7 if err := pprof.StartCPUProfile(f); err != nil {8 log.Fatal("could not start CPU profile: ", err)9 }10 defer pprof.StopCPUProfile()11 go func() {12 for {13 fmt.Println("Hello from goroutine")14 }15 }()16 time.Sleep(2 * time.Second)17 debug.SetTraceback("all")18 runtime.Gosched()19 buffer := make([]byte, 1<<16)20 buffer = buffer[:runtime.Stack(buffer, true)]21 fmt.Printf("Goroutine stack:\22}
linuxStallFrameExtractor
Using AI Code Generation
1import (2func main() {3 syscall.Getrusage(syscall.RUSAGE_SELF, &r)4 fmt.Println("Stall time in nanoseconds = ", r.Stime.Nano())5}6import (7func main() {8 syscall.Getrusage(syscall.RUSAGE_SELF, &r)9 fmt.Println("Stall time in nanoseconds = ", r.Stime.Nano())10}11import (12func main() {13 syscall.Getrusage(syscall.RUSAGE_SELF, &r)14 fmt.Println("Stall time in nanoseconds = ", r.Stime.Nano())15}16import (17func main() {18 syscall.Getrusage(syscall.RUSAGE_SELF, &r)19 fmt.Println("Stall time in nanoseconds = ", r.Stime.Nano())20}21import (22func main() {23 syscall.Getrusage(syscall.RUSAGE_SELF, &r)24 fmt.Println("Stall time in nanoseconds = ", r.Stime.Nano())25}26import (27func main() {28 syscall.Getrusage(syscall.RUSAGE_SELF, &r)29 fmt.Println("Stall time in nanoseconds = ", r.Stime.Nano())30}31import (32func main() {
linuxStallFrameExtractor
Using AI Code Generation
1func main() {2 r := report.NewReport()3 extractor := r.GetFrameExtractor()4 f := extractor.NewFrame()5 trace := f.ExtractStackTrace()6 fmt.Println(trace)7}8func main() {9 r := report.NewReport()10 extractor := r.GetFrameExtractor()11 f := extractor.NewFrame()12 trace := f.ExtractStackTrace()13 fmt.Println(trace)14}15func main() {16 r := report.NewReport()17 extractor := r.GetFrameExtractor()18 f := extractor.NewFrame()19 trace := f.ExtractStackTrace()20 fmt.Println(trace)21}22func main() {23 r := report.NewReport()24 extractor := r.GetFrameExtractor()25 f := extractor.NewFrame()26 trace := f.ExtractStackTrace()27 fmt.Println(trace)28}29func main() {30 r := report.NewReport()31 extractor := r.GetFrameExtractor()32 f := extractor.NewFrame()33 trace := f.ExtractStackTrace()34 fmt.Println(trace)35}
Learn to execute automation testing from scratch with LambdaTest Learning Hub. Right from setting up the prerequisites to run your first automation test, to following best practices and diving deeper into advanced test scenarios. LambdaTest Learning Hubs compile a list of step-by-step guides to help you be proficient with different test automation frameworks i.e. Selenium, Cypress, TestNG etc.
You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.
Get 100 minutes of automation test minutes FREE!!