mirror of
https://github.com/reactos/syzkaller.git
synced 2025-02-26 22:55:47 +00:00

Currently we always enable clock_gettime in config. This is required since the call is needed for generation of timespec/timeval structs. The negative side effect is that one gets clock_gettime even if he wants to fuzz a small set of unrelated syscalls. Don't enable clock_gettime by default. Instead handle timeval/timespec as other resources.
49 lines
1.4 KiB
Go
49 lines
1.4 KiB
Go
// 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.
|
|
|
|
package sys
|
|
|
|
import (
|
|
"testing"
|
|
)
|
|
|
|
func TestTransitivelyEnabledCalls(t *testing.T) {
|
|
calls := make(map[*Call]bool)
|
|
for _, c := range Calls {
|
|
calls[c] = true
|
|
}
|
|
if trans := TransitivelyEnabledCalls(calls); len(calls) != len(trans) {
|
|
for c := range calls {
|
|
if !trans[c] {
|
|
t.Logf("disabled %v", c.Name)
|
|
}
|
|
}
|
|
t.Fatalf("can't create some resource")
|
|
}
|
|
delete(calls, CallMap["epoll_create"])
|
|
if trans := TransitivelyEnabledCalls(calls); len(calls) != len(trans) {
|
|
t.Fatalf("still must be able to create epoll fd with epoll_create1")
|
|
}
|
|
delete(calls, CallMap["epoll_create1"])
|
|
trans := TransitivelyEnabledCalls(calls)
|
|
if len(calls)-3 != len(trans) ||
|
|
trans[CallMap["epoll_ctl"]] ||
|
|
trans[CallMap["epoll_wait"]] ||
|
|
trans[CallMap["epoll_pwait"]] {
|
|
t.Fatalf("epoll fd is not disabled")
|
|
}
|
|
}
|
|
|
|
func TestClockGettime(t *testing.T) {
|
|
calls := make(map[*Call]bool)
|
|
for _, c := range Calls {
|
|
calls[c] = true
|
|
}
|
|
// Removal of clock_gettime should disable all calls that accept timespec/timeval.
|
|
delete(calls, CallMap["clock_gettime"])
|
|
trans := TransitivelyEnabledCalls(calls)
|
|
if len(trans)+10 > len(calls) {
|
|
t.Fatalf("clock_gettime did not disable enough calls: before %v, after %v", len(calls), len(trans))
|
|
}
|
|
}
|