|
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. |