Date: Tue, 9 May 2023 19:19:53 -0700 From: Mark Millard <marklmi@yahoo.com> To: FreeBSD Hackers <freebsd-hackers@freebsd.org> Cc: freebsd-arm <freebsd-arm@freebsd.org> Subject: Cores of different performance vs. time spent creating threads: Windows Dev Kit 2023 example Message-ID: <11EBAA22-6E0F-4B27-9799-7786E149D9B1@yahoo.com> References: <11EBAA22-6E0F-4B27-9799-7786E149D9B1.ref@yahoo.com>
next in thread | previous in thread | raw e-mail | index | archive | help
First some context that reaches an oddity that seems to be involved in the time to create threads . . . The Windows Dev Kit 2023 (WDK23 abbrevation here) boot reports: CPUs (cores) 0..3: cortex-a78c (the slower cores) CPUs (cores) 4..7: cortex-x1c (the faster cores) Building a kernel explicitly via involving -mcpu= use gets the following oddity relative to cpu numbering when the kernel is used: -mcpu=cortex-x1c or -mcpu=cortex-a78c: Benchmarking tracks that number/performance pairing. -mcpu=cortex-a72: The slower vs. faster gets swapped number blocks. So, for -mcpu=cortex-a72 , 0..3 are the faster cores. This sets up for the following . . . But I also observe (a relative comparison of contexts via some benchmark-like activity): -mcpu=cortex-x1c or -mcpu=cortex-a78c based kernel: threads take more time to create -mcpu=cortex-a72 based kernel: threads take less time to create The difference is not trivial for the activity involved for this WDK23 context. If there is a bias as to which core(s) are involved in part of thread creation generally, it would appear to be important that the bias to be to the more performant cores (for what the activity involves). The above suggests that such is possibly not necessarily the case for FreeBSD as is. BIG/little (and analogous?) cause this to become more relevant. Does this hypothesis about what type of thing is going on fit with how FreeBSD actually works? As stands, I'm going to experiment with the WDK23 using a cortex-a72 targeted kernel but a cortex-x1c/cortex-a78c targeted world for my general operation of the WDK23. Note: While the benchmark results allow seeing in plots what traces back to thread creation time contributions, the benchmark itself does not directly measure that time. It is more like, the average work rate for a time changes based on the fraction of the time involved in the thread creations for each given problem size. The actual definition of work here involves a mathematical quantity for a mathematical problem (that need not be limited to computers doing the work). The benchmark results are more useful for discovering that there is something to potentially investigate than to actually do an investigation with. === Mark Millard marklmi at yahoo.com
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?11EBAA22-6E0F-4B27-9799-7786E149D9B1>