我是靠谱客的博主 温暖大米,最近开发中收集的这篇文章主要介绍FASTBOOT教程,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

参考:

  http://blog.csdn.net/geniusmen/article/details/7892398

  http://www.cnblogs.com/eastnapoleon/p/3270857.html

  http://www.omappedia.org/wiki/Android_Fastboot#Updating_system_image_on_NAND

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

Android手机分区

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

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

fastboot命令

1. 查看fastboot命令的帮助:

输入fastboot,显示如下信息:

usage: fastboot [ <option> ] <command>
 
commands:
  update <filename>                        reflash device from update.zip
  flashall                                 flash boot + recovery + system
  flash <partition> [ <filename> ]         write a file to a flash partition
  erase <partition>                        erase a flash partition
  getvar <variable>                        display a bootloader variable
  boot <kernel> [ <ramdisk> ]              download and boot kernel
  flash:raw boot <kernel> [ <ramdisk> ]    create bootimage and flash it
  devices                                  list all connected devices
  reboot                                   reboot device normally
  reboot-bootloader                        reboot device into bootloader
 
options:
  -w                                       erase userdata and cache
  -s <serial number>                       specify device serial number
  -p <product>                             specify product name
  -c <cmdline>                             override kernel commandline
  -i <vendor id>                           specify a custom USB vendor id
  -b <base_addr>                           specify a custom kernel base address
  -n <page size>                           specify the nand page size. default: 2048

2. 擦除分区:fastboot erase <partition>

$ sudo fastboot erase boot xx/boot.img
$ sudo fastboot erase system xx/system.img
$ sudo fastboot erase userdata xx/userdata.img
$ sudo fastboot erase cache xx/cache.img

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 开机画面

4. 烧写所有分区:fastboot flashall  

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

$ sudo fastboot flashall 

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

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

$ sudo fastboot update update.zip

6. 重启手机:

$ sudo fastboot reboot

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

  In addition to flashing the eMMC, Fastboot can also be used to boot from files already flashed to the eMMC. To do, so start Fastboot on the target, and then run a command on the host PC, for example to boot the u-boot:

# sudo fastboot boot u-boot.bin

8. 更新eMMC分区

  Regions in eMMC are given names. Their offsets and sizes are set in u-boot in the mmc.c file of the board directory that you are using. For example, for the Blaze, this file is u-boot/board/omap4430sdp/mmc.c:

static struct partition partitions[] = {
    {  },
    {  },
    {  },
    /* "misc" partition is required for recovery */
    {  },
    {  },
    {  },
    { * },
    { * },
    { * },
    { * },
    { },
    { ,  },
};

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

$ sudo fastboot oem format

9. 退出fastboot

  • 拔usb
  • ctrl+c
  • 超时退出命令 
    # fastboot 100
    或
    # fastboot 

     

10. 获取客户端(手机端)变量信息

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

getvar后和参数用:分开,它们的含义如下:

version 客户端支持的fastboot协议版本
version-bootloaderBootloader的版本号
version-baseband 基带版本
product         产品名称
serialno产品序列号
secure返回yes 表示在刷机时需要获取签名

11. 如何查看fastboot是否成功?

fastboot支持环境变量文件,通常在fastboot烧写nand flash时,会将偏移量和大小写入环境变量中,命名格式为:

<partition name>_nand_offset
<partition name>_nand_size

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

kernel_nand_offset=0x140000
kernel_nand_size=0x1f70000

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

nameoffsetsizetype of fileusual file
xloader0x000000000x00080000xloader binaryMLO
bootloader0x000800000x00180000uboot binaryu-boot.bin
environment0x001C00000x00040000text filelist of variables to set
kernel0x002000000x01D00000kernel or kernel + ramdiskuImage, uMulti
system0x020000000x0A000000yaffs2system.img
userdata0x0C0000000x02000000yaffs2userdata.img
cache0x0E0000000x02000000yaffs2?

fastboot重用内核的nand地址分配方式,并且大部分是可以变化的,但是xloader、bootloader 、environment地址是不变的。

13. 文件大小限制

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

最后

以上就是温暖大米为你收集整理的FASTBOOT教程的全部内容,希望文章能够帮你解决FASTBOOT教程所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(48)

评论列表共有 0 条评论

立即
投稿
返回
顶部