views:

471

answers:

8

I've been in the embedded space for a while now, and it seems that most programmers I talk to seem to be doing things pretty much the same way it was done 15 years or more ago: Waterfall(ish) Development, command line tools and a small group uses lint.

Contrast this with the server/desktop environment, where there seems to be lots of activity related to all sorts of facets of programming:

  • XP, Scrum, Iterative, Lean/Agile
  • Continuous Integration
  • Automated Builds
  • Automated Unit Testing Frameworks
  • Refactoring tool support

Is it just that the embedded environment makes it more difficult to implement new practices or tools?
Is it that the mindset of embedded programmers steers them away from new tools/concepts?
Is it that management in the typical embedded industry behind the curve compared to IT focused fields?

I do realize that this is a generalization, and some embedded projects do use Scrum, Agile, CI, Automated Builds (in fact I worked at a company that had that in place since the 80s). But my impression is that it is a very small percentage.

+13  A: 

We are all used to the fact that our desktop PC crashes once in a while (or at least an application on the desktop suddenly disappears). It's no big deal. The next patch will fix it.

In the embedded space, you are building something which can't be patched. Lives can depend on your device (in a car, an elevator or a medical system). Most devices are installed and then must run unattended for years. So embedded people tend to be very conservative. TCP/IP is often "too modern". They stick to their trusty serial bus with a communication "stack" that is roughly 50 lines of assembler code.

What's worse, you simply don't have the abundance of space on the device which means you can't use one of the latest programming languages which make TDD and automated builds a bliss.

Next, a lot of embedded development environments are proprietary. If your supplier doesn't support it, you won't get it. Linux has started to weaken this in the past years but a whole lot of devices are not powerful enough to run Linux, yet. And even if they were, the CPU power would be used for something else instead of running a fancy OS which comes with source.

So yes, there are powerful forces working in the background to keep the embedded space where it is.

Aaron Digulla
+1  A: 

I would say it's more lack of good toolsets. It's really frustrating when you want to use C++ for its compile-time features not present in C (templates, namespaces, object-orientedness, etc) rather than its run-time features (exceptions, virtual functions) -- but the device manufacturers & 3rd parties just give you a C compiler, not C++. This probably results more from market size (hundreds of millions of PCs running Windows, with hundreds of thousands or even millions of developers -- vs. hundreds of thousands of Chip X, with hundreds or low thousands of developers) than from device capability.

edit: w/r/t robustness: there are different markets out there. The car/elevator/aeronautics/medical device market is going to have to be rigorous about getting rid of bugs. Other markets (toys, MP3 players, & other consumer electronics) can be less rigorous, especially if it's possible to upgrade code in the field. ("Oops! We're sorry we deleted your music library! We just fixed that bug, you can grab the latest release at our website at your convenience!")

Jason S
+6  A: 

These some reasons I can think of:

  • Embedded teams are usually smaller that desktop/Web teams. Code base is smaller.
  • System testing is much more important than unit testing. The software needs to be tested together with hardware. Automated testing is not possible and can only be applied to a small fraction of the code base.
  • Embedded engineers have a different skill set than software engineers. They interact with hardware, know how to use an oscilloscope and a logic analyzer. Usually, the difficult part of their job is to find a glitch in the hardware. They do not have the time to adopt modern software methologies.
kgiannakakis
I was all set to give a +1 until you had to mention they do not have time to adopt modern software methodologies. Also, the code base is definately not smaller. I've been on 60 software developer teams through one developer teams.
Dunk
Compare teams of 60 developers with teams of thousands for desktop-web applications. In the average, embedded software teams are smaller. Also, I didn't meant that is not of any merit to adopt modern software methologies, but that sometimes it is too much to ask that from them.
kgiannakakis
+4  A: 

Embedded programmers are mostly electrical engineers, not computer scientists or software engineers.

They excel in their field of expertise. They bring a slower more methodical approach than most computer programmers. When it comes to programming firmware, electrical engineers know just enough to be dangerous.

Here are some of the things I've noticed electrical engineers doing in C:

  • All code in ONE single file
  • Math like variable names: x, y, z
  • No or missing indentation
  • No stardard comment headers
  • No comments at all
  • Too many comments

In their defense EE's didn't train to be computer programmers, it's not their job. I think software is the hardest part of creating embedded devices. Designing PCBs and choosing components requires skill but pales in comparison to the complexity of 10,000 lines of code.

Embedded programmers also have to deal IDE's that look and behave like the IDE's of the 90's.

Justin Tanner
+1: I just took a job writing firmware for a company that only had straight EE types. Yikes! I just finished a complete re-write. ;)
Judge Maygarden
Your experience that most embedded programmers are electrical engineers is different from mine. Yes there are some, but I have mostly been involved with Computer Engineers and occasionally Computer Science grads. Maybe DoD contracts require a bit more Software discipline than the commercial world.
Dunk
+1: I got my bachelors in EE last May but got really interested in SW, and embedded systems was a good place for me. The IDE's of the 90's comment made me laugh. If I could use VS for embedded work that would be great. I'll try to watch out for your list!
Sean
Sean, if your on stackoverflow that means you're probably not one of the EE's I talked about!
Justin Tanner
+3  A: 

Is it just that the embedded environment makes it more difficult to implement new practices or tools?

