The signal initiator should call signal_raise() to raise the signal level to its active level. Signals are always active high in Simics. Once raised, the same initiator may not call signal_raise() again without an intervening call to signal_lower().
The implementer must increment a level counter on every signal_raise() call, and decrement it on signal_lower(). The signal can not be treated as lowered until the counter reaches zero again. This allows multiple sources of the signal.
The signal target should handle the case where a signal is lowered directly when after it has been raised and treat it as a valid pulse. The target should also allow the signal to remain raised for some time before it is lowered.
An object that does lookup of the signal interface in another object should have an attribute that can be set in the configuration to the target object. This attribute should either be of the Sim_Val_Object kind, or a list with two entries, one Sim_Val_Object and one Sim_Val_String. If the object only format is used in the configuration, the interface should be looked up using SIM_get_interface(), and if the list format it used the interface should be obtained with SIM_get_port_interface().
A class that wishes to implement several signal inputs should use named interfaces.
struct signal_interface { void (*signal_raise)(conf_object_t *NOTNULL obj); void (*signal_lower)(conf_object_t *NOTNULL obj); }; #define SIGNAL_INTERFACE "signal"