Update contrib.
1 // Copyright (c) 1995-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 the License "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".
8 // Initial Contributors:
9 // Nokia Corporation - initial contribution.
14 // e32\include\e32rom.h
16 // WARNING: This file contains some APIs which are internal and are subject
17 // to change without notice. Such APIs should therefore not be used
18 // outside the Kernel and Hardware Services package.
24 #include <e32def_private.h>
28 #ifndef __SECURITY_INFO_DEFINED__
29 #define __SECURITY_INFO_DEFINED__
33 //This struct must be identical in size and offset to the one in e32cmn.h
34 //Functions need not be duplicated. But must be same structurally.
38 TUint32 iCaps[ENCapW];
39 inline const TUint32& operator[] (TInt aIndex) const { return iCaps[aIndex]; }
40 inline TUint32& operator[] (TInt aIndex) { return iCaps[aIndex]; }
46 //This struct must be identical in size and offset to the one in e32cmn.h
47 //Functions need not be duplicated. But must be same structurally.
60 struct SDemandPagingConfig
64 TUint16 iYoungOldRatio;
65 TUint16 iSpare[3]; // iSpare[0:1] are used for emulated rom paging,
66 // iSpare[2] is used for the old to oldest ratio.
79 enum TCompression // todo: compression type not exclusive to rom pages
86 TUint8 iCompressionType;
87 TUint8 iPagingAttributes;
94 Defines the size of the header for a ROM image.
98 const TUint KRomHeaderSize=0x200;
106 The format of the header for a ROM image.
108 This is retained as part of the ROM image.
109 It is generated by the rombuild tool, and is used by the Bootstrap and
115 enum { KDefaultDebugPort = -1 };
116 enum { KNumTraceMask = 8 }; // this is also defined in e23const.h
118 __ASSERT_COMPILE(KNumTraceMask==KNumTraceMaskWords);
122 Reserved for a small amount of Bootstrap code, if required.
123 The first 4 bytes of the binary image typically contains
124 a branch instruction which jumps to code at offset 0x100.
132 TLinAddr iRestartVector;
136 The date and time that the ROM image was built, in microseconds.
142 The high order 32 bits of the ROM image build date & time.
148 The virtual address of the base of the ROM.
154 The size of the ROM image, in bytes.
156 This includes the second section for sectioned ROMs.
162 The virtual address of the TRomRootDirectoryList structure.
164 @see TRomRootDirectoryList
166 TLinAddr iRomRootDirectoryList;
170 The virtual address of kernel data, when in RAM.
172 TLinAddr iKernDataAddress;
176 The virtual address of the top of the kernel region, when in RAM.
178 TLinAddr iKernelLimit;
182 The virtual address of the primarys ROM file image header.
186 TLinAddr iPrimaryFile;
190 The virtual address of the secondarys ROM file image header.
194 TLinAddr iSecondaryFile;
198 A computed constant that causes the 32-bit checksum of the image to equal
199 the value specified by the "romchecksum" keyword.
205 A unique number identifying the hardware for which this ROM image
208 Note that this is only used for testing purposes.
214 A bitmask identifying which of the languages are supported by the ROM image,
215 as specified by the "languages" keyword.
217 Note that this is only used for testing purposes.
223 Contains the flags that define the security options in force.
225 @see TKernelConfigFlags
227 TUint32 iKernelConfigFlags;
230 The virtual address of the TRomExceptionSearchTable structure.
232 @see TRomExceptionSearchTable
234 TLinAddr iRomExceptionSearchTable;
237 Current size of ROM header (Previously iUnused3)
238 If value is 0x69966996 then header size = 0x100
240 TUint32 iRomHeaderSize;
244 The virtual address of the ROM section header, if the ROM is sectioned.
246 @see TRomSectionHeader
248 TLinAddr iRomSectionHeader;
252 The total supervisor data size, i.e. the amount of memory mapped for
253 the kernel data chunk.
255 TInt iTotalSvDataSize;
259 The virtual address of the TRomEntry for the Variant file.
263 TLinAddr iVariantFile;
267 The virtual address of TRomEntry for the first extension file, if it exists.
269 If there is more than one extension, then the next extension field in
270 the extensions TRomImageHeader points to the TRomEntry for
273 @see TRomImageHeader::iNextExtension
277 TLinAddr iExtensionFile;
281 The virtual adress of the first area to be relocated into RAM, as defined
282 using the "area" keyword.
288 The old position of the kernel trace mask, see iTraceMask below
290 TUint32 iOldTraceMask; // The old location of the kernel tracemask
294 The virtual address of the user data area.
296 TLinAddr iUserDataAddress; // non-MMU stuff
300 The total size of the user data.
302 TInt iTotalUserDataSize; // non-MMU stuff
306 A value that is interpreted by the Bootstrap and kernel as the debug port
309 TUint32 iDebugPort; // semantic is ASSP-specific
313 The ROM version number.
319 The type of compression used for the image.
321 This is a UID, or 0 if there is no compression.
323 TUint32 iCompressionType; // compression type used
327 The size of the image after compression.
329 TUint32 iCompressedSize; // Size after compression
333 The size of the image before compression.
335 TUint32 iUncompressedSize; // Size before compression
340 TUint32 iDisabledCapabilities[2]; // 2==SSecurityInfo::ENCapW
344 The initial value for the kernel trace masks.
346 TUint32 iTraceMask[KNumTraceMask]; // The kernel debug trace masks
349 Initial values for fast-trace filter.
351 TUint32 iInitialBTraceFilter[8];
354 Initial value for size of fast-trace buffer.
356 TInt iInitialBTraceBuffer;
359 Initial value for size of fast-trace mode.
361 TInt iInitialBTraceMode;
364 Offset, in bytes from ROM start, for the start of the pageable ROM area.
366 TInt iPageableRomStart;
369 Size, in bytes, of the pageable ROM area.
371 TInt iPageableRomSize;
374 Offset, in bytes from ROM start, for the page index. (Array of SRomPageInfo objects.)
384 SDemandPagingConfig iDemandPagingConfig;
387 Offset, in bytes from ROM start, for the start of compressed un-paged ROM area
391 TUint32 iCompressedUnpagedStart;
395 Size, in bytes of the un-paged part of image after compression.
399 TUint32 iUnpagedCompressedSize;
403 Size, in bytes of the un-paged part of image before compression.
407 TUint32 iUnpagedUncompressedSize;
410 The virtual address at which the start of the HCR repository file is located in the unpaged part of the Core ROM Image.
414 TUint32 iHcrFileAddress;
419 TUint32 iSpare[36]; // spare : force size to be correct
423 __ASSERT_COMPILE(sizeof(TRomHeader)==KRomHeaderSize);
424 __ASSERT_COMPILE(SCapabilitySet::ENCapW==2); // TRomHeader::iDisabledCapabilities has hard coded 2 because h2inc.pl does not parse scoped identifiers
433 Contains information about a root directory.
435 A variable number of these are contained in a TRomRootDirectoryList structure.
437 @see TRomRootDirectoryList
443 The hardware variant for this root directory entry.
445 TUint iHardwareVariant;
449 The virtual address of the root directory.
453 TLinAddr iAddressLin;
463 A structure that allows you to find the root directories for each hardware
464 Variant supported by the ROM.
466 Usually, there is only one Variant and one root directory. However, a ROM can
467 have multiple root directories and directory trees, one for each hardware Variant
468 supported by the ROM. This ensures that the file server only sees the files
469 that are relevant to the hardware on which it is running. In this case, there
470 are multiple entries in the table describing each root directory.
472 class TRomRootDirectoryList
476 The number of root directory entries.
482 The root directory entries.
484 The number of entries is defined by iNumRootDirs.
486 TRootDirInfo iRootDir[1];
496 The format of a ROM section header.
498 class TRomSectionHeader
503 The ROM version number.
509 A computed constant that causes the 32-bit checksum of the upper
510 section to equal zero.
512 Upper sections checksum to zero so that the overall ROM checksum in
513 the TRomHeader is unaffected by changes to this section.
521 The date and time that the ROM image was built, in microseconds.
527 A bitmask identifying which of the languages are supported by the ROM image,
528 as specified by the "languages" keyword.
541 A structure that describes a file or a directory.
549 The size of the file.
555 The virtual address of the file, or of a TRomDir structure if this entry
556 describes another directory.
570 The length of the file or directory name.
576 A variable length field containing the file or directory name.
588 The size of the fixed part of a TRomEntry structure.
590 const TInt KRomEntrySize=(sizeof(TRomEntry)-2);
596 class TRomDirSortInfo;
602 A structure that describes the first part of a ROM directory.
604 This part of a ROM directory is a sequence of variable length entries,
605 each describing a file or a subdirectory, in the order that the members
606 were specified in the original obey file; the variable length entries are
607 the TRomEntry structures that follow the iSize member.
609 This part of the ROM directory is followed by a structure defined
610 by TRomDirSortInfo, which contains a pair of sorted tables suitable for
618 inline const TRomDirSortInfo* SortInfo() const;
619 inline const TRomEntry* SortedEntry(TInt aIndex) const;
620 inline TInt SubDirCount() const;
621 inline TInt FileCount() const;
622 inline TInt EntryCount() const;
623 TInt BinarySearch(const TDesC& aName, TInt aLengthLimit, TInt aMode, TBool aDir) const;
624 const TRomDir* FindLeafDir(const TDesC& aPath) const;
628 The number of bytes occupied by the set of TRomEntry structures
629 that follow this field.
637 A variable number of entries, each of which describes a file or a directory.
639 Each entry is 4-byte aligned, and may have padding to ensure that the entry
652 A structure that describes the second part of a ROM directory.
654 It contains a pair of sorted tables suitable for
655 a binary search. The sorted tables contain unsigned 16-bit scaled offsets,
656 which point to the start of the corresponding TRomEntry in the TRomDir.
660 class TRomDirSortInfo
665 The number of subdirectories in this directory.
667 TUint16 iSubDirCount; // number of subdirectories in this directory
671 The number of files in this directory.
673 TUint16 iFileCount; // number of non-directory files in this directory
677 The two sorted tables:
679 1. First one is a table of 16-bit scaled offsets to the directory entries.
681 2. Second one is a table of 16-bit scaled ofsets to the file entries.
682 This table starts at offset 2*iSubDirCount from the start of the first table.
684 If the offset is X, then the corresponding TRomEntry is at address:
686 4*X +(char*)address of the first TRomEntry
688 For example, the first entry is at offset zero.
690 The entries are sorted in the order of the UTF-8 representation of
691 the names in a case insensitive way (compare the C function stricmp()).
692 In effect, this folds upper and lowercase ASCII characters but leaves all
693 other Unicode characters unchanged.
695 TUint16 iEntryOffset[1]; // offsets of each entry from TRomDir::iEntry; extend
696 // order of offsets is directories first, then files, lexicographic order within each group
701 Gets a pointer to the start of the second part of the ROM directory,
702 as described by the TRomDirSortInfo structure.
704 @return The pointer to the start of the second part of the ROM directory.
706 inline const TRomDirSortInfo* TRomDir::SortInfo() const
707 { return (const TRomDirSortInfo*)( ((TLinAddr)&iEntry) + ( (iSize+sizeof(TUint32)-1) &~ (sizeof(TUint32)-1) )); }
713 Gets the TRomEntry corresponding to the file or directory located at
714 the specified index position within the sorted tables.
716 @param aIndex The index of the entry within the sorted tables.
717 Note that for the purpose of this function, the two tables
718 are treated as one single table.
720 @return The required TRomEntry
722 inline const TRomEntry* TRomDir::SortedEntry(TInt aIndex) const
724 const TRomDirSortInfo* s = SortInfo();
725 return (const TRomEntry*)(((TLinAddr)&iEntry) + s->iEntryOffset[aIndex] * sizeof(TUint32));
732 Gets the number of subdirectories in the directory.
734 @return The number of subdirectories.
736 inline TInt TRomDir::SubDirCount() const
737 { return SortInfo()->iSubDirCount; }
743 Gets the number of files in the directory.
745 @return The number of files.
747 inline TInt TRomDir::FileCount() const
748 { return SortInfo()->iFileCount; }
754 Gets the total number of files and subdirectories in the directory.
756 @return The total number of files and subdirectories.
758 inline TInt TRomDir::EntryCount() const
760 const TRomDirSortInfo* s = SortInfo();
761 return s->iSubDirCount + s->iFileCount;
768 // Header of ROM image files under the new scheme. (dlls & exes)
774 const TUint32 KRomImageFlagPrimary =0x80000000u;
780 const TUint32 KRomImageFlagVariant =0x40000000u;
786 const TUint32 KRomImageFlagExtension =0x20000000u;
792 const TUint32 KRomImageFlagDevice =0x10000000u;
798 const TUint32 KRomImageFlagsKernelMask =0xf0000000u;
804 const TUint32 KRomImageFlagSecondary =0x08000000u;
810 const TUint32 KRomImageFlagData =0x04000000u; // image has data and is not extension or variant
816 const TUint32 KRomImageFlagDataInit =0x02000000u; // image or non-EXE dependencies would require data initialisation
822 const TUint32 KRomImageFlagDataPresent =0x01000000u; // image or any dependencies have data
828 const TUint32 KRomImageFlagExeInTree =0x00800000u; // image depends on EXE
834 const TUint32 KRomImageFlagDll =0x00000001u;
840 const TUint32 KRomImageFlagFixedAddressExe =0x00000004u;
846 const TUint32 KRomImageABIMask =0x00000018u;
852 const TUint32 KRomImageABI_GCC98r2 =0x00000000u; // for ARM
858 const TUint32 KRomImageABI_EABI =0x00000008u; // for ARM
864 const TUint32 KRomImageEptMask =0x000000e0u; // entry point type
870 const TInt KRomImageEptShift =5;
876 const TUint32 KRomImageEpt_Eka1 =0x00000000u;
882 const TUint32 KRomImageEpt_Eka2 =0x00000020u;
885 Flag to indicate the image should not be code paged.
889 const TUint KRomImageFlagCodeUnpaged =0x00000100u;
893 Flag to indicate the image should be code paged.
897 const TUint KRomImageFlagCodePaged =0x00000200u;
903 Flag to indicate when named symbol export data present in image
905 const TUint KRomImageNmdExpData =0x00000400u;
910 Flag to indicate debuggability of this image.
912 const TUint KRomImageDebuggable =0x00000800u;
915 Flag to indicate the image will default to not be data paged,
916 this can be overridden when creating chunks, threads and user heaps.
920 const TUint KRomImageFlagDataUnpaged = 0x00001000u;
923 Flag to indicate the image will default to be data paged,
924 this can be overridden when creating chunks, threads and user heaps.
928 const TUint KRomImageFlagDataPaged = 0x00002000u;
931 Mask for the data paging flag bits.
935 const TUint KRomImageDataPagingMask = KRomImageFlagDataUnpaged | KRomImageFlagDataPaged;
939 Flag to indicate SMP safety of this image.
941 const TUint KRomImageSMPSafe =0x00004000u;
949 The format of the header for a ROM file image.
951 The structure of a file image is based on the native image file format,
952 but this can be compressed in the ROM image, as the relocation information
953 and the .idata section are discarded once the file is fixed up.
955 The Import Address Table (IAT) is also removed and each reference to
956 an IAT entry is converted into a reference to the associated Export Directory
957 entry in the corresponding DLL.
959 ROM file images have the following sections:
962 The header (as described by this structure)
964 .rdata - constant (read-only) data
965 .edata - the export directory
966 .data - initialised data that is copied to RAM when the executable runs.
967 The DLL reference table (a TDllRefTable structure), which is a list of DLLs
968 used by the executable.
971 @see TRomImageHeader::iDllRefTable
974 class TRomImageHeader
979 The UID1 for the file.
987 The UID2 for the file.
995 The UID3 for the file.
1003 The checksum of the UIDs
1005 TUint32 iUidChecksum;
1009 The entrypoint of this executable, i.e. the offset within this file.
1011 TUint32 iEntryPoint;
1015 This executables code address.
1017 TUint32 iCodeAddress;
1021 This executables data address.
1023 TUint32 iDataAddress;
1027 The size of the code.
1029 This includes the size of the constant data.
1035 The size of the executable code.
1037 This is the value of (iCodeSize - the size of the constant data).
1049 The size of the .bss (the zero-filled data)
1055 The minimum size of the heap.
1061 The maximum size of the heap.
1067 The size of the stack.
1073 The address of the DLL reference table.
1077 TDllRefTable* iDllRefTable;
1081 The number of functions exported by this executable.
1083 TInt iExportDirCount;
1087 The address of the export directory, which is a simple list of functions
1088 that can be indexed by ordinal.
1094 Security information, details of which are internal to Symbian.
1100 The version number of the tools used to generate this file image.
1102 TVersion iToolsVersion;
1112 The priority of the process.
1114 TProcessPriority iPriority;
1118 The virtual base address of the data and .bss, where the process expects
1119 its data chunk to be when it runs.
1121 TUint32 iDataBssLinearBase;
1125 The address of the TRomEntry for the next extension file.
1127 This field is only used if there is more than one extension.
1128 The first extension is found using the TRomHeader.
1133 TLinAddr iNextExtension;
1137 A number denoting the hardware Variant.
1139 It is used to determine whether this executable can run
1142 TUint32 iHardwareVariant;
1146 The total data size, including space reserved for DLLs
1148 TInt iTotalDataSize; // data+bss + space reserved for DLLs
1154 TUint32 iModuleVersion;
1157 The address of the Exception Descriptor if present.
1158 0 if no Exception descriptor
1160 TLinAddr iExceptionDescriptor;
1167 // Header for extension ROMs
1168 // Equivalent to TRomHeader
1175 The format of a ROM extension header.
1177 class TExtensionRomHeader
1182 The extension ROM image version number.
1188 The virtual address of the base of the extension ROM.
1194 The size of the extension ROM image.
1200 The virtual address of the TRomRootDirList structure for
1201 the combined kernel+extension ROM image.
1203 @see TRomRootDirList
1205 TLinAddr iRomRootDirectoryList;
1209 The date and time that the extension ROM image was built, in microseconds.
1215 The extension ROM image checksum
1222 Copy of the kernel ROM image version number.
1224 TVersion iKernelVersion;
1228 Copy of the kernel ROM image build date & time.
1234 Copy of the kernel ROM image checksum.
1236 TUint iKernelCheckSum;
1241 The type of compression used for the image.
1243 This is a UID, or 0 if there is no compression.
1245 TUint32 iCompressionType; // compression type used
1249 The size of the image after compression.
1251 TUint32 iCompressedSize; // Size after compression
1255 The size of the image before compression.
1257 TUint32 iUncompressedSize; // Size before compression
1261 The virtual address of the TRomExceptionSearchTable structure.
1263 @see TRomExceptionSearchTable
1265 TLinAddr iRomExceptionSearchTable;
1269 Reserved for future use.
1271 TUint32 iPad[32-15]; // sizeof(TExtensionRomHeader)=128
1282 A list of DLLs that an executable needs in order to run.
1284 Each DLL referenced in this list has a pointer to a TRomImageHeader structure
1285 that describes that DLL. This allows the DLL loader to search
1286 a dependency chain, and ensure that all required DLLs are loaded.
1288 @see TRomImageHeader
1301 The number of referenced DLLs in this list.
1303 TUint16 iNumberOfEntries;
1307 A set of pointers to the TRomImageHeader structures for each referenced DLL.
1309 TRomImageHeader* iEntry[1];