Slashdot Mirror


Career Path for Embedded Software Developers?

timmgrant asks: "Inspired by a love of technology I have always wanted to develop embedded software for consumer electronics. I have just finished a computer science degree and have now been looking for work in that industry but it seems that every job in this field requires previous professional experience in embedded programming. For those that have made it into this field (or any other specialised field) what path did you take? What steps do you propose would take me closer to my ultimate goal?"

10 of 39 comments (clear)

  1. requires previous professional experience by LarryRiedel · · Score: 3, Insightful

    Maybe in an abstract/theoretical sense "previous professional experience" is required, but in practice I have found there is an open position to be filled and there is a hiring manager and people in the department, and maybe someone in human resources and/or a recruiter, and getting the job requires convincing them I am the best candidate and that I can do the job.

    As far as "professional" experience, I think experience having done something which was real and actually used for something is often close enough to "professional" experience. Nowadays it is nice that there are some relatively high visibility "open source" projects which can be used to get something approaching "professional experience".

    If there is a candidate who appears to be a better "fit" for the "need", they will get the job. Sales is sales. Getting hired for a job is making a sale.

  2. Basic Stamps by Perdo · · Score: 4, Insightful

    Design your own USB coffee maker or animitronic toy. Put a real robot in robot wars instead of a glorified remote control car. Break in by doing not begging

    Other Sources

    --

    If voting were effective, it would be illegal by now.

    1. Re:Basic Stamps by stephend · · Score: 3, Interesting

      What you're saying is build a portfolio, which I think is very interesting.

      I think it was in Steve McConnells (excellent) After the Gold Rush that it's pointed out that in a lot of industries expect them (artists, photographers, models, mainly arty type stuff), but it's not something that the IT industry bothers with. With web and embedded project I really do think that this makes sense.

  3. be modest by jilles · · Score: 4, Informative

    No sane software architect is going to unleash a fresh college graduate on his multi million dollars worth of software. Expect to do relatively uninteresting work like e.g. testing for a while if you are hired by a company doing embedded systems development.

    Only when you prove your skills internally will they let you do some more interesting work. Also keep in mind that for the more cool kinds of jobs in companies doing embedded development there is quite a bit of competition internally. Nobody wants to do testing forever and the more experienced people usually end up getting the more interesting jobs simply because they are better at it and know the system better (it typically takes years to master even modestly sized systems).

    --

    Jilles
  4. Getting Embedded by PeteABastard · · Score: 4, Insightful

    I'm currently working writting embedded Forth. My previous jobs were C++ desktop stuff.

    The things that I think helped me getting this job were a good level of hardware knowledge (I was a motherboard tech with IBM for a year) and specific skills relevant to the current position (Forth and good maths as I have a physics degree). It also helped that there are very few Forth programmers in Australia so my employers had few applicants, especially as the R&D office is in a rural area.

    I hope to use this position to gain embedded skills that are transportable to future work, so I dont mind the daily 140km round trip.

    I have friends who do embedded work, and most of them come from an electronic engineeering background. They have a much closer skill fit than pure CS degrees normally do.

    Most of the embedded jobs advertised, when I was last looking, wanted Embedded C & Unix experience or experience with a particular technology (ie networking, phones, etc). They dont ever seem to advertise for graduate programmers.

    From an employers point of view (I used to be R&D manager for a small company) new graduates are a risk. Some complete their degree, but dont really like to code and you only find out once you've hired them. Also there is a lot not taught about professional proggramming in Universities, so there will be a learning curve. For these reasons you try to hire experienced people for the more critical or demanding areas, and let graduates prove themselves elsewhere first.

    With all this in mind you might do best to try and find a position where you can prove your programming skills, and pick up some technology
    skills on the way, so your second job is in the embbeded area.

    Small companies will probably allow you more scope for learning and taking on new duties, so a regular programming job with a small shop that also does embedded work may be good.

    Hope some of this is helpful

    Peter

  5. Embedded Systems by Detritus · · Score: 5, Informative

    You need more than a CS degree. Can you read schematics, use test equipment, fix/modify hardware?

    --
    Mea navis aericumbens anguillis abundat
    1. Re:Embedded Systems by Chelloveck · · Score: 3, Informative

      Agreed. Although in my experience about 2/3rds of embedded programmers have EE degrees and 1/3rd have CS degrees. So it's not quite as dismal as it may sound for a BSCS.

      And there are embedded companies which recruit and hire new graduates. Usually this is done at on-campus job fairs. New grad jobs are rarely advertised. They don't need to be; there's always a stack of fresh resumes to wade through. The only jobs advertised are the hard-to-fill positions that actually need a lot of experience and a proven track record.

      Go to job fairs. Mass-mail your resume out to the big guys, and go out of your way to find smaller companies. Be active in some sort of embedded side-project, and make sure to talk that up. When I'm interviewing I love to see that the candidate likes this stuff well enough to do it in the off-hours.

      --
      Chelloveck
      I give up on debugging. From now on, SIGSEGV is a feature.
  6. Co-Op or Internship by Phaid · · Score: 5, Informative

    Can't say it enough, working in your chosen field during college gives you a huge advantage in this regard. I work in embedded development, and my work experience during school was invaluable in jumpstarting my professional career.

    During my junior and senior years, I worked at a laser printer manufacturer, maintaining and upgrading code for older products. It wasn't super glamorous, but I also wasn't just getting coffee for people, and I learned more in that year and a half than I did in the entire rest of my academic career.

    After graduation, I had no trouble getting exactly the kind of work I wanted. I went to work on transportation projects at a major defense contractor for a few years, went back into the printer industry for a few years after that, and am now a senior engineer at a consulting firm working on several traffic management and wireless messaging solutions.

    When I graduated in 1994 the market was already fairly competitive, and someone who had real experience working in a team with other engineers, burning ROMs, documenting software, and producing embedded code which ran in real products, had an obvious advantage over someone whose experience consisted solely of implementing linked lists and writing papers on finite automata. With today's large numbers of out of work developers, and the proportionately larger number of CS graduates entering the market, it's incredibly important to distinguish yourself.

  7. Go back to school... by Uttles · · Score: 3

    Get a computer engineering degree with a focus on hardware (in the later years you can take specialized classes,) and while you're in school enlist in the cooperative education program and do your co-ops with hardware companies.

    --

    ~ now you know
  8. Catch 22 by selectspec · · Score: 3, Informative

    There is a catch 22 with embedded software design in that the development hardware is essentially unavailable outside of the industry. You can't just go buy eval boards on your own.

    However, you can learn to write your own boostrap loader, and you can work with some of the free OS's.

    OS work, porting, bootstrapping and driver engineering force you to work hands on with the hardware. Plus, the components are available off the shelf. I'd get involved in any of the driver or porting projects with NetBSD or Embedded Linux. This will give you a needed skill set for alot of embedded companies that are putting full OS's in their boxes. They are good stepping stones to the "for-loop" OS or the embedded OS's like QNX and VXWorks.

    --

    Someone you trust is one of us.