Hi John, On Fri, Dec 18, 2020 at 10:57:22AM -0500, John Kacur wrote: > On Fri, 18 Dec 2020, Daniel Wagner wrote: > > > As we have a hard dependency on libnuma we can simplify the code in > > cyclictest. This allows remove all the small helpers in rt_numa.h. And > > with this we can remove the header and reduce the confusion with > > rt-numa.h > > This is why I asked you to keep numa functions separate from any common > library. The reason the file exists, is in the past I had two versions > of each numa function, one for architectures that supported libnuma, and > empty wrapper versions for ones that didn't. This is what I figured as well. So with the decission to have the dependency on libnuma a lot of things can be simplified. > There are two buts. The first one, is that I see the other programs in > the test suite that mimic cyclictest behaviour are getting more attention, > so I could imagine as we try to strengthen their behaviour that we could > add numa support to these programs as well. Indeed, this is what I hand in mind too. Parsing the --affinity string should be done with the libnuma. One thing we could try to achieve is to common parser options so that we only have one function for it. Not sure if this would be possible though. > The other but, is that I'm > seeing the need recently to add support for a lot of architectures that > we didn't care so much about in the past, and not all of them have libnuma > so we might want to do the same trick as in the past, add wrapper versions > in a header file. I am sure with rt getting closer to mainline there will be more interest in the tests. I'd say we should rather get libnuma supported on those architectures instead of trying to work around here. Debian says libnuma is available on - alpha - amd64 - arm64 - armel - armhf - hppa - i386 - m68k - mips64el - mipsel - ppc64 - ppc64el - riscv64 - s390x - sh4 - sparc64 - x32 Which architectures is missing? > So I propose, we take your patches to get rid of the file, because it will > clean things up a lot, but then we may have to go back to creating > something like the rt_numa.h file anew. Removing rt_numa.h first is good > though, because if we don't have to create it anew the code has been > cleaned-up, and if we do recreate it from scratch, it will be better for > having cleaned-up how numa works in cyclictest Yes, that was my whole indent of this series. First to cleanup the current rt-numa.h code as much as possible before we adding new stuff. > This is also an example of something that was evoling in exactly this > direction. When Thomas wrote cyclictest, it made sense to have smp, but if > I were to rewrite everything from scratch I wouldn't have it there. That's why I opted to make '-a' a bit more powerful :) > Note also that smp isn't just a kind of hardware for cyclictest, you > can still see this is the help - it gathered up the -a and -t options > and put all threads at the same prio. This hasn't changed. So you can place N threads evenly placed on the provided cpumask. Not sure why I want to have more threads on the CPU, but well, it's supported. > So, thanks again for doing this. A word of warning I spent a long > time fiddling with affinity to make it finally work correctly, so > I'm going to test the sh*t out of your changes to make sure they don't > break anything before I accept them. Please test it carefully. I tried not to breaks it but I wouldn't be surprised you find something. > A final comment, the idea of an "unstable" devel branch, > the "unstable" refers not to the code being iffy, but to the fact > that I wanted developers to feel free to break the old API, and not be > constrained with backwards compatability, so as you clean this stuff-up > if you want to remove -S, it's fine with me. Hopefully if we take away > anything that users want they'll yell at us, but I think we're pretty > careful about necessary functionality. Maybe after things are cleaned-up > we will have to add a new flag to specify the same prio for all > threads? IIRC, Debian was not particular happy with the option getting dropped within a major version. So it's not just rtval using it. Also there is LAVA's test-definitions (which I use) but this shouldn't be a real problem as it's easy to update. Though as said, distros are not happy if we change the existing options. Given that it's not a real burden to keep -S around I would just cary around until we have a real need for it to go. > I think I'll spin off a new version of rt-tests before accepting this > set of patches. Good idea! Thanks, Daniel