NOTE(3EXT) Extended Library Functions NOTE(3EXT)
NAME
NOTE, _NOTE - annotate source code with info for tools
SYNOPSIS
#include <note.h>
NOTE(
NoteInfo);
or
#include <sys/note.h>
_NOTE(
NoteInfo);
DESCRIPTION
These macros are used to embed information for tools in program source. A
use of one of these macros is called an "annotation". A tool may define a
set of such annotations which can then be used to provide the tool with
information that would otherwise be unavailable from the source code.
Annotations should, in general, provide documentation useful to the human
reader. If information is of no use to a human trying to understand the
code but is necessary for proper operation of a tool, use another
mechanism for conveying that information to the tool (one which does not
involve adding to the source code), so as not to detract from the
readability of the source. The following is an example of an annotation
which provides information of use to a tool and to the human reader (in
this case, which data are protected by a particular lock, an annotation
defined by the static lock analysis tool
lock_lint).
NOTE(MUTEX_PROTECTS_DATA(foo_lock,
foo_list Foo)) Such annotations do not represent executable code; they are neither
statements nor declarations. They should not be followed by a semicolon.
If a compiler or tool that analyzes C source does not understand this
annotation scheme, then the tool will ignore the annotations. (For such
tools,
NOTE(x) expands to nothing.)
Annotations may only be placed at particular places in the source. These
places are where the following C constructs would be allowed:
o a top-level declaration (that is, a declaration not within a
function or other construct)
o a declaration or statement within a block (including the block
which defines a function)
o a member of a
struct or
union.
Annotations are not allowed in any other place. For example, the
following are illegal:
x = y + NOTE(...) z ;
typedef NOTE(...) unsigned int uint ;
While
NOTE and
_NOTE may be used in the places described above, a
particular type of annotation may only be allowed in a subset of those
places. For example, a particular annotation may not be allowed inside a
struct or
union definition.
NOTE vs _NOTE Ordinarily,
NOTE should be used rather than
_NOTE, since use of
_NOTE technically makes a program non-portable. However, it may be inconvenient
to use
NOTE for this purpose in existing code if
NOTE is already heavily
used for another purpose. In this case one should use a different macro
and write a header file similar to
/usr/include/note.h which maps that
macro to
_NOTE in the same manner. For example, the following makes
FOO such a macro:
#ifndef _FOO_H
#define _FOO_H
#define FOO _NOTE
#include <sys/note.h>
#endif
Public header files which span projects should use
_NOTE rather than
NOTE, since
NOTE may already be used by a program which needs to include
such a header file.
NoteInfo Argument The actual
NoteInfo used in an annotation should be specified by a tool
that deals with program source (see the documentation for the tool to
determine which annotations, if any, it understands).
NoteInfo must have one of the following forms:
NoteName NoteName(
Args)
where
NoteName is simply an identifier which indicates the type of
annotation, and
Args is something defined by the tool that specifies the
particular
NoteName. The general restrictions on
Args are that it be
compatible with an ANSI C tokenizer and that unquoted parentheses be
balanced (so that the end of the annotation can be determined without
intimate knowledge of any particular annotation).
ATTRIBUTES
See
attributes(7) for descriptions of the following attributes:
+---------------+-----------------+
|ATTRIBUTE TYPE | ATTRIBUTE VALUE |
+---------------+-----------------+
|MT-Level | Safe |
+---------------+-----------------+
SEE ALSO
note(5),
attributes(7) June 18, 2021
NOTE(3EXT)