URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Subversion Repositories openrisc
[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [libgo/] [go/] [crypto/] [rand/] [rand_windows.go] - Rev 867
Go to most recent revision | Compare with Previous | Blame | View Log
// Copyright 2010 The Go Authors. All rights reserved.// Use of this source code is governed by a BSD-style// license that can be found in the LICENSE file.// Windows cryptographically secure pseudorandom number// generator.package randimport ("os""sync""syscall")// Implemented by using Windows CryptoAPI 2.0.func init() { Reader = &rngReader{} }// A rngReader satisfies reads by reading from the Windows CryptGenRandom API.type rngReader struct {prov syscall.Handlemu sync.Mutex}func (r *rngReader) Read(b []byte) (n int, err error) {r.mu.Lock()if r.prov == 0 {const provType = syscall.PROV_RSA_FULLconst flags = syscall.CRYPT_VERIFYCONTEXT | syscall.CRYPT_SILENTerr := syscall.CryptAcquireContext(&r.prov, nil, nil, provType, flags)if err != nil {r.mu.Unlock()return 0, os.NewSyscallError("CryptAcquireContext", err)}}r.mu.Unlock()err = syscall.CryptGenRandom(r.prov, uint32(len(b)), &b[0])if err != nil {return 0, os.NewSyscallError("CryptGenRandom", err)}return len(b), nil}
Go to most recent revision | Compare with Previous | Blame | View Log
