We are hiring engineers to work on the CUDA driver and runtime, core components of our platform for accelerating general purpose computation on the GPU. Our team analyzes performance of applications, investigates bottlenecks in software or hardware and delivers features and improvements to better realize the potential of NVIDIA hardware for a growing range of computational workloads, ranging from deep learning, scientific computation, and self-driving cars to video games and virtual reality.
CUDA defines a unified programming model across a range of system configurations and hardware capabilities. To accomplish this, the CUDA driver interacts with GPU hardware, kernel mode drivers, and the operating system.
What you'll be doing:
Want more jobs like this?
Get Software Engineering jobs in Santa Clara, CA delivered to your inbox every week.
As a member of our team, you will use your design abilities, coding expertise, and creativity to deliver the best compute platform in the world. You will craft elegant solutions to exciting problems and craft the future direction of CUDA as you collaborate with your peers across NVIDIA. You will investigate complex performance problems and deliver robust solutions that accelerate applications.
- Evangelize, architect, and implement new features
- Analyze full stack performance ranging from application level through libraries, system software, kernel software and hardware
- Define forward-looking improvements to the CUDA APIs and programming model
- Create novel system software optimizations
- Write effective, maintainable, and well-tested code
- Develop code for multiple operating systems
What we need to see:
- BS or MS degree in Computer Science, Electrical Engineering (or equivalent experience)
- 1 to 3+ years of relevant industry experience or equivalent academic experience after BS
- Strong C programming skills
- Experience or comfort in working with large codebases
- Track record of debugging performance problems in complex environments with software and hardware components
- Experience with operating system interfaces for threads, process control, and virtual memory
- Experience writing and debugging multithreaded programs
- Deep understanding of technology and passionate about what you do
- Strong collaborative and interpersonal skills, specifically a proven ability to effectively guide and influence within a dynamic matrix environment. Good written communication.
Ways to stand out from the crowd:
- Understanding of system level architecture, such as interconnects, memory hierarchy, interrupts, and memory-mapped IO
- Experience with performance tuning of device drivers or low level system software
- Experience with performance optimizations across a variety of CPU architectures - like x86, POWER and ARM
- Knowledge of memory coherence and consistency models
NVIDIA is widely considered to be one of the technology world's most desirable employers. We have some of the most brilliant and hardworking people in the world working for us. If you're creative and autonomous, and are interested in working on novel problems in a collaborative environment, we want to hear from you!
The base salary range is 120,000 USD - 230,000 USD. Your base salary will be determined based on your location, experience, and the pay of employees in similar positions.
You will also be eligible for equity and benefits. NVIDIA accepts applications on an ongoing basis.
NVIDIA is committed to fostering a diverse work environment and proud to be an equal opportunity employer. As we highly value diversity in our current and future employees, we do not discriminate (including in our hiring and promotion practices) on the basis of race, religion, color, national origin, gender, gender expression, sexual orientation, age, marital status, veteran status, disability status or any other characteristic protected by law.