Debian AM62 Flash From Net: Difference between revisions

From Variscite Wiki
(Created page with "<!-- Set release according to "release" parameter in URL and use am62-debian-bookworm-6.1.83_09.02.01.10-v1.0 as default --> {{INIT_RELEASE_PARAM|am62-debian-bookworm-6.1.83_09.02.01.10-v1.0}}<!-- --> {{#lst:Debian_Platform_Customization|{{#var:RELEASE_PARAM}}}} <!-- --> {{PageHeader|{{#var:HARDWARE_NAME}} - Flash Debian images from network}} {{DocImage|category1={{#var:HARDWARE_NAME}}|category2=Debian}} __toc__ = Flashing a complete Debian system from Network using TFT...")
 
 
(2 intermediate revisions by the same user not shown)
Line 11: Line 11:


== Build {{#ifexpr:{{#var:DEBIAN_VERSION}} >= 11|minimal|}} file system ==
== Build {{#ifexpr:{{#var:DEBIAN_VERSION}} >= 11|minimal|}} file system ==
To setup a build environment follow steps 2 & 3 of the {{Varlink|Debian Build Release Stage|{{#var:RELEASE_LINK}}|Build Debian from source code}} guide.<br>
To setup a build environment follow steps to {{Varlink|Debian_Build_Release_TI|{{#var:RELEASE_LINK}}#Deploy_source|'''Build the Debian image'''}} guide.<br>
<!-- Distro features support by the build script has been introduced in Debian 11 (Bullseye) -->
{{#ifexpr:{{#var:DEBIAN_VERSION}} >= 11|
Then, disable all distro features listed in {{Varlink|Debian Build Release Stage#Distro features|{{#var:RELEASE_LINK}}|Distro Features}} to get a minimal file system.
|}}


And build the image:
And build the image:
  $ sudo {{#var:BUILD_SCRIPT}} -c all
$ cd {{#var:BUILD_FOLDER}}/{{#var:TI-BDEBSTRAP}}
  $ sudo ./build.sh {{#var:DEBIAN_BUILD_TARGET}}


Create a root file system and copy files:
Create a root file system and copy files:
{{#switch: {{#var:SOC_SERIES}} | imx8 | imx9=
 
<br>
  $ mkdir ~/flash_rootfs
  $ mkdir ~/flash_rootfs
  $ sudo tar xf {{#var:BUILD_FOLDER}}/output/rootfs.tar.gz -C ~/flash_rootfs
  $ sudo tar -xvf {{#var:BUILD_FOLDER}}/{{#var:TI-BDEBSTRAP}}/build/{{#var:DEBIAN_BUILD_TARGET}}/tisdk-am62-{{#var:DEBIAN_NAME_S}}-variscite-{{#var:MACHINE_NAME}}-rootfs.tar.gz -C ~/flash_rootfs
  $ sudo cp -a ~/flash_rootfs/boot/*.dtb /tftpboot
  $ sudo cp -a ~/flash_rootfs/boot/*.dtb /tftpboot
  $ sudo cp ~/flash_rootfs/boot/{{#var:KERNEL_IMAGE}} /tftpboot
  $ sudo cp ~/flash_rootfs/boot/{{#var:KERNEL_IMAGE}} /tftpboot
|#default=
<br>
$ mkdir ~/flash_rootfs
$ sudo tar xf {{#var:BUILD_FOLDER}}/output/rootfs.tar.gz -C ~/flash_rootfs
$ sudo cp {{#var:BUILD_FOLDER}}/output/{{#var:KERNEL_IMAGE}} /tftpboot
$ for f in {{#var:BUILD_FOLDER}}/output/*.dtb; do if <nowiki>[[ -L $f ]] && [[</nowiki> $f != *{{#var:MACHINE_NAME}}.dtb <nowiki>]]</nowiki>; then sudo cp $f /tftpboot/; fi done
$ sudo rename 's/{{#var:KERNEL_IMAGE}}-imx/imx/' /tftpboot/{{#var:KERNEL_IMAGE}}-*.dtb
}}


Edit /etc/exports. E.g.
Edit /etc/exports. E.g.

Latest revision as of 12:26, 11 December 2024

Warning: This page is designed to be used with a 'release' URL parameter.

This page is using the default release am62-debian-bookworm-6.1.83_09.02.01.10-v1.0.
To view this page for a specific Variscite SoM and software release, please follow these steps:

  1. Visit variwiki.com
  2. Select your SoM
  3. Select the software release
VAR-SOM-AM62 - Flash Debian images from network

Flashing a complete Debian system from Network using TFTP & NFS

NOTES:
  1. Please make sure your host system is ready to use TFTP/NFS. Use our Wiki if required: Debian Setup TFTP/NFS
  2. This is a concept Wiki. Please adapt it to your system and your requirements.

Build minimal file system

To setup a build environment follow steps to Build the Debian image guide.

And build the image:

$ cd ~/debian_am62x_var_som/ti-bdebstrap
$ sudo ./build.sh am62-bookworm-09.02.01.10_var01

Create a root file system and copy files:

$ mkdir ~/flash_rootfs
$ sudo tar -xvf ~/debian_am62x_var_som/ti-bdebstrap/build/am62-bookworm-09.02.01.10_var01/tisdk-am62-bookworm-variscite-am62x-var-som-rootfs.tar.gz -C ~/flash_rootfs
$ sudo cp -a ~/flash_rootfs/boot/*.dtb /tftpboot
$ sudo cp ~/flash_rootfs/boot/Image /tftpboot

Edit /etc/exports. E.g.

$ sudo gedit /etc/exports

...and add the following line to it (replace <uname> with the actual username):

/home/<uname>/flash_rootfs    *(rw,sync,no_root_squash,no_all_squash,no_subtree_check) 

Restart the NFS server:

$ sudo /etc/init.d/nfs-kernel-server restart

Insert the recovery SD card into your host PC and copy the following files from it (assuming it is mounted at /media):

$ sudo cp -a /media/rootfs/opt/images ~/flash_rootfs/opt/
$ sudo cp /media/rootfs/usr/bin/*.sh  ~/flash_rootfs/usr/bin/

Boot the board, stop the autoboot to get to the U-Boot command line, and set the following environment variables:

=> setenv serverip <your host ip address>
=> setenv nfsroot /home/<your username>/flash_rootfs

If you want to set the fdt file yourself, instead of using the default auto detection:
=> setenv fdt_file <relevant device tree>
=> setenv bootcmd 'run netboot'
=> saveenv
=> boot

On the target flash your system:

# install_debian.sh

A complete system is flashed into the SOMs internal storage (NAND flash/eMMC).
Once the file system is built you can use it again and again to flash your VAR-SOM-AM62.
You can update the images to use your images and/or customize install_debian.sh to your requirements.