All of lore.kernel.org
 help / color / mirror / Atom feed
From: Gilles Chanteperdrix <gilles.chanteperdrix@xenomai.org>
To: Steve Deiters <SteveDeiters@domain.hid>
Cc: xenomai@xenomai.org
Subject: Re: [Xenomai-help] Mixing skin calls (cancellation points)
Date: Wed, 07 Jul 2010 14:50:29 +0200	[thread overview]
Message-ID: <4C347815.9050107@domain.hid> (raw)
In-Reply-To: <181804936ABC2349BE503168465576460F3847C2@domain.hid>

Steve Deiters wrote:
> Is it in general valid to mix calls from different skins?  In
> particular, can I expect the native skin calls to work as POSIX
> cancellation points?  For example, if I have a POSIX thread with a
> pthread_t identifier which I know calls rt_cond_wait somewhere, will it
> work as a cancellation point when I call pthread_cancel?
> 
> The example program attached will not cancel if I have CANCEL_DEFERRED
> defined as 1 at the top, which sets the cancel type to deferred.  This
> is on a PowerPC with Xenomai 2.5.3.  I think this worked with Xenomai
> 2.4.10.

Hi,

I had a look at the code, and chances are, that in fact it never worked.
The native skin threads are created with asynchronous type, and the rest
 of the skin assumes that it is always the case. To kill a native skin
thread, you are supposed to use rt_task_delete instead of
pthread_cancel, and if you did not change the thread cancellation type,
it will work. If you are interested in waiting for the thread deletion,
you can create the thread joinable with T_JOINABLE, then wait for it
with rt_task_join.

We can, of course, modify the code to allow changing the native thread
cancellation type. But the question is: what is the use-case?


-- 
					    Gilles.


  parent reply	other threads:[~2010-07-07 12:50 UTC|newest]

Thread overview: 11+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-07-06 18:36 [Xenomai-help] Mixing skin calls (cancellation points) Steve Deiters
2010-07-06 18:41 ` Gilles Chanteperdrix
2010-07-06 19:03   ` Steve Deiters
2010-07-06 19:15     ` Gilles Chanteperdrix
2010-07-07 12:50 ` Gilles Chanteperdrix [this message]
2010-07-07 15:20   ` Steve Deiters
2010-07-07 16:36     ` Gilles Chanteperdrix
2010-07-07 16:55       ` Steve Deiters
2010-07-07 17:14         ` Gilles Chanteperdrix
2010-07-07 17:25         ` Gilles Chanteperdrix
2010-08-01 22:11           ` Gilles Chanteperdrix

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4C347815.9050107@domain.hid \
    --to=gilles.chanteperdrix@xenomai.org \
    --cc=SteveDeiters@domain.hid \
    --cc=xenomai@xenomai.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.