Windows的驱动比安卓丰富,这个很多人都说了,我不重复,操作系统的尺寸摆在那呢。
@崔巍提到了实模式和BSP,其实这跟实模式没什么关系,说BSP倒是对。而在x86体系里,最重要的一环是BIOS和ACPI。在这个问题里:
为什么Intel的CPU要规定加电时进入实模式?直接进保护模式不可以吗? - 中央处理器 (CPU) - 知乎,我有更详细的说明。
操作系统要启动不同硬件配置的计算机,首先要知道硬件配置。比如说CPU是什么型号的,桥片是什么型号的,有多少条PCI,各个IRQ怎么连接的。在x86体系里,BIOS、ACPI可以告诉操作系统具体的硬件配置(UEFI也有类似接口)。
安卓的刷机包问题在于,非x86体系里,没有一套公共的机制能告诉操作系统,设备的具体硬件配置情况,这样的话软件根本没办法知道硬件驱动。比如网卡,在某个设备上用的IRQ是10,在另一个是11,而操作系统没办法知道这些信息。
所以安卓(以及Linux、嵌入式开发等)需要BSP(board support package),需要根据硬件来定制一些最基础的代码。
所以安卓系统不能像Windows那样适应多个机型,哪怕带上足够的驱动也不行。
那么ARM架构为什么不搞类似ACPI或者BIOS的东西?因为ARM是卖CPU的(准确的说只卖授权),BIOS这套体系是在IBM之类的卖机器的厂商推动下发展起来的,而不是单纯靠Intel推动的,两家走的路完全不同,自然ARM没办法做类似的事情。
(注:制定ACPI标准的时候,是Intel和微软一起坐下来讨论的,但ARM没这个条件,做硬件的是ARM没错,但做安卓的软件厂商就太多了,而且内核又是Linux,即使跟谷歌谈,也不一定能推动整个Linux社区跟着改)
ACPI也不是完美的,因为它实际上是在内存里放着的,有些硬件在软重启时不重置ACPI的信息,就可能导致ACPI有可能被人修改而导致安全问题,所以现在又有了UEFI,总之,这些东西是告诉软件,硬件都有什么东西。