blob: 7379f1489adbf13bb41598f56c745b9e03fccd6d [file] [log] [blame]
Brad Fitzpatrick51947442016-03-01 22:57:46 +00001// Copyright 2010 The Go Authors. All rights reserved.
Peter Mundyccd28e82010-07-12 16:37:53 -07002// Use of this source code is governed by a BSD-style
3// license that can be found in the LICENSE file.
4
5// Windows cryptographically secure pseudorandom number
6// generator.
7
8package rand
9
10import (
Jason A. Donenfeldbb5075a2021-01-15 00:04:10 +010011 "internal/syscall/windows"
Peter Mundyccd28e82010-07-12 16:37:53 -070012 "os"
Peter Mundyccd28e82010-07-12 16:37:53 -070013)
14
Peter Mundyccd28e82010-07-12 16:37:53 -070015func init() { Reader = &rngReader{} }
16
Jason A. Donenfeld333e9042019-12-05 18:48:21 +010017type rngReader struct{}
Peter Mundyccd28e82010-07-12 16:37:53 -070018
Russ Coxc2049d22011-11-01 22:04:37 -040019func (r *rngReader) Read(b []byte) (n int, err error) {
Jason A. Donenfeld333e9042019-12-05 18:48:21 +010020 // RtlGenRandom only accepts 2**32-1 bytes at a time, so truncate.
21 inputLen := uint32(len(b))
Adam Langleyb752ab22012-09-09 20:07:09 -040022
Jason A. Donenfeld333e9042019-12-05 18:48:21 +010023 if inputLen == 0 {
Adam Langleyb752ab22012-09-09 20:07:09 -040024 return 0, nil
25 }
Jason A. Donenfeld333e9042019-12-05 18:48:21 +010026
Jason A. Donenfeldbb5075a2021-01-15 00:04:10 +010027 err = windows.RtlGenRandom(b)
Russ Coxc017a822011-11-13 22:44:52 -050028 if err != nil {
Jason A. Donenfeld333e9042019-12-05 18:48:21 +010029 return 0, os.NewSyscallError("RtlGenRandom", err)
Peter Mundyccd28e82010-07-12 16:37:53 -070030 }
Jason A. Donenfeld333e9042019-12-05 18:48:21 +010031 return int(inputLen), nil
Peter Mundyccd28e82010-07-12 16:37:53 -070032}