OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [ecos-2.0/] [doc/] [sgml/] [user-guide/] [configuration.sgml] - Blame information for rev 377

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 28 unneback
2
 
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
 
30
31
 
32
33
Configuration and the Package Repository
34
35
The following chapters contain information on running
36
        ecosconfig (the command line tool that
37
        manipulates configurations and constructs build trees) and on
38
        managing a source repository across multiple versions of
39
        eCos. 
40
41
42
Manual Configuration
43
 
44
    eCos developers will generally use the graphical
45
      Configuration Tool for configuring an eCos system and building
46
      the target library. However, some user prefer to use command
47
      line tools. These command line tools can also be used for batch
48
      operations on all platforms, for example as part of a nightly
49
      rebuild and testing procedure.
50
    
51
 
52
In the current release of the system the command line tools
53
      do not provide exactly the same functionality as the graphical
54
      tool. Most importantly, there is no facility to resolve
55
      configuration conflicts interactively.
56
The eCos configuration system, both graphical and command
57
      line tools, are under constant development and enhancement.
58
      Developers should note that the procedures described may change
59
      considerably in future releases. 
60
 
61
62
Directory Tree Structure
63
When building eCos there are three main directory trees to
64
        consider: the source tree, the build tree, and the install
65
        tree.
66
The source tree, also known as the component repository,
67
          is read-only. It is possible to use a single component
68
          repository for any number of different configurations, and
69
          it is also possible to share a component repository between
70
          multiple users by putting it on a network drive.
71
The build tree contains everything that is specific to a
72
          particular configuration, including header and other files
73
          that contain configuration data, and the object files that
74
          result from compiling the system sources for this
75
          configuration. 
76
The install tree is usually located in the install subdirectory
77
of the build tree. Once an eCos system has been built, the install
78
tree contains all the files needed for application development including
79
the header files and the target library. By making copies of the
80
install tree after a build it is possible to separate application
81
development and system configuration, which may be desirable for
82
some organizations. 
83
84
 
85
86
Creating the Build Tree
87
Generating a build tree is a non-trivial operation and
88
          should not be attempted manually. Instead, eCos is shipped
89
          with a tool called ecosconfig that should
90
          be used to create a build tree.
91
Usually ecosconfig will be
92
run inside the build tree itself. If you are creating a new build
93
tree then typically you will create a new empty directory using
94
the mkdir command, cd into
95
that directory, and then invoke ecosconfig to
96
create a configuration. By default, the configuration is stored
97
in a file ecos.ecc in the current
98
directory. The configuration may be modified by editing this file directly. ecosconfig itself
99
deals with a number of coarse-grained configuration options such
100
as the target platform and the packages that should be used.
101
The ecosconfig tool is also
102
used subsequently to generate a build tree for a configuration.
103
Once a build tree exists, it is possible to run ecosconfig again
104
inside the same build tree. This will be necessary if your wish
105
to change some of the configuration options.
106
ecosconfig does not generate
107
the top-level directory of the build tree; you must do this
108
        yourself. 
109
$ mkdir ecos-work
110
$ cd ecos-work
111
The next step is to run ecosconfig: 
112
$ ecosconfig <qualifiers> <command>
113
114
ecosconfig qualifiers
115
The available command line qualifiers for
116
            ecosconfig are as follows. Multiple
117
            qualifiers may be used on the command line:
118
          
119
120
121
122
123
Provides basic usage guidelines for the
124
              available commands and qualifiers.
125
126
127
128
129
130
Specifies an eCos configuration save file for
131
                  use by the tool. By default, the file
132
                  ecos.ecc in the
133
                  current directory is used. Developers may prefer to
134
                  use a common location for all their eCos
135
                  configurations rather than keep the configuration
136
                  information in the base of the build tree.
137
138
139
140
141
142
Specifies an alternative location for the
143
                  install tree. By default, the install tree resides
144
                  inside the install
145
                  directory in the build tree. Developers may prefer
146
                  to locate the build tree in a temporary file
147
                  hierarchy but keep the install tree in a more
148
                  permanent location.
149
150
151
152
153
154
Specifies the location of the component
155
                  repository. By default, the tool uses the location
156
                  specified in the
157
                  ECOS_REPOSITORY
158
                  environment variable. Developers may prefer to use
159
                  of this qualifier if they are working with more than
160
                  one repository.
161
162
163
164
165
166
Disables the implicit resolution of conflicts
167
                  while manipulating the configuration data.
168
                  developers may prefer to resolve conflicts by
169
                  editing the eCos configuration save file
170
                  manually.
171
172
173
174
175
176
177
178
By default, ecosconfig will exit with an error code if the current
179
configuration contains any conflicts, and it is not possible to
180
generate or update a build tree for such configurations. This
181
qualifier causes ecosconfig to ignore such problems, and hence it is
182
possible to generate a build tree even if there are still
183
conflicts. Of course, there are no guarantees that the resulting
184
system will actually do anything.
185
186
187
188
189
190
191
192
193
Display more information.
194
195
196
197
198
199
200
201
202
Display less information.
203
204
205
206
207
208
The ,  and
209
 qualifiers can also be written with two arguments,
210
for example:
211
212
213
ecosconfig --srcdir <dir> ...
214
215
216
This simplifies filename completion with some shells.
217
218
219
220
ecosconfig commands
221
The available commands for
222
            ecosconfig are as
223
            follows:
224
225
226
list
227
228
Lists the available packages, targets and
229
                  templates as installed in the eCos repository.
230
                  Aliases and package versions are also
231
                  reported.
232
233
234
235
new <target> [<template> [<version>]]
236
237
Creates a new eCos configuration for
238
                  the specified target hardware and saves it. A
239
                  software template may also be specified. By default,
240
                  the template named ‘default’ is used. If
241
                  the template version is not specified, the latest
242
                  version is used.
243
244
245
246
target <target>
247
248
Changes the target hardware selection
249
                  for the eCos configuration. This has the effect of
250
                  unloading packages supporting the target selected
251
                  previously and loading the packages which support
252
                  the new hardware. This command will be used
253
                  typically when switching between a simulator and
254
                  real hardware.
255
256
257
258
template <template> [<version>]
259
260
Changes the template selection for the eCos
261
                  configuration. This has the effect of unloading
262
                  packages specified by the template selected
263
                  previously and loading the packages specified by the
264
                  new template. By default, the latest version of the
265
                  specified template is used.
266
267
268
269
remove <packages>
270
271
Removes the specified packages from the eCos
272
                  configuration. This command will be used typically
273
                  when the template on which a configuration is based
274
                  contains packages which are not required.
275
276
277
278
add <packages>
279
280
Adds the specified packages to the eCos configuration. This
281
command will be used typically when the template on which a
282
configuration is based does not contain all the packages which are
283
required.For example, add-on packages provided by third parties will
284
not be known to the standard templates, so they will have to be added
285
explicitly. 
286
287
288
289
version <version> <packages>
290
291
Selects the specified version of a
292
                  number of packages in the eCos configuration. By
293
                  default, the most recent version of each package is
294
                  used. This command will be used typically when an
295
                  older version of a package is required.
296
297
298
299
check
300
301
Presents the following information
302
                  concerning the current configuration:
303
304
305
the selected target hardware
306
307
308
the selected template
309
310
311
additional packages
312
313
314
removed packages
315
316
317
the selected version of packages
318
                      where this is not the most recent
319
                      version
320
321
322
conflicts in the current configuration
323
324
325
326
327
328
resolve
329
330
Resolves conflicts identified in the
331
                  current eCos configuration by invoking an inference
332
                  capability. Resolved conflicts are reported, but not
333
                  all conflicts may be resolvable. This command will
334
                  be used typically following manual editing of the
335
                  configuration.
336
337
338
339
export <file>
340
341
Exports a minimal eCos configuration
342
                  save file with the specified name. This file
343
                  contains only those options which do not have their
344
                  default value. Such files are used typically to
345
                  transfer option values from one configuration to
346
                  another.
347
348
349
350
import <file>
351
352
Imports a minimal eCos configuration
353
                  save file with the specified name. The values of
354
                  those options specified in the file are applied to
355
                  the current configuration.
356
357
358
359
tree
360
361
Generates a build tree based on the current eCos
362
                  configuration. This command will be used typically
363
                  just before building eCos.Normally a build tree can
364
only be generated if if the configuration has no unresolved
365
conflicts, but  can be used to override
366
this.
367
368
369
370
371
372
373
Conflicts and constraints
374
Configuration options are not completely independent. For example
375
the C library's strtod() and atof()
376
functions rely on the math library package to provide certain functionality. If the math library package is removed then the C
377
library can no longer provide these functions. Each package describes constraints like these in CDL "requires" properties. If a constraint is not satisfied, then the configuration contains a conflict. For any given conflict there can
378
be several resolution options. For example, it would be possible to add the math library package back to the
379
configuration, or to disable the strtod() and atof() functions.
380
381
The eCos configuration tools will report any conflicts in the current configuration. If there are any such conflicts
382
then the configuration is usually unsafe and it makes no sense to build and run eCos in such circumstances. In fact,
383
any attempt at building eCos is likely to fail. In exceptional cases it is possible to override this by using e.g. the
384
 qualifier with ecosconfig.
