目录
  • fastboot简介
  • 1.Android手机分裂
  • 2.fastboot命令
    • 2.1 查看fastboot命令的帮助
    • 2.2 分区:fastboot erase <partition>
    • 2.3 烧写指定分区:fastboot flash <partition> [*.img]
    • 2.4 烧写所有分区:fastboot flashall
    • 2.5 一次烧写boot,system,recovery分区:fastboot update <*.zip>
    • 2.6重启手机
    • 2.7 以指定的img或bin启动系统,通常用于调试
    • 2.8 更新eMMC分区
    • 2.9 退出fastboot
    • 2.10 获取信息客户端(手机端)
    • 2.11 如何查看fastboot是否成功
    • 2.12 u-boot中定义的偏移和地址
    • 2.13 文件大小限制

fastboot简介

fastboot是Android快速升级的一种方法,fastboot的协议fastboot_protocol.txt在源码目录./bootable/bootloader/legacy下可以找到。

fastboot 是作为 Android 系统编译器的客户端,编译后位于 ./out/host/ Linux -x86/bin/fastboot 目录下。

fastboot实例命令:sudo fastboot flash kernel path-to-kernel/uImage

烧写rootfs 类似:sudo fastboot flash system path-to-system/system.img

1.Android手机分裂

  分区都可以被烧写,并有相应的img文件:

  • 引导启动画面区(splash1)
  • 数据恢复区(recovery)
  • 内核区(boot)
  • 系统区(system)
  • 数据缓存区(cache)
  • 用户数据区(userdata)

2.fastboot命令

2.1 查看fastboot命令的帮助

  输入fastboot,显示如下信息:

  update <filename> 从 update.zip 刷新设备
  flashall flash boot + recovery + system 
  flash <partition> [ <filename> ] 将文件写入 flash 分区
  erase <partition> 擦除 flash 分区
  getvar <variable> 显示引导加载程序变量
  boot <kernel> [ <ramdisk> ] 下载并启动内核
  flash:raw boot <kernel> [ <ramdisk> ] 创建 bootimage 并刷新
  设备 列出所有连接的设备
  正常重启重启设备
  reboot-bootloader 将设备重启到引导加载程序
选项:
  -w 擦除用户数据和缓存
  -s <serial number> 指定设备序列号
  -p <product> 指定产品名称
  -c <cmdline> 覆盖内核命令行
  -i <vendor id> 指定自定义 USB 供应商 id 
  -b <base_addr > 指定自定义内核基地址
  -n <page size> 指定nand 页面大小。默认值:2048</span></span></span></span>

2.2 分区:fastboot erase <partition>

sudo fastboot 擦除引导 xx/boot.img 
$ sudo fastboot 擦除系统 xx/system.img 
$ sudo fastboot 擦除用户数据 xx/userdata.img 
$ sudo fastboot 擦除缓存 xx/cache.img</span></span></span></span>

2.3 烧写指定分区:fastboot flash <partition> [*.img]

$ sudo fastboot flash boot path-to-kernel/boot.img 
$ sudo fastboot flash zimage path-to-kernel/arch/arm/boot/zImage 
$ sudo fastboot flash system path-to-system/system.img 
$ sudo fastboot flash splash1引导画面</span></span></span></span>

2.4 烧写所有分区:fastboot flashall

  注意:此命令会在当前中查找所有img文件,将这些img烧写到所有目录的文件中,然后重新启动手机。

 sudo fastboot flashall

2.5 一次烧写boot,system,recovery分区:fastboot update <*.zip>

  创建包含boot.img,system.img,recovery.img文件的update.zip。

sudo fastboot update update.zip

2.6重启手机

 sudo 快速启动重启

2.7 以指定的img或bin启动系统,通常用于调试

  除了刷入 eMMC,Fastboot 还可以用来从已经刷入 eMMC 的文件启动。为此,请在目标上启动 Fastboot,然后在主机 PC 上运行命令,例如启动 u-boot:

 sudo fastboot 引导 u-boot.bin

2.8 更新eMMC分区

  eMMC 中的区域被命名。它们的偏移量和大小在您正在使用的板目录的 mmc.c 文件中的 u-boot 中设置。例如,对于 Blaze,此文件为 u-boot/board/omap4430sdp/mmc.c:

static struct partition partitions[] = { 
    { "-", }, 
    { "xloader", }, 
    { "bootloader", }, 
    /* "misc" partitions is required for recovery */ 
    { "misc", }, 
    { " -", }, 
    { "efs", }, 
    { "recovery", * }, 
    { "boot", * }, 
    { "system", * }, 
    { "cache", * }, 
    { "userdata", } , 
    { , }, 
};

  修改上面的内容,然后执行:

sudo fastboot oem 格式

2.9 退出fastboot

  • 拔usb
  • Ctrl+C
  • 辞职命令
#fastboot 100
或
#fastboot </span></span>

2.10 获取信息客户端(手机端)

sudo fastboot getvar version:version-bootloader:version-baseband:product:serialno:secure

  getvar 后和参数使用:单独使用,它们的含义如下:

版本 客户端支持的fastboot协议版本
版本引导加载程序 Bootloader的版本号
版本基带 基带版本
产品 产品名称
序列号 产品序列号
安全的 返回yes 表示在刷机时需要获取签名

2.11 如何查看fastboot是否成功

  fastboot通常支持环境nand flash时,fastboot为变量写入中,命名量和大小和写入环境变量

  • <分区名称>_nand_offset
  • <分区名称>_nand_size

  例如,内核烧写完成后printenv可以看到:

  • kernel_nand_offset=0x140000
  • kernel_nand_size=0x1f70000

2.12 u-boot中定义的偏移和地址

姓名 抵消 尺寸 文件类型 普通文件
加载器 0x00000000 0x00080000 xloader 二进制文件 MLO
引导加载程序 0x00080000 0x00180000 uboot 二进制 u-boot.bin
环境 0x001C0000 0x00040000 文本文件 要设置的变量列表
核心 0x00200000 0x01D00000 内核或内核+ ramdisk uImage、uMulti
系统 0x02000000 0x0A000000 yaffs2 系统.img
用户数据 0x0C000000 0x02000000 yaffs2 用户数据.img
缓存 0x0E000000 0x02000000 yaffs2 ?

  fastboot重用内核的nand地址分配,并且对象是可以变化的方式,但是xloader、bootloader、环境地址是不变的。

2.13 文件大小限制

  最大下载文件大小为240M。

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。