os/persistentdata/persistentstorage/store/pcstore/src/checkeduid.cpp
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
     1 // Copyright (c) 2006-2009 Nokia Corporation and/or its subsidiary(-ies).
     2 // All rights reserved.
     3 // This component and the accompanying materials are made available
     4 // under the terms of "Eclipse Public License v1.0"
     5 // which accompanies this distribution, and is available
     6 // at the URL "http://www.eclipse.org/legal/epl-v10.html".
     7 //
     8 // Initial Contributors:
     9 // Nokia Corporation - initial contribution.
    10 //
    11 // Contributors:
    12 //
    13 // Description:
    14 //
    15 
    16 
    17 #include <assert.h>
    18 #include <memory.h>
    19 #include <pcstore/checkeduid.h>
    20 #include <pcstore/descriptors.h>
    21 #include <pcstore/storeexception.h>
    22 #include "pcstoreconst.h"
    23 
    24 namespace PCStore
    25 {
    26 const TUint crcTab[256] =
    27 	{
    28 	0x0000,0x1021,0x2042,0x3063,0x4084,0x50a5,0x60c6,0x70e7,0x8108,0x9129,0xa14a,
    29 	0xb16b,0xc18c,0xd1ad,0xe1ce,0xf1ef,0x1231,0x0210,0x3273,0x2252,0x52b5,0x4294,
    30 	0x72f7,0x62d6,0x9339,0x8318,0xb37b,0xa35a,0xd3bd,0xc39c,0xf3ff,0xe3de,0x2462,
    31 	0x3443,0x0420,0x1401,0x64e6,0x74c7,0x44a4,0x5485,0xa56a,0xb54b,0x8528,0x9509,
    32 	0xe5ee,0xf5cf,0xc5ac,0xd58d,0x3653,0x2672,0x1611,0x0630,0x76d7,0x66f6,0x5695,
    33 	0x46b4,0xb75b,0xa77a,0x9719,0x8738,0xf7df,0xe7fe,0xd79d,0xc7bc,0x48c4,0x58e5,
    34 	0x6886,0x78a7,0x0840,0x1861,0x2802,0x3823,0xc9cc,0xd9ed,0xe98e,0xf9af,0x8948,
    35 	0x9969,0xa90a,0xb92b,0x5af5,0x4ad4,0x7ab7,0x6a96,0x1a71,0x0a50,0x3a33,0x2a12,
    36 	0xdbfd,0xcbdc,0xfbbf,0xeb9e,0x9b79,0x8b58,0xbb3b,0xab1a,0x6ca6,0x7c87,0x4ce4,
    37 	0x5cc5,0x2c22,0x3c03,0x0c60,0x1c41,0xedae,0xfd8f,0xcdec,0xddcd,0xad2a,0xbd0b,
    38 	0x8d68,0x9d49,0x7e97,0x6eb6,0x5ed5,0x4ef4,0x3e13,0x2e32,0x1e51,0x0e70,0xff9f,
    39 	0xefbe,0xdfdd,0xcffc,0xbf1b,0xaf3a,0x9f59,0x8f78,0x9188,0x81a9,0xb1ca,0xa1eb,
    40 	0xd10c,0xc12d,0xf14e,0xe16f,0x1080,0x00a1,0x30c2,0x20e3,0x5004,0x4025,0x7046,
    41 	0x6067,0x83b9,0x9398,0xa3fb,0xb3da,0xc33d,0xd31c,0xe37f,0xf35e,0x02b1,0x1290,
    42 	0x22f3,0x32d2,0x4235,0x5214,0x6277,0x7256,0xb5ea,0xa5cb,0x95a8,0x8589,0xf56e,
    43 	0xe54f,0xd52c,0xc50d,0x34e2,0x24c3,0x14a0,0x0481,0x7466,0x6447,0x5424,0x4405,
    44 	0xa7db,0xb7fa,0x8799,0x97b8,0xe75f,0xf77e,0xc71d,0xd73c,0x26d3,0x36f2,0x0691,
    45 	0x16b0,0x6657,0x7676,0x4615,0x5634,0xd94c,0xc96d,0xf90e,0xe92f,0x99c8,0x89e9,
    46 	0xb98a,0xa9ab,0x5844,0x4865,0x7806,0x6827,0x18c0,0x08e1,0x3882,0x28a3,0xcb7d,
    47 	0xdb5c,0xeb3f,0xfb1e,0x8bf9,0x9bd8,0xabbb,0xbb9a,0x4a75,0x5a54,0x6a37,0x7a16,
    48 	0x0af1,0x1ad0,0x2ab3,0x3a92,0xfd2e,0xed0f,0xdd6c,0xcd4d,0xbdaa,0xad8b,0x9de8,
    49 	0x8dc9,0x7c26,0x6c07,0x5c64,0x4c45,0x3ca2,0x2c83,0x1ce0,0x0cc1,0xef1f,0xff3e,
    50 	0xcf5d,0xdf7c,0xaf9b,0xbfba,0x8fd9,0x9ff8,0x6e17,0x7e36,0x4e55,0x5e74,0x2e93,
    51 	0x3eb2,0x0ed1,0x1ef0
    52 	};
    53 
    54 /**
    55 Performs a CCITT CRC checksum on the specified data.
    56 
    57 On return from this function, the referenced 16 bit integer contains the checksum.
    58 
    59 @param aCrc    A reference to a 16 bit integer to contain the checksum.
    60 @param aPtr    A pointer to the start of the data to be checksum.
    61 @param aLength The length of the data to be checksum.
    62 */
    63 void Crc(TUint16& aCrc,const void* aPtr,TInt aLength)
    64 	{
    65 	const TUint8* pB=static_cast<const TUint8*>(aPtr);
    66 	const TUint8* pE=pB+aLength;
    67 	TUint crc=aCrc;
    68 	while (pB<pE)
    69 		{
    70 		crc=(crc<<8)^crcTab[((crc>>8)^*pB++)&0xff];
    71 		}
    72 	aCrc=(TUint16)crc;
    73 	}
    74 
    75 
    76 /**
    77 Generate a checksum for the object of TCheckedUid.
    78 
    79 @param aPtr The pointer to the TCheckedUid.
    80 @return The resulted checksum for the TCheckedUid.
    81 */
    82 TUint checkSum(const void *aPtr)
    83 	{
    84 	const TUint8* pB=static_cast<const TUint8*>(aPtr);
    85 	const TUint8* pE=pB+(KMaxCheckedUid*sizeof(TUid));
    86 	TUint8 buf[(KMaxCheckedUid*sizeof(TUid))>>1];
    87 	TUint8* pT=(&buf[0]);
    88 	while (pB<pE)
    89 		{
    90 		*pT++=(*pB);
    91 		pB+=2;
    92 		}
    93 	TUint16 crc=0;
    94 	Crc(crc,&buf[0],(KMaxCheckedUid*sizeof(TUid))>>1);
    95 	return(crc);
    96 	}
    97 
    98 /**
    99 Constructor that creates a zero-valued UID type.
   100 */
   101 TUidType::TUidType()
   102 	{
   103 	memset(this,0,sizeof(TUidType));
   104 	}
   105 
   106 
   107 /**
   108 Constructor that creates a UID type and sets the UID1 component
   109 to the specified value.
   110 
   111 The UID2 and UID3 components are set to KNullUid.
   112 
   113 @param aUid1 Value for UID1.
   114 */
   115 TUidType::TUidType(TUid aUid1)
   116 	{
   117 	memset(this,0,sizeof(TUidType));
   118 	iUid[0]=aUid1;
   119 	}
   120 
   121 
   122 /**
   123 Constructor that creates a UID type and sets the UID1 and UID2 components
   124 to the specified values. 
   125 
   126 The UID3 component is set to KNullUid.
   127 
   128 @param aUid1 Value for UID1. 
   129 @param aUid2 Value for UID2.
   130 */
   131 TUidType::TUidType(TUid aUid1, TUid aUid2)
   132 	{
   133 	iUid[0]=aUid1;
   134 	iUid[1]=aUid2;
   135 	iUid[2]=KNullUid;
   136 	}
   137 
   138 /**
   139 Constructor that creates a UID type and sets all three UID components
   140 to the specified values.
   141 
   142 @param aUid1 Value for UID1.
   143 @param aUid2 Value for UID2.
   144 @param aUid3 Value for UID3.
   145 */
   146 TUidType::TUidType(TUid aUid1, TUid aUid2, TUid aUid3)
   147 	{
   148 	iUid[0]=aUid1;
   149 	iUid[1]=aUid2;
   150 	iUid[2]=aUid3;
   151 	}
   152 
   153 
   154 /** 
   155 Compares this UID type for inequality with the specified UID type.
   156 
   157 @param aUidType The UID type to be compared.
   158 @return TRUE, if any component UID is not equal to the corresponding component 
   159 UID in the specified UID type; FALSE otherwise.
   160 */
   161 TBool TUidType::operator !=(const TUidType& aUidType) const
   162 	{
   163 	return(!(*this==aUidType));
   164 	}
   165 
   166 /**
   167 Compares this UID type for equality with the specified UID type.
   168 
   169 @param aUidType The reference to the UID type to be compared. 
   170 @return TRUE, if each component UID is equal to the corresponding component 
   171 UID in the specified UID type; FALSE, otherwise.
   172 */
   173 TBool TUidType::operator ==(const TUidType& aUidType) const 
   174 	{
   175 	return(iUid[0]==aUidType.iUid[0] &&
   176 		iUid[1]==aUidType.iUid[1] &&
   177 		iUid[2]==aUidType.iUid[2]);
   178 	}
   179 
   180 
   181 /**
   182 Gets the most derived UID.
   183 
   184 Taking the three UID components as a hierarchy with UID1 being the most general, 
   185 UID2 being more specific than UID1 and UID3 being more specific than UID2, 
   186 then the function returns:
   187 
   188 UID3, if UID3 is not KNullUid.
   189 UID2, if UID2 is not KNullUid.
   190 UID1, otherwise
   191 
   192 @return The most derived UID.
   193 */
   194 TUid TUidType::MostDerived() const
   195 	{
   196 	if (iUid[2]!=KNullUid) 
   197 		{
   198 		return(iUid[2]);
   199 		}
   200 	if (iUid[1]!=KNullUid) 
   201 		{
   202 		return(iUid[1]);
   203 		}
   204 	return(iUid[0]);
   205 	}
   206 
   207 /**
   208 Gets the UID component as identified by the specified index.
   209 
   210 @param aIndex Index value indicating which UID component to return.
   211 	0 specifies UID1,
   212 	1 specifies UID2,
   213 	2 specifies UID3.
   214 
   215 aIndex must be between 0 and 2.
   216 
   217 @return The reference to the required UID component.
   218 */
   219 const TUid& TUidType::operator[](TInt aIndex) const
   220 	{
   221 	assert(aIndex >= 0 && aIndex <= 2);
   222 	return(iUid[aIndex]);
   223 	}
   224 
   225 /**
   226 Tests the object for a valid (non-KNullUid) UID type.
   227 
   228 @return TRUE, if at least one of the component UIDs is not KNullUid; FALSE, 
   229 if all component UIDs are KNullUid.
   230 */
   231 TBool TUidType::IsValid() const 
   232 	{
   233 	 return(MostDerived()!=KNullUid);
   234 	}
   235 
   236 
   237 /**
   238 Default constructor.
   239 
   240 Initialises the object to binary zeroes.
   241 */
   242 TCheckedUid::TCheckedUid()
   243 	{
   244 	memset(this,0, sizeof(TCheckedUid));
   245 	} 
   246 
   247 
   248 /**
   249 Constructor taking an existing Uid type.
   250 
   251 The constructor calculates a checksum.
   252 
   253 @param aUidType The reference to a Uid type to be packaged.
   254 */
   255 TCheckedUid::TCheckedUid(const TUidType& aUidType) 
   256 	{
   257 	Set(aUidType);
   258 	}
   259 
   260 
   261 /**
   262 Constructor taking an existing TCheckedUid object encapsulated within
   263 a descriptor.
   264 
   265 The checksum is recalculated and must match the checksum value passed in the 
   266 encapsulated TCheckedUid object, otherwise the content of this object is reset 
   267 to binary zeroes.
   268 
   269 aDes should be an 8-bit descriptor which holds the contents of a TCheckedUid object.
   270 
   271 @param aDes The reference to an 8-bit descriptor containing an existing TCheckedUid 
   272 object. 
   273 */
   274 TCheckedUid::TCheckedUid(const CDes8& aDes)
   275 	{
   276 	Set(aDes);
   277 	}
   278 
   279 /**
   280 Sets the specified Uid type to be packaged, and recalculates the checksum.
   281 
   282 @param aUidType The reference to a Uid type to be set.
   283 */
   284 void TCheckedUid::Set(const TUidType& aUidType)
   285 	{
   286 	iType = aUidType;
   287 	iCheck = Check();
   288 	}
   289 
   290 /**
   291 Sets an existing TCheckedUid object encapsulated within a descriptor.
   292 
   293 The checksum is recalculated and must match the checksum value passed in the 
   294 encapsulated TCheckedUid object, otherwise the content of this object is reset 
   295 to binary zeroes.
   296 
   297 aDes should be an 8-bit descriptor which holds the contents of a TCheckedUid object.
   298 
   299 @param aDes The reference to a descriptor containing an existing TCheckedUid object.
   300 */
   301 void TCheckedUid::Set(const CDes8& aDes)
   302 	{
   303 	assert(aDes.Length() == sizeof(TCheckedUid));
   304 	memcpy(this,aDes.Ptr(),sizeof(TCheckedUid));
   305 	if (iCheck!=Check())
   306 		{
   307 		memset(this,0,sizeof(TCheckedUid));
   308 		}
   309 	}
   310 
   311 /**
   312 Gets a descriptor to represent this object's data.
   313 
   314 @return The descriptor for this object's data. The descriptor's length
   315 is the same as the length of a TCheckedUid object.
   316 */
   317 CDes8 TCheckedUid::Des() const
   318 	{
   319 	return(CDes8 (reinterpret_cast<const TUint8*>(this),sizeof(TCheckedUid)));
   320 	}
   321 
   322 /**
   323 Gets the Uid type contained in this object.
   324 
   325 @return The Uid type.
   326 */
   327 const TUidType&  TCheckedUid::UidType() const
   328 	{
   329 	return(iType);
   330 	}
   331 
   332 /**
   333 Calculates the checksum of the UIDs.
   334 
   335 @return The checksum.
   336 */
   337 TUint TCheckedUid::Check() const
   338 	{
   339 	return((checkSum((reinterpret_cast<TUint8*>(const_cast<TCheckedUid*>(this)))+1)<<16)|checkSum(this));
   340 	}
   341 }