385
386
387
Many constraints are fairly simple in nature, and the configuration tools contain an inference engine which can
388
resolve the associated conflicts automatically. For example, if the math library package is removed then the
389
inference engine can resolve the resulting conflict by disabling the configuration option for strtod() and atof(). All
390
such changes will be reported. Sometimes the inference engine cannot resolve a conflict, for example it is not
391
allowed to override a change that has been made explicitly by the user. Sometimes it will find a solution which does
392
not match the application's requirements.
393
394
395
A typical session involving conflicts would look something like this:
396
397
$ ecosconfig new pid
398
This creates a new configuration with the default template. For most targets this will not result in any conflicts,
399
because the default settings for the various options meet the requirements of the default template.
400
 For some targets
401
there may be conflicts and the inference engine would come into play.
402
403
$ ecosconfig remove libm
404
U CYGSEM_LIBC_STDIO_SCANF_FLOATING_POINT, new inferred value 0
405
U CYGFUN_LIBC_strtod, new inferred value 0
406
U CYGSEM_LIBC_STDIO_PRINTF_FLOATING_POINT, new inferred value 0
407
408
ecosconfig reports that this change caused three conflicts, all in the C library. The inference engine was able to
409
resolve all the conflicts and update the relevant configuration options accordingly. 
410
To suppress the inference engine  can be used:
411
412
$ ecosconfig new pid
413
$ ecosconfig --no-resolve remove libm
414
C CYGSEM_LIBC_STDIO_SCANF_FLOATING_POINT, "requires" constraint not satisfied:      CYGPKG_LIBM
415
C CYGSEM_LIBC_STDIO_PRINTF_FLOATING_POINT, "requires" constraint not satisfied:      CYGPKG_LIBM
416
C CYGFUN_LIBC_strtod, "requires" constraint not satisfied: CYGPKG_LIBM
417
418
Three unresolved conflicts are reported.
419
420
The check command can be used to get the current state of the
421
configuration, and the  qualifier will provide additional information: 
422
423
$ ecosconfig --srcdir /home/bartv/ecc/ecc --verbose check
424
Target: pid
425
Template: default
426
Removed:
427
 CYGPKG_LIBM
428
3 conflict(s):
429
C CYGFUN_LIBC_strtod, "requires" constraint not satisfied: CYGPKG_LIBM
430
 Possible solution:
431
    CYGFUN_LIBC_strtod -> 0
432
    CYGSEM_LIBC_STDIO_SCANF_FLOATING_POINT -> 0
433
C CYGSEM_LIBC_STDIO_PRINTF_FLOATING_POINT, "requires" constraint not satisfied:      CYGPKG_LIBM
434
 Possible solution:
435
    CYGSEM_LIBC_STDIO_PRINTF_FLOATING_POINT -> 0
436
C CYGSEM_LIBC_STDIO_SCANF_FLOATING_POINT, "requires" constraint not satisfied:      CYGPKG_LIBM
437
 Possible solution:
438
    CYGSEM_LIBC_STDIO_SCANF_FLOATING_POINT -> 0
439
440
441
If the proposed solutions are acceptable, the resolve command can be used to apply them:
442
443
$ ecosconfig resolve
444
U CYGSEM_LIBC_STDIO_SCANF_FLOATING_POINT, new inferred value 0
445
U CYGFUN_LIBC_strtod, new inferred value 0
446
U CYGSEM_LIBC_STDIO_PRINTF_FLOATING_POINT, new inferred value 0
447
448
The current configuration is again conflict-free and it is possible to generate a build tree. The  qualifier can
449
be used to suppress the change messages, if desired.
450
451
When changing individual configuration options by editing the ecos.ecc file (as described below), the resulting
452
system should be checked and any problems should be resolved. For example, if CYGFUN_LIBC_strtod is
453
explicitly enabled in the savefile:
454
455
$ edit ecos.ecc
456
$ ecosconfig check
457
Target: pid
458
Template: default
459
Removed:
460
    CYGPKG_LIBM
461
1 conflict(s):
462
C CYGFUN_LIBC_strtod, "requires" constraint not satisfied: CYGPKG_LIBM
463
$ ecosconfig resolve
464
C CYGFUN_LIBC_strtod, "requires" constraint not satisfied: CYGPKG_LIBM
465
466
In this case the inference engine cannot resolve the conflict automatically because that would involve changing a
467
user setting. Any attempt to generate a build tree will fail:
468
469
$ ecosconfig --srcdir /home/bartv/ecc/ecc tree
470
C CYGFUN_LIBC_strtod, "requires" constraint not satisfied: CYGPKG_LIBM
471
Unable to generate build tree, this configuration still contains conflicts.
472
Either resolve the conflicts or use --ignore-errors
473
474
475
It is still possible to generate a build tree:
476
477
$ ecosconfig --srcdir /home/bartv/ecc/ecc --ignore-errors tree
478
C CYGFUN_LIBC_strtod, "requires" constraint not satisfied: CYGPKG_LIBM
479
$ make
480
481
In this case eCos will fail to build. In other cases of unresolved conflicts eCos may build, but may not run. In
482
general all conflicts should be resolved by editing the ecos.ecc file, by letting the inference engine make appropriate
483
changes, or by other means, before any attempt is made to build or run eCos.
484
485
486
487
Building the System
488
Once a build tree has been generated with
489
          ecosconfig, building eCos is straightforward:
491
$ make
492
The build tree contains the subdirectories, makefiles,
493
          and everything else that is needed to generate the default
494
          configuration for the selected architecture and platform.
495
          The only requirement is that the tools needed for that
496
          architecture, for example
497
          powerpc-eabi-g++,
498
          are available using the standard search path. If this is not
499
          the case then the make will
500
          fail with an error message. If you have a multiprocessor
501
          system then it may be more efficient to use:
502
$ make -j n
503
where n is equal to the
504
          number of processors on your system.
505
Once the make process
506
          has completed, the install tree will contain the header
507
          files and the target library that are needed for application
508
          development. 
509
It is also possible to build the system’s test cases
510
for the current configuration:
511
$ make tests
512
The resulting test executables will end up in a
513
          tests subdirectory of the
514
          install tree. 
515
If disk space is scarce then it is possible to make the copy
516
of the install tree for application development purposes, and then
517
use: 
518
$ make clean
519
The build tree will now use up a minimum of disk space — the
520
bulk of what is left consists of configuration header files that
521
you may have edited and hence should not be deleted automatically.
522
However, it is possible to rebuild the system at any time without
523
re-invoking ecosconfig, just by
524
running make again. 
525
Under exceptional circumstances it may be necessary to run make
526
clean for other reasons, such as when a new release
527
of the toolchain is installed. The toolchain includes a number of
528
header files which are closely tied to the compiler, for example limits.h,
529
and these header files are not and should not be duplicated by eCos.
530
The makefiles perform header file dependency analysis, so that when
531
a header file is changed all affected sources will be rebuilt during
532
the next make. This is very useful
533
when the configuration header files are changed, but it also means
534
that a build tree containing information about the locations of
535
header files must be rebuilt. If a new version of the toolchain
536
is installed and the old version is removed then this location information
537
is no longer accurate, and make will
538
complain that certain dependencies cannot be satisfied. Under such circumstances
539
it is necessary to do a make clean first. 
540
541
542
Packages
543
eCos is a component architecture. The system comes as a
544
          number of packages which can be
545
          enabled or disabled as required, and new packages can be
546
          added as they become available. Unfortunately, the packages
547
          are not completely independent: for example the µITRON
548
          compatibility package relies almost entirely on
549
          functionality provided by the kernel package, and it would
550
          not make sense to try to build µITRON if the kernel
551
          was disabled. The C library has fewer dependencies: some
552
          parts of the C library rely on kernel functionality, but it
553
          is possible to disable these parts and thus build a system
554
          that has the C library but no kernel. The
555
        ecosconfig tool has the capability of
556
            checking that all the dependencies are satisfied, but it
557
            may still be possible to produce configurations that will
558
            not build or (conceivably) that will build but not run.
559
            Developers should be aware of this and take appropriate
560
            care.
561
By default, ecosconfig will
562
include all packages that are appropriate for the specified hardware
563
in the configuration. The common HAL package and
564
the eCos infrastructure must be present in every configuration. In
565
addition, it is always necessary to have one architectural HAL package
566
and one platform HAL package. Other packages are optional, and can
567
be added or removed from a configuration as required.
568
The application may not require all of the packages; for example,
569
it might not need the µITRON compatibility
570
package, or the floating point support provided by the math library.
571
There is a slight overhead when eCos is built because the packages
572
will get compiled, and there is also a small disk space penalty.
573
However, any unused facilities will get stripped out at link-time,
574
so having redundant packages will not affect the final executable. 
575
576
577
Coarse-grained Configuration
578
Coarse-grained configuration of
579
          an eCos system means making configuration changes using the
580
          ecosconfig tool. These changes
581
          include: 
582
583
584
switching to different target hardware
585
586
587
switching to a different template
588
589
590
adding or removing a package
591
592
593
changing the version of a package
594
595
596
Whenever ecosconfig generates or
597
          updates an eCos configuration, it generates a configuration
598
          save file.
599
Suppose that the configuration was first created using
600
          the following command line: 
601
$ ecosconfig new stdeval1
602
To change the target hardware to the Cogent CMA28x
603
          PowerPC board, the following command would be needed:
604
        
