Flashrom: 开源的内存编程工具

Flashrom是一个开源工具,用于读取、验证、擦除和写入嵌入式设备的固件,支持多种主板和闪存芯片。本文介绍了其功能、用途、特点以及在Linux系统中的使用示例,是更新BIOS/UEFI固件的理想选择。
摘要由CSDN通过智能技术生成

Flashrom: 开源的内存编程工具

是一个开源的内存编程工具,可以读取、验证、擦除和写入闪存芯片。它主要用于更新 BIOS/UEFI 固件、网络卡和其他嵌入式设备中的固件。

功能和用途

  • 读取闪存内容:你可以使用 Flashrom 来备份你的 BIOS/UEFI 固件或其他嵌入式设备的固件。
  • 验证闪存内容:使用 Flashrom 的验证功能,可以确保备份的固件文件与实际的闪存内容相同。
  • 擦除闪存:在更新固件之前,需要先将闪存的内容清除干净,Flashrom 可以帮助你完成这个任务。
  • 写入闪存:最后,你可以使用 Flashrom 将新的 BIOS/UEFI 固件或其他嵌入式设备的固件写入闪存中。

除了上述基本功能外,Flashrom 还支持多种不同的主板和闪存芯片,并且可以通过 Linux 内核模块进行驱动程序支持。

特点

  • 支持多种主板和闪存芯片
  • 简单易用的命令行界面
  • 具备验证功能,确保数据完整性
  • 开源软件,可自由使用和修改

如果你想更新你的 BIOS/UEFI 固件或嵌入式设备的固件,那么 Flashrom 是一个非常不错的选择。无论你是初级用户还是高级用户,都可以轻松上手并使用。

使用示例

要开始使用 Flashrom,请首先下载并安装最新版本的源代码。然后,按照以下步骤操作:

安装依赖库

在 Ubuntu 或 Debian 系统中,可以使用以下命令安装依赖库:

sudo apt-get install build-essential libpciaccess-dev libfuse-dev

编译并安装 Flashrom

wget https://github.com/flashrom/flashrom/releases/download/v1.0.0/flashrom-v1.0.0.tar.bz2
tar -xvjf flashrom-v1.0.0.tar.bz2
cd flashrom-v1.0.0
./configure
make
sudo make install

查看支持的硬件

使用以下命令查看 Flashrom 支持的硬件:

sudo flashrom -V

读取闪存内容

sudo flashrom -r backup.bin

验证闪存内容

sudo flashrom -v backup.bin

擦除闪存

sudo flashrom -p internal --erase

写入闪存

sudo flashrom -w newfirmware.bin

注意:在执行写入操作前,请确保已正确选择目标闪存芯片,避免损坏硬件。 以上就是 Flashrom 的基本使用方法,如果你想要了解更多的信息,请访问其官方网站 。

  • 11
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
支持当前流行的八脚SPI Flash, 特别适用于主板BIOS的DIY,无需购买昂贵的专业的编程器.本人刚刚用它恢复了我的华硕本本的BIOS,感觉比较方便,特此分享.只需稍微懂一些电路知识,不要把引脚弄错,任何人都可以DIY,再也不用担心主板不启动.该编程器只需连接四只200-400欧姆的电阻(图中为150ohm,但是不是很稳定,我是用四只270ohm的电阻成功的),一个并口连接公头,电源直接用普通干电池,3.3V的Flash系列用两节1.5V的干电池串联即可省去原理图中的1000µF电容,5V系列3节电池即可,连接前测一下,保证电压没有超过datasheet中的允许值.连接时最好能够使用转DIP的卡座,这样会省很多时间,而且也容易接错引脚.终端程序使用打印机接口模拟SPI,可以识别并支持下列SPI芯片: Atmel: AT26DF041 (512kB) AT26DF081 (1MB) AT26DF081A (1MB) AT26DF161 (2MB) AT26DF161A (2MB) AT26DF321 (4MB) Intel: QB25F016S33B8 (2MB) QB25F032S33B8 (4MB) QB25F064S33B8 (8MB) Macronix: MX25L1005 (128kB) MX25L2005 (256kB) MX25L4005 (512kB) MX25L8005 (1MB) MX25L1605 (2MB) MX25L3205 (4MB) MX25L6405 (8MB) Spansion: S25FL004A (512kB) S25FL008A (1MB) S25FL016A (2MB) S25FL032A (4MB) S25FL064A (8MB) S25FL128P (16MB) SST: SST25VF010 (128kB) SST25VF020 (256kB) SST25VF040 (512kB) SST25VF040B (512kB) SST25VF080A (1MB) SST25VF080B (1MB) SST25VF016 (2MB) SST25VF032 (4MB) SST25VF064 (8MB) SST25VF128 (16MB) SST26VF016 (2MB) SST26VF032 (4MB) SST26VF064 (8MB) ST Microelectronic: M25P10 (128kB) M25P20 (256kB) M25P40 (512kB) M25P80 (1MB) M25P16 (2MB) M25P32 (4MB) M25P64 (8MB) M25P128 (16MB) Winbond: W25X10 (128kB) W25X20 (256kB) W25X40 (512kB) W25X80 (1MB) W25X16 (2MB) W25X32 (4MB) W25X64 (8MB) 但是终端程序运行于DOS模式或者W2K, XP, Vista下的模拟DOS环境. 几个重要的命令行参数说明(方便不懂e文的)> 1. *** /i (如果芯片连接正确就会显示芯片的型号等信息,验证正确与否) 2. *** /d amibios.bin (自动备份SPI芯片中的内容到当前文件夹中的amibios.bin文件中,以备不时之需) 3. *** /e (清空芯片内容) 4. *** /p ami.bios (把名为ami.bios的文件写入SPI芯片中) 顺便罗嗦一句,操作时别忘了防静电,小心永久损坏芯片.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

戴洵珠Gerald

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值