mirror of
https://github.com/nasa/trick.git
synced 2025-01-22 04:18:09 +00:00
159 lines
6.7 KiB
Plaintext
159 lines
6.7 KiB
Plaintext
|
/**
|
|||
|
@page LEVEL2 Making the Simulation.
|
|||
|
|
|||
|
@section LEVEL3 Simulation Compilation Environment Variables
|
|||
|
|
|||
|
TRICK_CFLAGS and TRICK_CXXFLAGS affect where model source files are searched for and
|
|||
|
how the files are compiled. See section @ref Trick_Environment for more information
|
|||
|
to how to set TRICK_CFLAGS and TRICK_CXXFLAGS when compiling a simulation.
|
|||
|
|
|||
|
@section LEVEL3 Making the Simulation for the First Time.
|
|||
|
|
|||
|
Make and the makefiles contain all of the magic of building a simulation. When a
|
|||
|
simulation is ready to be built for the very first time run we run the
|
|||
|
configuration processor script (CP) in the simulation directory.
|
|||
|
|
|||
|
<tt><b>UNIX prompt></b> CP</tt>
|
|||
|
|
|||
|
CP creates a small makefile and calls make to start the simulation build process.
|
|||
|
The small makefile does not change and is the same from simulation to simulation.
|
|||
|
It can be copied from another simulation directory and the CP step may be skipped.
|
|||
|
From this point CP does not need to be run again, all compilations use "make".
|
|||
|
|
|||
|
When make is invoked, the first rule it executes is to parse the S_define file.
|
|||
|
The parser from this point will be referred to as CP. CP was the main compilation
|
|||
|
command before %Trick 10. Using the S_define file created by the user, the CP
|
|||
|
finds all source code related to the simulation, builds the code using a C compiler,
|
|||
|
and puts it all together to make one executable. In its processing it
|
|||
|
gathers/generates all the IO source code, default data, recursive
|
|||
|
header/object dependencies and external library dependencies.
|
|||
|
|
|||
|
After the initial CP is run, when there are changes made to model source code or
|
|||
|
the S_define file, they are recompiled using make.
|
|||
|
|
|||
|
<tt><b>UNIX prompt></b> make</tt>
|
|||
|
|
|||
|
@section LEVEL3 How Trick Finds Simulation Source Code
|
|||
|
|
|||
|
%Trick must compile a list of all of the source code required to create the
|
|||
|
simulation described in the S_define file. %Trick does this by creating a list
|
|||
|
of required header files, and the automatic I/O souce code it must build to go
|
|||
|
with those header files, and the model source code files.
|
|||
|
|
|||
|
Header files are searched for starting from the S_define file. Any file that is
|
|||
|
double pound "##" included in the S_define file is automatically included in the
|
|||
|
list of header files. Each header file is recursively parsed to determine all
|
|||
|
lower level header files on which the top level header is dependent on. Doing this
|
|||
|
for all double pound files gives us the full list of header files.
|
|||
|
|
|||
|
Model source files are found through LIBRARY DEPENDENCIES. Starting in the S_define
|
|||
|
file, any LIBRARY DEPENDENCIES listed are searched for. See
|
|||
|
@ref S_define_Library_Dependencies for more information on how to add dependencies
|
|||
|
in the S_define file. All of the header files gathered from the previous step are
|
|||
|
also searched for library dependencies. Finally all model source code found from
|
|||
|
the previous steps is recursively searched for additional dependencies.
|
|||
|
See @ref Library_Dependencies for more information on how to add dependencies to
|
|||
|
model source code. Rules to compile all of these files are written to the makefile.
|
|||
|
|
|||
|
@section LEVEL3 Changing Simulation Compilation through Makefile Overrides
|
|||
|
|
|||
|
Sometimes a programmer may want %Trick to pick up specific compiler flags or some
|
|||
|
special makefile rule for building a model or building the simulation. %Trick allows the
|
|||
|
programmer to override the default Makefile rules with a facility we are calling
|
|||
|
“makefile overrides”.
|
|||
|
|
|||
|
For overrides in model directories, a user can create a file called “makefile_overrides”.
|
|||
|
In this file s/he can override any of the rules that are within the Makefile. When a
|
|||
|
make_build command is issued, this makefile_overrides file is looked for and if it is
|
|||
|
present, it is included from the Makefile. The rules contained in the overrides file are
|
|||
|
then read in when make is called.
|
|||
|
|
|||
|
This same file is looked for in each directory when a CP is performed. Each
|
|||
|
“makefile_overrides” file in this case is read into memory and certain rules are translated
|
|||
|
so only those files in that directory are affected. Instead of just including these files
|
|||
|
(where there can be multiple files), all of the translated output is inserted into the Makefile.
|
|||
|
|
|||
|
For overrides in sim directories, there is a sim specific overrides file called
|
|||
|
“S_overrides.mk”. If this file is present in the sim directory, it is included after the
|
|||
|
directory specific overrides. The rules in this file are the last word in how things are
|
|||
|
going to compile.
|
|||
|
|
|||
|
@section LEVEL4 Example Of How To Optimize A Model
|
|||
|
|
|||
|
- Go to model dir to optimize
|
|||
|
|
|||
|
<tt><b>UNIX Prompt></b> cd /user/me/trick_models/ball/L1</tt>
|
|||
|
|
|||
|
- Edit a file called “makefile_overrides” with the following line:
|
|||
|
|
|||
|
<tt>objects: TRICK_CFLAGS += -O3</tt>
|
|||
|
|
|||
|
- Do a make_build
|
|||
|
|
|||
|
<tt><b>UNIX Prompt></b>make_build</tt>
|
|||
|
|
|||
|
After make_build, look at Makefile. There is a line
|
|||
|
“include makefile_overrides”. This is what will pick up the optimization flag.
|
|||
|
|
|||
|
- Build the model.
|
|||
|
|
|||
|
<tt><b>UNIX Prompt></b> make</tt>
|
|||
|
|
|||
|
That’s it.
|
|||
|
|
|||
|
@section LEVEL4 Example Of How To Add a Pre-compiled Library to the Simulation
|
|||
|
|
|||
|
- Go to simulation dir.
|
|||
|
|
|||
|
<tt><b>UNIX Prompt></b> cd /user/me/trick_sims/SIM_ball_L1</tt>
|
|||
|
|
|||
|
- Edit a file called “S_overrides.mk". Append to the TRICK_USER_LINK_LIBS variable.
|
|||
|
|
|||
|
<tt>TRICK_USER_LINK_LIBS = -L/path/to/library -lmy_lib</tt>
|
|||
|
|
|||
|
@section LEVEL4 Example Of How To Exclude a Directory from ICG during CP
|
|||
|
|
|||
|
- Go to simulation dir.
|
|||
|
|
|||
|
<tt><b>UNIX Prompt></b> cd /user/me/trick_sims/SIM_ball_L1</tt>
|
|||
|
|
|||
|
- Edit a file called “S_overrides.mk”. Append to the TRICK_ICG_EXCLDUE variable.
|
|||
|
|
|||
|
<tt>TRICK_ICG_EXCLUDE += /path/to/exclude:/another/path/to/exclude</tt>
|
|||
|
|
|||
|
@section LEVEL4 Example Of How To Exclude a Directory from most CP processing
|
|||
|
|
|||
|
- Edit a file called “S_overrides.mk”. Append to the TRICK_EXCLDUE variable.
|
|||
|
|
|||
|
<tt>TRICK_EXCLUDE += /path/to/exclude:/another/path/to/exclude</tt>
|
|||
|
|
|||
|
@section LEVEL3 Cleaning Up
|
|||
|
|
|||
|
There are several levels of clean.
|
|||
|
|
|||
|
<tt><b>UNIX Prompt></b> make clean</tt>
|
|||
|
|
|||
|
Clean tries to remove only object files directly related to the current simulation.
|
|||
|
It will remove all of the generated files in the simulation directory. Clean
|
|||
|
also selectively removes model object files used to link this simulation.
|
|||
|
|
|||
|
<tt><b>UNIX Prompt></b> make real_clean</tt>
|
|||
|
|
|||
|
Real_clean is equivalent to clean.
|
|||
|
|
|||
|
<tt><b>UNIX Prompt></b> make spotless</tt>
|
|||
|
|
|||
|
Spotless is less discriminate in the files it removes. In addition to all
|
|||
|
of the files that clean removes, spotless will remove complete model object
|
|||
|
directories where any file included in the simulation was found.
|
|||
|
|
|||
|
<tt><b>UNIX Prompt></b> make apocalypse</tt>
|
|||
|
|
|||
|
Apocalypse is a special case rule when simulation libraries are used to build
|
|||
|
a simulation. See section @ref Simulation_Libraries for more information
|
|||
|
about. In addition to all of files that spotless removes, apocalype will
|
|||
|
run the spotless rule on any simulation directory the current simulation
|
|||
|
includes.
|
|||
|
|
|||
|
*/
|