cross-posted from: https://lemmy.zip/post/26533086

Linux kernel 6.12 is one of the most significant releases of the year, delivering a feature nearly 20 years in the making: true real-time computing.

  • nanook@friendica.eskimo.com
    link
    fedilink
    arrow-up
    16
    ·
    2 months ago

    The 6.12 kernel UHD630 graphics worked when not compiled for realtime but just voluntary preemption. So I have filed Bug 219510. I suspect the kernel team will refer me to Intel since they actually maintain this driver, then Intel will say well it worked when the kernel people didn’t hack it for real time and it will end up going nowhere but time will tell. Without a working display, I can’t really test KVM/QEMU so will have to wait for action on this bug.

  • thingsiplay@beehaw.org
    link
    fedilink
    arrow-up
    11
    ·
    2 months ago

    As I understand it, most kernel operations can’t be interrupted (i.e., they’re non-preemptible). But PREEMPT_RT allows high-priority tasks to interrupt lower-priority ones near-instantly. For specific types of tasks this improves response times and thus performance.

    I never looked into the details of realtime Kernel. I know it is or was used for professional realtime audio mixing and recording and such. Besides that, if this improves response times, would gaming benefit from this? What are downsides for using a realtime Kernel for gaming?

    • CameronDev@programming.dev
      link
      fedilink
      arrow-up
      26
      ·
      edit-2
      2 months ago

      Realtime doesn’t necessarily mean low latency, it means consistent latency.

      So if the latency from and input takes 1s, that is realtime, as long as its always 1s.

      Typically for gaming you want the lowest latency possible, and at least historically, that meant not realtime.

      Edit: Some examples with made up numbers:

      Airbag: you want an airbag to go off EVERY time, and if that means it takes 10ms, thats usually OK. RT guarantees that your airbag will go off 10ms after a crash every time.

      Games: you want your inputs handled ASAP, ideally <5ms, but if one or two happen after 100ms, you’ll likely not notice. If you enable RT, maybe all your inputs get handled after 10ms consistently, which ends up feeling sluggish.

      Unless you know you need RT, you probably dont actually want it.

      • Realtime doesn’t necessarily mean low latency, it means consistent latency.

        This is such a critical distinction which can be counter-intuitive. In this case, their game may run slower, they just won’t get lags resulting from local resource contention. And even that statement has caveats.

        One of the biggest difference between self-taught developers and ones with CS degrees is that the ones with degrees usually understand a lot of important theory, such as O(1) means constant time, not necessarily fast time.

        • CameronDev@programming.dev
          link
          fedilink
          arrow-up
          2
          ·
          2 months ago

          It doesn’t help that its not well named, realtime makes it sound fast.

          One of the few things I remembered from my degree was the realtime programming course, because we got to program a model train set in Ada, on a 286(?), running on floppies. This was in ~2015, so ancient hardware even then, and it was slow, but it was “realtime”.

          Interestingly, my compsci degree never covered O notation, so that I’ve had to pick up along the way :/

          • Interestingly, my compsci degree never covered O notation, so that I’ve had to pick up along the way :/

            Really‽ That’s a shame. It’s one of the topics that, in my programming career, was regularly valuable and used. That, set theory, and discrete math have an been broadly applicable even in the most banal applications. It’s a shame if it’s not part of the CIS curriculum at some universities.

      • thingsiplay@beehaw.org
        link
        fedilink
        arrow-up
        7
        ·
        2 months ago

        Games: you want your inputs handled ASAP, ideally <5ms, but if one or two happen after 100ms, you’ll likely not notice. If you enable RT, maybe all your inputs get handled after 10ms consistently, which ends up feeling sluggish.

        Actually I think its the other way for gaming: If you have consistent input delay, it will not feel sluggish. Same why consistent 30 fps feels better than varying 31 to 39 fps. Similar for gaming, especially if you play speedrun or 1vs1 fighting games, you would want to have consistent delay. However, if that adds too much delay its probably counterproductive. But for single player games, a consistent delay is the opposite of sluggish.

        • CameronDev@programming.dev
          link
          fedilink
          arrow-up
          2
          ·
          2 months ago

          At low numbers, it doesnt matter. If you exqgerate the numbers the effect is more clear.

          Eg. if the latency was 100ms, it would feel your movments are behind by 100ms, which would be unplayable.

          But if you had a typical latency of 10ms, with rare spikes to 1s, the spikes would be considered lag, and annoying, but most of the time its good and playable.

          • nanook@friendica.eskimo.com
            link
            fedilink
            arrow-up
            4
            ·
            2 months ago

            @CameronDev @thingsiplay I refer you to this: https://www.pubnub.com/blog/how-fast-is-realtime-human-perception-and-technology/

            That said, we did an experiment in a physics class many years ago where by there was a beeper and an electromagnet that were powered by the same source. The electromagnet held a yard stick in place. When the beeper went off we were supposed to push a button in response. The button stopped the fall of the yardstick. Then by calculating how far the yard stick fell using the 32m/s^2 speed of gravitational acceleration we calculated how long response was, average was about 200ms, I responsed in 30ms, however this only works for me for auditory queues, visual is more delayed for me, and I can’t detect any change in under 20ms and just barely at that, let alone respond to it. But what I learned in that class was that reaction times varied individual to individual by a factor of about ten, so what is true for one person may not be for another.

            • Ghoelian@lemmy.dbzer0.com
              link
              fedilink
              arrow-up
              1
              ·
              2 months ago

              Yeah it definitely varies per person, and I think you can even train for it somewhat.

              I used to play a lot of guitar hero, and I think this improved my visual “latency” a lot, to the point where I could definitely tell when something was visually 5-10ms out of sync (in the case of guitar hero, when you strum the bar vs when the note lines up with the strikeline).

        • nanook@friendica.eskimo.com
          link
          fedilink
          arrow-up
          1
          ·
          2 months ago

          @thingsiplay @CameronDev I agree consistent delay is better because your brain automatically adjusts for it, it has several hundred milliseconds of delay built-in, but inconsistent sub-millisecond delay is not going to be humanly detectable.

    • nanook@friendica.eskimo.com
      link
      fedilink
      arrow-up
      1
      ·
      2 months ago

      @thingsiplay @recursive_recursion

      With respect to gaming, the answer is a definite “maybe”. Here is the thing with a real time kernel, context switching is expensive, and especially so when going between kernel and userland mode. This is because you have to save/restore all the registers on the stack so there are a lot of memory cycles involved in a context switch. A realtime kernel increases context switching a LOT so you’re going to eat more CPU than you otherwise would but on the other hand, critical things will get attended to in a more timely manner. So whether the latency or the overall computational efficiency is more important will make the difference in gaming. Also to some degree hardware, most games will only use 4 cores or so, a few more than that but most only about 4, so if you’ve got an 18 core machine, you have plenty of core for the extra kernel overhead, it is more likely to benefit than if you’re on a 4-core machine with all the cores already saturated.

  • SuperSpruce@lemmy.zip
    link
    fedilink
    arrow-up
    6
    ·
    2 months ago

    Does this turn Linux into a RTOS that can do stuff like control the ECU or traction control for a motorcycle?

  • nanook@friendica.eskimo.com
    link
    fedilink
    arrow-up
    2
    ·
    2 months ago

    I’ve avoided RT thus far because it was incompatible with KVM/QEMU. Am curious if this is still the case. Guess I can compile and install on my workstation and see
    if my virtual machines still work.

    • recursive_recursion they/them@lemmy.caOP
      link
      fedilink
      English
      arrow-up
      2
      ·
      2 months ago

      I’ve avoided RT thus far because it was incompatible with KVM/QEMU. Am curious if this is still the case.

      I didn’t even realize that this was a known problem.

      Guess I can compile and install on my workstation and see if my virtual machines still work.

      I’d appreciate it if you could also let me know how it goes! I’m hoping that it just_works.™️ on your end🫡

  • twinnie@feddit.uk
    link
    fedilink
    arrow-up
    1
    ·
    29 days ago

    “FireWire improvements”

    I haven’t heard anyone mention FireWire in 20 years.