All of lore.kernel.org
 help / color / mirror / Atom feed
From: Jan Kiszka <jan.kiszka@siemens.com>
To: Philippe Gerum <rpm@xenomai.org>
Cc: xenomai@xenomai.org
Subject: Re: [Dovetail] x86 test version available (kernel v5.10)
Date: Mon, 15 Feb 2021 18:19:47 +0100	[thread overview]
Message-ID: <1346fbeb-63b6-4f29-e91d-deb1f200a195@siemens.com> (raw)
In-Reply-To: <5a957790-9b3e-4df1-e0e8-96fa4e92e1eb@siemens.com>

On 15.02.21 17:53, Jan Kiszka via Xenomai wrote:
> On 15.02.21 16:11, Jan Kiszka via Xenomai wrote:
>> On 15.02.21 14:28, Jan Kiszka wrote:
>>> Now the next issue is
>>>
>>> /usr/lib/xenomai/testsuite/smokey: test sched_quota failed: Protocol error
>>> sched-quota.c:332, out of quota: 13.7%
>>> (on a real target, an Atom-class box).
>>>
>>
>> Testsuite issue, long pending:
>>
>> https://gitlab.denx.de/Xenomai/xenomai/-/blob/master/testsuite/smokey/sched-quota/sched-quota.c#L204
>>
>> Those pthread_kill() in the loop will kick the caller into non-rt, while
>> it is not yet done with collecting the loop counters from the other
>> workers. Result is pure random, sometimes still within the defined
>> limits, but sometimes reporting false overruns.
>>
>> No idea what those signal submissions supposed to do - test runs and
>> terminates fine without them as well.
>>
> 
> Correction: The pthread_kill stay in primary and do not cause the issue
> (they are still not needed IMHO, though).
> 
> It must be something compiler (setting?) related: smokey built with my
> gcc-7 from SUSE is fine, the one build with Debian's gcc-8 is not,
> causing noteworthy variations on the measured workload. Examining further...
> 

It was gcc-10 in fact on my machine - but the actual difference was
--enable-debug=full here vs. no debug in xenomai-images. Without full
debugging, the loop calibration becomes too instable, likely because the
inner __do_work is reduced to a simple

  417960:       48 8d 47 01             lea    0x1(%rdi),%rax
  417964:       c3                      retq

This can be mitigated by extending the calibration loop (crunch_loops =
100000).

Jan

-- 
Siemens AG, T RDA IOT
Corporate Competence Center Embedded Linux


  reply	other threads:[~2021-02-15 17:19 UTC|newest]

Thread overview: 20+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-01-31 16:06 [Dovetail] x86 test version available (kernel v5.10) Philippe Gerum
2021-02-01 17:32 ` Jan Kiszka
2021-02-03 17:35   ` Philippe Gerum
2021-02-06 12:29     ` Jan Kiszka
2021-02-06 17:23       ` Philippe Gerum
2021-02-15 13:28       ` Jan Kiszka
2021-02-15 15:11         ` Jan Kiszka
2021-02-15 16:53           ` Jan Kiszka
2021-02-15 17:19             ` Jan Kiszka [this message]
2021-02-15 17:07           ` Philippe Gerum
2021-02-15 17:21             ` Philippe Gerum
2021-02-22 15:35 ` Henning Schild
2021-02-22 17:59   ` Henning Schild
2021-03-11 16:35   ` Henning Schild
2021-03-12  7:22     ` Jan Kiszka
2021-03-12 11:32       ` Jan Kiszka
2021-03-12 18:18         ` Henning Schild
2021-03-12 19:46           ` Henning Schild
2021-03-12 19:53             ` Henning Schild
2021-03-15  7:57               ` 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=1346fbeb-63b6-4f29-e91d-deb1f200a195@siemens.com \
    --to=jan.kiszka@siemens.com \
    --cc=rpm@xenomai.org \
    --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.