diff options
| author | Dmitry Vyukov <dvyukov@google.com> | 2020-04-18 12:36:52 +0200 |
|---|---|---|
| committer | Dmitry Vyukov <dvyukov@google.com> | 2020-04-18 14:35:45 +0200 |
| commit | 67234372ef1e27c87a6be2e0141d70ae797231a1 (patch) | |
| tree | e6304ac41f5af586d81d84e31f9c8547754a32d9 /sys | |
| parent | ea36da8271c508fe4c8bcc80af20ec81c812b95a (diff) | |
prog: refactor target.MakeMmap
Make MakeMmap return more than 1 call.
This is a preparation for future changes.
Also remove addr/size as they are effectively
always the same and can be inferred from the target
(will also conflict with the future changes).
Also rename to MakeDataMmap to better represent
the new purpose: it's just some arbitrary mmap,
but rather mapping of the data segment.
Diffstat (limited to 'sys')
| -rw-r--r-- | sys/akaros/init.go | 2 | ||||
| -rw-r--r-- | sys/freebsd/init.go | 2 | ||||
| -rw-r--r-- | sys/fuchsia/init.go | 2 | ||||
| -rw-r--r-- | sys/linux/init.go | 2 | ||||
| -rw-r--r-- | sys/netbsd/init.go | 2 | ||||
| -rw-r--r-- | sys/openbsd/init.go | 2 | ||||
| -rw-r--r-- | sys/targets/common.go | 31 | ||||
| -rw-r--r-- | sys/test/init.go | 2 | ||||
| -rw-r--r-- | sys/trusty/init.go | 2 | ||||
| -rw-r--r-- | sys/windows/init.go | 25 |
10 files changed, 41 insertions, 31 deletions
diff --git a/sys/akaros/init.go b/sys/akaros/init.go index c5098ce7f..3016b3dee 100644 --- a/sys/akaros/init.go +++ b/sys/akaros/init.go @@ -16,7 +16,7 @@ func InitTarget(target *prog.Target) { arch := &arch{ MAP_FIXED: target.GetConst("MAP_FIXED"), } - target.MakeMmap = targets.MakePosixMmap(target, true) + target.MakeDataMmap = targets.MakePosixMmap(target, true) target.Neutralize = arch.Neutralize } diff --git a/sys/freebsd/init.go b/sys/freebsd/init.go index 8629ea235..eff43b288 100644 --- a/sys/freebsd/init.go +++ b/sys/freebsd/init.go @@ -13,7 +13,7 @@ func InitTarget(target *prog.Target) { unix: targets.MakeUnixNeutralizer(target), } - target.MakeMmap = targets.MakePosixMmap(target, true) + target.MakeDataMmap = targets.MakePosixMmap(target, true) target.Neutralize = arch.unix.Neutralize } diff --git a/sys/fuchsia/init.go b/sys/fuchsia/init.go index 30cb3d7d1..2fbbd4bdf 100644 --- a/sys/fuchsia/init.go +++ b/sys/fuchsia/init.go @@ -11,5 +11,5 @@ import ( ) func InitTarget(target *prog.Target) { - target.MakeMmap = targets.MakeSyzMmap(target) + target.MakeDataMmap = targets.MakeSyzMmap(target) } diff --git a/sys/linux/init.go b/sys/linux/init.go index 7638860d5..6a10c7d82 100644 --- a/sys/linux/init.go +++ b/sys/linux/init.go @@ -48,7 +48,7 @@ func InitTarget(target *prog.Target) { ARCH_SET_GS: target.ConstMap["ARCH_SET_GS"], } - target.MakeMmap = targets.MakePosixMmap(target, true) + target.MakeDataMmap = targets.MakePosixMmap(target, true) target.Neutralize = arch.neutralize target.SpecialTypes = map[string]func(g *prog.Gen, typ prog.Type, old prog.Arg) ( prog.Arg, []*prog.Call){ diff --git a/sys/netbsd/init.go b/sys/netbsd/init.go index 5a07bcb09..c90c51eb8 100644 --- a/sys/netbsd/init.go +++ b/sys/netbsd/init.go @@ -13,7 +13,7 @@ func InitTarget(target *prog.Target) { unix: targets.MakeUnixNeutralizer(target), } - target.MakeMmap = targets.MakePosixMmap(target, false) + target.MakeDataMmap = targets.MakePosixMmap(target, false) target.Neutralize = arch.unix.Neutralize } diff --git a/sys/openbsd/init.go b/sys/openbsd/init.go index 9f9a59ebf..40ab996f4 100644 --- a/sys/openbsd/init.go +++ b/sys/openbsd/init.go @@ -19,7 +19,7 @@ func InitTarget(target *prog.Target) { S_IFCHR: target.GetConst("S_IFCHR"), } - target.MakeMmap = targets.MakePosixMmap(target, false) + target.MakeDataMmap = targets.MakePosixMmap(target, false) target.Neutralize = arch.neutralize target.AnnotateCall = arch.annotateCall } diff --git a/sys/targets/common.go b/sys/targets/common.go index 72c485f81..75a1aba4f 100644 --- a/sys/targets/common.go +++ b/sys/targets/common.go @@ -7,8 +7,8 @@ import ( "github.com/google/syzkaller/prog" ) -// MakePosixMmap creates a "normal" posix mmap call that maps [addr, addr+size) range. -func MakePosixMmap(target *prog.Target, exec bool) func(addr, size uint64) *prog.Call { +// MakePosixMmap creates a "normal" posix mmap call that maps the target data range. +func MakePosixMmap(target *prog.Target, exec bool) func() []*prog.Call { meta := target.SyscallMap["mmap"] prot := target.GetConst("PROT_READ") | target.GetConst("PROT_WRITE") if exec { @@ -16,9 +16,10 @@ func MakePosixMmap(target *prog.Target, exec bool) func(addr, size uint64) *prog } flags := target.GetConst("MAP_ANONYMOUS") | target.GetConst("MAP_PRIVATE") | target.GetConst("MAP_FIXED") const invalidFD = ^uint64(0) - return func(addr, size uint64) *prog.Call { + size := target.NumPages * target.PageSize + return func() []*prog.Call { args := []prog.Arg{ - prog.MakeVmaPointerArg(meta.Args[0], addr, size), + prog.MakeVmaPointerArg(meta.Args[0], 0, size), prog.MakeConstArg(meta.Args[1], size), prog.MakeConstArg(meta.Args[2], prot), prog.MakeConstArg(meta.Args[3], flags), @@ -32,24 +33,28 @@ func MakePosixMmap(target *prog.Target, exec bool) func(addr, size uint64) *prog } args = append(args, prog.MakeConstArg(meta.Args[i], 0)) - return &prog.Call{ + mmapCall := &prog.Call{ Meta: meta, Args: args, Ret: prog.MakeReturnArg(meta.Ret), } + return []*prog.Call{mmapCall} } } -func MakeSyzMmap(target *prog.Target) func(addr, size uint64) *prog.Call { +func MakeSyzMmap(target *prog.Target) func() []*prog.Call { meta := target.SyscallMap["syz_mmap"] - return func(addr, size uint64) *prog.Call { - return &prog.Call{ - Meta: meta, - Args: []prog.Arg{ - prog.MakeVmaPointerArg(meta.Args[0], addr, size), - prog.MakeConstArg(meta.Args[1], size), + size := target.NumPages * target.PageSize + return func() []*prog.Call { + return []*prog.Call{ + &prog.Call{ + Meta: meta, + Args: []prog.Arg{ + prog.MakeVmaPointerArg(meta.Args[0], 0, size), + prog.MakeConstArg(meta.Args[1], size), + }, + Ret: prog.MakeReturnArg(meta.Ret), }, - Ret: prog.MakeReturnArg(meta.Ret), } } } diff --git a/sys/test/init.go b/sys/test/init.go index 815c99a98..ee2281f70 100644 --- a/sys/test/init.go +++ b/sys/test/init.go @@ -9,5 +9,5 @@ import ( ) func InitTarget(target *prog.Target) { - target.MakeMmap = targets.MakeSyzMmap(target) + target.MakeDataMmap = targets.MakeSyzMmap(target) } diff --git a/sys/trusty/init.go b/sys/trusty/init.go index d437b5d3f..2ec63cbf3 100644 --- a/sys/trusty/init.go +++ b/sys/trusty/init.go @@ -9,5 +9,5 @@ import ( ) func InitTarget(target *prog.Target) { - target.MakeMmap = targets.MakeSyzMmap(target) + target.MakeDataMmap = targets.MakeSyzMmap(target) } diff --git a/sys/windows/init.go b/sys/windows/init.go index 5c1a1e9a9..6a245cdba 100644 --- a/sys/windows/init.go +++ b/sys/windows/init.go @@ -9,16 +9,18 @@ import ( func InitTarget(target *prog.Target) { arch := &arch{ + target: target, virtualAllocSyscall: target.SyscallMap["VirtualAlloc"], MEM_COMMIT: target.GetConst("MEM_COMMIT"), MEM_RESERVE: target.GetConst("MEM_RESERVE"), PAGE_EXECUTE_READWRITE: target.GetConst("PAGE_EXECUTE_READWRITE"), } - target.MakeMmap = arch.makeMmap + target.MakeDataMmap = arch.makeMmap } type arch struct { + target *prog.Target virtualAllocSyscall *prog.Syscall MEM_COMMIT uint64 @@ -26,16 +28,19 @@ type arch struct { PAGE_EXECUTE_READWRITE uint64 } -func (arch *arch) makeMmap(addr, size uint64) *prog.Call { +func (arch *arch) makeMmap() []*prog.Call { meta := arch.virtualAllocSyscall - return &prog.Call{ - Meta: meta, - Args: []prog.Arg{ - prog.MakeVmaPointerArg(meta.Args[0], addr, size), - prog.MakeConstArg(meta.Args[1], size), - prog.MakeConstArg(meta.Args[2], arch.MEM_COMMIT|arch.MEM_RESERVE), - prog.MakeConstArg(meta.Args[3], arch.PAGE_EXECUTE_READWRITE), + size := arch.target.NumPages * arch.target.PageSize + return []*prog.Call{ + &prog.Call{ + Meta: meta, + Args: []prog.Arg{ + prog.MakeVmaPointerArg(meta.Args[0], 0, size), + prog.MakeConstArg(meta.Args[1], size), + prog.MakeConstArg(meta.Args[2], arch.MEM_COMMIT|arch.MEM_RESERVE), + prog.MakeConstArg(meta.Args[3], arch.PAGE_EXECUTE_READWRITE), + }, + Ret: prog.MakeReturnArg(meta.Ret), }, - Ret: prog.MakeReturnArg(meta.Ret), } } |
