crypto/weakcrypto/group/README.txt
branchRCL_3
changeset 61 641f389e9157
equal deleted inserted replaced
60:f18401adf8e1 61:641f389e9157
       
     1 The cryptography libraries should not build thumb.  
       
     2 
       
     3 On EKA1 they cannot build on thumb because the long long support files (supplied by base) contain instructions that are not supported on that platform.  This has the knock-on effect that those components that include bigint code in their build (and thus require the long long support files too) also cannot build thumb.  The entire list of components affected is as follows:
       
     4 
       
     5 the cryptography library cryptography.dll
       
     6 tasn1 (use CopyL, operator ==, operator < and operator *=) 
       
     7 tx509, twtlscert (both use operator < and > which are not exported from TInteger) 
       
     8 
       
     9 
       
    10 On EKA2 it should not build thumb either, because it has been deemed to be too slow.  
       
    11 
       
    12 Thus the cryptography library must be built on the ARMi platform to substitute for the thumb binary where a thumb set of binaries is required (eg for Lubbock roms).  The ARMi build should occur first in the build order.  To speed up the build process, I've stopped our testcode building ARMi where it's not required to do so.
       
    13 
       
    14 Some information (from Chris Mokes) about how to prevent the cryptography library building on thumb, and how to manage ROM building follows:
       
    15 
       
    16 
       
    17 (a)	To stop thumb being built do this in the PRJ_MMPFILES section of   bld.inf
       
    18 
       
    19 #if !defined(MARM_THUMB)
       
    20 	mmpfilename
       
    21 #endif
       
    22 
       
    23 or I think you can specify -THUMB in bld.inf but that'll stop everything being build for thumb.
       
    24 
       
    25 
       
    26 (b)	You need to build the dll for ARMI, but still build a thumb lib file for thumb binaries which use the dll to be linked with.  Thumb and armi dlls are interchangable, armi code linked with the armi lib can call exports in a thumb dll and the other way around.
       
    27 
       
    28 As you've seen the rombuild downgrades to armi if the thumb binary isn't present., so if you have built the armi version and not the thumb one it will pick up the correct one.
       
    29 
       
    30 Euser has its own define EUSER_ABI in the rombuilding scripts.  EUSER_ABI is ARM4 in an ARM4 build and ARMI for thumb and armi builds. 
       
    31 
       
    32 The nicest solution is to add to epoc32\rom\include\header.iby to define a CRYPTO_ABI which will be basically the same as the euser one.
       
    33 
       
    34 Thus,
       
    35 
       
    36 header.iby 
       
    37 <snip>
       
    38 #ifdef _ARM4
       
    39 define DESIRED_ABI     ARM4
       
    40 define EUSER_ABI       ARM4
       
    41 define ELOCL_ABI       ARM4
       
    42 define CRYPTO_ABI      ARM4
       
    43 #endif
       
    44 
       
    45 #ifdef _ARMI
       
    46 define DESIRED_ABI     ARMI
       
    47 define EUSER_ABI       ARMI
       
    48 define ELOCL_ABI       ARM4
       
    49 define CRYPTO_ABI      ARMI
       
    50 #endif
       
    51 
       
    52 #ifdef _THUMB
       
    53 define DESIRED_ABI     THUMB
       
    54 define EUSER_ABI       ARMI
       
    55 define ELOCL_ABI       ARM4
       
    56 define CRYPTO_ABI      ARMI
       
    57 #endif
       
    58 <snip>
       
    59 
       
    60 
       
    61 Then use  CRYPTO_ABI rather than ABI_DIR  in cryptalg.iby.
       
    62 
       
    63 So, the simplest way is the just build armi and arm4 and the armi one will be downgraded to in a thumb rom.  This is the situation at present.  The most complex but best is to use the define CRYPTO_ABI as explained above.  This cannot be done until the cryptography libraries are submitted to the build and the Master Codeline accepts divergence from 7.0s release.