Differences
This shows you the differences between two versions of the page.
| Next revision | Previous revision | ||
| en:docs:fapi:dossetsighandler [2018/08/31 14:13] – created prokushev | en:docs:fapi:dossetsighandler [2021/09/18 15:04] (current) – prokushev | ||
|---|---|---|---|
| Line 1: | Line 1: | ||
| + | {{page> | ||
| + | |||
| + | ====== DosSetSigHandler ====== | ||
| + | |||
| This call notifies OS/2 of a handler for a signal. It may also be used to ignore a signal or install a default action for a signal. | This call notifies OS/2 of a handler for a signal. It may also be used to ignore a signal or install a default action for a signal. | ||
| - | ==Syntax== | + | ===== Syntax | 
| - |  | + | <code c> | 
| + | DosSetSigHandler (Routine, PrevAddress, | ||
| + | </ | ||
| + | |||
| + | ===== Parameters ===== | ||
| + | |||
| + | * Routine (PFNSIGHANDLER) - input : Address of the entry point of routine that receives control when a signal equal to SigNumber is received. | ||
| + | * PrevAddress (PFNSIGHANDLER FAR *) - output: Address of the previous signal handler. This operand may be coded as null (= 0), then it is ignored. | ||
| + | * PrevAction (PUSHORT) - output : Address of the previous signal action. Only values 0 to 3 are returned. This operand may be coded as null (= 0), then it is ignored. | ||
| + | * Action (USHORT) - input : Indicates what action to take when the specified signal is received: | ||
| + | |||
| + | ^ Value ^ Definition ^ | ||
| + | | 0 | The system default action is installed for the signal. | | ||
| + | | 1 | The signal is to be ignored. | | ||
| + | | 2 | The routine receives control when the SigNumber occurs. | | ||
| + | | 3 | It is an error for any program to signal this SigNumber to this process. | | ||
| + | | 4 | The current signal is reset without affecting the disposition of the signal. | | ||
| + | |||
| + | * SigNumber (USHORT) - input : Signal number to be intercepted by this signal handler. The signal numbers defined are: | ||
| + | |||
| + | ^ Value ^ Definition ^ | ||
| + | | 1 | Ctrl-C (SIGINTR) | | ||
| + | | 3 | Program terminated (SIGTERM) | | ||
| + | | 4 | Ctrl-Break (SIGBREAK) | | ||
| + | | 5 | Process flag A (SIGPFA) | | ||
| + | | 6 | Process flag B (SIGPFB) | | ||
| + | | 7 | Process flag C (SIGPFC) | | ||
| - | ==Parameters== | ||
| - | ;Routine (PFNSIGHANDLER) - input : Address of the entry point of routine that receives control when a signal equal to SigNumber is received. | ||
| - | ; | ||
| - | ;PrevAction (PUSHORT) - output : Address of the previous signal action. Only values 0 to 3 are returned. This operand may be coded as null (= 0), then it is ignored. | ||
| - | ;Action (USHORT) - input : Indicates what action to take when the specified signal is received: | ||
| - | ''' | ||
| - |  | ||
| - |  | ||
| - |  | ||
| - |  | ||
| - |  | ||
| - | ; SigNumber (USHORT) - input : Signal number to be intercepted by this signal handler. The signal numbers defined are: | ||
| - | ''' | ||
| - |  | ||
| - |  | ||
| - |  | ||
| - |  | ||
| - |  | ||
| - |  | ||
| ''' | ''' | ||
|  |  | ||
| The following chart indicates what signal to specify to cause the signal handler to get control for the CTRL-C and CTRL-Break key sequences in each of the keyboard modes (ASCII and Binary): | The following chart indicates what signal to specify to cause the signal handler to get control for the CTRL-C and CTRL-Break key sequences in each of the keyboard modes (ASCII and Binary): | ||
| - | {|class=" | + | ^ ^ ASCII Mode ^ BINARY Mode ^ | 
| - | ! ||ASCII Mode||BINARY Mode | + | |CTRL-C|SIGINTR| | | 
| - | |- | + | |CTRL-Break|SIGINTR|SIGBREAK| | 
| - | |CTRL-C||SIGINTR|| | + | |
| - | |- | + | |
| - | |CTRL-Break||SIGINTR||SIGBREAK | + | |
| - | |} | + | |
| - | ==Return Code== | + | ===== Return Code ===== | 
| - | ;rc (USHORT) - return: | + | |
| - | * 0 | + | rc (USHORT) - return: | 
| - | * | + | |
| - | * 209 ERROR_INVALID_SIGNAL_NUMBER | + |  | 
| - | * 210 ERROR_THREAD_1_INACTIVE | + | * | 
| + | * 209 ERROR_INVALID_SIGNAL_NUMBER | ||
| + | * 210 ERROR_THREAD_1_INACTIVE | ||
| + | |||
| + | ===== Remarks ===== | ||
| - | ==Remarks== | ||
| When the signal indicated by SigNumber occurs, the signal handling routine receives control with: | When the signal indicated by SigNumber occurs, the signal handling routine receives control with: | ||
| - | (SS: | + | |
| - |  | + | (SS: | 
| - |  | + | (SS: | 
| + | (SS: | ||
| Other than SS, SP, CS, IP and flags, all registers contain the same values they contained at the time the signal was received. The handler may exit by executing an intersegment return instruction, | Other than SS, SP, CS, IP and flags, all registers contain the same values they contained at the time the signal was received. The handler may exit by executing an intersegment return instruction, | ||
| Line 59: | Line 71: | ||
| Initially, a session has no signal focus for SIGINTR (or SIGBREAK). A process becomes the signal focus for SIGINTR ( or SIGBREAK) within its session if it calls DosSetSigHandler with ActionCode equal to 1, 2, or 3. A process remains the signal focus until: | Initially, a session has no signal focus for SIGINTR (or SIGBREAK). A process becomes the signal focus for SIGINTR ( or SIGBREAK) within its session if it calls DosSetSigHandler with ActionCode equal to 1, 2, or 3. A process remains the signal focus until: | ||
| - | * The process terminates. | + |  | 
| - | * The process calls DosSetSigHandler with ActionCode equal to zero. | + | * The process calls DosSetSigHandler with ActionCode equal to zero. | 
| - | * Another process calls DosSetSigHandler with ActionCode equal to 1, 2, or 3. | + | * Another process calls DosSetSigHandler with ActionCode equal to 1, 2, or 3. | 
| In the first two cases, the parent or its closest related ancestor process that has a handler installed for the appropriate signal becomes the focus. If no eligible process exists, the session ceases to have a signal focus for that signal. | In the first two cases, the parent or its closest related ancestor process that has a handler installed for the appropriate signal becomes the focus. If no eligible process exists, the session ceases to have a signal focus for that signal. | ||
| Line 67: | Line 79: | ||
| If a device driver makes a SendEvent call for CTRL-C or CTRL-BREAK and the current session has no focus for the corresponding signal, all processes in the session are signaled with SIGTERM to terminate. | If a device driver makes a SendEvent call for CTRL-C or CTRL-BREAK and the current session has no focus for the corresponding signal, all processes in the session are signaled with SIGTERM to terminate. | ||
| - | ==Family API Considerations== | + | ==== Family API Considerations ==== | 
| Some options operate differently in the DOS mode than in OS/2 mode. Therefore, the following restriction applies to DosSetSigHandler when coding in DOS mode: | Some options operate differently in the DOS mode than in OS/2 mode. Therefore, the following restriction applies to DosSetSigHandler when coding in DOS mode: | ||
| - | * The only signals recognized in DOS are SIGINTR (Ctrl-C) and SIGBREAK. | + |  | 
| - | * The option Action=3 generates an " | + | * The option Action=3 generates an " | 
| - | * If SigNumber is any value other than SIGINTR or SIGBREAK, then an " | + | * If SigNumber is any value other than SIGINTR or SIGBREAK, then an " | 
| SIGINTR is fully supported, and SIGBREAK is related to SIGINTR. Therefore, if SIGINTR is specified, both SIGINTR and SIGBREAK are transferred to the SIGINTR handler. SIGBREAK is permitted as a coded value, but the request to set SIGBREAK is ignored. To be compatible in all environments, | SIGINTR is fully supported, and SIGBREAK is related to SIGINTR. Therefore, if SIGINTR is specified, both SIGINTR and SIGBREAK are transferred to the SIGINTR handler. SIGBREAK is permitted as a coded value, but the request to set SIGBREAK is ignored. To be compatible in all environments, | ||
| - | ===C Binding=== | + | ===== Bindings ===== | 
| - | <PRE> | + | |
| + | ==== C Binding ==== | ||
| + | |||
| + | <code c> | ||
| #define INCL_DOSSIGNALS | #define INCL_DOSSIGNALS | ||
| Line 89: | Line 105: | ||
| USHORT | USHORT | ||
| - | </PRE> | + | </code> | 
| + | |||
| + | |||
| + | ==== MASM Binding ==== | ||
| + | |||
| + | <code asm> | ||
| + | EXTRN  DosSetSigHandler: | ||
| + | INCL_DOSSIGNALS | ||
| + | |||
| + | PUSH@  DWORD | ||
| + | PUSH@  DWORD | ||
| + | PUSH@  WORD    PrevAction | ||
| + | PUSH | ||
| + | PUSH | ||
| + | CALL | ||
| + | |||
| + | Returns WORD | ||
| + | </ | ||
| + | |||
| + | ===== Example ===== | ||
| - | ==Example== | ||
| The following example illustrates the use of a user-defined flag to signal time-critical events. The main thread installs a routine, named FlagA_Handler(), | The following example illustrates the use of a user-defined flag to signal time-critical events. The main thread installs a routine, named FlagA_Handler(), | ||
| - | <PRE> | + | <code c> | 
| #define INCL_DOSPROCESS | #define INCL_DOSPROCESS | ||
| #define INCL_DOSSIGNALS | #define INCL_DOSSIGNALS | ||
| Line 160: | Line 194: | ||
| printf(" | printf(" | ||
| } | } | ||
| - | </PRE> | + | </code> | 
| - | + | ||
| - | ===MASM Binding=== | + | |
| - | < | + | |
| - | EXTRN  DosSetSigHandler: | + | |
| - | INCL_DOSSIGNALS | + | |
| - | + | ||
| - | PUSH@  DWORD | + | |
| - | PUSH@  DWORD | + | |
| - | PUSH@  WORD    PrevAction | + | |
| - | PUSH | + | |
| - | PUSH | + | |
| - | CALL | + | |
| - | + | ||
| - | Returns WORD | + | |
| - | </ | + | |
| - | ====== Note ====== | + | ===== Note ===== | 
| Text based on [[http:// | Text based on [[http:// | ||




