Slashdot Mirror


Linus Torvalds No Longer Knows the Whole Linux Kernel and That's OK (eweek.com)

darthcamaro writes: In a wide-ranging conversation at the Open Source Summit, Linus Torvalds admitted that he no longer knows everything that's in LInux. "Nobody knows the whole kernel anymore," Torvalds said. "Having looked at patches for many years, I know the big picture of all the areas in the kernel and I can look at a patch and know if it's right or wrong." Overall, he emphasized that being open source has enabled Linux to attract new developers that can pick up code and maintain all the various systems in Linux. In his view, the only way to deal with complexity is to be open. "When you have complexity you can't manage it in a closed environment, you need to have the people that actually find problems and give them the ability to get involved and help you to fix them," Torvalds said. "It's a complicated world and the only way to deal with complexity is the open exchange of ideas."

46 of 119 comments (clear)

  1. Blame Google by Aighearach · · Score: 1

    He probably just has too many search tools, so now he's more stupider.

  2. Re: Open source is winning. by jfdavis668 · · Score: 1

    No, but there is a Palm OS.

  3. Re:Monolithic Kernels by Anonymous Coward · · Score: 3, Insightful

    I'll bite the flamebait regarding monolithic vs micro kernels.

    The assertion that Torvalds not knowing all of what in Linux simply means that those subsystems were logically delegated out. In a microkernel, those same subsystem functions would still be done by a different group, except they wouldn't be in kernel.

    Simply because a kernel is "monolithic" doesn't mean that there aren't subsystems that your primary kernel architect needs to fully understand. For example, a video driver. That's very specific knowledge that you wouldn't expect Torvalds to really need to know.

    In a lot of ways Torvalds has moved on to more of a project manager/architect role than just a straight code hacker.

  4. Re: Open source is winning. by Anonymous Coward · · Score: 1

    The only app that it can run is twitter. Anything else results in a kernel panic saying, "I never crash."

  5. Steered clear of toxic community issues by Tough+Love · · Score: 1

    Linus steered clear of toxic community issues and the interviewer softballed him on it, or actually completely glossed over it. Can't see that as a good thing, it looks a lot like the ostrich defence.

    --
    When all you have is a hammer, every problem starts to look like a thumb.
    1. Re:Steered clear of toxic community issues by guruevi · · Score: 2

      What toxic community issues? The Linux kernel is going well regardless of small skirmishes in the political arena. It's good that Linus steers clear of them because nobody wins.

      --
      Custom electronics and digital signage for your business: www.evcircuits.com
    2. Re:Steered clear of toxic community issues by Tough+Love · · Score: 1
      --
      When all you have is a hammer, every problem starts to look like a thumb.
    3. Re:Steered clear of toxic community issues by guruevi · · Score: 1

      All those articles point to one idiot that quit because he couldn't take criticism. Being criticized is not toxic.

      --
      Custom electronics and digital signage for your business: www.evcircuits.com
    4. Re:Steered clear of toxic community issues by Anonymous Coward · · Score: 1

      Every single person who uses the term toxic in this way is an absolute fucking moron. I'm glad you people use it, though, because it makes it easy to identify and ignore you wankers. You'll probably need to find a safe space to deal with this.

    5. Re:Steered clear of toxic community issues by Anonymous Coward · · Score: 5, Informative

      I read them, they all concern Sarah Sharp, the looney feminist substandard kernel dev who tried to inject herself into a linux kernel ml thread she wasn't even a part of and bait Linus into saying something nasty to her and failed miserably do it. Standard SJW ploy targeting male leadership who aren't cowed by feminist bullshit. In shame, she had to leave the project. Not even sure if she's still employed by Intel anymore. Probably not.

      OMG, they is hilarious!!

      Sage Sharp @_sagesharp_Diversity & inclusion consultant at @ottertechllc. @outreachy organizer. Explorer of the kyriarchy. Hufflepuff. Non-binary (agender trans masculine). They/them.

      Not even a programmer anymore. Pathetic.

    6. Re:Steered clear of toxic community issues by Zero__Kelvin · · Score: 1

      He said in the Altoa talk that "People who are offended should be offended." In other words he is well aware that it keeps people like you away, and that is a good thing ... a very, very good thing.

      --
      Guns don't kill people; Physics kills people! - John Lithgow as Dick Solomon on Third Rock From The Sun
    7. Re:Steered clear of toxic community issues by Tough+Love · · Score: 1

      You must be lots of fun at parties

      --
      When all you have is a hammer, every problem starts to look like a thumb.
    8. Re:Steered clear of toxic community issues by KiloByte · · Score: 1

      He doesn't let political crap into the kernel. One example here.

      --
      The creatures outside looked from Alt-Right to Antifa; but already it was impossible to say which was which.
  6. stop it by ArylAkamov · · Score: 3, Informative

    "and that's okay"
    I agree in this case. However. Stop trying to tell me how to feel and think, you cunt. Your job is to report.

    1. Re:stop it by Jeremi · · Score: 1

      Dude's job is whatever his boss says it is. He who pays the piper calls the tune, not the entitled and obnoxious freeloaders of the Internet.

      --


      I don't care if it's 90,000 hectares. That lake was not my doing.
    2. Re:stop it by Zero__Kelvin · · Score: 3, Insightful

      Linus says it is OK (as in not some OMFG issue to be concerned about) and the reporter reported that. DOH!

      --
      Guns don't kill people; Physics kills people! - John Lithgow as Dick Solomon on Third Rock From The Sun
  7. Nice excuse there, I guess by Anonymous Coward · · Score: 1

    "When you have complexity you can't manage it in a closed environment, you need to have the people that actually find problems and give them the ability to get involved and help you to fix them,"

    And that's how backdoors can be slipped into the Kernel by the big bad guys who are pretending to be fixing something or updating its drivers.
    Complexity (in software) is indeed the enemy of security.

     

  8. Spoken like a true idiot by Anonymous Coward · · Score: 1

    "When you have complexity you can't manage it in a closed environment"

    Try working in a manufacturing environment some time, Linus, because we manage the complexity all the time. For example, solar panels - HUGE amounts of detail you need to pay attention to (even one bad solder joint destroys a panel during lamination) and yet we manage this all the time, with all of our documentation very much closed off to the outside world. Hell, we even manage our constantly-changing crew, and there's not much of a problem there, either.

    You just can't manage the complexity it because you lost 100% control. Admit it. Just like you lose control of your mouth.

    1. Re: Spoken like a true idiot by Anonymous Coward · · Score: 1

      Elon?

  9. Software more efficient? by phantomfive · · Score: 5, Interesting

    "Performance is not really doubling every two years and that's good," Torvalds said. "It means we'll maybe go back to the time when you cared more about performance on the software side and you had to be more careful and couldn't just rely on hardware getting better."

    He's wrong: it means we'll just get slower and slower software because hardly anyone knows how to do anything besides paste libraries together.

    --
    "First they came for the slanderers and i said nothing."
    1. Re:Software more efficient? by Kjella · · Score: 1

      He's wrong: it means we'll just get slower and slower software because hardly anyone knows how to do anything besides paste libraries together.

      Except when they write massive kludges of spaghetti code that should have been a library or used the standard library. It's not that libraries are inherently bad, I mean you couldn't even write print( "Hello world!" ) without something interpreting letters to bitmaps and defining what a "standard output" is. The problem is often that these libraries grow because there's always one more use case to cover until they become huge and complex. At which point somebody decides fuck it, I don't need this let's just start over.

      For example take the software above, it would be really nice if we had some kind of string class right? With convenience functions like length(), substring(), append() etc. but real simple ASCII with values 0-127 that always means the same. Then comes a European who wants their mööse and you got code pages. Then Unicode and multi-byte, variable or fixed length characters, sort collations and so on. And while it doesn't necessarily gets slower the library becomes big and complex with a big interface. And then someone says fuck it, this is too much for me to bother with.

      And then you have the printing of "Hello world!", it's no longer a bitmap. It's a FreeType font of vector shapes with kerning and anti-aliasing and whatnot requiring an advanced rendering engine to actually have something to display. And if you wanted to print the date, well there's probably a huge library for that too with short forms and long forms and conversions to/from string format and leap seconds and whatnot. And that's not even starting to get into the fun of input/output devices, networking or whatever... you are in a library world already. Some of them are just a really bad idea.

      --
      Live today, because you never know what tomorrow brings
    2. Re:Software more efficient? by Zero__Kelvin · · Score: 1

      Now that is hilarious. I guarantee you that anyone like that has *never* had their code make it into staging, never mind mainline.

      --
      Guns don't kill people; Physics kills people! - John Lithgow as Dick Solomon on Third Rock From The Sun
    3. Re:Software more efficient? by phantomfive · · Score: 1

      . It's not that libraries are inherently bad,

      It's not that libraries are inherently bad, but a lot of the ones powering the 'modern' web are bad.

      --
      "First they came for the slanderers and i said nothing."
  10. Bill neither by hcs_$reboot · · Score: 1

    Gates and his "640k ought to be enough for anybody" proved he didn't know what was happening within his OS.

    --
    Slashdot, fix the reply notifications... You won't get away with it...
    1. Re:Bill neither by Stormwatch · · Score: 1

      He denied ever saying such a thing. And to be fair, that was a lot back then. Most 1980s home computers maxed out at 64 KB.

    2. Re:Bill neither by Zero__Kelvin · · Score: 1

      It was Paul Allen's OS actually. Gates was the Jobs at Microsoft. Allen was the Wozniak.

      --
      Guns don't kill people; Physics kills people! - John Lithgow as Dick Solomon on Third Rock From The Sun
    3. Re:Bill neither by Zero__Kelvin · · Score: 1

      Starting with a purchased codebase doesn't mean the guy who takes it forward until Cutler got involved is "just a BASIC guru." I guess you didn't know that Applesoft BASIC was written in assembly language just like DR DOS.

      --
      Guns don't kill people; Physics kills people! - John Lithgow as Dick Solomon on Third Rock From The Sun
    4. Re:Bill neither by Megol · · Score: 1

      Gates wrote code, did Jobs?

    5. Re:Bill neither by Zero__Kelvin · · Score: 1

      6 year olds write code. Trying to say writing code makes you someone that at one point understood a whole OS - even one as relatively simple as DOS - is absurd. I have seen an interview with Gates where he himself states that he was never a good coder. Remember when Gates told stories about his many technical interactions with Wozniak? No, that is right ... every time there was an interaction between Gates and Apple it was Gates talking to Jobs. Are there any other brilliant rhetorical questions or assertions you would like to make?

      --
      Guns don't kill people; Physics kills people! - John Lithgow as Dick Solomon on Third Rock From The Sun
    6. Re:Bill neither by Zero__Kelvin · · Score: 1

      You have confused competent programmer with bullshit artist. Nobody with a clue, and I mean nobody, would make such a ridiculously absurd claim. Real programmers have had the experience of looking at code they wrote last year and wondering who wrote it.

      --
      Guns don't kill people; Physics kills people! - John Lithgow as Dick Solomon on Third Rock From The Sun
  11. Re: Open source is winning. by Daemonik · · Score: 1

    TrumpOS loudly declares all other OSes to be enemies of the people and fake data.

  12. Re: Monolithic Kernels by Stormwatch · · Score: 2

    Mach. Good enough?

  13. Re:Monolithic Kernels by LostMyBeaver · · Score: 5, Interesting

    There is something in-between.

    I love microkernels and have written a few for personal entertainment. I have even been following Fuschia OS's development quite closely... though I can't believe anyone would make something that shitty from the ground up in 2018.

    A more or less monolithic with a pluggable and stable ABI and API is often the best of both worlds. Add some form of module signing and code review process and we're in a good place.

    After all these years, there has been ample opportunity to optimize microprocessor design to make a better microkernel CPU. There is generally just too much cost involved in the constant context swaps for a desktop OS. Remember that we spent many years trying to trim the fat between application and graphics subsystems. Even today, it's pretty simply to almost devastate the performance of a micro kernel with a massive amount of disk I/O operations.

    Last month, I wrote a new Linux kernel module. I needed to implement the Cisco Discovery Protocol on Linux in a less stupid way than it's been done until now. I believe I achieved doing it equally dumb from an opposite direction. This is because the Linux Kernel is an enormous disaster of crap on crap.

    Let's talk about something relatively simple that should have been ripped out and entirely moved out of the kernel a LONG time ago... the network stack.

    The Linux network stack is amazingly fast and should be given credit for being that way.

    It's also a cesspool of shit code from almost end to end. Probably the most important piece of code in the Linux kernel is sk_buff. Oh... sk_buff, you are the biggest, ugliest and shittiest piece of code in the entire world. I mean... you're a buffer... a kinda sorta reference counted buffer which never really gets deleted...except when you do. You're a huge chunk of trash code that looks like you were designed by a drug fuddled preschooler that wanted to try daddy's C compiler while on a series trip.

    sk_buff is probably the most critical piece of code to keep the documentation up to date on. This is the code which makes things like kernel panics in the weirdest ways when even the slightest thing goes wrong. And yet, after 27 years of Linux, you guys still can't seem to stabilize the API for the frigging network buffer!!!

    Then let's consider procfs...

    So... procfs is basically the ability for a user mode application to access a file and it calls procedures for reads and writes... well all files in the kernel work that way, but procfs is a bit special, it was meant to be informative and work in a printf'ish kinda way.

    procfs for the most part is nothing more than, open, read, write, seek, close. It doesn't need anything other than that. It's a simple random access file stream.

    Somehow, the API is still changing like mad... and worse the transition mechanisms that support the newer APIs are actually getting removed from the kernel ... I'm not talking about a few years after stabilizing, I'm talking as soon as the monster code base called the kernel no longer depends on them. Forget that there are external modules build from DKMS other other tools that need to handle different versions. And we're not talking about massive APIs, we're talking about things that support name changes.

    I was looking into adding a new address family to the kernel for CDP... and I tried looking at other code for a good example. I absolutely refuse to make pull requests to the Linux kernel unless it's a bug fix (and deleting the whole tree and starting over doesn't count). I believe that tools like DKMS should point to git repositories and download drivers and build them against the kernel. CDP does not need to be part of the mainstream kernel. It's a tool.

    Well, as I said, I was looking into it. And after this many years, because of the absolute shitty state of the kernel... I'd at least have to register AF_CDP and PF_CDP somewhere so that I could have my very own protocol number. And for the most part, that would prob

  14. Re:Monolithic Kernels by religionofpeas · · Score: 2

    After all these years, there has been ample opportunity to optimize microprocessor design to make a better microkernel CPU. There is generally just too much cost involved in the constant context swaps for a desktop OS

    The reason that microkernels suck has nothing to do with context swap inefficiencies. The biggest problem is trying to maintain a synchronised state between the different tasks across different memory protection areas.

    A simple example is a file system. Imagine a dozen different tasks, all working on the same file system, As soon as one task makes a change (say, delete a file), all other tasks are working with an outdated snapshot of the file system state. Unless notified of the change, this will lead to corruption. And notifying all tasks of every little change would be hugely inefficient, not just because of all the overhead of sending the messages, but also because tasks would need to be made with frequent check points. In the end, it would do nothing to simplify the overall system, because you'd basically be implementing a virtual shared memory, and you'd have to deal with exactly the same issues as with a real shared memory.

    The tradition solution in microkernels is to have a single task running the file system. This may be a practical idea on some small scale single user systems, but it's totally unacceptable on a larger server, say a big web server with a few hundred simultaneous connections.

  15. Re: Monolithic Kernels by Stormwatch · · Score: 1

    You better be trolling.

  16. Re:Monolithic Kernels by Zero__Kelvin · · Score: 4, Insightful

    What did Linus say when you used your obviously elite dev skills to rewrite sk_buff elegantly and submitted it to him and his team for review?

    --
    Guns don't kill people; Physics kills people! - John Lithgow as Dick Solomon on Third Rock From The Sun
  17. Re:Monolithic Kernels by Megol · · Score: 1

    You have no idea what a microkernel is right?

  18. Re:Monolithic Kernels by religionofpeas · · Score: 1

    Of course I do. The key feature of a microkernel is that it uses different access spaces. with protection barriers between them. In contrast, a monolithic kernel has shared access spaces, so different tasks can modify the same data and keep common state synchronized.

    That's the only really important difference.

  19. True for many years now by OneHundredAndTen · · Score: 1

    The Linux kernel has consisted of millions of lines of code for many years. It is doubtful that anyone can understand, really understand, all the ins and outs of more than a few tens of thousands of lines of code.

  20. Re:Monolithic Kernels by religionofpeas · · Score: 1

    Looking at some other tasks state involves two context switches - to that other task and back to the current.

    Looking at another task's state means making a copy of the state, a snapshot if you will. As soon as you make a copy, you now have two versions. Right after you make a copy, before the 2nd task can even examine it, the original state can change again.

    To be efficient on a large server, it obviously has to support many parallel threads of execution - but should still be a single memory context

    Yes, that's very efficient. That's what a monolithic kernel does.

  21. Re:microkernel deployments by drinkypoo · · Score: 1

    Mach (and BSD) are used in Apple's various OSes. Does that qualify as "reasonable amount of usage and performance" of the original comment?

    Not really. Apple uses Mach as a HAL. All process management is done by the monolithic BSD kernel which runs atop Mach. That's why OSX is not a microkernel-based system any more than NT (which also has a HAL.)

    --
    "You're right," Fisheye says. "I should have set it on 'whip' or 'chop.'"
  22. Linus quote by TheDarkener · · Score: 4, Insightful

    "It's a complicated world and the only way to deal with complexity is the open exchange of ideas."

    This is a quote that Mr. Torvalds should be known for, forever. It applies to much more than just software.

    --
    It is pitch black. You are likely to be eaten by a grue.
    1. Re:Linus quote by strikethree · · Score: 1

      You are correct. The quote should go down in history as the turning point towards more "individual friendly" governing systems. But then, the architecture of the kernel itself says that we will never see these systems materialize. *sigh*

      --
      "Someone needs to talk to the tree of liberty about its ghoulish drinking problem." by ohnocitizen
  23. Re:Monolithic Kernels by Eravnrekaree · · Score: 1

    C++ has some of the features you mention, such as vectors. Proposals to introduce C++ to the kernel are quickly rejected.

    Kernel code is bound to be difficult. I've often thought, for drivers, maybe a compatibility layer that presents a nice stable API can be provided for people to write drivers for (not forced, the internal API can also be exposed), but as another option.This would avoid cluttering kernel internals with backwards compatability stuff but would provide a nice stable API for drivers to use.

  24. Re:Monolithic Kernels by Eravnrekaree · · Score: 1

    If people did that it would certainly address a lot of their concerns about C without needing a new language

  25. Re: Monolithic Kernels by WorBlux · · Score: 1

    L4, QNX are probably the top 2. And performance is tied to old hardware limitations and models, which make context switches expensive. A cpu better suited to micro-kernels, like the Mill could bring about a different story. If a context switch cost 5-10 cycles instead of hundreds, all of a sudden the micro-kernel architecture looks a lot better.