RtTerminateProcess

RtTerminateProcess terminates the specified process and all its threads.

Syntax

Copy
BOOL RtTerminateProcess(
    [in]    HANDLE hProcess,
    [in]    UINT uExitCode
);

Parameters

[in] hProcess

Handle to the process to terminate. The handle must have PROCESS_TERMINATE access. If an invalid handle is specified, the function fails and sets last error to ERROR_INVALID_HANDLE.

[in] uExitCode

The exit code for the process and for all threads terminated as a result of this call. Use RtGetExitCodeProcess to retrieve the process's exit value. Use GetExitCodeThread to retrieve a thread's exit value.

Return Value

If the function succeeds, it returns TRUE. If the function fails, it returns FALSE. Call GetLastError to obtain an error code.

Remarks

RtTerminateProcess is used to unconditionally cause a process to exit.

RtTerminateProcess causes all threads within a process to terminate, and causes a process to exit, but DLLs attached to the process are not notified that the process is terminating.

Caution: Use this function only in extreme circumstances. The state of global data maintained by dynamic-link libraries (DLLs) may be compromised if RtTerminateProcess is used rather than exit or ExitProcess.

Terminating a process causes the following:

  1. All object handles opened by the process are closed.
  2. All threads in the process terminate their execution.
  3. The state of the process object becomes signaled, satisfying any threads waiting for the process to terminate.
  4. The states of all threads of the process become signaled, satisfying any threads that had been waiting for the threads to terminate.
  5. The termination status of the process changes from STILL_ACTIVE to the exit value of the process.

Terminating a process does not cause child processes to be terminated.

Terminating a process does not necessarily remove the process object from the system. A process object is deleted when the last handle to the process is closed.

IMPORTANT: There is risk of a Windows system crash if any of the wRTOS optional components such as the TCP/IP Stack (Rttcpip.rtss), wRTOS Network Link Layer (Rtnl2.rtss), or wRTOS E-CAT Fieldbus (Rtecat.rtss) processes are terminated.

Requirements

Minimum supported version Header Library

wRTOS 1.0 SDK

RtApi.h

RtApi.lib (Windows), Startup.lib (RTSS)

See Also: