Contents Index Search Related Documents Previous Next
13.3 Operational and Representation Attributes
1/1
The
values of certain implementation-dependent characteristics can be obtained
by interrogating appropriate operational or representation attributes.
Some of these attributes are specifiable via an
attribute_definition_clause.
Syntax
2
attribute_definition_clause
::=
for local_name'
attribute_designator use expression;
|
for local_name'
attribute_designator use name;
Name Resolution Rules
3
For an attribute_definition_clause
that specifies an attribute that denotes a value, the form with an expression
shall be used. Otherwise, the form with a name
shall be used.
4
For an
attribute_definition_clause
that specifies an attribute that denotes a value or an object, the expected
type for the expression or
name
is that of the attribute.
For an
attribute_definition_clause
that specifies an attribute that denotes a subprogram, the expected profile
for the
name is the profile required
for the attribute. For an
attribute_definition_clause
that specifies an attribute that denotes some other kind of entity, the
name shall resolve to denote an
entity of the appropriate kind.
Legality Rules
5/1
An
attribute_designator
is allowed in an
attribute_definition_clause
only if this International Standard explicitly allows it, or for an implementation-defined
attribute if the implementation allows it.
Each specifiable
attribute constitutes an
operational aspect or aspect
of representation.
6
For an
attribute_definition_clause
that specifies an attribute that denotes a subprogram, the profile shall
be mode conformant with the one required for the attribute, and the convention
shall be Ada. Additional requirements are defined for particular attributes.
Static Semantics
7/2
A
Size clause is an
attribute_definition_clause
whose
attribute_designator is Size.
Similar definitions apply to the other specifiable attributes.
8
A
storage
element is an addressable element of storage in the machine.
A
word is the largest amount of storage that can be conveniently
and efficiently manipulated by the hardware, given the implementation's
run-time model. A word consists of an integral number of storage elements.
8.1/2
A
machine scalar
is an amount of storage that can be conveniently and efficiently loaded,
stored, or operated upon by the hardware. Machine scalars consist of
an integral number of storage elements. The set of machine scalars is
implementation defined, but must include at least the storage element
and the word. Machine scalars are used to interpret
component_clauses
when the nondefault bit ordering applies.
9/1
The following representation attributes are
defined: Address, Alignment, Size, Storage_Size, and Component_Size.
10/1
For a prefix
X that denotes an object, program unit, or label:
11
- X'Address
-
Denotes the address of the first
of the storage elements allocated to X. For a program unit or label,
this value refers to the machine code associated with the corresponding
body or statement. The value of
this attribute is of type System.Address.
12
- Address
may be specified for stand-alone objects and for program units via an
attribute_definition_clause.
Erroneous Execution
13
If an Address is specified,
it is the programmer's responsibility to ensure that the address is valid;
otherwise, program execution is erroneous.
Implementation Advice
14
For an array X, X'Address should point at the
first component of the array, and not at the array bounds.
15
The recommended level of
support for the Address attribute is:
16
- X'Address
should produce a useful result if X is an object that is aliased or of
a by-reference type, or is an entity whose Address has been specified.
17
- An implementation should support Address
clauses for imported subprograms.
18/2
- This paragraph
was deleted.
19
- If the Address of an object is specified,
or it is imported or exported, then the implementation should not perform
optimizations based on assumptions of no aliases.
20
1 The specification of
a link name in a pragma Export (see
B.1) for a subprogram or object is an alternative
to explicit specification of its link-time address, allowing a link-time
directive to place the subprogram or object within memory.
21
2 The rules for the Size
attribute imply, for an aliased object X, that if X'Size = Storage_Unit,
then X'Address points at a storage element containing all of the bits
of X, and only the bits of X.
Static Semantics
22/2
For a prefix
X that denotes an object:
23/2
- X'Alignment
-
The value of this attribute is
of type universal_integer, and nonnegative; zero means that the
object is not necessarily aligned on a storage element boundary. If X'Alignment
is not zero, then X is aligned on a storage unit boundary and X'Address
is an integral multiple of X'Alignment (that is, the Address modulo the
Alignment is zero).
24/2
- This paragraph was deleted.
25/2
- Alignment
may be specified for stand-alone objects via an attribute_definition_clause;
the expression of such a clause shall be static, and its value nonnegative.
26/2
- This paragraph was deleted.
26.1/2
For every subtype
S:
26.2/2
- S'Alignment
-
The value of this attribute is
of type universal_integer, and nonnegative.
26.3/2
- For an object X of subtype S,
if S'Alignment is not zero, then X'Alignment is a nonzero integral multiple
of S'Alignment unless specified otherwise by a representation item.
27/2
- Alignment
may be specified for first subtypes via an attribute_definition_clause;
the expression of such a clause shall be static, and its value nonnegative.
Erroneous Execution
28
Program execution is erroneous
if an Address clause is given that conflicts with the Alignment.
29/2
For an object that is not
allocated under control of the implementation, execution is erroneous
if the object is not aligned according to its Alignment.
Implementation Advice
30
The recommended level of
support for the Alignment attribute for subtypes is:
31/2
- An implementation
should support an Alignment clause for a discrete type, fixed point type,
record type, or array type, specifying an Alignment value that is zero
or a power of two, subject to the following:
32/2
- An implementation need not support
an Alignment clause for a signed integer type specifying an Alignment
greater than the largest Alignment value that is ever chosen by default
by the implementation for any signed integer type. A corresponding limitation
may be imposed for modular integer types, fixed point types, enumeration
types, record types, and array types.
33/2
- An implementation need not support
a nonconfirming Alignment clause which could enable the creation of an
object of an elementary type which cannot be easily loaded and stored
by available machine instructions.
33.1/2
- An implementation need not support
an Alignment specified for a derived tagged type which is not a multiple
of the Alignment of the parent type. An implementation need not support
a nonconfirming Alignment specified for a derived untagged by-reference
type.
34
The
recommended level of support for the Alignment attribute for objects
is:
35/2
- This paragraph
was deleted.
36
- For stand-alone library-level objects
of statically constrained subtypes, the implementation should support
all Alignments supported by the target linker. For example, page alignment
is likely to be supported for such objects, but not for subtypes.
36.1/2
- For other objects, an implementation
should at least support the alignments supported for their subtype, subject
to the following:
36.2/2
- An implementation need not support
Alignments specified for objects of a by-reference type or for objects
of types containing aliased subcomponents if the specified Alignment
is not a multiple of the Alignment of the subtype of the object.
37
3 Alignment is a subtype-specific
attribute.
38/2
This paragraph
was deleted.4
39
5 A component_clause,
Component_Size clause, or a pragma
Pack can override a specified Alignment.
Static Semantics
40/1
For a prefix
X that denotes an object:
41
- X'Size
-
Denotes the size in bits of the
representation of the object. The value of this attribute is of the type
universal_integer.
42
- Size
may be specified for stand-alone objects via an attribute_definition_clause;
the expression of such a clause shall be static and its value nonnegative.
Implementation Advice
42.1/2
The size of an array object should not include
its bounds.
43/2
The recommended level of
support for the Size attribute of objects is the same as for subtypes
(see below), except that only a confirming Size clause need be supported
for an aliased elementary object.
44/2
- This paragraph
was deleted.
Static Semantics
45
For every subtype
S:
46
- S'Size
-
If S is definite, denotes the
size (in bits) that the implementation would choose for the following
objects of subtype S:
47
- A record component of subtype
S when the record type is packed.
48
- The formal parameter of an
instance of Unchecked_Conversion that converts from subtype S to some
other subtype.
49
- If S is indefinite, the meaning
is implementation defined. The value of this attribute is of the type
universal_integer. The
Size of an object is at least as large as that of its subtype, unless
the object's Size is determined by a Size clause, a component_clause,
or a Component_Size clause. Size may be specified for first subtypes
via an attribute_definition_clause;
the expression of such a clause shall be static and its value nonnegative.
Implementation Requirements
50
In an implementation, Boolean'Size shall be 1.
Implementation Advice
51/2
If the Size of
a subtype allows for efficient independent addressability (see
9.10)
on the target architecture, then the Size of the following objects of
the subtype should equal the Size of the subtype:
52
- Aliased objects (including components).
53
- Unaliased components, unless the Size
of the component is determined by a component_clause
or Component_Size clause.
54
A Size clause on a composite subtype should not
affect the internal layout of components.
55
The
recommended level of support for the Size attribute of subtypes is:
56
- The Size (if not specified) of a static
discrete or fixed point subtype should be the number of bits needed to
represent each value belonging to the subtype using an unbiased representation,
leaving space for a sign bit only if the subtype contains negative values.
If such a subtype is a first subtype, then an implementation should support
a specified Size for it that reflects this representation.
57
- For a subtype implemented with levels
of indirection, the Size should include the size of the pointers, but
not the size of what they point at.
57.1/2
- An implementation
should support a Size clause for a discrete type, fixed point type, record
type, or array type, subject to the following:
57.2/2
- An implementation need not support
a Size clause for a signed integer type specifying a Size greater than
that of the largest signed integer type supported by the implementation
in the absence of a size clause (that is, when the size is chosen by
default). A corresponding limitation may be imposed for modular integer
types, fixed point types, enumeration types, record types, and array
types.
57.3/2
- A nonconfirming size clause
for the first subtype of a derived untagged by-reference type need not
be supported.
58
6 Size is a subtype-specific
attribute.
59
7 A component_clause
or Component_Size clause can override a specified Size. A pragma
Pack cannot.
Static Semantics
60/1
For a prefix
T that denotes a task object (after any implicit dereference):
61
- T'Storage_Size
-
Denotes the number of storage
elements reserved for the task. The value of this attribute is of the
type universal_integer. The Storage_Size includes the size of
the task's stack, if any. The language does not specify whether or not
it includes other storage associated with the task (such as the “task
control block” used by some implementations.) If a pragma
Storage_Size is given, the value of the Storage_Size attribute is at
least the value specified in the pragma.
62
A
pragma
Storage_Size specifies the amount of storage to be reserved for the execution
of a task.
Syntax
63
The form of
a pragma Storage_Size is as follows:
64
pragma Storage_Size(
expression);
65
A pragma
Storage_Size is allowed only immediately within a task_definition.
Name Resolution Rules
66
The
expression
of a
pragma Storage_Size is expected
to be of any integer type.
Dynamic Semantics
67
A
pragma
Storage_Size is elaborated when an object of the type defined by the
immediately enclosing
task_definition
is created.
For the elaboration of a
pragma
Storage_Size, the
expression is
evaluated; the Storage_Size attribute of the newly created task object
is at least the value of the
expression.
68
At
the point of task object creation, or upon task activation, Storage_Error
is raised if there is insufficient free storage to accommodate the requested
Storage_Size.
Static Semantics
69/1
For a prefix
X that denotes an array subtype or array object (after any implicit dereference):
70
- X'Component_Size
-
Denotes the size in bits of components
of the type of X. The value of this attribute is of type universal_integer.
71
- Component_Size
may be specified for array types via an attribute_definition_clause;
the expression of such a clause shall be static, and its value nonnegative.
Implementation Advice
72
The
recommended level of support for the Component_Size attribute is:
73
- An implementation need not support
specified Component_Sizes that are less than the Size of the component
subtype.
74
- An implementation should support specified
Component_Sizes that are factors and multiples of the word size. For
such Component_Sizes, the array should contain no gaps between components.
For other Component_Sizes (if supported), the array should contain no
gaps between components when packing is also specified; the implementation
should forbid this combination in cases where it cannot support a no-gaps
representation.
Static Semantics
74.1/1
The following operational attribute is defined:
External_Tag.
75/1
For every subtype
S of a tagged type T (specific or class-wide):
76/1
- S'External_Tag
-
S'External_Tag
denotes an external string representation for S'Tag; it is of the predefined
type String. External_Tag may be specified for a specific tagged type
via an attribute_definition_clause;
the expression of such a clause shall be static. The default external
tag representation is implementation defined. See 3.9.2
and 13.13.2. The value of External_Tag
is never inherited; the default value is always used unless a new value
is directly specified for a type.
Implementation Requirements
77
In an implementation, the default external tag
for each specific tagged type declared in a partition shall be distinct,
so long as the type is declared outside an instance of a generic body.
If the compilation unit in which a given tagged type is declared, and
all compilation units on which it semantically depends, are the same
in two different partitions, then the external tag for the type shall
be the same in the two partitions. What it means for a compilation unit
to be the same in two different partitions is implementation defined.
At a minimum, if the compilation unit is not recompiled between building
the two different partitions that include it, the compilation unit is
considered the same in the two partitions.
78/2
8 The following language-defined
attributes are specifiable, at least for some of the kinds of entities
to which they apply: Address, Alignment, Bit_Order, Component_Size, External_Tag,
Input, Machine_Radix, Output, Read, Size, Small, Storage_Pool, Storage_Size,
Stream_Size, and Write.
79
9 It follows from the general
rules in 13.1 that if one writes “for
X'Size use Y;” then the X'Size attribute_reference
will return Y (assuming the implementation allows the Size clause). The
same is true for all of the specifiable attributes except Storage_Size.
Examples
80
Examples of
attribute definition clauses:
81
Byte : constant := 8;
Page : constant := 2**12;
82
type Medium is range 0 .. 65_000;
for Medium'Size use 2*Byte;
for Medium'Alignment use 2;
Device_Register : Medium;
for Device_Register'Size use Medium'Size;
for Device_Register'Address use System.Storage_Elements.To_Address(16#FFFF_0020#);
83
type Short is delta 0.01 range -100.0 .. 100.0;
for Short'Size use 15;
84
for Car_Name'Storage_Size use -- specify access type's storage pool size
2000*((Car'Size/System.Storage_Unit) +1); -- approximately 2000 cars
85
function My_Read(Stream : access Ada.Streams.Root_Stream_Type'Class)
return T;
for T'Read use My_Read; -- see 13.13.2
86
10 Notes on the examples:
In the Size clause for Short, fifteen bits is the minimum necessary,
since the type definition requires Short'Small <= 2**(–7).
Contents Index Search Related Documents Previous Next Legal