Introduction

The firmware API enables kernel code to request files requiredfor functionality from userspace, the uses vary:

  • Microcode for CPU errata

  • Device driver firmware, required to be loaded onto devicemicrocontrollers

  • Device driver information data (calibration data, EEPROM overrides),some of which can be completely optional.

Types of firmware requests

There are two types of calls:

  • Synchronous

  • Asynchronous

Which one you use vary depending on your requirements, the rule of thumbhowever is you should strive to use the asynchronous APIs unless you alsoare already using asynchronous initialization mechanisms which will notstall or delay boot. Even if loading firmware does not take a lot of timeprocessing firmware might, and this can still delay boot or initialization,as such mechanisms such as asynchronous probe can help supplement drivers.