605
$ ecosconfig target cma28x
606
To switch to the PowerPC simulator instead: 
607
$ ecosconfig target psim
608
As the hardware changes, hardware-related packages such as
609
the HAL packages and device drivers will be added to and removed
610
from the configuration as appropriate. 
611
To remove any package from the current configuration, use
612
the remove command: 
613
$ ecosconfig remove uitron
614
You can disable multiple packages using multiple arguments,
615
for example: 
616
$ ecosconfig remove uitron libm
617
If this turns out to have been a mistake then you can
618
          re-enable one or more packages with the
619
          add command: 
620
$ ecosconfig add libm
621
Changing the desired version for a package is also
622
          straightforward:
623
$ ecosconfig version v2_1 kernel
624
It is necessary to regenerate the build tree and header
625
          files following any changes to the configuration before
626
          rebuilding eCos:
627
$ ecosconfig tree
628
629
630
Fine-grained Configuration
631
ecosconfig only provides
632
          coarse-grained control over the configuration: the hardware,
633
          the template and the packages that should be built. Unlike
634
          the Configuration Tool,
635
          ecosconfig does not provide
636
          any facilities for manipulating finer-grained configuration options such as how many
638
          priority levels the scheduler should support. There are
639
          hundreds of these options, and manipulating them by means of
640
          command line arguments would not be sensible. 
641
In the current system fine-grained configuration options may
642
be manipulated by manual editing of the configuration file. When
643
a file has been edited in this way, the ecosconfig tool
644
should be used to check the configuration for any conflicts which
645
may have been introduced:
646
$ ecosconfig check
647
The check command will list
648
all conflicts and will also rewrite the configuration file, propagating
649
any changes which affect other options. The user may choose to resolve
650
the conflicts either by re-editing the configuration file manually
651
or by invoking the inference engine using the resolve command:
652
$ ecosconfig resolve
653
The  resolve command will
654
list all conflicts which can be resolved and save the resulting changes
655
to the configuration.
656
It is necessary to regenerate the build tree and header files
657
following any changes to the configuration before rebuilding eCos:
658
$ ecosconfig tree
659
All the configuration options and their descriptions are listed
660
in the eCos Reference Manual. 
661
662
663
Editing an <productname>eCos</productname> Savefile
664
The eCos configuration information is held in a single
665
          savefile, typically ecos.ecc, which can
666
          be generated by either the GUI configuration tool or by the
667
          command line ecosconfig tool. The file
668
          normally exists at the top level of the build tree. It is a
669
          text file, allowing the various configurations options to be
670
          edited inside a suitable text editor or by other programs or
671
          scripts, as well as in the GUI config tool.
672
An eCos savefile is actually a script in the Tcl programming
673
language, so any modifications to the file need to preserve Tcl
674
syntax. For most configuration options, any modifications will be
675
trivial and there is no need to worry about Tcl syntax. For example,
676
changing a 1 to a 0 to disable an option.  For more complicated
677
options, for example CYGDAT_UITRON_TASK_EXTERNS,
678
which involves some lines of C code, more care has
679
to be taken. If an edited savefile is no longer a valid Tcl script
680
then the configuration tools will be unable to read back the data
681
for further processing, for example to generate a build tree. An
682
outline of Tcl syntax is given below. One point worth noting here
683
is that a line that begins with a “#” is
684
usually a comment, and the bulk of an eCos savefile actually consists
685
of such comments, to make it easier to edit.
686
687
Header
688
An eCos savefile begins with a header, which typically
689
            looks something like this:
690
# eCos saved configuration
691
# ---- commands --------------------------------------------------------
692
# This section contains information about the savefile format.
693
# It should not be edited. Any modifications made to this section
694
# may make it impossible for the configuration tools to read
695
# the savefile.
696
 
697
cdl_savefile_version 1;
698
cdl_savefile_command cdl_savefile_version {};
699
cdl_savefile_command cdl_savefile_command {};
700
cdl_savefile_command
701
cdl_configuration { description hardware template package };
702
cdl_savefile_command cdl_package { value_source user_value wizard_value inferred_value };
703
cdl_savefile_command cdl_component { value_source user_value wizard_value inferred_value };
704
cdl_savefile_command cdl_option { value_source user_value wizard_value inferred_value };
705
cdl_savefile_command cdl_interface { value_source user_value wizard_value inferred_value };
706
      
707
This section of the savefile is intended for use by the
708
        configuration system, and should not be edited. If this
709
        section is edited then the various configuration tools may no
710
        longer be able to read in the modified savefile.
711
712
713
Toplevel Section
714
The header is followed by a section that defines the
715
            configuration as a whole. A typical example would
716
            be:
717
# ---- toplevel --------------------------------------------------------
718
# This section defines the toplevel configuration object. The only
719
# values that can be changed are the name of the configuration and
720
# the description field. It is not possible to modify the target,
721
# the template or the set of packages simply by editing the lines
722
# below because these changes have wide-ranging effects. Instead
723
# the appropriate tools should be used to make such modifications.
724
 
725
cdl_configuration eCos {
726
description ““ ;
727
 
728
# These fields should not be modified.
729
hardware    pid ;
730
template    uitron ;
731
package -hardware CYGPKG_HAL_ARM current ;
732
package -hardware CYGPKG_HAL_ARM_PID current ;
733
package -hardware CYGPKG_IO_SERIAL current ;
734
package -template CYGPKG_HAL current ;
735
package -template CYGPKG_IO current ;
736
package -template CYGPKG_INFRA current ;
737
package -template CYGPKG_KERNEL current ;
738
package -template CYGPKG_UITRON current ;
739
package -template CYGPKG_LIBC current ;
740
package -template CYGPKG_LIBM current ;
741
package -template CYGPKG_DEVICES_WALLCLOCK current ;
742
package -template CYGPKG_ERROR current ;
743
};
744
      
745
This section allows the configuration tools to reload the
746
various packages that make up the configuration. Most of the information
747
should not be edited. If it is necessary to add a new package or
748
to remove an existing one then the appropriate tools should be used
749
for this, for example:
750
$ ecosconfig remove CYGPKG_LIBM
751
There are two fields which can be edited. Configurations have
752
a name; in this case eCos. They can also have a description, which
753
is some arbitrary text. The configuration tools do not make use
754
of these fields, they exist so that users can store additional information
755
about a configuration.
756
757
758
Conflicts Section
759
The toplevel section is followed by details of all the
760
            conflicts (if any) in the configuration, for
761
            example:
762
# ---- conflicts -------------------------------------------------------
763
# There are 2 conflicts.
764
#
765
# option CYGNUM_LIBC_TIME_DST_DEFAULT_OFFSET
766
#   Property LegalValues
767
#   Illegal current value 100000
768
#   Legal values are: -90000 to 90000
769
#
770
# option CYGSEM_LIBC_TIME_CLOCK_WORKING
771
#   Property Requires
772
#   Requires constraint not satisfied: CYGFUN_KERNEL_THREADS_TIMER
773
          
774
When editing a configuration you may end up with something
775
that is invalid. Any problems in the configuration will be reported
776
in the conflicts section. In this case there are two conflicts.
777
The option CYGNUM_LIBC_TIME_DST_DEFAULT_OFFSET has
778
been given an illegal value: typically this would be fixed by searching
779
for the definition of that option later on in the savefile and modifying
780
the value. The second conflict is more interesting, an unsatisfied requires constraint.
781
Configuration options are not independent: disabling some functionality
782
in, say, the kernel, can have an impact elsewhere; in this case
783
the C library. The various dependencies between the options are
784
specified by the component developers and checked by the configuration
785
system. In this case there are two obvious ways in which the conflict could
786
be resolved: re-enabling CYGFUN_KERNEL_THREADS_TIMER,
787
or disabling CYGSEM_LIBC_TIME_CLOCK_WORKING.
788
Both of these options will be listed later on in the file.
789
Some care has to be taken when modifying configuration options,
790
to avoid introducing new conflict. For instance it is possible that
791
there might be other options in the system which have a dependency
792
on CYGSEM_LIBC_TIME_CLOCK_WORKING,
793
so disabling that option may not be the best way to resolve the
794
conflict. Details of all such dependencies are provided in the appropriate
795
places in the savefile.
796
It is not absolutely required that a configuration be conflict-free
797
before generating a build tree and building eCos. It is up to the
798
developers of each component to decide what would happen if an attempt
799
is made to build eCos while there are still conflicts. In serious
800
cases there is likely to be a compile-time failure, or possibly
801
a link-time failure. In less serious cases the system may build
802
happily and the application can be linked with the resulting library,
803
but the component may not quite function as intended - although
804
it may still be good enough for the specific needs of the application.
805
It is also possible that everything builds and links, but once in
806
a while the system will unaccountably crash. Using a configuration
807
that still has conflicts is done entirely at the user’s
808
risk.
809
810
811
Data Section
812
The bulk of the savefile lists the various packages,
813
            components, and options, including their values and the
814
            various dependencies. A number of global options come
815
            first, especially those related to the build process such
816
            as compiler flags. These are followed by the various
817
            packages, and the components and options within those
818
            packages, in order.
819
Packages, components and options are organized in a
820
            hierarchy. If a particular component is disabled then all
821
            options and sub-components below it will be inactive: any
822
            changes made to these will have no effect. The savefile
823
            contains information about the hierarchy in the form of
824
            comments, for example:
