Back to resources

Building Software in a Hardware Company

Internal Communication
Collaboration

30 April, 2021

Marissa Mocenigo
Marissa Mocenigo

Senior Engineering Manager at Taxfix

Marissa Mocenigo, Engineering Manager at Taxfix, speaks of her challenges as a software engineer in a hardware company as she shares how ensuring a close working relationship and good communication between hardware and software engineers is at the forefront of success.

Problem

As a software engineer, working in a hardware company has different challenges and obstacles. Longer lead times on hardware can cause delays or blockers for software development milestones, without delaying deadlines. Testing can be limited by the availability of devices. Once the hardware is manufactured, software might be the only option for adapting necessary workarounds.

Actions taken

Bring together hardware and software engineers early to brainstorm and document risks and solutions.
It’s never too early to start documenting risks that may result from hardware design or failures. There may be some cases where software can provide a simple workaround, and it helps to prioritizes potential pain points that cannot easily be solved with a software solution.

If possible, create a virtual testing platform that replicates the hardware.

Everything should eventually be tested on the actual hardware, but it may take several iterations to get a feature working properly. Many early hardware startups only have a couple, if any prototypes, available for testing and small, early hardware runs can be expensive to produce. Creating a virtual version of the hardware can unblock software development and can also reduce the need for mass testing devices.

Create resource calendars to book hardware devices.

This tip probably seems relatively trivial, but I’ve seen so many places fail to do this and struggle with who has what device where and for how long. As above, it’s important to test on the hardware but availability can be limited for many reasons. Use the company’s calendaring system to book devices similarly to booking a meeting room. If marketing needs a device to take to trade shows, they should be sure to book it in advance. If an engineer needs a device for testing, they know who to ask if all the devices are booked up, and they can plan around availability when working on a feature.

Document a common understanding of shared APIs.

This is important at any company, but it’s even more important when bridging across hardware and software. Ideally, this will allow you to parallelize tasks as much as possible. Front-end engineers, for example, can start developing features and mock up calls to the device that can then be implemented later.

Lessons learned

Working at a hardware company has some of the same challenges as working in any software startup; however, some challenges can be exacerbated by timelines, coordination, and collaboration. The focus of many of these actions is communication, and ensuring a close working relationship and good communication between hardware and software engineers is at the forefront of success.

Discover Plato

Scale your coaching effort for your engineering and product teams
Develop yourself to become a stronger engineering / product leader


Related stories

Myth Busting

10 December

Supporting principles on why being data led (not driven) helps with the story telling.

Alignment
Managing Expectations
Building A Team
Leadership
Collaboration
Productivity
Feedback
Psychological Safety
Stakeholders
Vikash Chhaganlal

Vikash Chhaganlal

Head of Engineering at Xero

The Growth Mindset in Modern Product Engineering

28 November

The impact you can have with a Growth Mindset' and the factors involved in driving orchestrated change.

Building A Team
Leadership
Collaboration
Feedback
Ownership
Stakeholders
Vikash Chhaganlal

Vikash Chhaganlal

Head of Engineering at Xero

How to improve engagement and retention in remote engineering teams?

25 October

Mrunal Kapade, an Engineering leader, based in Silicon Valley, shares tips that helped reduce attrition in the remote engineering teams while leading multiple teams from startups to Fortune 500 companies.

Remote
Company Culture
Collaboration
Motivation
Team Processes
Mrunal Kapade

Mrunal Kapade

Director of Engineering at Inspire Energy

How to Maintain Happiness: The Underrated Aspect of Creating Team Dynamic

2 August

Jonathan Ducharme, Engineering Manager at AlleyCorp Nord, encourages the importance of a workplace environment that cultivates mental wellness.

Personal Growth
Company Culture
Leadership
Internal Communication
Psychological Safety
Jonathan Ducharme

Jonathan Ducharme

Engineering Manager at AlleyCorp Nord

How to Organize, Manage, and Grow Your Team

12 July

Vineet Puranik, Senior Engineering Manager at DocuSign, discusses the impact of roadmaps, organization, and proper management for your teams to procure growth.

Managing Expectations
Delegate
Collaboration
Roadmap
Strategy
Vineet Puranik

Vineet Puranik

Senior Engineering Manager at DocuSign