All of lore.kernel.org
 help / color / mirror / Atom feed
From: Gilles Chanteperdrix <gilles.chanteperdrix@xenomai.org>
To: Jan Kiszka <jan.kiszka@siemens.com>
Cc: Xenomai <xenomai@xenomai.org>
Subject: Re: [Xenomai] RTDM syscalls & switching
Date: Thu, 12 May 2016 18:31:42 +0200	[thread overview]
Message-ID: <20160512163142.GC18298@hermes.click-hack.org> (raw)
In-Reply-To: <5734A9F8.10305@siemens.com>

On Thu, May 12, 2016 at 06:06:16PM +0200, Jan Kiszka wrote:
> Gilles,
> 
> regarding commit bec5d0dd42 (rtdm: make syscalls conforming rather than
> current) - I remember a discussion on that topic, but I do not find its
> traces any more. Do you have a pointer
> 
> In any case, I'm confronted with a use case for the old (Xenomai 2),
> lazy switching behaviour: lightweight, performance sensitive IOCTL
> services that can (and should) be called without any switching from both
> domains.

Why not using a plain linux driver? ioctl_nrt callbacks are
redundant with plain linux drivers.

> 
> What were the arguments in favour of migrating threads to real-time first?
> 
> I currently see the real need only for IOCTLs, but the question is then
> if we shouldn't go back to "__xn_exec_current" in all RTDM cases to
> avoid unwanted migration costs (which are significantly higher than
> syscall restarts).

I do not find commit bec5d0dd42 in xenomai-2.6 git tree, and I do
not remember merging this. However I find commit
13bfdd477ab880499d2e8f3b82c49ef4d2cccff0 from 2010 which seems to
explain the reason pretty clear.

At the time of the discussion we had concluded that it was the way
to go. With __xn_exec_current you may enter the ioctl_rt callback
from secondary domain, which is counter-intuitive, error-prone, and
forces you to cripple driver code for checks for the current domain.
It optimizes the secondary mode case at the expense of the primary
mode case which is the inverse of what should be done. With
__xn_exec_conforming, you have the guarantee to enter ioctl_rt over
primary domain and ioctl_nrt over secondary domain.

See Philippe prose here also:
https://xenomai.org/migrating-from-xenomai-2-x-to-3-x/#Adaptive_syscalls

-- 
					    Gilles.
https://click-hack.org


  reply	other threads:[~2016-05-12 16:31 UTC|newest]

Thread overview: 46+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-05-12 16:06 [Xenomai] RTDM syscalls & switching Jan Kiszka
2016-05-12 16:31 ` Gilles Chanteperdrix [this message]
2016-05-12 16:50   ` Jan Kiszka
2016-05-12 16:59     ` Gilles Chanteperdrix
2016-05-12 17:12       ` Gilles Chanteperdrix
2016-05-12 17:17         ` Jan Kiszka
2016-05-12 18:20           ` Gilles Chanteperdrix
2016-05-12 18:24             ` Jan Kiszka
2016-05-12 18:30               ` Gilles Chanteperdrix
2016-05-12 18:33                 ` Jan Kiszka
2016-05-12 18:35               ` Philippe Gerum
2016-05-12 18:42                 ` Jan Kiszka
2016-05-12 19:08                   ` Philippe Gerum
2016-05-12 19:27                     ` Jan Kiszka
2016-05-12 19:47                       ` Gilles Chanteperdrix
2016-05-12 22:26                       ` Philippe Gerum
2016-05-13  5:54                         ` Jan Kiszka
2016-05-13 13:38                           ` Philippe Gerum
2016-05-13 15:32                             ` Jan Kiszka
2016-06-14 15:09                               ` Jan Kiszka
2016-06-14 15:23                                 ` Philippe Gerum
2016-06-14 15:27                                   ` Jan Kiszka
2016-06-14 15:38                                     ` Gilles Chanteperdrix
2016-06-14 15:43                                       ` Jan Kiszka
2016-06-14 15:51                                         ` Gilles Chanteperdrix
2016-06-14 16:03                                           ` Jan Kiszka
2016-06-14 16:12                                             ` Gilles Chanteperdrix
2016-06-14 16:25                                               ` Jan Kiszka
2016-06-14 16:42                                                 ` Gilles Chanteperdrix
2016-06-14 16:59                                                   ` Jan Kiszka
2016-06-14 22:12                                                     ` Gilles Chanteperdrix
2016-06-14 15:47                                     ` Jan Kiszka
2016-06-14 19:48                                     ` Philippe Gerum
2016-06-14 20:03                                       ` Jan Kiszka
2016-06-14 20:13                                         ` Philippe Gerum
2016-06-14 17:13                                   ` Jan Kiszka
2016-06-14 20:11                                     ` Philippe Gerum
2016-06-14 20:35                                       ` Gilles Chanteperdrix
2016-05-12 19:11               ` Gilles Chanteperdrix
2016-05-12 19:31                 ` Jan Kiszka
2016-05-12 19:39                   ` Gilles Chanteperdrix
2016-05-12 17:14       ` Jan Kiszka
2016-05-12 17:38     ` Philippe Gerum
2016-05-12 17:51       ` Jan Kiszka
2016-05-12 18:22         ` Gilles Chanteperdrix
2016-05-12 18:31           ` Jan Kiszka

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=20160512163142.GC18298@hermes.click-hack.org \
    --to=gilles.chanteperdrix@xenomai.org \
    --cc=jan.kiszka@siemens.com \
    --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.