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.
next prev 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.