crypto/weakcrypto/source/random/threadrandom.cpp
author Santosh Patil <santosh.v.patil@nokia.com>
Wed, 08 Jul 2009 11:25:26 +0100
changeset 0 2c201484c85f
permissions -rw-r--r--
Move the Security package to EPL, and add the implementations of the cryptographic algorithms

/*
* Copyright (c) 2003-2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of the License "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description: 
*
*/


#include <random.h>

_LIT(KThreadRandom, "threadrandom.cpp");

EXPORT_C void SetThreadRandomL(CRandom* aRNG)
	{
	User::LeaveIfError(Dll::SetTls(aRNG));	
	}

EXPORT_C void SetThreadRandomLC(CRandom* aRNG)
	{
	CleanupStack::PushL(aRNG);
	SetThreadRandomL(aRNG);
	//This pop before the push isn't a problem as the PushL can't fail. 
	//We just did a push before this and thus there is enough room on the
	//cleanupstack such that OOM is not possible.
	CleanupStack::Pop(aRNG);
	CleanupStack::PushL(TCleanupItem(&DeleteThreadRandom, Dll::Tls()));
	}

void DeleteThreadRandom(TAny* aPtr)
	{
	CRandom* random = reinterpret_cast<CRandom*>(aPtr);
	delete random;
	TInt result = Dll::SetTls(0);
	__ASSERT_ALWAYS(result == 0, User::Panic(KThreadRandom, 1));
	}

EXPORT_C void DestroyThreadRandom(void)
	{
	delete (CRandom*)(Dll::Tls());
	TInt result = Dll::SetTls(0);
	__ASSERT_ALWAYS(result == 0, User::Panic(KThreadRandom, 1));
	}

EXPORT_C void GenerateRandomBytesL(TDes8& aDest)
	{
	TAny* tls = Dll::Tls();
	if(tls)
		{
		((CRandom*)tls)->GenerateBytesL(aDest);
		}
	else
		{
		TRandom::RandomL(aDest);
		}
	}