It's partly a matter of scale. Software is NOT the product, the product is the product. however, there are thousands of different types of microcontrollers and microprocessors out there, and the most popular thousand have 3-4 different compilers that aren't completely compatible.

So a given tool is only going to be used by a few hundred or thousand engineers.

In windows development, however, there are millions of programmers of many levels - the tools produce software directly which is the product, and so it's going to get more eyeballs, and more money.

Each new product that an engineer puts out might have a different processor.

Is it that the mindset of embedded programmers steers them away from new tools/concepts?

Embedded programmers are generally software or firmware engineers, as opposed to programmers. Engineering implies a certain amount of design, design analysis, and design proof prior to implementation - in other words a ton of work is done before the first line of code is written, and the documentation, ideally, is specific enough that implementation is merely turning pseudocode like documentation into compilable code.

New tools and concepts are needed in the design phase, not the implementation phase. An IDE with intellisense may be nice, but by the time the code is being written it's useless cruft - they already know what they need.

CAD - computer aided design - tools are being developed for firmware engineers that are used in the design phase to develop models and simulations that are directly turned into code. Matlab and simulink are good examples of this. The system as a whole is designed.

In fact, one might wonder why software developers are still writing code while the engineers are making data/program flow charts and state machine diagrams. Why is UML uptake so slow in the application world? It sounds like application developers can use some of the tools in common use among embedded systems engineers...

Is it that management in the typical embedded industry behind the curve compared to IT focused fields?

Actually, it's likely the reverse. When a project starts the engineers have to pick the processor.

The processor manufacturers get less money on older chips, so they pitch the latest and greatest, and they are generally cheaper overall than the chips used in the previous design (either by die shrinks, more integration, etc).

So the design is actually using the latest and greatest chips.

The downside is that the compiler and tools are often immature. They can only build so much on the older tools, and since the target moves with each new processor, they can't focus on a lot of the nice features application programmers might like. Especially since many of those features won't be useful to an embedded engineer.

There are many other factors, some of which are enumerated by other answers, but it's really a different field even though they both involve programming.

Adam Davis
A: 

I'd say different sorts of problem environments.

The biggest problem with the waterfall methodology is that requirements change. In every environment I've been in, there has been at least the likelihood of a requirements change, which means that the successful methodologies are those that keep flexibility as long as possible. Even if the customer has signed off in blood, and stands to forfeit his left hand if he suggests a change, there are changes coming in the future.

In embedded programming, it is possible to nail the requirements down up front. They come from the behavior of the system as a whole, and engineers are good at nailing down system requirements. Nobody's going to come in halfway through and say that the user now wants the pacemaker to deliver syncopated impulses while the recipient is dancing.

Once the requirements are frozen beyond thawing, which never happens in software designed for human use, waterfall is a very efficient methodology. The team proceeds from well-specified requirements to overall design, then detailed design, then coding, verifying all the way that the stages are done correctly. Then it's time to debug the code (since it's never perfect when written), and final tests to make sure the code meets the requirements.

David Thornley
+11  A: 

Are embedded developers more conservative than their desktop brethrens?

Yes, because they are more concerned with the consequences of making errors. It’s a big deal to patch an embedded device. Not so much for a desktop app.

Waterfallish development is necessary in the embedded world because you are generally building hardware at the same time as the software. You need to know as soon as possible how much memory, how much processor speed, how big a flash, what if any special hardware is necessary etc...The hardware design can’t complete until you know these answers. Once you decide, that is pretty much it. The lead time for redoing a board is far too long. If you mess up then the software is going to have to work around any short-comings. Not usually an ideal situation.

As for the tools, that is largely based on what the supplier provides and any biases of the developers. On some projects I have used XP Embedded and got pretty much everything that the desktop developer gets.

XP, Scrum, Iterative, Lean/Agile:

Since most of the design is done up front (by necessity), and you usually don’t have working hardware when it is time to code, the quick turn-around processes don’t really provide much benefit.

Continuous Integration/Automated Builds Nice to have, but not really necessary. What…it takes about 15 seconds to open the IDE and press the compile button.

Automated Unit Testing

No reason why this shouldn't be done, but only part of the code can truly be automatically tested because the other part is either hardware dependent or has some other dependencies like timing. So you can't really tell if the code is working by the automated tests.

Refactoring Tool Support

The vendors of embedded processors product is the processor. They provide the IDE support in order to encourage you to purchase their processor. They couldn't possibly afford to pay for a Visual Studio sized development team in order to add all the bells and whistles to the IDE which isn't even their product.

Dunk
+1  A: 

I would also add a couple of points here:

  • In general embedded projects tend to be smaller than desktop projects. This decreases the need for very elaborated software processes.
  • Requirements for embedded project are often precise and better defined. Therefore SCRUM and agile are not so crucial
  • Finally embedded projects are generally a mix of software and hardware. The software being only a part of the project embedded developpers invest less time in software processes
zaiphos
"This decreases the need for very elaborated software processes"I've found the opposite to be true. Mistakes on software only projects are far less costly to fix than having to redesign and remanufacture hardware. Embedded systems require much more rigor.
Dunk
"Requirements for embedded project are often precise and better defined". In the beginning they are no better defined than a software only project. Because hardware needs to be built that can do the job, more analysis is done up front to get these right.
Dunk
"embedded developpers invest less time in software processes" IME, there are hardware developers and software developers. Why would the software developers invest less time in the software process?
Dunk