Network Processor Units (NPU) FTW

Network Processor Units (NPU) FTW

Network processing Units (NPU) for the Win


About the Author

Brent SalisburyI have over 15 years of experience wearing various hats from, network engineer, architect, devops and software engineer. I currently have the pleasure of working at the company that develops my favorite software I have ever used, Docker. My comments here are my personal thoughts and opinions. More at Brent's BioView all posts by Brent Salisbury →

  1. Wes FelterWes Felter03-26-2013

    Based on the sizes of the heatsinks, it looks like Cavium is doing almost none of the work. It’s an NPU, but not a very big one.

  2. Brent SalisburyBrent Salisbury03-26-2013

    Pretty excited about NPUs in general. Of course we wont get our hands on this one :(

    NPUs and FMPS seem like a nice combination instead of nickel and dime CPU. Seems the Cavium is popping up in a couple of platforms. Maybe you can get IBM to get us an open box like this to dev on :)

    Thanks for popping in Was,

  3. Wes FelterWes Felter03-26-2013

    I think the lack of openness has really marginalized NPUs. Years ago I did some programming on the NP4GS3 but there was very little “buzz” around it because it was encrusted in NDAs. There was only one open NPU – the Intel IXP – and so it got 100% of the mindshare in academia even though IMO its architecture sucks. (People said they were doing NPU research but really they were doing IXP research.) Now the “traditional” NPUs have been replaced by MIPS GPNPUs (e.g. Cavium, Raza/NetLogic/Broadcom) which should be easier to program but there’s still zero public discussion and zero cool Github repos because everything is locked away behind NDAs. Even if they have technical advantages, the fact that it costs you ~$100K to find out what they are basically kills innovation. Might as well just use x86 (Intel claims Sandy Bridge can drive 100 Gbps…)

    • Brent SalisburyBrent Salisbury03-30-2013

      Very interesting as always Wes. What’s your take on FPGAs moving forward?