2015-12-27 12:20:00 +01:00
|
|
|
// Copyright 2015 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.
|
|
|
|
|
2017-09-05 13:31:14 +02:00
|
|
|
package prog
|
2015-12-27 12:20:00 +01:00
|
|
|
|
|
|
|
import (
|
2017-09-14 19:25:01 +02:00
|
|
|
"runtime"
|
2015-12-27 12:20:00 +01:00
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
2017-06-06 17:02:19 +02:00
|
|
|
func TestResourceCtors(t *testing.T) {
|
2017-09-14 19:25:01 +02:00
|
|
|
target, err := GetTarget("linux", runtime.GOARCH)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
for _, c := range target.Syscalls {
|
|
|
|
for _, res := range c.inputResources() {
|
|
|
|
if len(target.calcResourceCtors(res.Desc.Kind, true)) == 0 {
|
2017-06-06 17:02:19 +02:00
|
|
|
t.Errorf("call %v requires input resource %v, but there are no calls that can create this resource", c.Name, res.Desc.Name)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-12-27 12:20:00 +01:00
|
|
|
func TestTransitivelyEnabledCalls(t *testing.T) {
|
2017-05-25 16:37:05 +02:00
|
|
|
t.Parallel()
|
2017-09-14 19:25:01 +02:00
|
|
|
target, err := GetTarget("linux", runtime.GOARCH)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2017-09-05 10:38:22 +02:00
|
|
|
calls := make(map[*Syscall]bool)
|
2017-09-14 19:25:01 +02:00
|
|
|
for _, c := range target.Syscalls {
|
2015-12-27 12:20:00 +01:00
|
|
|
calls[c] = true
|
|
|
|
}
|
2017-09-14 19:25:01 +02:00
|
|
|
if trans := target.TransitivelyEnabledCalls(calls); len(calls) != len(trans) {
|
2015-12-27 12:20:00 +01:00
|
|
|
for c := range calls {
|
|
|
|
if !trans[c] {
|
|
|
|
t.Logf("disabled %v", c.Name)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
t.Fatalf("can't create some resource")
|
|
|
|
}
|
2017-09-14 19:25:01 +02:00
|
|
|
delete(calls, target.SyscallMap["epoll_create"])
|
|
|
|
if trans := target.TransitivelyEnabledCalls(calls); len(calls) != len(trans) {
|
2015-12-27 12:20:00 +01:00
|
|
|
t.Fatalf("still must be able to create epoll fd with epoll_create1")
|
|
|
|
}
|
2017-09-14 19:25:01 +02:00
|
|
|
delete(calls, target.SyscallMap["epoll_create1"])
|
|
|
|
trans := target.TransitivelyEnabledCalls(calls)
|
2017-11-27 09:09:06 +01:00
|
|
|
if len(calls)-6 != len(trans) ||
|
2017-09-14 19:25:01 +02:00
|
|
|
trans[target.SyscallMap["epoll_ctl$EPOLL_CTL_ADD"]] ||
|
|
|
|
trans[target.SyscallMap["epoll_ctl$EPOLL_CTL_MOD"]] ||
|
|
|
|
trans[target.SyscallMap["epoll_ctl$EPOLL_CTL_DEL"]] ||
|
|
|
|
trans[target.SyscallMap["epoll_wait"]] ||
|
2017-11-27 09:09:06 +01:00
|
|
|
trans[target.SyscallMap["epoll_pwait"]] ||
|
|
|
|
trans[target.SyscallMap["kcmp$KCMP_EPOLL_TFD"]] {
|
2015-12-27 12:20:00 +01:00
|
|
|
t.Fatalf("epoll fd is not disabled")
|
|
|
|
}
|
|
|
|
}
|
2017-01-05 14:33:44 +01:00
|
|
|
|
|
|
|
func TestClockGettime(t *testing.T) {
|
2017-05-25 16:37:05 +02:00
|
|
|
t.Parallel()
|
2017-09-14 19:25:01 +02:00
|
|
|
target, err := GetTarget("linux", runtime.GOARCH)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2017-09-05 10:38:22 +02:00
|
|
|
calls := make(map[*Syscall]bool)
|
2017-09-14 19:25:01 +02:00
|
|
|
for _, c := range target.Syscalls {
|
2017-01-05 14:33:44 +01:00
|
|
|
calls[c] = true
|
|
|
|
}
|
|
|
|
// Removal of clock_gettime should disable all calls that accept timespec/timeval.
|
2017-09-14 19:25:01 +02:00
|
|
|
delete(calls, target.SyscallMap["clock_gettime"])
|
|
|
|
trans := target.TransitivelyEnabledCalls(calls)
|
2017-01-05 14:33:44 +01:00
|
|
|
if len(trans)+10 > len(calls) {
|
|
|
|
t.Fatalf("clock_gettime did not disable enough calls: before %v, after %v", len(calls), len(trans))
|
|
|
|
}
|
|
|
|
}
|