lib_subsys.md (1414B)
@dir /lib/subsys @brief lib/subsys: Types for declaring a "subsystem".
Subsystems in Tor
A subsystem is a module with support for initialization, shutdown, configuration, and so on.
Many parts of Tor can be initialized, cleaned up, and configured somewhat independently through a table-driven mechanism. Each such part is called a "subsystem".
To declare a subsystem, make a global const instance of the subsys_fns_t
type, filling in the function pointer fields that you require with ones
corresponding to your subsystem. Any function pointers left as "NULL" will
be a no-op. Each system must have a name and a "level", which corresponds to
the order in which it is initialized. (See app/main/subsystem_list.c for a
list of current subsystems and their levels.)
Then, insert your subsystem in the list in app/main/subsystem_list.c. It
will need to occupy a position corresponding to its level.
At this point, your subsystem will be handled like the others: it will get initialized at startup, torn down at exit, and so on.
Historical note: Not all of Tor's code is currently handled as
subsystems. As you work with older code, you may see some parts of the code
that are initialized from tor_init() or run_tor_main_loop() or
tor_run_main(); and torn down from tor_cleanup(). We aim to migrate
these to subsystems over time; please don't add any new code that follows
this pattern.