So, to paraphrase: BFS is vastly superior, but not in any way that you can actually measure.
From my understanding, your interpretation is not correct. BFS is about latency, not throughput. Ingo chose all the wrong benchmarks.
Also, it's a dick move by Ingo. CK hasn't even made a public announcement about BFS yet.
Finally, you should use code that has technical merit, regardless of the personality behind the writer. I imagine the kernel you're running on has code in it written by some pretty unfriendly people.
From my understanding, your interpretation is not correct. BFS is about latency, not throughput. Ingo chose all the wrong benchmarks.
Then how about CK showing up the right ones?
Also, it's a dick move by Ingo. CK hasn't even made a public announcement about BFS yet.
He announced it publicly enough that I knew about it, and I haven't followed this stuff in years. Given that, I hardly think that commenting on his efforts on LKML constitutes a premature "outing".
Finally, you should use code that has technical merit, regardless of the personality behind the writer. I imagine the kernel you're running on has code in it written by some pretty unfriendly people.
Indeed: one of them murdered his wife. But you brought up personalities, not me. The part of CK's post that I quoted is rather dickish, but I deliberately avoided commenting on that.
Why? It's not as if CK is trying to get it into the mainline. I think the only reason why CK got angry is that Ingo's benchmarks appear to be deliberately chosen to make BFS look bad. Anyone who took the time to read the documentation would realize that testing throughput is not correct. That'd be like benchmarking Python and C using matrix multiplication and concluding that Python sucks. Two different tools for different purposes.
He announced it publicly enough that I knew about it, and I haven't followed this stuff in years. Given that, I hardly think that commenting on his efforts on LKML constitutes a premature "outing.".
I think the announcement was mostly the work of Reddit et al., but fair enough.
Indeed: one of them murdered his wife. But you brought up personalities, not me.
Reiser was a crazy one. ;) I actually only brought up personalities because I was under the impression that you wouldn't try CK's patch because of his personality. I say if there's interesting code out there, it shouldn't go to waste because of the quirks of the author. I apologize if I misinterpreted.
Why? It's not as if CK is trying to get it into the mainline.
What does one have to do with the other? If I'm going to spend the necessary 20 minutes to compile a new kernel using CK's patch, I want some evidence that I'm going to be gaining something.
What does one have to do with the other? If I'm going to spend the necessary 20 minutes to compile a new kernel using CK's patch, I want some evidence that I'm going to be gaining something.
Then perhaps you should pay Con Kolivas to prove the value of his freely provided no-warranty work-in-progress code for you.
Nothing is ever free unless your time has no value. I've published and contributed to a great deal of open source software, much of it successful. I've been among these communities for a very long time and understand the social expectations. One of them is this: if you want anyone to care about your work, then you'd better be prepared to defend it. I would find any contrary expectation to be unbearably narcissistic, and, whatever his other failings, I think CK would agree with me on this. Think of it this way: if you published an essay containing controversial opinions, would you demand that it be immune to criticism on the basis that you're giving it away for free? I don't think software should be considered different in any case, and certainly not in this one given that CK is representing his work as an improvement over someone else's.
I've published and contributed to a great deal of open source software, much of it successful.
I have also published a great deal of open source software, much of it successful, and some of it almost universally used. Unfortunately, that does absolutely nothing to bolster either of our arguments.
If you published an essay containing controversial opinions, would you demand that it be immune to criticism on the basis that you're giving it away for free
You asked for: "I want some evidence that I'm going to be gaining something".
If we try to apply that to your analogy, why is it the author's responsibility to not only produce the work, document the work, but then also supply their own literary criticism so that you can decide if the work is worthwhile, all before the essay is completed and ready for publication?
Open source developers regularly produce software just because they want to, and feel no impetus or desire to convince you of anything. That's not, as you put it, some sort of "narcissistic" behavior, but rather a desire to simply share without additional burden or demands by others.
For what it's worth, the kind of analysis dfranke expects is required in the academic community. If you provide no evidence that what you've created is better than the status-quo, then no one will care. I don't consider this an "additional burden."
What does one have to do with the other? If I'm going to spend the necessary 20 minutes to compile a new kernel using CK's patch, I want some evidence that I'm going to be gaining something.
Ok, I can accept that. For me personally though, the quality of -ck patchset is enough for me to give CK's new stuff a shot.
Personality can be a huge problem because the kernel and its parts are a long term project and I would prefer people that can work together for its entire duration.
Accusations like "/me sees Ingo run off to find the right combination of hardware and benchmark to prove his point." is far from the level of civility I would entrust my favorite OS's kernel. The proper response would be something in the line "it will suck on this benchmarks, but it will excell in these others and in these hardware configurations" and show numbers. It's always possible to act in a civilized way.
That said, CK seems only a bit off when compared to a couple others. There are a lot of people who like to be quite caustic from time to time. I must confess I have to refrain myself frequently and HN is not LKML.
And, more important: this whole discussion is more or less pointless. It doesn't matter how good a modern scheduler is, all of them impose a very little penalty on a modern kernel. Are we really going to fight this bitterly over a couple percentage points?
Would that be so hard as to include a "-scheduler=" switch in the kernel for it to be selectable at boot time (and so I can pick one that fits both my netbook and my SGI 4096 CPU monster when I want to)? This would pretty much end this discussion.
All good kernel micro-benchmarks will involve a ton of volume, and thus be exercising throughput. All the micro-benchmarks Ingo used are extremely latency-focused: a few processes blocking on Pipe I/O or messaging as frequently as possible -- the only subject of the test is how fast the scheduler can toggle between the processes.
BFS was dramatically worse across the board in all the benchmarks, except curiously when the # of processes == # of logical processors -- to me that's evidence of extreme naivete in its design.
It's not that Ingo chose the wrong benchmarks. The right benchmarks don't exist, and we're not even sure how to build them. Unfortunately, building a scheduler optimized for "unbenchmarkable" use cases is a recipe for misunderstanding.
The right benchmarks for the stated goals of BFS do exist. BFS is hardly "unbemchmarkable"; the only thing being misunderstood here is the goal of BFS.
From my understanding, your interpretation is not correct. BFS is about latency, not throughput. Ingo chose all the wrong benchmarks.
Also, it's a dick move by Ingo. CK hasn't even made a public announcement about BFS yet.
Finally, you should use code that has technical merit, regardless of the personality behind the writer. I imagine the kernel you're running on has code in it written by some pretty unfriendly people.