Android烧录指令fastboot简介

来自:网络
时间:2024-06-09
阅读:

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中定义的偏移和地址

姓名抵消尺寸文件类型普通文件
加载器0x000000000x00080000xloader 二进制文件MLO
引导加载程序0x000800000x00180000uboot 二进制u-boot.bin
环境0x001C00000x00040000文本文件要设置的变量列表
核心0x002000000x01D00000内核或内核+ ramdiskuImage、uMulti
系统0x020000000x0A000000yaffs2系统.img
用户数据0x0C0000000x02000000yaffs2用户数据.img
缓存0x0E0000000x02000000yaffs2?

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

2.13 文件大小限制

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

返回顶部
顶部