crypto/weakcrypto/source/symmetric/rijndael.cpp
author hgs
Thu, 12 Aug 2010 21:07:10 +0530
changeset 90 8c545fea2798
parent 72 de46a57f75fb
permissions -rw-r--r--
201031_01
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
72
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     1
/*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     2
* Copyright (c) 2002-2009 Nokia Corporation and/or its subsidiary(-ies).
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     3
* All rights reserved.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     5
* under the terms of the License "Eclipse Public License v1.0"
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     8
*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     9
* Initial Contributors:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    11
*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    12
* Contributors:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    13
*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    14
* Description: 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    15
*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    16
*/
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    17
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    18
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    19
#include "rijndael.h"
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    20
#include "rijndaeltables.h"
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    21
#include "../common/inlines.h"
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    22
#include <cryptostrength.h>
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    23
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    24
const TUint KAESKeyBytes128 = 16;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    25
const TUint KAESKeyBytes192 = 24;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    26
const TUint KAESKeyBytes256 = 32;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    27
const TUint KAESBlockBytes = 16;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    28
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    29
/* CRijndael */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    30
EXPORT_C CRijndael::CRijndael(void)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    31
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    32
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    33
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    34
void CRijndael::Reset()
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    35
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    36
	SetKey(*iKey);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    37
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    38
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    39
TInt CRijndael::KeySize() const
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    40
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    41
	return (4*(iRounds+1));
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    42
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    43
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    44
CRijndael::~CRijndael()
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    45
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    46
	delete iKey;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    47
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    48
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    49
void CRijndael::ConstructL(const TDesC8& aKey)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    50
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    51
	TUint keySize = aKey.Size();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    52
	assert((keySize==KAESKeyBytes128)||(keySize==KAESKeyBytes192)||(keySize==KAESKeyBytes256));
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    53
	iKey = aKey.AllocL();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    54
	iRounds = keySize/4 + 6;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    55
	SetKey(aKey);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    56
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    57
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    58
void CRijndael::SetKey(const TDesC8& aKey)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    59
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    60
	TUint keySize = aKey.Size();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    61
	TUint32 temp; 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    62
	TUint32* rk = &iK[0];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    63
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    64
	TUint i = 0;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    65
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    66
	GetUserKeyBigEndian(rk, keySize/4, &aKey[0], keySize);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    67
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    68
	switch(keySize)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    69
		{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    70
		case (KAESKeyBytes128):
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    71
			{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    72
			FOREVER
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    73
				{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    74
				temp  = rk[3];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    75
				rk[4] = rk[0] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    76
					(RIJNDAEL_TABLE::Te4[GETBYTE(temp, 2)] & 0xff000000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    77
					(RIJNDAEL_TABLE::Te4[GETBYTE(temp, 1)] & 0x00ff0000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    78
					(RIJNDAEL_TABLE::Te4[GETBYTE(temp, 0)] & 0x0000ff00) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    79
					(RIJNDAEL_TABLE::Te4[GETBYTE(temp, 3)] & 0x000000ff) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    80
					RIJNDAEL_TABLE::rcon[i];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    81
				rk[5] = rk[1] ^ rk[4];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    82
				rk[6] = rk[2] ^ rk[5];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    83
				rk[7] = rk[3] ^ rk[6];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    84
				if (++i == 10)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    85
					break;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    86
				rk += 4;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    87
				}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    88
			}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    89
		break;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    90
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    91
		case (KAESKeyBytes192):
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    92
			{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    93
			FOREVER
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    94
				{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    95
				temp = rk[ 5];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    96
				rk[ 6] = rk[ 0] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    97
					(RIJNDAEL_TABLE::Te4[GETBYTE(temp, 2)] & 0xff000000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    98
					(RIJNDAEL_TABLE::Te4[GETBYTE(temp, 1)] & 0x00ff0000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    99
					(RIJNDAEL_TABLE::Te4[GETBYTE(temp, 0)] & 0x0000ff00) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   100
					(RIJNDAEL_TABLE::Te4[GETBYTE(temp, 3)] & 0x000000ff) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   101
					RIJNDAEL_TABLE::rcon[i];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   102
				rk[ 7] = rk[ 1] ^ rk[ 6];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   103
				rk[ 8] = rk[ 2] ^ rk[ 7];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   104
				rk[ 9] = rk[ 3] ^ rk[ 8];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   105
				if (++i == 8)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   106
					break;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   107
				rk[10] = rk[ 4] ^ rk[ 9];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   108
				rk[11] = rk[ 5] ^ rk[10];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   109
				rk += 6;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   110
				}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   111
			}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   112
		break;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   113
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   114
		case (KAESKeyBytes256):
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   115
			{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   116
			FOREVER
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   117
				{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   118
        		temp = rk[ 7];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   119
        		rk[ 8] = rk[ 0] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   120
        			(RIJNDAEL_TABLE::Te4[GETBYTE(temp, 2)] & 0xff000000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   121
        			(RIJNDAEL_TABLE::Te4[GETBYTE(temp, 1)] & 0x00ff0000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   122
        			(RIJNDAEL_TABLE::Te4[GETBYTE(temp, 0)] & 0x0000ff00) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   123
        			(RIJNDAEL_TABLE::Te4[GETBYTE(temp, 3)] & 0x000000ff) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   124
        			RIJNDAEL_TABLE::rcon[i];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   125
        		rk[ 9] = rk[ 1] ^ rk[ 8];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   126
        		rk[10] = rk[ 2] ^ rk[ 9];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   127
        		rk[11] = rk[ 3] ^ rk[10];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   128
				if (++i == 7)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   129
					break;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   130
        		temp = rk[11];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   131
        		rk[12] = rk[ 4] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   132
        			(RIJNDAEL_TABLE::Te4[GETBYTE(temp, 3)] & 0xff000000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   133
        			(RIJNDAEL_TABLE::Te4[GETBYTE(temp, 2)] & 0x00ff0000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   134
        			(RIJNDAEL_TABLE::Te4[GETBYTE(temp, 1)] & 0x0000ff00) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   135
        			(RIJNDAEL_TABLE::Te4[GETBYTE(temp, 0)] & 0x000000ff);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   136
        		rk[13] = rk[ 5] ^ rk[12];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   137
        		rk[14] = rk[ 6] ^ rk[13];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   138
        		rk[15] = rk[ 7] ^ rk[14];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   139
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   140
				rk += 8;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   141
				}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   142
			}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   143
		break;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   144
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   145
		default:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   146
			assert(0);	//	Shouldn't get here, keeps compiler happy
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   147
		}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   148
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   149
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   150
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   151
/* CAESEncryptor */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   152
EXPORT_C CAESEncryptor* CAESEncryptor::NewL(const TDesC8& aKey)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   153
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   154
	CAESEncryptor* me = CAESEncryptor::NewLC(aKey);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   155
	CleanupStack::Pop(me);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   156
	return (me);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   157
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   158
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   159
EXPORT_C CAESEncryptor* CAESEncryptor::NewLC(const TDesC8& aKey)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   160
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   161
	CAESEncryptor* me = new (ELeave) CAESEncryptor();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   162
	CleanupStack::PushL(me);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   163
	me->ConstructL(aKey);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   164
	TCrypto::IsSymmetricWeakEnoughL(BytesToBits(aKey.Size()));
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   165
	return (me);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   166
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   167
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   168
TInt CAESEncryptor::BlockSize() const
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   169
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   170
	return KAESBlockBytes;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   171
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   172
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   173
void CAESEncryptor::Transform(TDes8& aBlock)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   174
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   175
	assert((TUint)aBlock.Size()==KAESBlockBytes);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   176
	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   177
	TUint32 s0, s1, s2, s3, t0, t1, t2, t3;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   178
	const TUint32* rk = &iK[0];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   179
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   180
/*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   181
 *	map byte array block to cipher state
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   182
 *	and add initial round key:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   183
*/
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   184
	GetBlockBigEndian((TUint8*)&aBlock[0], s0, s1, s2, s3);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   185
	s0 ^= rk[0];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   186
	s1 ^= rk[1];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   187
	s2 ^= rk[2];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   188
	s3 ^= rk[3];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   189
/*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   190
 *	Nr - 1 full rounds:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   191
*/
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   192
    TUint r = iRounds >> 1;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   193
	FOREVER
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   194
		{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   195
        t0 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   196
            RIJNDAEL_TABLE::Te0[GETBYTE(s0, 3)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   197
            RIJNDAEL_TABLE::Te1[GETBYTE(s1, 2)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   198
            RIJNDAEL_TABLE::Te2[GETBYTE(s2, 1)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   199
            RIJNDAEL_TABLE::Te3[GETBYTE(s3, 0)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   200
            rk[4];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   201
        t1 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   202
            RIJNDAEL_TABLE::Te0[GETBYTE(s1, 3)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   203
            RIJNDAEL_TABLE::Te1[GETBYTE(s2, 2)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   204
            RIJNDAEL_TABLE::Te2[GETBYTE(s3, 1)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   205
            RIJNDAEL_TABLE::Te3[GETBYTE(s0, 0)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   206
            rk[5];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   207
        t2 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   208
            RIJNDAEL_TABLE::Te0[GETBYTE(s2, 3)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   209
            RIJNDAEL_TABLE::Te1[GETBYTE(s3, 2)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   210
            RIJNDAEL_TABLE::Te2[GETBYTE(s0, 1)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   211
            RIJNDAEL_TABLE::Te3[GETBYTE(s1, 0)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   212
            rk[6];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   213
        t3 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   214
            RIJNDAEL_TABLE::Te0[GETBYTE(s3, 3)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   215
            RIJNDAEL_TABLE::Te1[GETBYTE(s0, 2)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   216
            RIJNDAEL_TABLE::Te2[GETBYTE(s1, 1)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   217
            RIJNDAEL_TABLE::Te3[GETBYTE(s2, 0)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   218
            rk[7];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   219
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   220
        rk += 8;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   221
        if (--r == 0) 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   222
			break;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   223
        
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   224
        s0 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   225
            RIJNDAEL_TABLE::Te0[GETBYTE(t0, 3)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   226
            RIJNDAEL_TABLE::Te1[GETBYTE(t1, 2)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   227
            RIJNDAEL_TABLE::Te2[GETBYTE(t2, 1)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   228
            RIJNDAEL_TABLE::Te3[GETBYTE(t3, 0)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   229
            rk[0];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   230
        s1 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   231
            RIJNDAEL_TABLE::Te0[GETBYTE(t1, 3)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   232
            RIJNDAEL_TABLE::Te1[GETBYTE(t2, 2)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   233
            RIJNDAEL_TABLE::Te2[GETBYTE(t3, 1)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   234
            RIJNDAEL_TABLE::Te3[GETBYTE(t0, 0)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   235
            rk[1];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   236
        s2 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   237
            RIJNDAEL_TABLE::Te0[GETBYTE(t2, 3)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   238
            RIJNDAEL_TABLE::Te1[GETBYTE(t3, 2)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   239
            RIJNDAEL_TABLE::Te2[GETBYTE(t0, 1)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   240
            RIJNDAEL_TABLE::Te3[GETBYTE(t1, 0)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   241
            rk[2];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   242
        s3 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   243
            RIJNDAEL_TABLE::Te0[GETBYTE(t3, 3)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   244
            RIJNDAEL_TABLE::Te1[GETBYTE(t0, 2)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   245
            RIJNDAEL_TABLE::Te2[GETBYTE(t1, 1)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   246
            RIJNDAEL_TABLE::Te3[GETBYTE(t2, 0)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   247
            rk[3];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   248
		}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   249
/*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   250
 *	apply last round and
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   251
 *	map cipher state to byte array block:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   252
*/
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   253
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   254
	s0 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   255
		(RIJNDAEL_TABLE::Te4[GETBYTE(t0, 3)] & 0xff000000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   256
		(RIJNDAEL_TABLE::Te4[GETBYTE(t1, 2)] & 0x00ff0000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   257
		(RIJNDAEL_TABLE::Te4[GETBYTE(t2, 1)] & 0x0000ff00) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   258
		(RIJNDAEL_TABLE::Te4[GETBYTE(t3, 0)] & 0x000000ff) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   259
		rk[0];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   260
	s1 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   261
		(RIJNDAEL_TABLE::Te4[GETBYTE(t1, 3)] & 0xff000000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   262
		(RIJNDAEL_TABLE::Te4[GETBYTE(t2, 2)] & 0x00ff0000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   263
		(RIJNDAEL_TABLE::Te4[GETBYTE(t3, 1)] & 0x0000ff00) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   264
		(RIJNDAEL_TABLE::Te4[GETBYTE(t0, 0)] & 0x000000ff) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   265
		rk[1];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   266
	s2 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   267
		(RIJNDAEL_TABLE::Te4[GETBYTE(t2, 3)] & 0xff000000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   268
		(RIJNDAEL_TABLE::Te4[GETBYTE(t3, 2)] & 0x00ff0000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   269
		(RIJNDAEL_TABLE::Te4[GETBYTE(t0, 1)] & 0x0000ff00) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   270
		(RIJNDAEL_TABLE::Te4[GETBYTE(t1, 0)] & 0x000000ff) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   271
		rk[2];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   272
	s3 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   273
		(RIJNDAEL_TABLE::Te4[GETBYTE(t3, 3)] & 0xff000000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   274
		(RIJNDAEL_TABLE::Te4[GETBYTE(t0, 2)] & 0x00ff0000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   275
		(RIJNDAEL_TABLE::Te4[GETBYTE(t1, 1)] & 0x0000ff00) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   276
		(RIJNDAEL_TABLE::Te4[GETBYTE(t2, 0)] & 0x000000ff) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   277
		rk[3];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   278
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   279
	PutBlockBigEndian((TUint8*)&aBlock[0], s0, s1, s2, s3);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   280
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   281
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   282
CAESEncryptor::CAESEncryptor(void)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   283
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   284
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   285
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   286
/* CAESDecryptor */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   287
EXPORT_C CAESDecryptor* CAESDecryptor::NewL(const TDesC8& aKey)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   288
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   289
	CAESDecryptor* me = CAESDecryptor::NewLC(aKey);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   290
	CleanupStack::Pop(me);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   291
	return (me);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   292
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   293
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   294
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   295
EXPORT_C CAESDecryptor* CAESDecryptor::NewLC(const TDesC8& aKey)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   296
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   297
	CAESDecryptor* me = new (ELeave) CAESDecryptor();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   298
	CleanupStack::PushL(me);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   299
	me->ConstructL(aKey);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   300
	TCrypto::IsSymmetricWeakEnoughL(BytesToBits(aKey.Size()));
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   301
	return (me);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   302
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   303
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   304
TInt CAESDecryptor::BlockSize() const
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   305
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   306
	return KAESBlockBytes;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   307
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   308
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   309
void CAESDecryptor::Transform(TDes8& aBlock)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   310
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   311
	TUint32 s0, s1, s2, s3, t0, t1, t2, t3;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   312
    const TUint32* rk = &iK[0];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   313
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   314
/*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   315
 *	map byte array block to cipher state
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   316
 *	and add initial round key:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   317
*/
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   318
	GetBlockBigEndian((TUint8*)&aBlock[0], s0, s1, s2, s3);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   319
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   320
	s0 ^= rk[0];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   321
	s1 ^= rk[1];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   322
	s2 ^= rk[2];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   323
	s3 ^= rk[3];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   324
/*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   325
 *	Nr - 1 full rounds:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   326
*/
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   327
    TUint r = iRounds >> 1;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   328
    FOREVER
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   329
		{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   330
        t0 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   331
            RIJNDAEL_TABLE::Td0[GETBYTE(s0, 3)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   332
            RIJNDAEL_TABLE::Td1[GETBYTE(s3, 2)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   333
            RIJNDAEL_TABLE::Td2[GETBYTE(s2, 1)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   334
            RIJNDAEL_TABLE::Td3[GETBYTE(s1, 0)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   335
            rk[4];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   336
        t1 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   337
            RIJNDAEL_TABLE::Td0[GETBYTE(s1, 3)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   338
            RIJNDAEL_TABLE::Td1[GETBYTE(s0, 2)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   339
            RIJNDAEL_TABLE::Td2[GETBYTE(s3, 1)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   340
            RIJNDAEL_TABLE::Td3[GETBYTE(s2, 0)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   341
            rk[5];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   342
        t2 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   343
            RIJNDAEL_TABLE::Td0[GETBYTE(s2, 3)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   344
            RIJNDAEL_TABLE::Td1[GETBYTE(s1, 2)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   345
            RIJNDAEL_TABLE::Td2[GETBYTE(s0, 1)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   346
            RIJNDAEL_TABLE::Td3[GETBYTE(s3, 0)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   347
            rk[6];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   348
        t3 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   349
            RIJNDAEL_TABLE::Td0[GETBYTE(s3, 3)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   350
            RIJNDAEL_TABLE::Td1[GETBYTE(s2, 2)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   351
            RIJNDAEL_TABLE::Td2[GETBYTE(s1, 1)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   352
            RIJNDAEL_TABLE::Td3[GETBYTE(s0, 0)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   353
            rk[7];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   354
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   355
        rk += 8;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   356
        if (--r == 0)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   357
            break;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   358
        
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   359
        s0 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   360
            RIJNDAEL_TABLE::Td0[GETBYTE(t0, 3)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   361
            RIJNDAEL_TABLE::Td1[GETBYTE(t3, 2)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   362
            RIJNDAEL_TABLE::Td2[GETBYTE(t2, 1)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   363
            RIJNDAEL_TABLE::Td3[GETBYTE(t1, 0)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   364
            rk[0];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   365
        s1 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   366
            RIJNDAEL_TABLE::Td0[GETBYTE(t1, 3)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   367
            RIJNDAEL_TABLE::Td1[GETBYTE(t0, 2)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   368
            RIJNDAEL_TABLE::Td2[GETBYTE(t3, 1)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   369
            RIJNDAEL_TABLE::Td3[GETBYTE(t2, 0)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   370
            rk[1];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   371
        s2 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   372
            RIJNDAEL_TABLE::Td0[GETBYTE(t2, 3)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   373
            RIJNDAEL_TABLE::Td1[GETBYTE(t1, 2)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   374
            RIJNDAEL_TABLE::Td2[GETBYTE(t0, 1)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   375
            RIJNDAEL_TABLE::Td3[GETBYTE(t3, 0)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   376
            rk[2];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   377
        s3 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   378
            RIJNDAEL_TABLE::Td0[GETBYTE(t3, 3)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   379
            RIJNDAEL_TABLE::Td1[GETBYTE(t2, 2)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   380
            RIJNDAEL_TABLE::Td2[GETBYTE(t1, 1)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   381
            RIJNDAEL_TABLE::Td3[GETBYTE(t0, 0)] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   382
            rk[3];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   383
		}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   384
/*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   385
 *	apply last round and
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   386
 *	map cipher state to byte array block:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   387
*/
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   388
   	s0 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   389
   		(RIJNDAEL_TABLE::Td4[GETBYTE(t0, 3)] & 0xff000000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   390
   		(RIJNDAEL_TABLE::Td4[GETBYTE(t3, 2)] & 0x00ff0000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   391
   		(RIJNDAEL_TABLE::Td4[GETBYTE(t2, 1)] & 0x0000ff00) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   392
   		(RIJNDAEL_TABLE::Td4[GETBYTE(t1, 0)] & 0x000000ff) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   393
   		rk[0];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   394
   	s1 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   395
   		(RIJNDAEL_TABLE::Td4[GETBYTE(t1, 3)] & 0xff000000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   396
   		(RIJNDAEL_TABLE::Td4[GETBYTE(t0, 2)] & 0x00ff0000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   397
   		(RIJNDAEL_TABLE::Td4[GETBYTE(t3, 1)] & 0x0000ff00) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   398
   		(RIJNDAEL_TABLE::Td4[GETBYTE(t2, 0)] & 0x000000ff) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   399
   		rk[1];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   400
   	s2 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   401
   		(RIJNDAEL_TABLE::Td4[GETBYTE(t2, 3)] & 0xff000000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   402
   		(RIJNDAEL_TABLE::Td4[GETBYTE(t1, 2)] & 0x00ff0000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   403
   		(RIJNDAEL_TABLE::Td4[GETBYTE(t0, 1)] & 0x0000ff00) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   404
   		(RIJNDAEL_TABLE::Td4[GETBYTE(t3, 0)] & 0x000000ff) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   405
   		rk[2];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   406
   	s3 =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   407
   		(RIJNDAEL_TABLE::Td4[GETBYTE(t3, 3)] & 0xff000000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   408
   		(RIJNDAEL_TABLE::Td4[GETBYTE(t2, 2)] & 0x00ff0000) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   409
   		(RIJNDAEL_TABLE::Td4[GETBYTE(t1, 1)] & 0x0000ff00) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   410
   		(RIJNDAEL_TABLE::Td4[GETBYTE(t0, 0)] & 0x000000ff) ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   411
   		rk[3];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   412
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   413
	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   414
	PutBlockBigEndian((TUint8*)&aBlock[0], s0, s1, s2, s3);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   415
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   416
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   417
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   418
void CAESDecryptor::SetKey(const TDesC8& aKey)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   419
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   420
	CRijndael::SetKey(aKey);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   421
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   422
	TUint i, j;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   423
	TUint32* rk = &iK[0];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   424
	TUint32 temp;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   425
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   426
//	invert the order of the round keys 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   427
	for (i = 0, j = 4*iRounds; i < j; i += 4, j -= 4)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   428
		{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   429
		temp = rk[i    ]; rk[i    ] = rk[j    ]; rk[j    ] = temp;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   430
		temp = rk[i + 1]; rk[i + 1] = rk[j + 1]; rk[j + 1] = temp;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   431
		temp = rk[i + 2]; rk[i + 2] = rk[j + 2]; rk[j + 2] = temp;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   432
		temp = rk[i + 3]; rk[i + 3] = rk[j + 3]; rk[j + 3] = temp;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   433
		}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   434
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   435
//	apply the inverse MixColumn transform to all round keys but the first and the last
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   436
	for (i = 1; i < iRounds; i++)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   437
		{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   438
		rk += 4;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   439
		rk[0] =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   440
			RIJNDAEL_TABLE::Td0[RIJNDAEL_TABLE::Te4[GETBYTE(rk[0], 3)] & 0xff] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   441
			RIJNDAEL_TABLE::Td1[RIJNDAEL_TABLE::Te4[GETBYTE(rk[0], 2)] & 0xff] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   442
			RIJNDAEL_TABLE::Td2[RIJNDAEL_TABLE::Te4[GETBYTE(rk[0], 1)] & 0xff] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   443
			RIJNDAEL_TABLE::Td3[RIJNDAEL_TABLE::Te4[GETBYTE(rk[0], 0)] & 0xff];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   444
		rk[1] =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   445
			RIJNDAEL_TABLE::Td0[RIJNDAEL_TABLE::Te4[GETBYTE(rk[1], 3)] & 0xff] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   446
			RIJNDAEL_TABLE::Td1[RIJNDAEL_TABLE::Te4[GETBYTE(rk[1], 2)] & 0xff] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   447
			RIJNDAEL_TABLE::Td2[RIJNDAEL_TABLE::Te4[GETBYTE(rk[1], 1)] & 0xff] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   448
			RIJNDAEL_TABLE::Td3[RIJNDAEL_TABLE::Te4[GETBYTE(rk[1], 0)] & 0xff];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   449
		rk[2] =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   450
			RIJNDAEL_TABLE::Td0[RIJNDAEL_TABLE::Te4[GETBYTE(rk[2], 3)] & 0xff] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   451
			RIJNDAEL_TABLE::Td1[RIJNDAEL_TABLE::Te4[GETBYTE(rk[2], 2)] & 0xff] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   452
			RIJNDAEL_TABLE::Td2[RIJNDAEL_TABLE::Te4[GETBYTE(rk[2], 1)] & 0xff] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   453
			RIJNDAEL_TABLE::Td3[RIJNDAEL_TABLE::Te4[GETBYTE(rk[2], 0)] & 0xff];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   454
		rk[3] =
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   455
			RIJNDAEL_TABLE::Td0[RIJNDAEL_TABLE::Te4[GETBYTE(rk[3], 3)] & 0xff] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   456
			RIJNDAEL_TABLE::Td1[RIJNDAEL_TABLE::Te4[GETBYTE(rk[3], 2)] & 0xff] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   457
			RIJNDAEL_TABLE::Td2[RIJNDAEL_TABLE::Te4[GETBYTE(rk[3], 1)] & 0xff] ^
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   458
			RIJNDAEL_TABLE::Td3[RIJNDAEL_TABLE::Te4[GETBYTE(rk[3], 0)] & 0xff];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   459
		}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   460
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   461
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   462
CAESDecryptor::CAESDecryptor()
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   463
	{	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   464
	}