• Ephera
    link
    fedilink
    arrow-up
    82
    ·
    11 months ago

    Nevermind using such frivolous things as a file system.

    • bus_factor@lemmy.world
      link
      fedilink
      arrow-up
      27
      arrow-down
      2
      ·
      11 months ago

      Using a file system is much less bad than dynamically allocating memory, at least as long as you keep a predefined set of files.

      • Troy@lemmy.ca
        link
        fedilink
        arrow-up
        34
        ·
        11 months ago

        I hate to alarm you but… What is a file system except dynamically allocated memory. ;)

              • owenfromcanada@lemmy.world
                link
                fedilink
                English
                arrow-up
                4
                ·
                11 months ago

                If you want to get really freaky, try accessing the same flash or RAM from multiple instances of FreeRTOS running on a hypervisor.

                • noli@programming.dev
                  link
                  fedilink
                  arrow-up
                  3
                  ·
                  11 months ago

                  Is that just like the shared memory model of parallel computing or are there any added complications? Have you done this before? Please do share your experiences if so cause now I’m interested :p

                  • owenfromcanada@lemmy.world
                    link
                    fedilink
                    English
                    arrow-up
                    3
                    ·
                    11 months ago

                    It’s similar, but the general idea of a hypervisor is to separate resources and avoid this exact situation (it’s nuanced and there are some exceptions, but that’s the general use case).

                    The added complication would be that when you compile a binary for one virtual machine, the compiler may optimize things, blissfully unaware that there are other players possibly affecting memory. In a typical multithreaded environment, the compiler has a better picture of how shared resources are being used across threads, but that has to be declared manually for a hypervisor. So if you configure your hypervisor to share resources, you have to be even more vigilant in configuring the individual compilers to play nice.

                    I don’t have a ton of experience with embedded hypervisors, though. And it’s worth noting that there are lots of “hypervisors” out there, and some work very differently from others.

      • kevincox
        link
        fedilink
        arrow-up
        3
        ·
        11 months ago

        a predefined set of files

        …with predefined sizes located in predefined regions of storage.