For over four decades, Cirrus Logic has been propelled by the top engineers in mixed-signal processing. Our rockstar team thrives on solving complex challenges with innovative end-user solutionsΒ for the world's top consumer brands. Cirrus Logic is also known for its award-winning culture, built on a foundation of inclusion and fairness, meaningful community engagement, and delivering enjoyable employee experiences at every turn. But we couldnβt do it without our extraordinary workforce β and thatβs where you come in. Join our team and help us continue to make Cirrus Logic an exceptional place to grow your career!Β
Responsibilities:
β’ Design, implement, and maintain embedded firmware for DSP cores.
β’ Develop firmware using a mix of C/C++ (and selective assembly where appropriate), with strong focus on fixed point performance, memory, and power optimization.
β’ Design, simulate, characterize and optimize algorithms to prove that they meet intended goals, and map to the constraints of custom hardware or DSP cores.
β’ Develop test strategies: unit tests, test harnesses and lab setups to prove the capabilities and limitations of experimental algorithms, and provide manufacturing/production diagnostics.
β’ Collaborate with our chip design, applications, systems and marketing teams to define requirements and interfaces.
β’ Contribute to driving new ideas, creating IP, methodologies and techniques to improve existing software solutions.
β’ Contribute to documentation and planning: design and requirement specs, interface specs, work packages, and bring-up guides.
β’ Participate in code reviews and help establish best practices for embedded quality, and maintainability.
β’ Use debugging/profiling tools: JTAG/SWD, logic analyzers, oscilloscopes, trace and cycle-accurate profiling when available.
β’ Bring up new hardware: boot flows, clocks, memory maps, interrupt vectors, peripheral init, and early validation.
Required Skills and Qualifications:
β’ Degree (1st or 2.1) or equivalent, in Electronics, Embedded Software, Signal Processing or related discipline
β’ Strong professional experience of developing embedded firmware in C/C++ for fixed-point and floating-point DSPs and embedded platforms.
β’ Ability to go from a Matlab algorithm design to an embedded firmware design in C/C++ for fixed-point and floating-point
β’ DSPs and embedded platforms.
β’ Proven ability to optimize firmware: cycle counting, memory layout, DMA usage, cache behavior, minimizing latency and jitter.
β’ Experience in several of the following: filter design, adaptive filtering, audio / sensor signal processing; FFT/spectral based processing and machine learning in an audio context.
β’ Solid understanding of embedded software fundamentals:
β’ register-level programming, memory-mapped I/O
β’ concurrency (ISRs, RTOS tasks), race conditions, timing determinism
β’ fixed-point arithmetic, numerical precision, and overflow/underflow management
β’ Proven ability to optimize firmware: cycle counting, memory layout, DMA usage, cache behavior, minimizing latency and jitter.
β’ Ability to pick up a broad range of responsibilities from design and simulation to prototyping and implementation on custom hardware.
β’ Ability to plan and work to a managed schedule across multiple functional teams.
β’ Comfortable with toolchains and build systems:
β’ GCC/LLVM-based toolchains, cross-compilation
β’ CMake/Make, Meson, linker scripts, map files
β’ Strong debugging skills with hardware and firmware:
β’ JTAG/SWD debugging
β’ root-cause analysis of timing and performance issues
β’ Source control expertise (Git, GitHub) and disciplined engineering practices (code reviews, CI).
Preferred Skills and Qualifications:
β’ Languages:
β’ Firmware and algorithm design/development: C, C++, Matlab, assembly (optional).
β’ Test tooling/scripting: Python, TCL (optional), PowerShell (optional), Groovy (optional)
β’ Architectures:
β’ DSP cores - Synopsys DSP cores, Tensilica Hifi DSP cores
β’ Tools:
β’ JTAG/SWD debuggers, GDB, OpenOCD/J-Link, logic analyzer, oscilloscope, trace tools
β’ Practices:
β’ profiling, unit/integration testing, Jenkins CI/CD, Git and GitHub workflows
β’ Experience with common DSP libraries/techniques (e.g., CMSIS-DSP, vendor DSP libs) and SIMD/vector optimization patterns.
β’ Experience of Machine Learning frameworks such as PyTorch or Tensorflow: how to train and tune a Machine Learning model, how to debug and test Machine Learning models.
β’ Experience of implementing a Machine Learning model on a fixed-point embedded platform/DSP core.
Export control restrictions based upon applicable laws and regulations would prohibit candidates who are nationals of certain embargoed countries from working in this position without Cirrus Logic first obtaining an export license.Β Candidates for this role must be able to access technical data without a requirement for an export license. We are unable to sponsor or obtain export licenses for this role.
At Cirrus Logic, we believe that diversity drives innovation, and we are committed to encouraging an open and collaborative culture where different approaches, ideas, and points of view are respected and valued. We aim to promote a workplace where everyone can contribute irrespective of race, colour, national origin, religion or belief, gender or gender identity, sexual orientation, age, marital status, pregnancy status, or disability.