os/mm/mmtestenv/mmtesttools/Build/readme.txt
author sl
Tue, 10 Jun 2014 14:32:02 +0200 (2014-06-10)
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
Summary of files in this directory
sl@0
     2
==================================
sl@0
     3
sl@0
     4
Commands for developers
sl@0
     5
-----------------------
sl@0
     6
sl@0
     7
(these are perl-based, and include a .bat file to merely call the perl).
sl@0
     8
sl@0
     9
mmbuild.bat/.pl: Rebuild Multimedia in the current codeline (see below)
sl@0
    10
mmbuildrom.bat/.pl: Build a rom, possibly including Multimedia test files (see below)
sl@0
    11
sl@0
    12
Commands intended for test builds
sl@0
    13
---------------------------------
sl@0
    14
sl@0
    15
fullMmBuild.bat/.pl: Designed to be called from Tools/auto.bat to do full rebuild, as part of test build
sl@0
    16
winsMmBuild.bat/.pl: Similar but only build WINS - used for ODC integration
sl@0
    17
testExtras.bat: Build those things required by test build but not built by mmbuild
sl@0
    18
testExtras_ccov.bat: Similar to testExtras.bat, but for CCover builds
sl@0
    19
testExtras_clean.bat: Again similar, but used to remove the associated components
sl@0
    20
sl@0
    21
Note that the action carried out is configured by editing the .mbc files of the same name.
sl@0
    22
sl@0
    23
Usage of MmBuild and MmBuildRom
sl@0
    24
-------------------------------
sl@0
    25
sl@0
    26
MmBuild is intended to be a central place where any developer can rebuild the whole of the codeline, essentially as the test build - and thus similarly to the overnight build.
sl@0
    27
sl@0
    28
A standard sequence would be:
sl@0
    29
sl@0
    30
	mmbuild setup 		// work out which things to build and run bldmake
sl@0
    31
	mmbuild -t clean	// do reallyclean - -t means on test files *too*
sl@0
    32
	mmbuild build 		// build main code
sl@0
    33
	mmbuild -t build	// build test code - testframework, unit test etc
sl@0
    34
sl@0
    35
[ As an aside, the fullmmbuild command can be used to run the above sequence, as in:
sl@0
    36
	 fullmmbuild.bat -c > bld.log 2>&1
sl@0
    37
  where the -c does the clean stage - generally use for the first time you build from that
sl@0
    38
  area, and leave out subsequently].
sl@0
    39
sl@0
    40
By default, build runs through WINS, WINSCW, ARM4 and MCOT - for MCOT only the DevSound and device driver layers are built. You can give the target to build instead, just as you want with "abld build", except that it is not possible to only build udeb or urel. For EKA2, where WINS is not build as part of the DevBuild, the WINS stage is just an "export". 
sl@0
    41
sl@0
    42
There are some useful flags to be added to "setup", that change what happens on subsequent build/clean calls:
sl@0
    43
	-x	include "optional" modules
sl@0
    44
	-i	Build/Clean ICL only
sl@0
    45
	-m	Build/Clean MMF only
sl@0
    46
sl@0
    47
eg.
sl@0
    48
sl@0
    49
	mmbuild -x -m setup
sl@0
    50
sl@0
    51
Note that mmbuild works by generating some temporary files, so these options only need be given on setup.
sl@0
    52
sl@0
    53
MmBuildRom is similarly designed to build the rom. 
sl@0
    54
sl@0
    55
	mmbuildrom -t
sl@0
    56
sl@0
    57
will build a rom including all the non-optional multimedia software.
sl@0
    58
sl@0
    59
Again there are some useful options:
sl@0
    60
	-t	include test software 
sl@0
    61
	-x	include optional modules, and where -t is given, their tests
sl@0
    62
	-i	if -t given, only include icl-unit tests
sl@0
    63
	-m	if -t given, only include mmf-unit tests
sl@0
    64
sl@0
    65
sl@0
    66
Configuration files
sl@0
    67
-------------------
sl@0
    68
sl@0
    69
The following .mbc files are used by mmbuild to determine what is built, eg. so it knows what is the main ICL code, what is optional, and what is test.
sl@0
    70
sl@0
    71
Misc.mbc	Main "Misc" modules - potentially ECam
sl@0
    72
icl.mbc		Main ICL modules
sl@0
    73
mmf.mbc		Main MMF modules
sl@0
    74
sl@0
    75
MiscOpt.mbc/ICLOpt.mbc/MMFOpt.mbc: Optional Misc/ICL/MMF Modules respectively
sl@0
    76
sl@0
    77
MiscTest.mbc/ICLTest.mbc/MMFTest.mbc: Main Misc/ICL/MMF test code modules respectively
sl@0
    78
sl@0
    79
MiscOptTest.mbc/ICLOptTest.mbc/MMFOptTest.mbc: Optional Misc/ICL/MMF test code modules respectively
sl@0
    80
sl@0
    81
mmfNotOptTest.mbc: MMF test code for when mmfOptTest.mbc is not employed (currently mmf-only)
sl@0
    82
sl@0
    83
mmfPhys.mbc: What to build for MMF with real targets like MCOT
sl@0
    84
mmfPhysOpt.mbc: Optional things to build for real targets
sl@0
    85
sl@0
    86
It should be noted that the definition of "optional" v. "non-optional" is whether it is part of the current "standard" build - rather than whether a module is theorectically optional or not.
sl@0
    87
sl@0
    88
These .mbc files are intended to be maintained - particularly if new sub-components are added or when they cease to become "optional", etc.
sl@0
    89
sl@0
    90
testExtras.mbc and testExtras_ccov.mbc support the associated .bat files. They build test programs such as tmdavid, tmdaaud and timageviewer. They might also need maintaining if things change.
sl@0
    91
sl@0
    92
Temporary files
sl@0
    93
---------------
sl@0
    94
sl@0
    95
Please ignore and don't add to perforce
sl@0
    96
sl@0
    97
__main.mbc
sl@0
    98
__phys.mbc
sl@0
    99
__test.mbc
sl@0
   100
$NULL