Beefy Boxes and Bandwidth Generously Provided by pair Networks
The stupid question is the question not asked
 
PerlMonks  

Re: Signals vs. Windows

by Anonymous Monk
on Oct 03, 2012 at 16:38 UTC ( #997096=note: print w/replies, xml ) Need Help??


in reply to Signals vs. Windows

but the child thread doesn't appear to be acting immediately on the signals

By design, see safe signals in perlrun

Signals are not a good way to do IPC, see threads/forks, Re: controlling threads with Tk: while loop vs. signals

Replies are listed 'Best First'.
Re^2: Signals vs. Windows
by DanEllison (Beadle) on Oct 03, 2012 at 17:33 UTC

    The pertinent text I missed was actually out of "threads" which was:

    Correspondingly, sending a signal to a thread does not disrupt the operation the thread is currently working on: The signal will be acted upon after the current operation has completed. For instance, if the thread is stuck on an I/O call, sending it a signal will not cause the I/O call to be interrupted such that the signal is acted up immediately.

    Nothing in the documentation suggests that signals are not the way to perform IPC, but simply threads don't react to signals as well as processes. Keep in mind, I don't want to simply suspend or terminate the thread, but interrupt it and send it off in another direction. So, the problem restated is, I guess, how do I interrupt a thread from an I/O operation?

      So, the problem restated is, I guess, how do I interrupt a thread from an I/O operation?

      1. dont use blocking I/O, use overlapped/async I/O

      2. use Native API, create an alertable *synchronous* file handle using NtCreateFile, post a timer APC to the blocked thread with SetWaitableTimer, the APC will call CancelIo from within the blocked thread, and the blocked I/O will unblock.
        I'm trying to avoid a Windows only solution.

      Nothing in the documentation suggests that signals are not the way to perform IPC

      Hmm, "unsafe" about says it all :)

      So, the problem restated is, I guess, how do I interrupt a thread from an I/O operation?

      stop using safe signals, use unsafe signals, use kill

Log In?
Username:
Password:

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://997096]
help
Chatterbox?
[hippo]: :-D
[Eily]: you mean a dll where the SW was written in perl? That sounds unlikely
[muthusathish]: please help me regarding this
[hippo]: Easier just to go and look at the source, no?
[Eily]: mostly because perl isn't compiled in the usual sense of the meaning, you can't execute the opcodes directly, you need the perl engine
[muthusathish]: i dont have the environment too, but i need to get the logics so that i can re-wite
[Eily]: what makes you think your dll is "perl based" ?
[muthusathish]: i dont have source code too
[muthusathish]: it is used in VB 6 appln, while debugging is getting error
[hippo]: Somebody has. Ask the author.

How do I use this? | Other CB clients
Other Users?
Others studying the Monastery: (8)
As of 2018-02-23 09:14 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?
    When it is dark outside I am happiest to see ...














    Results (301 votes). Check out past polls.

    Notices?