Hardware Compiler Engineer

About SiFive

As the pioneers who introduced RISC-V to the world, SiFive is transforming the future of compute by bringing the limitless potential of RISC-V to the highest performance and most data-intensive applications in the world. SiFive’s unrivaled compute platforms have enabled leading technology companies around the world to innovate, optimize, and deliver the most advanced solutions of tomorrow across every market segment of chip design, including artificial intelligence, machine learning, automotive, datacenter, mobile, and consumer. With SiFive, the future of RISC-V has no limits.

At SiFive, we use the latest in Compiler technologies and programming languages to design hardware.  Our customers require that designs be delivered in the traditional languages of Verilog and SystemVerilog.  As a hardware compiler engineer, you will be designing the software infrastructure to compile, generate and verify RISC-V cores and other designs for high performance and low power.

Responsibilities:

  • Development of transforms, Operations, Types in  MLIR for the design system.
  • Architect abstractions to model hardware, software and verification constructs in MLIR.
  • Own software development projects that lower IR representations of the design to simulators, FPGAs and other models required by the design systems.
  •  Develop tests for the MLIR code.
  • Work on hardware simulators and FPGAs to debug the transforms.
  • Debug and maintain previously developed code in MLIR.
  • Document and explain implementation details, benefits and effort estimates.

Qualifications:

  • Expert in programming languages.  C++, Python are MUST.  Expertise in Rust, Scala, Swift are desirable. 
  • Must be able to demonstrate software coding skills.
  • Must demonstrate expertise with software development tools (one or more): VS Code, Gprof, Valgrind,..
  • Must be an expertise in data structures, algorithms and be able to suitably solve problems through efficient use of the same or debug issues in implementations. 
  • Knowledge of computer architecture, hardware design with Verilog highly desirable.
  • Expertise in FPGA usage is valued.
  • Knowledge of hardware simulators and verification systems such as UVM will be seen as valuable.
  • Be willing to learn, innovate and build and show extreme curiosity to understand how the system operates. 
  • Be opinionated but open to new ideas.
SiFive is proud to be an equal employment opportunity workplace. We offer a competitive compensation package that includes flexible paid time off; flexible work environment; health, vision and dental benefits; 401(k) plan; employee stock option program, and much more.
We will ensure that individuals with disabilities are provided reasonable accommodation to participate in the job application or interview process, to perform essential job functions, and to receive other benefits and privileges of employment. Please contact us to request accommodation.
If you yearn to be challenged and wish to work in an environment where the boundaries of your creativity and skills will be tested, then SiFive is the place for you!
Notice to Staffing Agencies / External Recruiters:
Thank you for your interest in SiFive Inc. Please note that SiFive does not accept unsolicited resumes from external agencies unless contracted to fill a specific position. Agencies are hereby specifically directed NOT to contact SiFive employees directly in an attempt to present candidates – all applications must go through SiFive's internal recruiting team. Any third-party resume forwarded by agencies/external recruiters to a SiFive mailing address, fax machine or email address, directly to SiFive employees, or to SiFive's resume database will be considered property of SiFive Inc and treated as a direct application. This exchange does not constitute an agreement between SiFive and the agency/external recruiter. SiFive reserves the right to contact the candidate directly. Employment agencies/external recruiters will receive no compensation from SiFive or its companies.