Índice:
- Suprimentos
- Etapa 1: Atualizar o controlador incorporado no T420
- Etapa 2: Prepare o Raspberry Pi para piscar. (ON RPI)
- Etapa 3: preparar o computador 'principal' para construir o Coreboot (no PC principal)
- Etapa 4: conecte o clipe
- Etapa 5: Acesse o Chip do BIOS
- Etapa 6: Conecte o clipe ao chip do BIOS
- Etapa 7: Leia o Flash Chip (no RPI)
- Etapa 8: Compare os 3 arquivos (no RPI)
- Etapa 9: Limpe o ME (no PC principal)
- Etapa 10: Divida a imagem Rom. (No PC principal)
- Etapa 11: Configurar a imagem Coreboot. (No PC principal)
- Etapa 12: construir o Coreboot (no PC principal)
- Etapa 13: Grave Coreboot para T420 (no RPI)
2025 Autor: John Day | [email protected]. Última modificação: 2025-01-13 06:58
Coreboot é um substituto do BIOS de código aberto. Este guia descreverá as etapas necessárias para instalá-lo em um Lenovo T420.
Antes de começar, você deve se sentir confortável para usar um terminal Linux e também para desmontar seu laptop.
Há uma chance de que isso bloqueie seu laptop, você faz isso por sua própria conta e risco.
Suprimentos
- Ponoma 5250 Test Clip - Para conectar ao chip do BIOS.
- Cabos de jumper de placa de ensaio fêmea para fêmea - também conhecidos como fios Dupont.
- Chave Phillips
- Alicate pequeno ou broca hexagonal de 5,0 mm.
- Composto térmico
- Álcool isopropílico
- Cotonetes
- Lenovo T420
- Computador com Linux. "PC Principal"
- Raspberry Pi (3 ou 4) - executando a versão mais recente ou Raspberry Pi OS - As instruções de instalação podem ser encontradas aqui.
- Manual de manutenção de hardware T420
Etapa 1: Atualizar o controlador incorporado no T420
É uma boa ideia atualizar o controlador incorporado para a versão mais recente. A maneira mais fácil de fazer isso é instalar a versão mais recente do BIOS de fábrica. Coreboot não consegue tocar no EC. Você não poderá atualizá-lo após o flash, a menos que reverta para o BIOS de fábrica.
Etapa 2: Prepare o Raspberry Pi para piscar. (ON RPI)
Para ler / gravar no chip do BIOS, você precisa habilitar alguns módulos do kernel.
Acesse o utilitário de configuração raspberry pi.
sudo raspi-config
Nas opções de interface, habilite:
- P2 SSH - se você for executar o pi sem cabeça
- P4 SPI
- P5 I2C
- P8 GPIO remoto - se estiver usando ssh para se conectar ao pi
Etapa 3: preparar o computador 'principal' para construir o Coreboot (no PC principal)
A primeira coisa a fazer é instalar as dependências necessárias para construir o coreboot.
Para um sistema baseado em Debian
sudo apt install git build-essential gnat flex bison libncurses5-dev wget zlib1g-dev
Para um sistema baseado em Arch
sudo pacman -S base-devel gcc-ada flex bison ncurses wget zlib git
Crie um diretório em seu diretório inicial para trabalhar. Neste exemplo, irei chamá-lo de 'trabalho'. Você também vai querer um diretório para armazenar as imagens de fábrica. Vou chamar esse diretório de 'roms' Você pode fazer isso em uma linha para economizar tempo
mkdir -p ~ / work / roms
Mova para o diretório de trabalho
cd ~ / trabalho
Baixe a última versão do ME_Cleaner do github
git clone
Baixe a última versão do Coreboot
git clone
Mova para o diretório coreboot
cd ~ / work / coreboot
Baixe os submódulos necessários
git submodule update --init --checkout
Crie um diretório para armazenar alguns arquivos específicos para o seu T420 que serão necessários mais tarde.
mkdir -p ~ / work / coreboot / 3rdparty / blobs / mainboard / lenovo / t420
Crie a ferramenta ifd. Isso será usado para dividir o BIOS da fábrica em suas diferentes regiões.
cd ~ / work / coreboot / utils / ifdtool
faço
Etapa 4: conecte o clipe
Use o fio 6 fêmea para fêmea para conectar o clipe ao Pi
Bios 1> Pi 24
Bios 2> Pi 21
Bios 4> Pi 25
Bios 5> Pi 19
Bios 7> Pi 23
Bios 8> Pi 17
Os pinos 3 e 7 no BIOS não são usados.
Etapa 5: Acesse o Chip do BIOS
O chip do BIOS está localizado sob a gaiola de proteção. Para acessá-lo, você precisará remover a placa-mãe.
O Manual de manutenção de hardware pode fornecer instruções se você estiver tendo problemas para descobri-lo.
Eu incluí minhas imagens de desmontagem. Elas nunca foram destinadas à exibição pública (minha caligrafia é horrível, desculpe), mas que diabos elas podem ajudar.
Etapa 6: Conecte o clipe ao chip do BIOS
Com o Pi desligado, conecte o clipe ao chip do BIOS.
Etapa 7: Leia o Flash Chip (no RPI)
Ligue o Pi
Crie um diretório roms e vá para ele.
mkdir -p ~ / work / roms
cd ~ / work / roms
Para ler e gravar o chip, você precisará usar um programa chamado Flashrom. Primeiro certifique-se de que está instalado
sudo apt install flashrom
Use o flashrom para sondar o chip e certifique-se de que ele está conectado
flashrom -p linux_spi: dev = / dev / spidev0.0, spispeed = 128
Leia o BIOS de fábrica do chip 3 vezes e salve-o como factory1.rom factory2.rom factory3.rom
Use a opção -c para especificar seu chip flash. Certifique-se de inserir tudo entre as aspas
Cada leitura levará algum tempo, dependendo do chip, podendo durar entre 30-45 minutos cada leitura. Não se preocupe se parecer que o pi está pendurado.
flashrom -p linux_spi: dev = / dev / spidev0.0, spispeed = 128 -c -r factory1.rom
flashrom -p linux_spi: dev = / dev / spidev0.0, spispeed = 128 -c -r factory2.rom
flashrom -p linux_spi: dev = / dev / spidev0.0, spispeed = 128 -c -r factory3.rom
Etapa 8: Compare os 3 arquivos (no RPI)
Em seguida, você deseja comparar os 3 arquivos para se certificar de que teve uma boa leitura / conexões
sha512sum factory *.rom
Se todos corresponderem, copie-os para o computador principal no diretório ~ / work / roms.
Desligue o Pi. Você pode deixar o clipe conectado.
Etapa 9: Limpe o ME (no PC principal)
Mover para ~ / work / roms
cd ~ / work / roms
As ROMs de fábrica não devem ser editadas. Faça uma cópia de um deles para limpar.
cp fábrica1.rom limpo.rom
Limpe o IME em.rom limpo
~ / work / me_cleaner / me_cleaner.py -S Clean.rom
Etapa 10: Divida a imagem Rom. (No PC principal)
O chip do BIOS é dividido em 4 regiões. Você precisa dividir a imagem cleaning.rom em suas diferentes regiões com a ferramenta ifd fornecida pelo coreboot
~ / work / coreboot / utils / ifdtool / ifdtool -x clean.rom
Isso produzirá 4 arquivos. Precisamos renomear 3 deles e podemos excluir 1
Renomeie a região do descritor
mv flashregion_0_flashdescriptor.bin descriptor.bin
Exclua a região do BIOS - ela será substituída por coreboot.
rm flashregion_1_bios.bin
Renomear a região GBE
mv flashregion_2_gbe.bin gbe.bin
Renomear a região ME
mv flashregion_3_me.bin me.bin
Copie os arquivos para o diretório coreboot
cp descriptor.bin gbe.bin me.bin ~ / work / coreboot / 3rdparty / blobs / mainboard / lenovo / t420 /
Etapa 11: Configurar a imagem Coreboot. (No PC principal)
Mova para o diretório coreboot
cd ~ / work / coreboot
Configure o coreboot.
make nconfig
Isso abrirá o editor de configuração do Coreboot. A maioria das configurações padrão está correta, mas há algumas que podem ser adicionadas. Esta é uma configuração muito básica. Opções mais avançadas, como telas iniciais, vga roms e cargas úteis alternativas, estão disponíveis. Essas opções estão além do escopo deste guia.
Configuração geral
Use CMOS para valores de configuração
Placa-mãe
- Fornecedor da placa-mãe >>> Selecione >> Lenovo
- Modelo da placa-mãe >>> Selecione >>> T420
Chipset
- Adicionar arquivo descritor.bin da Intel
- Adicionar firmware Intel ME / TXE
- Adicionar configuração Gigabit Ethernet
Dispositivos
- Habilitar gerenciamento de energia do clock PCIe
- Ativar Subestado PCIe ASPM L1
Driver Genérico
PS / 2 teclado init
Etapa 12: construir o Coreboot (no PC principal)
É hora de compilar!
Construiu primeiro o conjunto de ferramentas gcc
make crossgcc-i386 CPUS = X
X = o número de threads que sua CPU possui.
Construir coreboot
fazer iasl
faço
Isso produzirá um arquivo ~ / work / coreboot / build / coreboot.rom.
Ligue o Pi e copie esse arquivo para o diretório ~ / work / roms.
Etapa 13: Grave Coreboot para T420 (no RPI)
Mover para o diretório roms
cd ~ / work / roms
Sondar o chip para certificar-se de que foi detectado
flashrom -p linux_spi: dev = / dev / spidev0.0, spispeed = 128
Escreva a imagem coreboot. Isso vai demorar mais do que ler a imagem.
flashrom -p linux_spi: dev = / dev / spidev0.0, spispeed = 128 -c -w coreboot.rom
Depois que a gravação for verificada, desligue o pi. Remova o clipe e monte novamente o T420.
Parabéns, você acabou de atualizar o Coreboot.