Jump to content

DCEThreads

From Wikipedia, the free encyclopedia

This is an old revision of this page, as edited by Cherrell410 (talk | contribs) at 15:56, 25 July 2023 (Filled in 0 bare reference(s) with reFill 2). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

DCEThreads is an implementation of POSIX Draft 4 threads. DCE Stands for "Distributed Computing Environment" [1] DCEThreads allowed users to create multiple avenues of execution in a single process.[2] It is based on pthreads interface.[3]

History

DCE/RPC was under development, but the POSIX committee had not finalised POSIX threads at the time. The Open Group had to make a decision about which to use, and the final POSIX threads were different from their selection.

POSIX Draft 4 threads were limited to begin with (the final standard fixed these). Microsoft adopted DCE/RPC wholesale in Windows NT as MSRPC and also in DCOM. Most of the stability and reliability problems that programmers associate with DCOM services - especially memory leaks, exception handling problems and thread cancellation stability issues - can be traced back to the use of POSIX Draft 4 threads.

DCE/RPC is sufficiently complex that the issue of updating it to solve and modernise the POSIX Draft 4 threading problem requires highly skilled and highly specific programming knowledge. Consequently, despite its capacities, the reference implementation of DCE/RPC has been held up due to a lack of information and resources.

The key difference between POSIX Draft 4 threads and the final POSIX threads specification, aside from a number of functions being interruptible where others are not, is thread cancellation. DCE/RPC utilises thread cancellation to propagate signals across the "Remote" of RPC, such that for example a client application terminating a thread results in its corresponding thread on the server also being terminated in the same way. The final POSIX specification does not include such sophisticated cancellation methodology, and, given the difficulties that the Unix vendors had in correctly implementing the POSIX threads specification, it was removed.

Recent developments

Linux, since the introduction of NPTL and the Linux 2.6 kernel, has proper support for thread cancellation.

Current use

DCEThreads now only realistically exists as an emulation layer.

References

  1. ^ "IBM Docs". IBM.
  2. ^ "dec95a1.pdf" (PDF).
  3. ^ "What is DCE Threads?".