825
cdl_package CYGPKG_KERNEL ...
826
# >
827
cdl_component CYGPKG_KERNEL_EXCEPTIONS ...
828
# >
829
cdl_option CYGSEM_KERNEL_EXCEPTIONS_DECODE ...
830
cdl_option CYGSEM_KERNEL_EXCEPTIONS_GLOBAL ...
831
# <
832
cdl_component CYGPKG_KERNEL_SCHED ...
833
# >
834
cdl_option CYGSEM_KERNEL_SCHED_MLQUEUE ...
835
cdl_option CYGSEM_KERNEL_SCHED_BITMAP ...
836
# <
837
# <
838
          
839
This corresponds to the following hierarchy:
840
 CYGPKG_KERNEL
841
   CYGPKG_KERNEL_EXCEPTIONS
842
     CYGSEM_KERNEL_EXCEPTIONS_DECODE
843
     CYGSEM_KERNEL_EXCEPTIONS_GLOBAL
844
   CYGPKG_KERNEL_SCHED
845
     CYGSEM_KERNEL_SCHED_MLQUEUE
846
     CYGSEM_KERNEL_SCHED_BITMAP
847
          
848
Providing the hierarchy information in this way allows
849
            programs or scripts to analyze the savefile and readily
850
            determine the hierarchy. It could also be used by a
851
            sufficiently powerful editor to support structured editing
852
            of eCos savefiles. The information is not used by the
853
            configuration tools themselves since they obtain the
854
            hierarchy from the original CDL scripts.
855
Each configurable entity is preceded by a comment, of
856
            the following form:
857
# Kernel schedulers
858
# doc: ref/ecos-ref/ecos-kernel-overview.html#THE-SCHEDULER
859
# The eCos kernel provides a choice of schedulers. In addition
860
# there are a number of configuration options to control the
861
# detailed behaviour of these schedulers.
862
cdl_component CYGPKG_KERNEL_SCHED {
863
...
864
};
865
          
866
This provides a short textual alias
867
            Kernel schedulers for the
868
            component. If online documentation is available for the
869
            configurable entity then this will come next. Finally
870
            there is a short description of the entity as a whole. All
871
            this information is provided by the component
872
            developers.
873
Each configurable entity takes the form:
874
<type> <name> {
875
     <data>
876
};
877
Configurable entities may not be active. This can be either
878
because the parent is disabled or inactive, or because there are
879
one or more active_if properties. Modifying
880
the value of an inactive entity has no effect on the configuration,
881
so this information is provided first:
882
883
cdl_option CYGSEM_KERNEL_EXCEPTIONS_DECODE {
884
# This option is not active
885
# The parent CYGPKG_KERNEL_EXCEPTIONS is disabled
886
...
887
};
888
 
889
...
890
 
891
cdl_option CYGIMP_IDLE_THREAD_YIELD {
892
# This option is not active
893
# ActiveIf constraint: (CYGNUM_KERNEL_SCHED_PRIORITIES == 1)
894
#     CYGNUM_KERNEL_SCHED_PRIORITIES == 32
895
#   --> 0
896
...
897
};
898
 
899
900
For CYGIMP_IDLE_THREAD_YIELD the
901
savefile lists the expression that must be satisfied if the option
902
is to be active, followed by the current value of all entities that
903
are referenced in the expression, and finally the result of evaluating
904
that expression.
905
Not all options are directly modifiable in the savefile. First,
906
the value of packages (which is the version of that package loaded
907
into the configuration) cannot be modified here.
908
909
 
910
cdl_package CYGPKG_KERNEL {
911
# Packages cannot be added or removed, nor can their version be changed,
912
# simply by editing their value. Instead the appropriate configuration
913
# should be used to perform these actions.
914
...
915
};
916
 
917
918
The version of a package can be changed using e.g.:    
919
$ ecosconfig version 1.3 CYGPKG_KERNEL
920
Even though a package’s value cannot be modified
921
here, it is still important for the savefile to contain the details.
922
In particular packages may impose constraints on other configurable
923
entities and may be referenced by other configurable entities. Also
924
it would be difficult to understand or extract the configuration’s
925
hierarchy if the packages were not listed in the appropriate places
926
in the savefile.
927
Some components (or, conceivably, options) do not have any
928
associated data. Typically they serve only to introduce another
929
level in the hierarchy, which can be useful in the context of the
930
GUI configuration tool.
931
932
 
933
cdl_component CYGPKG_HAL_COMMON_INTERRUPTS {
934
# There is no associated value.
935
};
936
 
937
938
Other components or options have a calculated value. These
939
are not user-modifiable, but typically the value will depend on
940
other options which can be modified. Such calculated options can
941
be useful when controlling what gets built or what ends up in the
942
generated configuration header files. A calculated value may also
943
effect other parts of the configuration, for instance, via a requires constraint.
944
945
 
946
cdl_option BUFSIZ {
947
# Calculated value: CYGSEM_LIBC_STDIO_WANT_BUFFERED_IO ? CYGNUM_LIBC_STDIO_BUFSIZE : 0
948
#     CYGSEM_LIBC_STDIO_WANT_BUFFERED_IO == 1
949
#     CYGNUM_LIBC_STDIO_BUFSIZE == 256
950
# Current_value: 256
951
};
952
 
953
954
A special type of calculated value is the interface.
955
The value of an interface is the number of active and enabled options
956
which implement that interface. Again the value
957
of an interface cannot be modified directly; only by modifying the
958
options which implement the interface. However, an interface can
959
be referenced by other parts of the configuration. 
960
cdl_interface CYGINT_KERNEL_SCHEDULER {
961
# Implemented by CYGSEM_KERNEL_SCHED_MLQUEUE, active, enabled
962
# Implemented by CYGSEM_KERNEL_SCHED_BITMAP, active, disabled
963
# This value cannot be modified here.
964
# Current_value: 1
965
# Requires: 1 == CYGINT_KERNEL_SCHEDULER
966
#     CYGINT_KERNEL_SCHEDULER == 1
967
#   --> 1
968
 
969
970
# The following properties are affected by this value
971
# interface CYGINT_KERNEL_SCHEDULER
972
#     Requires: 1 == CYGINT_KERNEL_SCHEDULER
973
}; 
974
If the configurable entity is modifiable then there will be
975
lines like the following:
976
977
cdl_option CYGSEM_KERNEL_SCHED_MLQUEUE {
978
...
979
# Flavor: bool
980
# No user value, uncomment the following line to provide one.
981
# user_value 1
982
# value_source default
983
# Default value: 1
984
...
985
};
986
 
987
988
Configurable entities can have one of four different flavors:
989
none, bool, data and booldata. Flavor none indicates that there
990
is no data associated with the entity, typically it just acts as
991
a placeholder in the overall hierarchy. Flavor bool is the most
992
common, it is a simple yes-or-no choice. Flavor data is for more
993
complicated configuration choices, for instance the size of an array
994
or the name of a device. Flavor booldata is a combination of bool
995
and data: the option can be enabled or disabled, and there is some
996
additional data associated with the option as well.
997
In the above example the user has not modified this particular
998
option, as indicated by the comment and by the commented-out user_value line.
999
To disable this option the file should be edited to:
1000
1001
 
1002
cdl_option CYGSEM_KERNEL_SCHED_MLQUEUE {
1003
...
1004
# Flavor: bool
1005
# No user value, uncomment the following line to provide one.
1006
user_value 0
1007
# value_source default
1008
# Default value: 1
1009
...
1010
}
1011
 
1012
1013
The comment preceding the user_value
1014
0 line can be removed if desired, otherwise it
1015
will be removed automatically the next time the file is read and
1016
updated by the configuration tools.
1017
Much the same process should be used for options with the
1018
data flavor, for example:
1019
1020
cdl_option CYGNUM_LIBC_TIME_DST_DEFAULT_OFFSET {
1021
# Flavor: data
1022
# No user value, uncomment the following line to provide one.
1023
# user_value 3600
1024
# value_source default
1025
# Default value: 3600
1026
# Legal values: -90000 to 90000
1027
};
1028
 
1029
1030
can be changed to:
1031
1032
 
