Bootchain

The bootchain (or secure boot chain, also called chain of trust) is the system by which Apple tries to ensure that only signed/trusted code is loaded on an iOS device.

The initial code (bootrom) is contained within the processor and cannot be changed. It decrypts the next stage and verifies integrity before it executes any code of the next stage. This continues for all stages until the execution of the kernel and applications. The integrity verification uses the keys on the device. To sign such code, you need the corresponding private key that only Apple holds. This way Apple has total control of any code that runs on your device. The idea of jailbreaking is to break this chain somewhere so that you can run any application or customize some firmware changes (unlock for example).

Application Processor

 * Bootrom
 * LLB
 * iBoot
 * Kernel
 * Applications

Baseband

 * Bootrom
 * Bootloader
 * Firmware