aboutsummaryrefslogtreecommitdiffstats
path: root/vm/vmimpl/linux.go
blob: 0406035f69d2c0c2440dc2b63e6f66953429cb14 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// Copyright 2020 syzkaller project authors. All rights reserved.
// Use of this source code is governed by Apache 2 LICENSE that can be found in the LICENSE file.

package vmimpl

import (
	"regexp"
	"strings"

	"github.com/google/syzkaller/pkg/report"
)

// DiagnoseLinux diagnoses some Linux kernel bugs over the provided ssh callback.
func DiagnoseLinux(rep *report.Report, ssh func(args ...string) ([]byte, error)) (output []byte, wait, handled bool) {
	if !strings.Contains(rep.Title, "MAX_LOCKDEP") {
		return nil, false, false
	}
	// Dump /proc/lockdep* files on BUG: MAX_LOCKDEP_{KEYS,ENTRIES,CHAINS,CHAIN_HLOCKS} too low!
	output, err := ssh("cat", "/proc/lockdep_stats", "/proc/lockdep", "/proc/lockdep_chains")
	if err != nil {
		output = append(output, err.Error()...)
	}
	// Remove mangled pointer values, they take lots of space but don't add any value.
	output = regexp.MustCompile(` *\[?[0-9a-f]{8,}\]?\s*`).ReplaceAll(output, nil)
	return output, false, true
}