1033
cdl_option CYGNUM_LIBC_TIME_DST_DEFAULT_OFFSET {
1034
# Flavor: data
1035
user_value 7200
1036
# value_source default
1037
# Default value: 3600
1038
# Legal values: -90000 to 90000 };
1039
 
1040
1041
Note that the original text provides the default value in
1042
the user_value comment,
1043
on the assumption that the desired new value is likely to be similar
1044
to the default value. The value_source comment
1045
does not need to be updated, it will be fixed up if the savefile
1046
is fed back into the configuration system and regenerated.
1047
For options with the booldata flavor, the user_value line
1048
needs take two arguments. The first argument is for the boolean
1049
part, the second for the data part. For example:
1050
1051
cdl_component CYGNUM_LIBM_COMPATIBILITY {
1052
# Flavor: booldata
1053
# No user value, uncomment the following line to provide one.
1054
# user_value 1 POSIX
1055
# value_source default
1056
# Default value: 1 POSIX
1057
# Legal values:  “POSIX” “IEEE” “XOPEN” “SVID”
1058
...
1059
};
1060
 
1061
1062
could be changed to:
1063
1064
cdl_component CYGNUM_LIBM_COMPATIBILITY {
1065
# Flavor: booldata
1066
user_value 1 IEEE
1067
# value_source default
1068
# Default value: 1 POSIX
1069
# Legal values:  “POSIX” “IEEE” “XOPEN” “SVID”
1070
...
1071
};
1072
 
1073
1074
or alternatively, if the whole component should be disabled,
1075
to:
1076
1077
cdl_component CYGNUM_LIBM_COMPATIBILITY {
1078
# Flavor: booldata
1079
user_value 0 POSIX
1080
# value_source default
1081
# Default value: 1 POSIX
1082
# Legal values:  “POSIX” “IEEE” “XOPEN” “SVID”
1083
...
1084
};
1085
 
1086
1087
Some options take values that span multiple lines. An example
1088
would be:
1089
1090
 
1091
cdl_option CYGDAT_UITRON_MEMPOOLVAR_INITIALIZERS {
1092
# Flavor: data
1093
# No user value, uncomment the following line to provide one.
1094
# user_value \
1095
# “CYG_UIT_MEMPOOLVAR( vpool1, 2000 ), \\
1096
#  CYG_UIT_MEMPOOLVAR( vpool2, 2000 ), \\
1097
#  CYG_UIT_MEMPOOLVAR( vpool3, 2000 ),”
1098
# value_source default
1099
# Default value: \
1100
#     “CYG_UIT_MEMPOOLVAR( vpool1, 2000 ), \\
1101
#      CYG_UIT_MEMPOOLVAR( vpool2, 2000 ), \\
1102
#      CYG_UIT_MEMPOOLVAR( vpool3, 2000 ),”
1103
};
1104
 
1105
1106
Setting a user value for this option involves uncommenting
1107
and modifying all relevant lines, for example:
1108
1109
 
1110
cdl_option CYGDAT_UITRON_MEMPOOLVAR_INITIALIZERS {
1111
# Flavor: data
1112
user_value \
1113
“CYG_UIT_MEMPOOLVAR( vpool1, 4000 ), \\
1114
CYG_UIT_MEMPOOLVAR( vpool2, 4000 ),”
1115
# value_source default
1116
# Default value: \
1117
#     “CYG_UIT_MEMPOOLVAR( vpool1, 2000 ), \\
1118
#      CYG_UIT_MEMPOOLVAR( vpool2, 2000 ), \\
1119
#      CYG_UIT_MEMPOOLVAR( vpool3, 2000 ),”
1120
};
1121
 
1122
1123
In such cases appropriate care has to be taken to preserve
1124
Tcl syntax, as discussed below.
1125
The configuration system has the ability to keep track of
1126
          several different values for any given option. All options
1127
          start off with a default value, in other words their value
1128
          source is set to default. If a
1129
          configuration involves conflicts and the configuration
1130
          system’s inference engine is allowed to resolve these
1131
          automatically then it may provide an
1132
          inferred value instead, for
1133
          example:
1134
1135
 
1136
cdl_option CYGMFN_KERNEL_SYNCH_CONDVAR_TIMED_WAIT {
1137
# Flavor: bool
1138
# No user value, uncomment the following line to provide one.
1139
# user_value 1
1140
# The inferred value should not be edited directly.
1141
inferred_value 0
1142
# value_source inferred
1143
# Default value: 1
1144
...
1145
};
1146
 
1147
1148
Inferred values are calculated by the configuration system
1149
and should not be edited by the user. If the inferred value is not
1150
correct then a user value should be substituted instead:
1151
1152
 
1153
cdl_option CYGMFN_KERNEL_SYNCH_CONDVAR_TIMED_WAIT {
1154
# Flavor: bool
1155
user_value 1
1156
# The inferred value should not be edited directly.
1157
inferred_value 0
1158
# value_source inferred
1159
# Default value: 1
1160
...
1161
}; 
1162
The inference engine will not override a user value with an
1163
inferred one. Making a change like this may well re-introduce a
1164
conflict, since the inferred value was only calculated to resolve
1165
a conflict. Another run of the inference engine may find a different
1166
and more acceptable way of resolving the conflict, but this is not guaranteed
1167
and it may be up to the user to examine the various dependencies
1168
and work out an acceptable solution.
1169
Inferred values are listed in the savefile because the exact
1170
inferred value may depend on the order in which changes were made
1171
and conflicts were resolved. If the inferred values were absent
1172
then it is possible that reloading a savefile would not exactly
1173
restore the configuration. Default values on the other hand are
1174
entirely deterministic so there is no actual need for the values
1175
to be listed in the savefile. However, the default value can be
1176
very useful information so it is provided in a comment.
1177
Occasionally the user will want to do some experimentation,
1178
and temporarily switch an option from a user value back to a default
1179
or inferred one to see what the effect would be. This could be achieved
1180
by simply commenting out the user value. For instance, if the current
1181
savefile contains:
1182
1183
cdl_option CYGMFN_KERNEL_SYNCH_CONDVAR_TIMED_WAIT {
1184
# Flavor: bool
1185
user_value 1
1186
# The inferred value should not be edited directly.
1187
inferred_value 0
1188
# value_source user
1189
# Default value: 1
1190
...
1191
};
1192
 
1193
1194
then the inferred value could be restored by commenting out
1195
or removing the user_value line:
1196
1197
cdl_option CYGMFN_KERNEL_SYNCH_CONDVAR_TIMED_WAIT {
1198
# Flavor: bool
1199
# user_value 1
1200
# The inferred value should not be edited directly.
1201
inferred_value 0
1202
# value_source user
1203
# Default value: 1
1204
...
1205
};
1206
 
1207
1208
This is fine for simple values. However if the value is complicated
1209
then there is a problem: commenting out the user_value line
1210
or lines means that the user value becomes invisible to the configuration system,
1211
so if the savefile is loaded and then regenerated the information
1212
will be lost. An alternative approach is to keep the user_value but
1213
explicitly set the value_source line,
1214
for example:
1215
1216
 
1217
cdl_option CYGMFN_KERNEL_SYNCH_CONDVAR_TIMED_WAIT {
1218
# Flavor: bool
1219
user_value 1
1220
# The inferred value should not be edited directly.
1221
inferred_value 0
1222
value_source inferred
1223
# Default value: 1
1224
...
1225
};
1226
 
1227
1228
In this case the configuration system will use the inferred
1229
value for the purposes of dependency analysis etc., even though
1230
a user value is present. To restore the user value the value_source line
1231
can be commented out again. If there is no explicit value_source then
1232
the configuration system will just use the highest priority one:
1233
the user value if it exists; otherwise the inferred value if it
1234
exists; otherwise the default value which always exists.
1235
The default value for an option can be a simple constant,
1236
or it can be an expression involving other options. In the latter
1237
case the expression will be listed, together with the values for
1238
all options referenced in the expression and the current result
1239
of evaluating that expression. This is for informational purposes
1240
only, the default value is always recalculated deterministically
1241
when loading in a savefile.
1242
1243
 
1244
cdl_option CYGBLD_GLOBAL_COMMAND_PREFIX {
1245
# Flavor: data
1246
# No user value, uncomment the following line to provide one.
1247
# user_value arm-elf
1248
# value_source default
1249
# Default value:  CYGHWR_THUMB ? “thumb-elf” : “arm-elf”
1250
#     CYGHWR_THUMB == 0
1251
#   --> arm-elf
1252
};
1253
 
1254
1255
For options with the data or booldata flavor, there are likely
1256
to be constraints on the possible values. If the value is supposed
1257
to be a number in a given range and a user value of “hello
1258
world” is provided instead then there
1259
are likely to be compile-time failures. Component developers can
1260
specify constraints on the legal values, and these will be listed
1261
in the savefile.
1262
1263
cdl_option X_TLOSS {
1264
# Flavor: data
1265
# No user value, uncomment the following line to provide one.
1266
# user_value 1.41484755040569E+16
1267
# value_source default
1268
# Default value: 1.41484755040569E+16
1269
# Legal values: 1 to 1e308
1270
};
1271
 
1272
1273
cdl_component CYGNUM_LIBM_COMPATIBILITY {
1274
# Flavor: booldata
1275
# No user value, uncomment the following line to provide one.
1276
# user_value 1 POSIX
1277
# value_source default
1278
# Default value: 1 POSIX
1279
# Legal values:  “POSIX” “IEEE” “XOPEN” “SVID”
1280
...
1281
};
1282
 
1283
1284
In some cases the legal values list may be an expression involving
1285
other options. If so then the current values of the referenced options
1286
will be listed, together with the result of evaluating the list
1287
expression, just as for default value expressions.
1288
If an illegal value is provided then this will result in a
1289
conflict, listed in the conflicts section of the savefile. For more
1290
complicated options a simple legal values list is not sufficient
1291
to allow the current value to be validated, and the configuration
1292
system will be unable to flag conflicts. This issue will be addressed in
1293
future releases of the configuration system.
1294
Following the value-related fields for a given option, any requires constraints belonging
1295
to this option will be listed. These constraints are only effective
1296
if the option is active and, for bool and booldata flavors, enabled.
1297
If some aspect of eCos functionality is inactive or disabled then
1298
it cannot impose any constraints on the rest of the system. As usual,
1299
the full expression will be listed followed by the current values
1300
of all options that are referenced and the result of evaluating
1301
the expression:
1302
1303
 
1304
cdl_option CYGSEM_LIBC_TIME_TIME_WORKING {
1305
...
1306
# Requires: CYGPKG_DEVICES_WALLCLOCK
1307
#     CYGPKG_DEVICES_WALLCLOCK == current
1308
#   --> 1
1309
};
1310
 
1311
1312
When modifying the value of an option it is useful to know
1313
not only what constraints the option imposes on the rest of the
1314
system but also what other options in the system depend in some
1315
way on this one. The savefile provides this information:
1316
cdl_option CYGFUN_KERNEL_THREADS_TIMER {
1317
...
1318
# The following properties are affected by this value
1319
# option CYGMFN_KERNEL_SYNCH_CONDVAR_TIMED_WAIT
1320
#     Requires: CYGFUN_KERNEL_THREADS_TIMER
1321
# option CYGIMP_UITRON_STRICT_CONFORMANCE
1322
#     Requires: CYGFUN_KERNEL_THREADS_TIMER
1323
# option CYGSEM_LIBC_TIME_CLOCK_WORKING
1324
#     Requires: CYGFUN_KERNEL_THREADS_TIMER
1325
};
1326
 
1327
1328
1329
1330
Tcl Syntax
1331
eCos savefiles are implemented as Tcl scripts, and are read
1332
in by running the data through a standard Tcl interpreter that has
1333
been extended with a small number of additional commands such as cdl_option and cdl_configuration.
1334
In many cases this is an implementation detail that can be safely
1335
ignored while editing a savefile: simply replacing a 1 with
1336
a 0 to disable some functionality
1337
is not going to affect whether or not the savefile is still a valid
1338
Tcl script and can be processed by a Tcl interpreter. However, there
1339
are more complicated cases where an understanding of Tcl syntax
1340
is at least desirable, for example:
1341
1342
 
1343
cdl_option CYGDAT_UITRON_MEMPOOLVAR_EXTERNS {
1344
     # Flavor: data
1345
     user_value \
1346
      “static char vpool1\[ 2000 \], \\
1347
      vpool2\[ 2000 \], \\
1348
       vpool3\[ 2000 \];”
1349
# value_source default
1350
# Default value: \
1351
     #     “static char vpool1\[ 2000 \], \\
1352
     #      vpool2\[ 2000 \], \\
1353
    #      vpool3\[ 2000 \];”
1354
};
1355
 
1356
1357
The backslash at the end of the user_value line
1358
is processed by the Tcl interpreter as a line continuation character.
1359
The quote marks around the user data are also interpreted by the
1360
Tcl interpreter and serve to turn the entire data field into a single
1361
argument. The backslashes preceding the opening and closing square
1362
brackets prevent the Tcl interpreter from treating these characters
1363
specially, otherwise there would be an attempt at command
1364
substitution as described below. The double backslashes
1365
at the end of each line of the data will be turned into a single
1366
backslash by the Tcl interpreter, rather than escaping the newline
1367
character, so that the actual data seen by the configuration system
1368
is:
1369
1370
 
1371
static char vpool1[ 2000 ], \
1372
      vpool2[ 2000 ], \
1373
      vpool3[ 2000 ];
1374
 
1375
1376
This is of course the data that should end up in the µITRON
1377
configuration header file. The opening and closing braces surrounding
1378
the entire body of the option data are also significant and cause
1379
this body to be passed as a single argument to the cdl_option command.
1380
The closing semicolon is optional in this example, but provides
1381
a small amount of additional robustness if the savefile is edited
1382
such that it is no longer a valid Tcl script. If the data contained
1383
any $ characters then
1384
these would have to be treated specially as well, via a backslash escape.
1385
In spite of what all the above might seem to suggest, Tcl
1386
is actually a very simple yet powerful scripting language: the syntax
1387
is defined by just eleven rules. On occasion this simplicity means
1388
that Tcl’s behaviour is subtly different from other languages,
1389
which can confuse newcomers.
1390
When the Tcl interpreter is passed some data such as puts
1391
Hello, it splits this data into a command and its
1392
arguments. The command will be terminated by a newline or by a semicolon,
1393
unless one of the quoting mechanisms is used. The command and each
1394
of its arguments are separated by white space. So in the following
1395
example:
1396
puts Hello
1397
set x 42 
1398
will result in two separate commands being executed. The first
1399
command is puts and is passed a
1400
single argument, Hello. The second
1401
command is set and is passed two
1402
arguments, x and 42.
1403
The intervening newline character serves to terminate the first
1404
command, and a semi-colon separator could be used instead: 
1405
puts Hello;set x 42
1406
Any white space surrounding the semicolon is just ignored
1407
because it does not serve to separate arguments.
1408
Now consider the following:
1409
set x Hello world
1410
This is not valid Tcl. It is an attempt to invoke the set command
1411
with three arguments: x, Hello,
1412
and world. The set only
1413
takes two arguments, a variable name and a value, so it is necessary
1414
to combine the data into a single argument by quoting:
1415
set x “Hello world”
1416
When the Tcl interpreter encounters the first quote character
1417
it treats all subsequent data up to but not including the closing
1418
quote as part of the current argument. The quote marks are removed
1419
by the interpreter, so the second argument passed to the set command
1420
is just Hello world without the
1421
quote characters. This can be significant in the context of eCos savefiles.
1422
For instance, consider the following configuration option:
1423
1424
 
1425
cdl_option CYGDAT_LIBC_STDIO_DEFAULT_CONSOLE {
1426
# Flavor: data
1427
# No user value, uncomment the following line to provide one.
1428
# user_value “\”/dev/ttydiag\””
1429
# value_source default
1430
# Default value: “\”/dev/ttydiag\””
1431
};
1432
 
1433
1434
The desired value of the configuration option should be a
1435
valid C string, complete with quote characters. If the savefile
1436
was edited to: 
1437
1438
 
1439
cdl_option CYGDAT_LIBC_STDIO_DEFAULT_CONSOLE {
1440
# Flavor: data
1441
user_value “/dev/ttydiag”
1442
# value_source default
1443
# Default value: “\”/dev/ttydiag\””
1444
};
1445
 
1446
1447
then the Tcl interpreter would remove the quote marks when
1448
the savefile is read back in, so the option’s value would
1449
not have any quote marks and would not be a valid C string. The
1450
configuration system is not yet able to perform the required validation
1451
so the following #define would
1452
be generated in the configuration header file:
1453
#define CYGDAT_LIBC_STDIO_DEFAULT_CONSOLE /dev/ttydiag 
1454
This is likely to cause a compile-time failure when building
1455
eCos.
1456
A quoted argument continues until the closing quote character
1457
is encountered, which means that it can span multiple lines. This
1458
can also be encountered in eCos savefiles, for instance, in the CYGDAT_UITRON_MEMPOOLVAR_EXTERNS example
1459
mentioned earlier. Newline or semicolon characters do not terminate
1460
the current command in such cases.
1461
The Tcl interpreter supports much the same forms of backslash
1462
substitution as other common programming languages. Some backslash
1463
sequences such as \n will
1464
be replaced by the appropriate character. The sequence \\ will
1465
be replaced by a single backslash. A backslash at the very end of
1466
a line will cause that backslash, the newline character, and any
1467
white space at the start of the next line to be replaced by a single
1468
space. Hence the following two Tcl commands are equivalent:
1469
puts  “Hello\nworld\n”
1470
puts \
1471
“Hello
1472
world
1473
1474
In addition to quote and backslash characters, the Tcl interpreter
1475
treats square brackets, the $ character,
1476
and braces specially. Square brackets are used for command substitution,
1477
for example:
1478
puts “The answer is [expr 6 * 9]”
1479
When the Tcl interpreter encounters the square brackets it
1480
will treat the contents as another command that should be executed
1481
first, and the result of executing that is used when continuing
1482
to process the script. In this case the Tcl interpreter will execute
1483
the command expr 6 * 9,
1484
yielding a result of 54, and then the Tcl interpreter will execute
1485
puts “The answer is 54”. It should be noted that
1486
the interpreter contains only one level of substitution: if the
1487
result of performing command substitution performs further special
1488
characters such as square brackets then these will not be treated
1489
specially.
1490
Command line substitution is very unlikely to prove useful
1491
in the context of an eCos savefile, but it is part of the Tcl language
1492
and hence cannot be easily suppressed while reading in a savefile.
1493
As a result care has to be taken when savefile data involves square
1494
brackets. Consider the following:
1495
1496
 
1497
cdl_option CYGDAT_UITRON_MEMPOOLFIXED_EXTERNS {
1498
     ...
1499
     user_value \
1500
“static char fpool1[ 2000 ],
1501
fpool2[ 2000 ];”
1502
     ...
1503
};
1504
1505
The Tcl interpreter will interpret the square brackets as
1506
an attempt at command substitution and hence it will attempt to
1507
execute the command 2000 with no
1508
arguments. No such command is defined by the Tcl language or by
1509
the savefile-related extensions provided by the configuration system,
1510
so this will result in an error when an attempt is made to read
1511
back the savefile. Instead it is necessary to backslash-escape the
1512
square brackets and thus suppress command substitution:
1513
1514
 
1515
cdl_option CYGDAT_UITRON_MEMPOOLFIXED_EXTERNS {
1516
     ...
1517
     user_value \
1518
“static char fpool1\[ 2000 \],
1519
fpool2\[ 2000 \];”
1520
     ...
1521
}; 
1522
Similarly the $ character
1523
is used in Tcl scripts to perform variable substitution:
1524
set x [expr 6 * 9]
1525
puts “The answer is $x” 
1526
Variable substitution, like command substitution, is very
1527
unlikely to prove useful in the context of an eCos savefile. Should
1528
it be necessary to have a $ character
1529
in configuration data then again a backslash escape needs to be
1530
used.
1531
cdl_option FOODAT_MONITOR_PROMPT {
1532
     ...
1533
     user_value “\$ “
1534
     ...
1535
};
1536
Braces are used to collect a sequence of characters into a
1537
single argument, just like quotes. The difference is that variable,
1538
command and backslash substitution do not occur inside braces (with
1539
the sole exception of backslash substitution at the end of a line).
1540
So, for example, the CYGDAT_UITRON_MEMPOOL_EXTERNFIXED_EXTERNS value
1541
could be written as:
1542
cdl_option CYGDAT_UITRON_MEMPOOLFIXED_EXTERNS {
1543
     ...
1544
     user_value \
1545
{static char fpool1[ 2000 ],
1546
fpool2[ 2000 ];}
1547
     ...
1548
};
1549
The configuration system does not use this when generating
1550
savefiles because for simple edits of a savefile by inexperienced
1551
users the use of brace characters is likely to be a little bit more
1552
confusing than the use of quotes.
1553
At this stage it is worth noting that the basic format of
1554
each configuration option in the savefile makes use of braces:
1555
cdl_option <name> {
1556
     ...
1557
};
1558
The configuration system extends the Tcl language with a small
1559
number of additional commands such as cdl_option.
1560
These commands take two arguments, a name and a body, where the
1561
body consists of all the text between the braces. First a check
1562
is made that the specified option is actually present in the configuration.
1563
Then the body is executed in a recursive invocation of the Tcl interpreter,
1564
this time with additional commands such as user_value and value_source.
1565
If, after editing, the braces are not correctly matched up then
1566
the savefile will no longer be a valid Tcl script and errors will
1567
be reported when the savefile is loaded again.
1568
Comments in Tcl scripts are introduced by a hash character #.
1569
However, a hash character only introduces a comment if it occurs
1570
where a command is expected. Consider the following:
1571
# This is a comment
1572
puts “Hello” # world 
1573
The first line is a valid comment, since the hash character
1574
occurs right at the start where a command name is expected. The
1575
second line does not contain a comment. Instead it is an attempt
1576
to invoke the puts command with
1577
three arguments: Hello, # and world.
1578
These are not valid arguments for the puts command
1579
so an error will be raised.
1580
If the second line was rewritten as:
1581
puts “Hello”; # world
1582
then this is a valid Tcl script. The semicolon identifies
1583
the end of the current command, so the hash character occurs at
1584
a point where the next command would start and hence it is interpreted
1585
as the start of a comment.
1586
This handling of comments can lead to subtle behaviour. Consider
1587
the following:
1588
cdl_option WHATEVER {
1589
     # This is a comment }
1590
     user_value 42
1591
     ...
1592
}
1593
Consider the way the Tcl interpreter processes this. The command
1594
name and the first argument do not pose any special difficulties.
1595
The opening brace is interpreted as the start of the next argument,
1596
which continues until a closing brace is encountered. In this case
1597
the closing brace occurs on the second line, so the second argument
1598
passed to cdl_option is \n # This is a comment . This second argument
1599
is processed in a recursive invocation of the Tcl interpreter and
1600
does not contain any commands, just a comment. Toplevel savefile
1601
processing then resumes, and the next command that is encountered
1602
is user_value. Since the
1603
relevant savefile code is not currently processing a configuration
1604
option this is an error. Later on the Tcl interpreter would encounter
1605
a closing brace by itself, which is also an error. Fortunately this
1606
sequence of events is very unlikely to occur when editing generated
1607
savefiles.
1608
This should be sufficient information about Tcl to allow for
1609
safe editing of eCos savefiles. Further information is available
1610
from a wide variety of sources, for example the book Tcl
1611
and the Tk Toolkit by John K Ousterhout.
1612
1613
1614
1615
Editing the Sources
1616
For many users, controlling the packages and
1617
          manipulating the available configuration options will be
1618
          sufficient to create an embedded operating system that meets
1619
          the application's requirements. However, since eCos is
1620
          shipped entirely in source form, it is possible to go
1621
          further when necessary: you can edit the eCos sources themselves. This requires some
1623
          understanding of the way the eCos build system works.
1624
        
1625
The most obvious place to edit the source code is directly
1626
in the component repository. For example, you could
1627
edit the file kernel/&Version;/src/sync/mutex.cxx
1628
to change the way kernel mutexes work, or possibly just to add some
1629
extra diagnostics or assertions. Once the file has been edited,
1630
it is possible to invoke make at
1631
the top level of the build tree and the target library will be rebuilt
1632
as required. A small optimization is possible: the build tree is
1633
largely a mirror of the component repository, so it too will contain
1634
a subdirectory kernel/&Version;;
1635
if make is invoked in this directory
1636
then it will only check for changes to the kernel sources, which
1637
is a bit more efficient than checking for changes throughout the component
1638
repository. 
1639
Editing a file in the component repository is fine if this
1640
tree is used for only one eCos configuration. If the repository
1641
is used for several different configurations, however, and especially
1642
if it is shared by multiple users, then making what may be experimental
1643
changes to the master sources would be a bad idea. The build system provides
1644
an alternative. It is possible to make a copy of the file in the
1645
build tree, in other words copy mutex.cxx from
1646
the kernel/&Version;/src/sync directory
1647
in the component repository to kernel/&Version;/src/sync in
1648
the build tree, and edit the file in the build tree. When make is
1649
invoked it will pick up local copies of any of the sources in preference
1650
to the master versions in the component repository. Once you have
1651
finished modifying the eCos sources you can install the final version
1652
back in the component repository. If the changes were temporary
1653
in nature and only served to aid the debugging process, then you
1654
can discard the modified version of the sources. 
1655
The situation is slightly more complicated for the header
1656
files that a package may export, such as the C library’s stdio.h header
1657
file, which can be found in the directory language/c/libc/&Version;/include.
1658
If such a header file is changed, either directly in the component
1659
repository or after copying it to the build tree, then make must
1660
be invoked at the top level of the build tree. In cases like this
1661
it is not safe to rebuild just the C library because other packages
1662
may depend on the contents of stdio.h. 
1663
1664
1665
Modifying the Memory Layout
1666
Each eCos platform package is supplied with linker script
1667
fragments which describe the location of memory regions on the evaluation
1668
board and the location of memory sections within these regions.
1669
The correct linker script fragment is selected and included in the
1670
eCos linker script target.ld when
1671
eCos is built.
1672
It is not necessary to modify the default memory
1673
layouts in order to start development with eCos. However, it will
1674
be necessary to edit a linker script fragment when the memory map
1675
of the evaluation board is changed. For example, if additional memory
1676
is added, the linker must be notified that the new memory is available
1677
for use. As a minimum, this would involve modifying the length of
1678
the corresponding memory region. Where the available memory is non-contiguous,
1679
it may be necessary to declare a new memory region and reassign
1680
certain linker output sections to the new region.
1681
Linker script fragments and memory layout header files should
1682
be edited within the eCos install tree. They are
1683
located at include/pkgconf/mlt_*.*.
1684
Where multiple start-up types are in use, it will be necessary to
1685
edit multiple linker script fragments and header files. The information
1686
provided in the header file and the corresponding linker script
1687
fragment must always match. A typical linker script fragment is
1688
shown below:
1689
1690
<productname>eCos</productname> linker script fragment
1691
MEMORY
1692
{
1693
 rom : ORIGIN = 0x40000000, LENGTH = 0x80000
1694
 ram : ORIGIN = 0x48000000, LENGTH = 0x200000
1695
}
1696
 
1697
SECTIONS
1698
{
1699
 SECTIONS_BEGIN
1700
 SECTION_rom_vectors (rom, 0x40000000, LMA_EQ_VMA)
1701
 SECTION_text (rom, ALIGN (0x1), LMA_EQ_VMA)
1702
 SECTION_fini (rom, ALIGN (0x1), LMA_EQ_VMA)
1703
 SECTION_rodata (rom, ALIGN (0x1), LMA_EQ_VMA)
1704
 SECTION_rodata1 (rom, ALIGN (0x1), LMA_EQ_VMA)
1705
 SECTION_fixup (rom, ALIGN (0x1), LMA_EQ_VMA)
1706
 SECTION_gcc_except_table (rom, ALIGN (0x1), LMA_EQ_VMA)
1707
 SECTION_data (ram, 0x48000000, FOLLOWING (.gcc_except_table))
1708
 SECTION_bss (ram, ALIGN (0x4), LMA_EQ_VMA)
1709
 SECTIONS_END
1710
}
1711
1712
The file consists of two blocks, the MEMORY block
1713
contains lines describing the address (ORIGIN)
1714
and the size (LENGTH) of each memory
1715
region. The MEMORY block is followed
1716
by the SECTIONS block which contains
1717
lines describing each of the linker output sections. Each section
1718
is represented by a macro call. The arguments of these macros are
1719
ordered as follows: 
1720
1721
1722
The memory region in which the section will finally
1723
              reside.
1724
1725
1726
The final address (
1727
VMA
1728
) of the section. This is expressed using one of the following forms:
1729
1730
1731
n
1732
1733
at the absolute address specified by the
1734
                    unsigned integer n
1735
1736
1737
1738
ALIGN (n)
1739
1740
following the final location of the previous section
1741
                    with alignment to the next n-byte
1742
                    boundary
1743
1744
1745
1746
1747
1748
The initial address (LMA)
1749
              of the section. This is expressed using one of the
1750
              following forms:
1751
1752
1753
LMA_EQ_VMA
1754
1755
the LMA
1756
                    equals the VMA (no relocation)
1757
1758
1759
1760
AT (n)
1761
1762
at the absolute address specified by the
1763
                    unsigned integer n
1764
1765
1766
1767
FOLLOWING (.name)
1768
1769
following the initial location of section
1770
                    name
1771
1772
1773
1774
1775
1776
In order to maintain compatibility with linker script
1777
          fragments and header files exported by the
1778
          eCos Configuration Tool, the use
1779
          of other expressions within these files is not
1780
          recommended.
1781
Note that the names of the linker output sections will vary
1782
between target architectures. A description of these sections can
1783
be found in the specific GCC documentation for
1784
your architecture.
1785
1786
1787
1788
Managing the <!-- <index></index> -->Package Repository
1789
A source distribution of eCos consists of a number of
1790
        packages, such as the kernel, the C library, and the
1791
        µITRON subsystems. These are
1792
        individually versioned in the tree structure of the source
1793
        code, to support distribution on a per-package basis and to
1794
        support third party packages whose versioning systems might be
1795
        different. The eCos Package
1796
          Administration Tool is used to manage the
1797
        installation and removal of packages from a variety of sources
1798
        with potentially multiple versions.
1799
The presence of the version information in the source tree
1800
        structure might be a hindrance to the use of a separate source
1801
        control system such as CVS or
1802
        SourceSafe. To work
1803
        in this way, you can rename all the version components to some
1804
        common name (such as “current”) thus unifying the
1805
        structure of source trees from distinct eCos releases.
1806
The eCos build system will treat any such name as just another
1807
version of the package(s), and support building in exactly the same
1808
way. However, performing this rename invalidates any existing build
1809
trees that referred to the versioned source tree, so do the rename
1810
first, before any other work, and do a complete rebuild afterwards.
1811
1812
Package Installation
1813
Package installation and removal is performed using the
1814
          eCos Package Administration Tool. This
1815
          tool is a Tcl script named
1816
        ecosadmin.tcl which allows
1817
          the user to add new eCos packages and new versions of
1818
          existing packages to an eCos repository. Such packages must
1819
          be distributed as a single file in the eCos package
1820
          distribution format. Unwanted packages may also be removed
1821
          from the repository using this tool. A graphical version of
1822
          the tool is provided as part of the
1823
          eCos Configuration Tool.
1824
1825
Using the Administration Tool The graphical
1826
version of the eCos Package
1827
Administration Tool, provided as part of the
1828
eCos Configuration
1829
Tool, provides functions equivalent to the command-line
1830
version for those who prefer a Windows-based interface.
1831
It may be invoked in one of two ways:
1832
1833
1834
from the start menu (by default
1835
                Start->Programs->
1836
                  eCos->Package Administration
1837
                  Tool)
1838
1843
 
1844
1845
1846
from the eCos Configuration
1847
                  Tool via the
1848
                Tools->Administration
1849
                menu item
1850
1851
1852
1853
The main window of the tool displays the packages which are
1854
currently installed in the form of a tree. The installed versions
1855
of each package may be examined by expanding the tree.
1856
Packages may be added to the eCos repository by clicking on
1857
the Add button. The eCos package distribution
1858
file to be added is then selected via a File Open dialog
1859
box.
1860
Packages may be removed by selecting a package in the tree
1861
and then clicking on the Remove button. If
1862
a package node is selected, all versions of the selected package
1863
will be removed. If a package version node is selected, only the
1864
selected version of the package will be removed.
1865
1866
1867
Using the command line
1868
The ecosadmin.tcl
1869
            script is located in the base of the eCos repository. Use
1870
            a command of the following form under versions of
1871
            UNIX:
1872
$ tclsh ecosadmin.tcl <command>
1873
Under Windows, a command of the following form may be used
1874
at the Cygwin command line prompt:
1875
$ cygtclsh80 ecosadmin.tcl <command>
1876
The following commands are available:
1877
1878
1879
add <file>
1880
1881
Adds the packages contained with the specified package distribution
1882
file to the eCos repository and updates the package database accordingly.
1883
By convention, eCos package distribution files are given the .epk suffix.
1884
1885
1886
1887
remove <package> [ --version=<version> ]
1888
1889
Removes the specified package from the eCos
1890
                  repository and updates the package database
1891
                  accordingly. Where the optional version qualifier is
1892
                  used, only the specified version of the package is
1893
                  removed.
1894
1895
1896
1897
list
1898
1899
Produces a list of the packages which
1900
                  are currently installed and their versions. The
1901
                  available templates and hardware targets are also
1902
                  listed.
1903
1904
1905
1906
Note that is is possible to remove critical packages
1907
            such as the common HAL package using this tool. Users
1908
            should take care to avoid such errors since core eCos
1909
            packages may only be re-installed in the context of a
1910
            complete re-installation of eCos.
1911
1912
1913
1914
Package Structure
1915
The files in an installed eCos source tree are organized in
1916
a natural tree structure, grouping together files which work together
1917
into Packages. For example, the kernel files
1918
are all together in: 
1919
1920
BASE_DIR/kernel/&Version;/include/
1921
            BASE_DIR/kernel/&Version;/src/
1922
        BASE_DIR/kernel/&Version;/tests/
1923
1924
and µITRON compatibility layer files are in:
1925
        
1926
1927
            BASE_DIR/compat/uitron/&Version;/include/
1928
        BASE_DIR/compat/uitron/&Version;/src/
1929
        BASE_DIR/compat/uitron/&Version;/tests/
1930
1931
The feature of these names which is of interest here is
1932
          the &Version; near the end. It may seem odd to place a version number deep in the
1933
          path, rather than having something like
1934
          BASE_DIR/&Version;/...everything...
1935
          or leaving it up to you to choose a different
1936
          install-place when a new release of the system arrives.
1937
        
1938
There is a rationale for this organization: as
1939
          indicated, the kernel and the
1940
          µITRON compatibility subsystem
1941
          are examples of software packages. For the first few
1942
          releases of eCos, all the packages will move along
1943
          in step, i.e. Release 1.3.x will feature Version
1944
          1.3.x of every package, and so forth. But in future,
1945
          especially when third party packages become available, it is
1946
          intended that the package be the unit of software
1947
          distribution, so it will be possible to build a system from
1948
          a selection of packages with different version numbers, and
1949
          even differing versioning schemes. A
1950
          Tcl script ecosadmin.tcl is
1951
          provided in the eCos repository to manage the installation
1952
          and removal of packages in this way.
1953
Many users will have their own source code control system,
1954
version control system or equivalent, and will want to use it with
1955
eCos sources. In that case, since a new release of eCos comes with
1956
different pathnames for all the source files, a bit of work is necessary
1957
to import a new release into your source repository. 
1958
One way of handling the import is to rename all the version
1959
parts to some common name, for example “current”,
1960
and continue to work. “current” is suggested because ecosconfig recognizes
1961
it and places it first in any list of versions. In the future, we
1962
may provide a tool to help with this, or an option in the install
1963
wizard. Alternatively, in a POSIX shell environment (Linux or Cygwin
1964
on Windows) use the following command: 
1965
find . -name &Version; -type d -printf 'mv %p %h/current\n' | sh
1966
Having carried out such a renaming operation, your
1967
          source tree will now look like this: 
1968
BASE_DIR/kernel/current/include/
1969
BASE_DIR/kernel/current/src/
1970
BASE_DIR/kernel/current/tests/
1971
        ...
1972
BASE_DIR/compat/uitron/current/include/
1973
BASE_DIR/compat/uitron/current/src/
1974
BASE_DIR/compat/uitron/current/tests/
1975
        
1976
which is a suitable format for import into your own
1977
          source code control system. When you get a subsequent
1978
          release of eCos, do the same thing and use your own source
1979
          code control system to manage the new source base, by
1980
          importing the new version from 
1981
NEW_BASE_DIR/kernel/current/include/
1982
and so on. 
1983
The eCos build tool will now offer only the
1984
          “current” version of each package; select this
1985
          for the packages you wish to use. 
1986
Making such a change has implications for any build
1987
          trees you already have in use. A configured build tree
1988
          contains information about the selected packages and their
1989
          selected versions. Changing the name of the
1990
          “versioning” folder in the source tree
1991
          invalidates this information, and in consequence it also
1992
          invalidates any local configuration options you have set up
1993
          in this build tree. So if you want to change the version
1994
          information in the source tree, do it first, before
1995
          investing any serious time in configuring and building your
1996
          system. When you create a new build tree to deal with the
1997
          new source layout, it will contain default settings for all
1998
          the configuration options, just like the old build tree did
1999
          before you configured it. You will need to redo that
2000
          configuration work in the new tree. 
2001
Moving source code around also invalidates debugging information
2002
in any programs or libraries built from the old tree; these will
2003
need to be rebuilt. 
2004
2005
2006
2007

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.