xref: /aoo4110/main/sal/rtl/source/random.c (revision b1cdbd2c)
1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski #define _RTL_RANDOM_C_ "$Revision: 1.6 $"
25*b1cdbd2cSJim Jagielski 
26*b1cdbd2cSJim Jagielski #include <sal/types.h>
27*b1cdbd2cSJim Jagielski #include <osl/thread.h>
28*b1cdbd2cSJim Jagielski #include <osl/time.h>
29*b1cdbd2cSJim Jagielski #include <rtl/alloc.h>
30*b1cdbd2cSJim Jagielski #include <rtl/digest.h>
31*b1cdbd2cSJim Jagielski #include <rtl/random.h>
32*b1cdbd2cSJim Jagielski #include <osl/time.h>
33*b1cdbd2cSJim Jagielski 
34*b1cdbd2cSJim Jagielski /*========================================================================
35*b1cdbd2cSJim Jagielski  *
36*b1cdbd2cSJim Jagielski  * rtlRandom internals.
37*b1cdbd2cSJim Jagielski  *
38*b1cdbd2cSJim Jagielski  *======================================================================*/
39*b1cdbd2cSJim Jagielski #define RTL_RANDOM_RNG_1(a) ((a) * 16807L)
40*b1cdbd2cSJim Jagielski #define RTL_RANDOM_RNG_2(a) ((a) * 65539L)
41*b1cdbd2cSJim Jagielski 
42*b1cdbd2cSJim Jagielski #define RTL_RANDOM_RNG(x, y, z) \
43*b1cdbd2cSJim Jagielski { \
44*b1cdbd2cSJim Jagielski 	(x) = 170 * ((x) % 178) - 63 * ((x) / 178); \
45*b1cdbd2cSJim Jagielski 	if ((x) < 0) (x) += 30328L; \
46*b1cdbd2cSJim Jagielski 	\
47*b1cdbd2cSJim Jagielski 	(y) = 171 * ((y) % 177) -  2 * ((y) / 177); \
48*b1cdbd2cSJim Jagielski 	if ((y) < 0) (y) += 30269L; \
49*b1cdbd2cSJim Jagielski 	\
50*b1cdbd2cSJim Jagielski 	(z) = 172 * ((z) % 176) - 35 * ((z) / 176); \
51*b1cdbd2cSJim Jagielski 	if ((z) < 0) (z) += 30307L; \
52*b1cdbd2cSJim Jagielski }
53*b1cdbd2cSJim Jagielski 
54*b1cdbd2cSJim Jagielski /** RandomData_Impl.
55*b1cdbd2cSJim Jagielski  */
56*b1cdbd2cSJim Jagielski typedef struct random_data_impl_st
57*b1cdbd2cSJim Jagielski {
58*b1cdbd2cSJim Jagielski 	sal_Int16 m_nX;
59*b1cdbd2cSJim Jagielski 	sal_Int16 m_nY;
60*b1cdbd2cSJim Jagielski 	sal_Int16 m_nZ;
61*b1cdbd2cSJim Jagielski } RandomData_Impl;
62*b1cdbd2cSJim Jagielski 
63*b1cdbd2cSJim Jagielski /** __rtl_random_data.
64*b1cdbd2cSJim Jagielski  */
65*b1cdbd2cSJim Jagielski static double __rtl_random_data (RandomData_Impl *pImpl);
66*b1cdbd2cSJim Jagielski 
67*b1cdbd2cSJim Jagielski /** RandomPool_Impl.
68*b1cdbd2cSJim Jagielski  */
69*b1cdbd2cSJim Jagielski #define RTL_RANDOM_DIGEST      rtl_Digest_AlgorithmMD5
70*b1cdbd2cSJim Jagielski #define RTL_RANDOM_SIZE_DIGEST RTL_DIGEST_LENGTH_MD5
71*b1cdbd2cSJim Jagielski #define RTL_RANDOM_SIZE_POOL   1023
72*b1cdbd2cSJim Jagielski 
73*b1cdbd2cSJim Jagielski typedef struct random_pool_impl_st
74*b1cdbd2cSJim Jagielski {
75*b1cdbd2cSJim Jagielski 	rtlDigest  m_hDigest;
76*b1cdbd2cSJim Jagielski 	sal_uInt8  m_pDigest[RTL_RANDOM_SIZE_DIGEST];
77*b1cdbd2cSJim Jagielski 	sal_uInt8  m_pData[RTL_RANDOM_SIZE_POOL + 1];
78*b1cdbd2cSJim Jagielski 	sal_uInt32 m_nData;
79*b1cdbd2cSJim Jagielski 	sal_uInt32 m_nIndex;
80*b1cdbd2cSJim Jagielski 	sal_uInt32 m_nCount;
81*b1cdbd2cSJim Jagielski } RandomPool_Impl;
82*b1cdbd2cSJim Jagielski 
83*b1cdbd2cSJim Jagielski /** __rtl_random_initPool.
84*b1cdbd2cSJim Jagielski  */
85*b1cdbd2cSJim Jagielski static sal_Bool __rtl_random_initPool (
86*b1cdbd2cSJim Jagielski 	RandomPool_Impl *pImpl);
87*b1cdbd2cSJim Jagielski 
88*b1cdbd2cSJim Jagielski /** __rtl_random_seedPool.
89*b1cdbd2cSJim Jagielski  */
90*b1cdbd2cSJim Jagielski static void __rtl_random_seedPool (
91*b1cdbd2cSJim Jagielski 	RandomPool_Impl *pImpl, const sal_uInt8 *pBuffer, sal_Size nBufLen);
92*b1cdbd2cSJim Jagielski 
93*b1cdbd2cSJim Jagielski /** __rtl_random_readPool.
94*b1cdbd2cSJim Jagielski  */
95*b1cdbd2cSJim Jagielski static void __rtl_random_readPool (
96*b1cdbd2cSJim Jagielski 	RandomPool_Impl *pImpl, sal_uInt8 *pBuffer, sal_Size nBufLen);
97*b1cdbd2cSJim Jagielski 
98*b1cdbd2cSJim Jagielski /*
99*b1cdbd2cSJim Jagielski  * __rtl_random_data.
100*b1cdbd2cSJim Jagielski  */
__rtl_random_data(RandomData_Impl * pImpl)101*b1cdbd2cSJim Jagielski static double __rtl_random_data (RandomData_Impl *pImpl)
102*b1cdbd2cSJim Jagielski {
103*b1cdbd2cSJim Jagielski 	register double random;
104*b1cdbd2cSJim Jagielski 
105*b1cdbd2cSJim Jagielski 	RTL_RANDOM_RNG (pImpl->m_nX, pImpl->m_nY, pImpl->m_nZ);
106*b1cdbd2cSJim Jagielski 	random = (((double)(pImpl->m_nX) / 30328.0) +
107*b1cdbd2cSJim Jagielski 			  ((double)(pImpl->m_nY) / 30269.0) +
108*b1cdbd2cSJim Jagielski 			  ((double)(pImpl->m_nZ) / 30307.0)   );
109*b1cdbd2cSJim Jagielski 
110*b1cdbd2cSJim Jagielski 	random -= ((double)((sal_uInt32)(random)));
111*b1cdbd2cSJim Jagielski 	return (random);
112*b1cdbd2cSJim Jagielski }
113*b1cdbd2cSJim Jagielski 
114*b1cdbd2cSJim Jagielski /*
115*b1cdbd2cSJim Jagielski  * __rtl_random_initPool.
116*b1cdbd2cSJim Jagielski  */
__rtl_random_initPool(RandomPool_Impl * pImpl)117*b1cdbd2cSJim Jagielski static sal_Bool __rtl_random_initPool (RandomPool_Impl *pImpl)
118*b1cdbd2cSJim Jagielski {
119*b1cdbd2cSJim Jagielski 	pImpl->m_hDigest = rtl_digest_create (RTL_RANDOM_DIGEST);
120*b1cdbd2cSJim Jagielski 	if (pImpl->m_hDigest)
121*b1cdbd2cSJim Jagielski 	{
122*b1cdbd2cSJim Jagielski 		oslThreadIdentifier id;
123*b1cdbd2cSJim Jagielski 		TimeValue           tv;
124*b1cdbd2cSJim Jagielski 		RandomData_Impl     rd;
125*b1cdbd2cSJim Jagielski 		double              seed;
126*b1cdbd2cSJim Jagielski 
127*b1cdbd2cSJim Jagielski         /* The use of uninitialized stack variables as a way to
128*b1cdbd2cSJim Jagielski          * enhance the entropy of the random pool triggers
129*b1cdbd2cSJim Jagielski          * memory checkers like purify and valgrind.
130*b1cdbd2cSJim Jagielski          */
131*b1cdbd2cSJim Jagielski 
132*b1cdbd2cSJim Jagielski         /*
133*b1cdbd2cSJim Jagielski 		__rtl_random_seedPool (pImpl, (sal_uInt8*)&id, sizeof(id));
134*b1cdbd2cSJim Jagielski 		__rtl_random_seedPool (pImpl, (sal_uInt8*)&tv, sizeof(tv));
135*b1cdbd2cSJim Jagielski 		__rtl_random_seedPool (pImpl, (sal_uInt8*)&rd, sizeof(rd));
136*b1cdbd2cSJim Jagielski         */
137*b1cdbd2cSJim Jagielski 
138*b1cdbd2cSJim Jagielski 		id = osl_getThreadIdentifier (NULL);
139*b1cdbd2cSJim Jagielski 		id = RTL_RANDOM_RNG_2(RTL_RANDOM_RNG_1(id));
140*b1cdbd2cSJim Jagielski 		__rtl_random_seedPool (pImpl, (sal_uInt8*)&id, sizeof(id));
141*b1cdbd2cSJim Jagielski 
142*b1cdbd2cSJim Jagielski 		osl_getSystemTime (&tv);
143*b1cdbd2cSJim Jagielski 		tv.Seconds = RTL_RANDOM_RNG_2(tv.Seconds);
144*b1cdbd2cSJim Jagielski 		tv.Nanosec = RTL_RANDOM_RNG_2(tv.Nanosec);
145*b1cdbd2cSJim Jagielski 		__rtl_random_seedPool (pImpl, (sal_uInt8*)&tv, sizeof(tv));
146*b1cdbd2cSJim Jagielski 
147*b1cdbd2cSJim Jagielski 		rd.m_nX = (sal_Int16)(((id         >> 1) << 1) + 1);
148*b1cdbd2cSJim Jagielski 		rd.m_nY = (sal_Int16)(((tv.Seconds >> 1) << 1) + 1);
149*b1cdbd2cSJim Jagielski 		rd.m_nZ = (sal_Int16)(((tv.Nanosec >> 1) << 1) + 1);
150*b1cdbd2cSJim Jagielski 		__rtl_random_seedPool (pImpl, (sal_uInt8*)&rd, sizeof(rd));
151*b1cdbd2cSJim Jagielski 
152*b1cdbd2cSJim Jagielski 		while (pImpl->m_nData < RTL_RANDOM_SIZE_POOL)
153*b1cdbd2cSJim Jagielski 		{
154*b1cdbd2cSJim Jagielski 			seed = __rtl_random_data (&rd);
155*b1cdbd2cSJim Jagielski 			__rtl_random_seedPool (pImpl, (sal_uInt8*)&seed, sizeof(seed));
156*b1cdbd2cSJim Jagielski 		}
157*b1cdbd2cSJim Jagielski 		return sal_True;
158*b1cdbd2cSJim Jagielski 	}
159*b1cdbd2cSJim Jagielski 	return sal_False;
160*b1cdbd2cSJim Jagielski }
161*b1cdbd2cSJim Jagielski 
162*b1cdbd2cSJim Jagielski /*
163*b1cdbd2cSJim Jagielski  * __rtl_random_seedPool.
164*b1cdbd2cSJim Jagielski  */
__rtl_random_seedPool(RandomPool_Impl * pImpl,const sal_uInt8 * pBuffer,sal_Size nBufLen)165*b1cdbd2cSJim Jagielski static void __rtl_random_seedPool (
166*b1cdbd2cSJim Jagielski 	RandomPool_Impl *pImpl, const sal_uInt8 *pBuffer, sal_Size nBufLen)
167*b1cdbd2cSJim Jagielski {
168*b1cdbd2cSJim Jagielski 	sal_Size i;
169*b1cdbd2cSJim Jagielski 	sal_sSize  j, k;
170*b1cdbd2cSJim Jagielski 
171*b1cdbd2cSJim Jagielski 	for (i = 0; i < nBufLen; i += RTL_RANDOM_SIZE_DIGEST)
172*b1cdbd2cSJim Jagielski 	{
173*b1cdbd2cSJim Jagielski 		j = nBufLen - i;
174*b1cdbd2cSJim Jagielski 		if (j > RTL_RANDOM_SIZE_DIGEST)
175*b1cdbd2cSJim Jagielski 			j = RTL_RANDOM_SIZE_DIGEST;
176*b1cdbd2cSJim Jagielski 
177*b1cdbd2cSJim Jagielski 		rtl_digest_update (
178*b1cdbd2cSJim Jagielski 			pImpl->m_hDigest, pImpl->m_pDigest, RTL_RANDOM_SIZE_DIGEST);
179*b1cdbd2cSJim Jagielski 
180*b1cdbd2cSJim Jagielski 		k = (pImpl->m_nIndex + j) - RTL_RANDOM_SIZE_POOL;
181*b1cdbd2cSJim Jagielski 		if (k > 0)
182*b1cdbd2cSJim Jagielski 		{
183*b1cdbd2cSJim Jagielski 			rtl_digest_update (
184*b1cdbd2cSJim Jagielski 				pImpl->m_hDigest, &(pImpl->m_pData[pImpl->m_nIndex]), j - k);
185*b1cdbd2cSJim Jagielski 			rtl_digest_update (
186*b1cdbd2cSJim Jagielski 				pImpl->m_hDigest, &(pImpl->m_pData[0]), k);
187*b1cdbd2cSJim Jagielski 		}
188*b1cdbd2cSJim Jagielski 		else
189*b1cdbd2cSJim Jagielski 		{
190*b1cdbd2cSJim Jagielski 			rtl_digest_update (
191*b1cdbd2cSJim Jagielski 				pImpl->m_hDigest, &(pImpl->m_pData[pImpl->m_nIndex]), j);
192*b1cdbd2cSJim Jagielski 		}
193*b1cdbd2cSJim Jagielski 
194*b1cdbd2cSJim Jagielski 		rtl_digest_update (pImpl->m_hDigest, pBuffer, j);
195*b1cdbd2cSJim Jagielski 		pBuffer += j;
196*b1cdbd2cSJim Jagielski 
197*b1cdbd2cSJim Jagielski 		rtl_digest_get (
198*b1cdbd2cSJim Jagielski 			pImpl->m_hDigest, pImpl->m_pDigest, RTL_RANDOM_SIZE_DIGEST);
199*b1cdbd2cSJim Jagielski 		for (k = 0; k < j; k++)
200*b1cdbd2cSJim Jagielski 		{
201*b1cdbd2cSJim Jagielski 			pImpl->m_pData[pImpl->m_nIndex++] ^= pImpl->m_pDigest[k];
202*b1cdbd2cSJim Jagielski 			if (pImpl->m_nIndex >= RTL_RANDOM_SIZE_POOL)
203*b1cdbd2cSJim Jagielski 			{
204*b1cdbd2cSJim Jagielski 				pImpl->m_nData  = RTL_RANDOM_SIZE_POOL;
205*b1cdbd2cSJim Jagielski 				pImpl->m_nIndex = 0;
206*b1cdbd2cSJim Jagielski 			}
207*b1cdbd2cSJim Jagielski 		}
208*b1cdbd2cSJim Jagielski 	}
209*b1cdbd2cSJim Jagielski 
210*b1cdbd2cSJim Jagielski 	if (pImpl->m_nIndex > pImpl->m_nData)
211*b1cdbd2cSJim Jagielski 		pImpl->m_nData = pImpl->m_nIndex;
212*b1cdbd2cSJim Jagielski }
213*b1cdbd2cSJim Jagielski 
214*b1cdbd2cSJim Jagielski /*
215*b1cdbd2cSJim Jagielski  * __rtl_random_readPool.
216*b1cdbd2cSJim Jagielski  */
__rtl_random_readPool(RandomPool_Impl * pImpl,sal_uInt8 * pBuffer,sal_Size nBufLen)217*b1cdbd2cSJim Jagielski static void __rtl_random_readPool (
218*b1cdbd2cSJim Jagielski 	RandomPool_Impl *pImpl, sal_uInt8 *pBuffer, sal_Size nBufLen)
219*b1cdbd2cSJim Jagielski {
220*b1cdbd2cSJim Jagielski 	sal_Int32 j, k;
221*b1cdbd2cSJim Jagielski 
222*b1cdbd2cSJim Jagielski 	while (nBufLen > 0)
223*b1cdbd2cSJim Jagielski 	{
224*b1cdbd2cSJim Jagielski 		j = nBufLen;
225*b1cdbd2cSJim Jagielski 		if (j > RTL_RANDOM_SIZE_DIGEST/2)
226*b1cdbd2cSJim Jagielski 			j = RTL_RANDOM_SIZE_DIGEST/2;
227*b1cdbd2cSJim Jagielski 		nBufLen -= j;
228*b1cdbd2cSJim Jagielski 
229*b1cdbd2cSJim Jagielski 		rtl_digest_update (
230*b1cdbd2cSJim Jagielski 			pImpl->m_hDigest,
231*b1cdbd2cSJim Jagielski 			&(pImpl->m_pDigest[RTL_RANDOM_SIZE_DIGEST/2]),
232*b1cdbd2cSJim Jagielski 			RTL_RANDOM_SIZE_DIGEST/2);
233*b1cdbd2cSJim Jagielski 
234*b1cdbd2cSJim Jagielski 		k = (pImpl->m_nIndex + j) - pImpl->m_nData;
235*b1cdbd2cSJim Jagielski 		if (k > 0)
236*b1cdbd2cSJim Jagielski 		{
237*b1cdbd2cSJim Jagielski 			rtl_digest_update (
238*b1cdbd2cSJim Jagielski 				pImpl->m_hDigest, &(pImpl->m_pData[pImpl->m_nIndex]), j - k);
239*b1cdbd2cSJim Jagielski 			rtl_digest_update (
240*b1cdbd2cSJim Jagielski 				pImpl->m_hDigest, &(pImpl->m_pData[0]), k);
241*b1cdbd2cSJim Jagielski 		}
242*b1cdbd2cSJim Jagielski 		else
243*b1cdbd2cSJim Jagielski 		{
244*b1cdbd2cSJim Jagielski 			rtl_digest_update (
245*b1cdbd2cSJim Jagielski 				pImpl->m_hDigest, &(pImpl->m_pData[pImpl->m_nIndex]), j);
246*b1cdbd2cSJim Jagielski 		}
247*b1cdbd2cSJim Jagielski 
248*b1cdbd2cSJim Jagielski 		rtl_digest_get (
249*b1cdbd2cSJim Jagielski 			pImpl->m_hDigest, pImpl->m_pDigest, RTL_RANDOM_SIZE_DIGEST);
250*b1cdbd2cSJim Jagielski 		for (k = 0; k < j; k++)
251*b1cdbd2cSJim Jagielski 		{
252*b1cdbd2cSJim Jagielski 			if (pImpl->m_nIndex >= pImpl->m_nData) pImpl->m_nIndex = 0;
253*b1cdbd2cSJim Jagielski 			pImpl->m_pData[pImpl->m_nIndex++] ^= pImpl->m_pDigest[k];
254*b1cdbd2cSJim Jagielski 			*pBuffer++ = pImpl->m_pDigest[k + RTL_RANDOM_SIZE_DIGEST/2];
255*b1cdbd2cSJim Jagielski 		}
256*b1cdbd2cSJim Jagielski 	}
257*b1cdbd2cSJim Jagielski 
258*b1cdbd2cSJim Jagielski 	pImpl->m_nCount++;
259*b1cdbd2cSJim Jagielski 	rtl_digest_update (
260*b1cdbd2cSJim Jagielski 		pImpl->m_hDigest, &(pImpl->m_nCount), sizeof(pImpl->m_nCount));
261*b1cdbd2cSJim Jagielski 	rtl_digest_update (
262*b1cdbd2cSJim Jagielski 		pImpl->m_hDigest, pImpl->m_pDigest, RTL_RANDOM_SIZE_DIGEST);
263*b1cdbd2cSJim Jagielski 	rtl_digest_get (
264*b1cdbd2cSJim Jagielski 		pImpl->m_hDigest, pImpl->m_pDigest, RTL_RANDOM_SIZE_DIGEST);
265*b1cdbd2cSJim Jagielski }
266*b1cdbd2cSJim Jagielski 
267*b1cdbd2cSJim Jagielski /*========================================================================
268*b1cdbd2cSJim Jagielski  *
269*b1cdbd2cSJim Jagielski  * rtlRandom implementation.
270*b1cdbd2cSJim Jagielski  *
271*b1cdbd2cSJim Jagielski  *======================================================================*/
272*b1cdbd2cSJim Jagielski /*
273*b1cdbd2cSJim Jagielski  * rtl_random_createPool.
274*b1cdbd2cSJim Jagielski  */
rtl_random_createPool(void)275*b1cdbd2cSJim Jagielski rtlRandomPool SAL_CALL rtl_random_createPool (void)
276*b1cdbd2cSJim Jagielski {
277*b1cdbd2cSJim Jagielski 	RandomPool_Impl *pImpl = (RandomPool_Impl*)NULL;
278*b1cdbd2cSJim Jagielski 	pImpl = (RandomPool_Impl*)rtl_allocateZeroMemory (sizeof(RandomPool_Impl));
279*b1cdbd2cSJim Jagielski 	if (pImpl)
280*b1cdbd2cSJim Jagielski 	{
281*b1cdbd2cSJim Jagielski 		if (!__rtl_random_initPool (pImpl))
282*b1cdbd2cSJim Jagielski 		{
283*b1cdbd2cSJim Jagielski 			rtl_freeZeroMemory (pImpl, sizeof(RandomPool_Impl));
284*b1cdbd2cSJim Jagielski 			pImpl = (RandomPool_Impl*)NULL;
285*b1cdbd2cSJim Jagielski 		}
286*b1cdbd2cSJim Jagielski 	}
287*b1cdbd2cSJim Jagielski 	return ((rtlRandomPool)pImpl);
288*b1cdbd2cSJim Jagielski }
289*b1cdbd2cSJim Jagielski 
290*b1cdbd2cSJim Jagielski /*
291*b1cdbd2cSJim Jagielski  * rtl_random_destroyPool.
292*b1cdbd2cSJim Jagielski  */
rtl_random_destroyPool(rtlRandomPool Pool)293*b1cdbd2cSJim Jagielski void SAL_CALL rtl_random_destroyPool (rtlRandomPool Pool)
294*b1cdbd2cSJim Jagielski {
295*b1cdbd2cSJim Jagielski 	RandomPool_Impl *pImpl = (RandomPool_Impl *)Pool;
296*b1cdbd2cSJim Jagielski 	if (pImpl)
297*b1cdbd2cSJim Jagielski 	{
298*b1cdbd2cSJim Jagielski 		rtl_digest_destroy (pImpl->m_hDigest);
299*b1cdbd2cSJim Jagielski 		rtl_freeZeroMemory (pImpl, sizeof (RandomPool_Impl));
300*b1cdbd2cSJim Jagielski 	}
301*b1cdbd2cSJim Jagielski }
302*b1cdbd2cSJim Jagielski 
303*b1cdbd2cSJim Jagielski /*
304*b1cdbd2cSJim Jagielski  * rtl_random_addBytes.
305*b1cdbd2cSJim Jagielski  */
rtl_random_addBytes(rtlRandomPool Pool,const void * Buffer,sal_Size Bytes)306*b1cdbd2cSJim Jagielski rtlRandomError SAL_CALL rtl_random_addBytes (
307*b1cdbd2cSJim Jagielski 	rtlRandomPool Pool, const void *Buffer, sal_Size Bytes)
308*b1cdbd2cSJim Jagielski {
309*b1cdbd2cSJim Jagielski 	RandomPool_Impl *pImpl   = (RandomPool_Impl *)Pool;
310*b1cdbd2cSJim Jagielski 	const sal_uInt8 *pBuffer = (const sal_uInt8 *)Buffer;
311*b1cdbd2cSJim Jagielski 
312*b1cdbd2cSJim Jagielski 	if ((pImpl == NULL) || (pBuffer == NULL))
313*b1cdbd2cSJim Jagielski 		return rtl_Random_E_Argument;
314*b1cdbd2cSJim Jagielski 
315*b1cdbd2cSJim Jagielski 	__rtl_random_seedPool (pImpl, pBuffer, Bytes);
316*b1cdbd2cSJim Jagielski 	return rtl_Random_E_None;
317*b1cdbd2cSJim Jagielski }
318*b1cdbd2cSJim Jagielski 
319*b1cdbd2cSJim Jagielski /*
320*b1cdbd2cSJim Jagielski  * rtl_random_getBytes.
321*b1cdbd2cSJim Jagielski  */
rtl_random_getBytes(rtlRandomPool Pool,void * Buffer,sal_Size Bytes)322*b1cdbd2cSJim Jagielski rtlRandomError SAL_CALL rtl_random_getBytes (
323*b1cdbd2cSJim Jagielski 	rtlRandomPool Pool, void *Buffer, sal_Size Bytes)
324*b1cdbd2cSJim Jagielski {
325*b1cdbd2cSJim Jagielski 	RandomPool_Impl *pImpl   = (RandomPool_Impl *)Pool;
326*b1cdbd2cSJim Jagielski 	sal_uInt8       *pBuffer = (sal_uInt8 *)Buffer;
327*b1cdbd2cSJim Jagielski 
328*b1cdbd2cSJim Jagielski 	if ((pImpl == NULL) || (pBuffer == NULL))
329*b1cdbd2cSJim Jagielski 		return rtl_Random_E_Argument;
330*b1cdbd2cSJim Jagielski 
331*b1cdbd2cSJim Jagielski 	__rtl_random_readPool (pImpl, pBuffer, Bytes);
332*b1cdbd2cSJim Jagielski 	return rtl_Random_E_None;
333*b1cdbd2cSJim Jagielski }
334*b1cdbd2cSJim Jagielski 
335