--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/crypto/weakcrypto/test/tasymmetric/trsasignfb.cpp Wed Jul 08 11:25:26 2009 +0100
@@ -0,0 +1,313 @@
+/*
+* Copyright (c) 1998-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 "trsasignfb.h"
+#include "t_input.h"
+#include <asymmetric.h>
+#include <padding.h>
+#include <bigint.h>
+#include "performancetest.h"
+
+_LIT8(KInputStart, "<input>");
+_LIT8(KKeyBitsStart, "<keybits>");
+_LIT8(KKeyBitsEnd, "</keybits>");
+
+CRSASignFB::~CRSASignFB()
+ {
+ delete iBody;
+ }
+
+CRSASignFB::CRSASignFB(RFs& aFs, CConsoleBase& aConsole, Output& aOut)
+ : CTestAction(aConsole, aOut), iFs(aFs), iPerfTestIterations(100)
+ {
+ }
+
+CTestAction* CRSASignFB::NewL(RFs& aFs, CConsoleBase& aConsole, Output& aOut,
+ const TTestActionSpec& aTestActionSpec)
+ {
+ CTestAction* self = CRSASignFB::NewLC(aFs, aConsole,
+ aOut, aTestActionSpec);
+ CleanupStack::Pop();
+ return self;
+ }
+
+CTestAction* CRSASignFB::NewLC(RFs& aFs, CConsoleBase& aConsole, Output& aOut,
+ const TTestActionSpec& aTestActionSpec)
+ {
+ CRSASignFB* self = new(ELeave) CRSASignFB(aFs, aConsole, aOut);
+ CleanupStack::PushL(self);
+ self->ConstructL(aTestActionSpec);
+ return self;
+ }
+
+
+TRSAPrivateKeyType CRSASignFB::TypeOfCrypto()
+ {
+ return iCryptoType;
+ }
+
+void CRSASignFB::ConstructL(const TTestActionSpec& aTestActionSpec)
+{
+ CTestAction::ConstructL(aTestActionSpec);
+ iBody = HBufC8::NewL(aTestActionSpec.iActionBody.Length());
+ iBody->Des().Copy(aTestActionSpec.iActionBody);
+
+ if (CPerformance::PerformanceTester()->IsTestingPerformance())
+ {// Number of test iterations
+ TPtrC8 itsPtr = Input::ParseElement(aTestActionSpec.iActionBody, KIterationsStart, KIterationsEnd);
+ if (itsPtr!=KNullDesC8)
+ {
+ TLex8 lex;
+ lex.Assign(itsPtr);
+ User::LeaveIfError(lex.Val(iPerfTestIterations));
+ if (iPerfTestIterations > KMaxIterations)
+ User::Panic(_L("AsymmetricPerformance.exe"), KErrArgument);
+
+ }
+ TPtrC8 cryptoPtr = Input::ParseElement(aTestActionSpec.iActionBody, KTypeOfCryptoStart, KTypeOfCryptoEnd);
+ if (cryptoPtr.CompareF(KRSAStandard) == 0)
+ {
+ iCryptoType = EStandard;
+ }
+ else if (cryptoPtr.CompareF(KRSAStandardCRT) == 0)
+ {
+ iCryptoType = EStandardCRT;
+ }
+ else
+ {
+ User::Panic(_L("AsymmetricPerformance.exe"), KErrArgument);
+ }
+ }
+
+ TPtrC8 keyBitsPtr = Input::ParseElement(*iBody, KKeyBitsStart, KKeyBitsEnd);
+ if (keyBitsPtr!=KNullDesC8)
+ {
+ TLex8 lex;
+ lex.Assign(keyBitsPtr);
+ User::LeaveIfError(lex.Val(iKeyBits));
+ }
+}
+
+void CRSASignFB::DoPerformPrerequisite(TRequestStatus& aStatus)
+ {
+ TRequestStatus* status = &aStatus;
+
+ HBufC8* input = Input::ParseElementHexL(*iBody, KInputStart);
+ CleanupStack::PushL(input);
+ iSigInput = CHashingSignatureInput::NewL(CMessageDigest::ESHA1);
+ iSigInput->Update(*input);
+ iInput = iSigInput->Final().AllocL();
+ CleanupStack::PopAndDestroy(input);
+
+ User::RequestComplete(status, KErrNone);
+ iActionState = CTestAction::EAction;
+ }
+
+void CRSASignFB::DoPerformPostrequisite(TRequestStatus& aStatus)
+ {
+ TRequestStatus* status = &aStatus;
+ delete iInput;
+ delete iSigInput;
+
+ iFinished = ETrue;
+ User::RequestComplete(status, iActionResult);
+ }
+
+void CRSASignFB::DoReportAction(void)
+ {
+ }
+
+void CRSASignFB::DoCheckResult(TInt)
+ {
+ if (iResult)
+ iConsole.Printf(_L("."));
+ else
+ iConsole.Printf(_L("X"));
+ }
+
+void CRSASignFB::Hex(HBufC8& aString)
+ {
+ TPtr8 ptr=aString.Des();
+ if (aString.Length()%2)
+ {
+ ptr.SetLength(0);
+ return;
+ }
+ TInt i;
+ for (i=0;i<aString.Length();i+=2)
+ {
+ TUint8 tmp;
+ tmp=(TUint8)(aString[i]-(aString[i]>'9'?('A'-10):'0'));
+ tmp*=16;
+ tmp|=(TUint8)(aString[i+1]-(aString[i+1]>'9'?('A'-10):'0'));
+ ptr[i/2]=tmp;
+ }
+ ptr.SetLength(aString.Length()/2);
+ }
+
+void CRSASignFB::PerformAction(TRequestStatus& aStatus)
+ {
+ TRequestStatus* status = &aStatus;
+
+ if (CPerformance::PerformanceTester()->IsTestingPerformance())
+ {
+ iConsole.Printf(_L(">")); // Indicates start of test
+ TRAP(iActionResult, DoPerformanceTestActionL());
+ }
+ else
+ {
+ TRAP(iActionResult, DoPerformActionL());
+ }
+
+ if (iActionResult==KErrNoMemory)
+ User::Leave(iActionResult); // For OOM testing
+
+ User::RequestComplete(status, iActionResult);
+ iActionState = CTestAction::EPostrequisite;
+ }
+
+
+void CRSASignFB::DoPerformanceTestActionL()
+{
+ __UHEAP_MARK;
+ iResult = EFalse;
+
+ TTimeIntervalMicroSeconds keyCreateTime(0);
+ TTimeIntervalMicroSeconds signTime(0);
+ TTimeIntervalMicroSeconds verifyTime(0);
+ TTime start, end;
+ TTimeIntervalSeconds diff(0);
+ const TTimeIntervalSeconds KIterationTime(iPerfTestIterations);
+
+ // Time key pair creation
+ CRSAKeyPair *rsaPair = NULL;
+ TUint noRSAPairs = 0;
+ start.UniversalTime();
+ while (diff < KIterationTime)
+ {
+ rsaPair = CRSAKeyPair::NewLC(iKeyBits, TypeOfCrypto());
+ CleanupStack::PopAndDestroy();
+ noRSAPairs++;
+ end.UniversalTime();
+ end.SecondsFrom(start, diff);
+ }
+ end.UniversalTime();
+ keyCreateTime = end.MicroSecondsFrom(start);
+ TReal keycreatetime = I64REAL(keyCreateTime.Int64());
+
+ rsaPair=CRSAKeyPair::NewLC(iKeyBits, TypeOfCrypto()); // Create one keypair for operations
+
+ CRSAPKCS1v15Signer* signer = CRSAPKCS1v15Signer::NewL(rsaPair->PrivateKey());
+ CleanupStack::PushL(signer);
+ CRSAPKCS1v15Verifier* verifier = CRSAPKCS1v15Verifier::NewL(rsaPair->PublicKey());
+ CleanupStack::PushL(verifier);
+
+ const CRSASignature *testSig;
+
+ // Time signing
+ diff = 0;
+ TInt noSignings = 0;
+ start.UniversalTime();
+ while (diff < KIterationTime)
+ {
+ testSig = signer->SignL(*iInput);
+ delete testSig;
+ noSignings++;
+ end.UniversalTime();
+ end.SecondsFrom(start, diff);
+ }
+ end.UniversalTime();
+ signTime = end.MicroSecondsFrom(start);
+ TReal signtime = I64REAL(signTime.Int64());
+ // Time verification
+ TInt noVerifies = 0;
+ diff = 0;
+ testSig = signer->SignL(*iInput);
+ CleanupStack::PushL(const_cast<CRSASignature*>(testSig));
+ start.UniversalTime();
+ while (diff < KIterationTime)
+ {
+ iResult = verifier->VerifyL(*iInput, *testSig);
+
+ // do as many verfies as possible
+ if (!iResult)
+ {
+ break;
+ }
+ noVerifies++;
+ end.UniversalTime();
+ end.SecondsFrom(start, diff);
+ }
+ end.UniversalTime();
+ verifyTime = end.MicroSecondsFrom(start);
+ TReal verifytime = I64REAL(verifyTime.Int64());
+ CleanupStack::PopAndDestroy(4); // verifier,signer,testSig,rsaPairs
+ __UHEAP_MARKEND;
+
+ if (iResult)
+ {
+ TBuf<256> buf;
+ TReal rate = I64REAL(keyCreateTime.Int64()) / noRSAPairs;
+
+ _LIT(KKeyCreateTime, "\n\tKeyCreate: %f us/key creation (no creations: %i in %f us)\r\n");
+ buf.Format(KKeyCreateTime, rate, noRSAPairs, keycreatetime);
+ iOut.writeString(buf);
+
+ rate = I64REAL(signTime.Int64()) / noSignings;
+ _LIT(KSignTime, "\tSigning: %f us/signing (no signings: %i in %f us)\r\n");
+ buf.Format(KSignTime, rate, noSignings, signtime);
+ iOut.writeString(buf);
+
+ rate = I64REAL(verifyTime.Int64()) / noVerifies;
+ _LIT(KVerifyTime, "\tVerifying: %f us/verify (no verfies: %i in %f us)\r\n");
+ buf.Format(KVerifyTime, rate, noVerifies, verifytime);
+ iOut.writeString(buf);
+ }
+ else
+ {
+ _LIT(KNoTimingInfo, "\tTest Failed! No benchmark data\n");
+ iOut.writeString(KNoTimingInfo);
+ }
+}
+
+void CRSASignFB::DoPerformActionL()
+ {
+ __UHEAP_MARK;
+
+ iResult = EFalse;
+
+ CRSAKeyPair* rsaPair = CRSAKeyPair::NewLC(512, TypeOfCrypto());
+
+ CRSAPKCS1v15Signer* signer = CRSAPKCS1v15Signer::NewL(rsaPair->PrivateKey());
+ CleanupStack::PushL(signer);
+
+ CRSAPKCS1v15Verifier* verifier = CRSAPKCS1v15Verifier::NewL(rsaPair->PublicKey());
+ CleanupStack::PushL(verifier);
+
+ const CRSASignature* signature = signer->SignL(*iInput);
+ CleanupStack::PushL(const_cast<CRSASignature*>(signature));
+
+ if(verifier->VerifyL(*iInput, *signature))
+ {
+ iResult = ETrue;
+ }
+
+ CleanupStack::PopAndDestroy(4, rsaPair); //signature, verifier, signer, rsaPair
+
+ __UHEAP_MARKEND;
+ }