Jonas Maebe wrote:
On 27/02/16 12:40, Mark Morgan Lloyd wrote:
Is there a way of sending an unambiguous system-level kill signal to a
thread? KillThread(ThreadID) doesn't appear to be brutal enough, and I'm
unsure of the correct way to access pthread_kill().

You cannot asynchronously kill threads on Unix platforms with the cthreads unit, and even on platforms where you can, you should never do it. All resources held by that thread will leak, and locks it held will never be unlocked.

Ouch. But as I said, this is specifically at termination, I'd like to shut down in good order so that I can output the number of times each thread's spun and none of them will be reused.

KillThread() on Unix calls pthread_cancel(), which indicates to the system libraries (or any other libraries that include support for this) that that as soon as they know it is safe to kill the current thread, they should abort it and call its registered cleanup functions.

Since you are in an emulator, the way to solve this is probably to have your own threads regularly check the "terminated" property of the tthread and if it's set (which you can do by calling thread.terminate "on it" from another thread), to clean up everything and abort.

It's not so much /in/ an emulator as the code /is/ an emulator.

The threads check for various termination conditions every time they spin, but in this test case one of them's gone into a syscall that can't be completed.

Interestingly, this is /exactly/ why a dot was added after the final END in a number of ALGOL dialects: the emulator is for a B5500 and the hardware doesn't have a "no more cards in hopper" signal.

"The first thing that Dijkstra wanted to see was BEGIN END.
compiled and executed.

"We apologized for the “.” being required since that was not a part of Algol. The “.” did not bother him at all. He thought it was a good idea."

And that's obviously why we've got it in Pascal as well.

--
Mark Morgan Lloyd
markMLl .AT. telemetry.co .DOT. uk

[Opinions above are the author's, not those of his employers or colleagues]
_______________________________________________
fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
http://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal

Reply via email to