Difference between revisions of "R-Car/Boards/Yocto-Gen3/v3.21.0"
Line 264: | Line 264: | ||
</li> | </li> | ||
</ol> | </ol> | ||
+ | |||
+ | ==How to prepare and boot from eMMC/SD card== | ||
+ | |||
+ | This section describes steps that are necessary for preparing and booting from SD card. | ||
+ | |||
+ | ===Preparing eMMC/SD card=== | ||
+ | In order to prepare you SD card, follow these instructions: | ||
+ | |||
+ | 1.Partion your SD card to set 1 partition and ID=83 (Linux) | ||
+ | |||
+ | $ fdisk /dev/mmcblk0 | ||
+ | -> d | ||
+ | -> n | ||
+ | -> p | ||
+ | -> 1 | ||
+ | -> t | ||
+ | -> 83 | ||
+ | |||
+ | 2.Format this partition to ext3 (or ext4) | ||
+ | |||
+ | $ mkfs.ext3 /dev/mmcblk0p1 | ||
+ | |||
+ | 3.Mount this partition on your host to any directory and upack the core-image-weston-XXXX.tar.bz2 into mounted folder. | ||
+ | |||
+ | $ mount /dev/mmcblk0p1 /mnt | ||
+ | $ cd <your_yocto_build_directory> | ||
+ | $ tar xfj build/tmp/deploy/images/salvator-x/core-image-weston-salvator-x-20160927181256.rootfs.tar.bz2 -C /mnt | ||
+ | |||
+ | NOTE: probably you need to be a root user, hence use "sudo" | ||
+ | |||
+ | ===Configure U-Boot to boot from SD card=== | ||
+ | |||
+ | Proper U-Boot command to boot from SD: | ||
+ | # setenv bootargs 'rw root=/dev/mmcblk1p1 rootfstype=ext3 rootwait' | ||
+ | # ext2load mmc 0:1 0x48080000 /boot/Image | ||
+ | # ext2load mmc 0:1 0x48000000 /boot/Image-r8a7795-salvator-x.dtb | ||
+ | # booti 0x48080000 - 0x48000000' | ||
+ | |||
+ | Exaple of a proper hardware log: | ||
+ | baudrate=115200 | ||
+ | bootargs_emmc=rw root=/dev/mmcblk0p1 rootfstype=ext3 rootwait | ||
+ | bootargs_nfs=rw root=/dev/nfs rootwait ip=dhcp | ||
+ | bootargs_sd0=rw root=/dev/mmcblk1p1 rootfstype=ext3 rootwait | ||
+ | bootargs_sd2=rw root=/dev/mmcblk2p1 rootfstype=ext3 rootwait | ||
+ | bootcmd=run bootcmd_sd0 | ||
+ | bootcmd_emmc=set bootargs ${bootargs_emmc};ext2load mmc 1:1 0x48080000 /boot/Image;ext2load mmc 1:1 0x48000000 /boot/${dtb};run booti_cmd | ||
+ | bootcmd_nfs=set bootargs ${bootargs_nfs};bootp 0x48080000 Image;tftp 0x48000000 ${dtb};run booti_cmd | ||
+ | bootcmd_sd0=set bootargs ${bootargs_sd0};ext2load mmc 0:1 0x48080000 /boot/Image;ext2load mmc 0:1 0x48000000 /boot/${dtb};run booti_cmd | ||
+ | bootcmd_sd2=set bootargs ${bootargs_sd2};ext2load mmc 2:1 0x48080000 /boot/Image;ext2load mmc 2:1 0x48000000 /boot/${dtb};run booti_cmd | ||
+ | bootdelay=3 | ||
+ | booti_cmd=booti 0x48080000 - 0x48000000 | ||
+ | dtb=Image-r8a7795-salvator-x.dtb | ||
+ | ethact=ravb | ||
+ | ethaddr=2E:09:0A:00:BE:11 | ||
+ | fdt_high=0xffffffffffffffff | ||
+ | initrd_high=0xffffffffffffffff | ||
+ | stderr=serial | ||
+ | stdin=serial | ||
+ | stdout=serial | ||
+ | ver=U-Boot 2015.04 (Sep 23 2016 - 13:45:29)<br> | ||
+ | Environment size: 1092/131068 bytes | ||
+ | |||
+ | To verify the SD card you type the following: | ||
+ | => mmc dev 0 | ||
+ | switch to partitions #0, OK | ||
+ | mmc0 is current device | ||
+ | => mmc info | ||
+ | Device: sh-sdhi | ||
+ | Manufacturer ID: 3 | ||
+ | OEM: 5344 | ||
+ | Name: SL64G | ||
+ | Tran Speed: 50000000 | ||
+ | Rd Block Len: 512 | ||
+ | SD version 3.0 | ||
+ | High Capacity: Yes | ||
+ | Capacity: 59.5 GiB | ||
+ | Bus Width: 4-bit | ||
+ | Erase Group Size: 512 Bytes | ||
+ | => ext2ls mmc 0:1 /boot | ||
+ | <DIR> 4096 . | ||
+ | <DIR> 4096 .. | ||
+ | <SYM> 32 Image | ||
+ | 14039040 Image-4.6.0-yocto-standard | ||
+ | 69584 Image-r8a7795-salvator-x.dtb | ||
== Build scripts examples == | == Build scripts examples == |
Revision as of 04:30, 27 October 2016
This page contains information on building and running Yocto on Renesas R-Car-H3/M3 Salvator-X, Renesas R-Car-H3/M3 Salvator-X.View, Renesas R-Car-H3 Starter Kit Premier, Renesas R-Car-H3 H3ULCB.View and Renesas R-Car-H3 H3ULCB.HAD, Renesas R-Car-M3 Starter Kit Pro, Renesas R-Car-M3 M3ULCB.View boards.
R-Car Starter Kit Premier is an official name of H3ULCB board
R-Car Starter Kit Pro is an official name of M3ULCB board
Yocto versions
Poky-2.0.1 is supported. Specific commit of meta-openembedded is required.
Preliminary steps
- Download evaluation version of proprietary graphics and multimedia drivers from Renesas.
To download Multimedia and Graphics library, please use the following link:
https://www.renesas.com/en-us/software/D6000290.html
To download related Linux drivers, please use the following link:
https://www.renesas.com/en-us/media/secret/solutions/automotive/rcar-demoboard/R-Car_Gen3_Series_Evaluation_Software_Package_of_Linux_Drivers-20160906.zip
Graphic drivers are required for X11 and Wayland. Multimedia drivers are optional.
- Install required packages
Ubuntu and Debian
sudo apt-get install gawk wget git-core diffstat unzip texinfo gcc-multilib \ build-essential chrpath socat libsdl1.2-dev xterm python-crypto
Fedora
sudo yum install gawk make wget tar bzip2 gzip python unzip perl patch \ diffutils diffstat git cpp gcc gcc-c++ glibc-devel texinfo chrpath \ ccache perl-Data-Dumper perl-Text-ParseWords perl-Thread-Queue socat \ SDL-devel xterm
Refer to Yocto Project Quick Start for more information.
Building the BSP for Renesas R-Car Salvator-X H3/M3, Salvator-X.View H3/M3, H3ULCB, H3ULCB.View, H3ULCB.HAD, M3ULCB, M3ULCB.View
- Create a directory and switch to it
Warning! Yocto builds require a lot of disk space (up to 100 GB). Make sure you have got enough before starting the build.mkdir build cd build export WORK=`pwd`
- Clone basic Yocto layers:
cd $WORK git clone git://git.yoctoproject.org/poky git clone git://git.openembedded.org/meta-openembedded git clone git://git.linaro.org/openembedded/meta-linaro.git
-
Switch to proper branches/commits
-
For Yocto v2.12.0
cd $WORK/poky git checkout -b tmp 40376446904ae3529be41737fed9a0b650ed167d cd $WORK/meta-openembedded git checkout -b tmp 8ab04afbffb4bc5184cfe0655049de6f44269990 cd $WORK/meta-linaro git checkout -b tmp 9b1fd178309544dff1f7453e796a9437125bc0d9
Another versions are not tested for compatibility.
-
For Yocto v2.12.0
-
Clone Renesas BSP layer and switch to the proper branch:
-
For Yocto v2.12.0
cd $WORK git clone git://github.com/CogentEmbedded/meta-rcar.git meta-renesas -b v2.12.0
-
For Yocto v2.12.0
-
Apply Linaro-GCC patch file:
cd $WORK/meta-renesas export PATCH_DIR=meta-rcar-gen3/docs/sample/patch/patch-for-linaro-gcc patch -p1 < ${PATCH_DIR}/0001-rcar-gen3-add-readme-for-building-with-Linaro-Gcc.patch unset PATCH_DIR
-
Unzip downloaded proprietary driver modules to $WORK/proprietary folder.
You should see the following files:-
For Yocto v2.12.0
$ ls -1 $WORK/proprietary R-Car_Gen3_Series_Evaluation_Software_Package_for_Linux-20160906.tar.gz R-Car_Gen3_Series_Evaluation_Software_Package_of_Linux_Drivers-20160906.tar.gz
-
For Yocto v2.12.0
-
Populate meta-renesas with proprietary software packages.
PKGS_DIR=$WORK/proprietary cd $WORK/meta-renesas sh meta-rcar-gen3/docs/sample/copyscript/copy_evaproprietary_softwares.sh -f $PKGS_DIR
-
Setup build environment
cd $WORK source poky/oe-init-build-env
-
Prepare default configuration files.
cp $WORK/meta-renesas/meta-rcar-gen3/docs/sample/conf/<salvator-x|h3ulcb|m3ulcb>/linaro-gcc/mmp/*.conf ./conf/
For weston/wayland:
cd $WORK/build cp conf/local-wayland.conf conf/local.conf
For X11:
cd $WORK/build cp conf/local-x11.conf conf/local.conf
- Edit $WORK/build/conf/local.conf to enable/disable graphics and multimedia proprietary drivers support
- Edit local.conf to choose machine extension variant
-
Edit local.conf to select IO configuration (by default only H3ULCB board peripherals are enabled):
MACHINE_FEATURES_append = " h3ulcb-view" (use this append for View IO configuration)
or
MACHINE_FEATURES_append = " h3ulcb-had" (use this append for HAD IO configuration)
-
Edit local.conf to select IO configuration (by default only Salvator-X board peripherals are enabled):
MACHINE_FEATURES_append = " salvator-x-view" (use this append for View IO configuration) SOC_FAMILY = "r8a7796" (make this change only for M3 Salvator-X, since the default is H3 Salvator-X)
-
Edit local.conf to select IO configuration (by default only M3ULCB board peripherals are enabled):
MACHINE_FEATURES_append = " m3ulcb-view" (use this append for View IO configuration)
-
Edit local.conf to enable multicluster boot (enable both CA57 and CA53 clusters):
CA57CA53BOOT = "1"
-
Edit local.conf with evaluation packages requirements:
-
For Yocto v2.12.0 (to enable EVA_ prefix during packages install)
DISTRO_FEATURES_append = " use_eva_pkg"
-
For Yocto v2.12.0 (to enable EVA_ prefix during packages install)
-
Start the build
For weston/wayland:bitbake core-image-weston
For X11:
bitbake core-image-x11
-
Building image can take upto a few hours depending on your host system performance.
After the build has been completed successfuly, you should see the output similar to:NOTE: Tasks Summary: Attempted 4704 tasks of which 31 didn't need to be rerun and all succeeded.
and the command prompt should return.
-
Bitbake has generated all the necessary files in ./tmp/deploy/images directory.
You can verify its content:$ ls -1 `find ./tmp/deploy/images/h3ulcb/ -maxdepth 1 -type l -print` ./tmp/deploy/images/h3ulcb/core-image-weston-h3ulcb.cpio.gz ./tmp/deploy/images/h3ulcb/core-image-weston-h3ulcb.ext4 ./tmp/deploy/images/h3ulcb/core-image-weston-h3ulcb.manifest ./tmp/deploy/images/h3ulcb/core-image-weston-h3ulcb.tar.bz2 ./tmp/deploy/images/h3ulcb/Image ./tmp/deploy/images/h3ulcb/Image-h3ulcb.bin ./tmp/deploy/images/h3ulcb/Image-r8a7795-h3ulcb.dtb ./tmp/deploy/images/h3ulcb/Image-r8a7795-h3ulcb-had.dtb ./tmp/deploy/images/h3ulcb/Image-r8a7795-h3ulcb-view.dtb ./tmp/deploy/images/h3ulcb/modules-h3ulcb.tgz ./tmp/deploy/images/h3ulcb/u-boot.bin ./tmp/deploy/images/h3ulcb/u-boot-elf-h3ulcb.srec ./tmp/deploy/images/h3ulcb/u-boot-elf.srec ./tmp/deploy/images/h3ulcb/u-boot-h3ulcb.bin
Image is a Kernel image, *.dtb is a blob file, core-image-weston-h3ulcb.tar.bz2 is the rootfs, modules-h3ulcb.tgz are kernel modules.
- You can now boot R-Car H3 H3ULCB board over TFTP and NFS
For H3ULCB board only:
For Salvator-X board only:
For M3ULCB board only:
How to prepare and boot from eMMC/SD card
This section describes steps that are necessary for preparing and booting from SD card.
Preparing eMMC/SD card
In order to prepare you SD card, follow these instructions:
1.Partion your SD card to set 1 partition and ID=83 (Linux)
$ fdisk /dev/mmcblk0 -> d -> n -> p -> 1 -> t -> 83
2.Format this partition to ext3 (or ext4)
$ mkfs.ext3 /dev/mmcblk0p1
3.Mount this partition on your host to any directory and upack the core-image-weston-XXXX.tar.bz2 into mounted folder.
$ mount /dev/mmcblk0p1 /mnt $ cd <your_yocto_build_directory> $ tar xfj build/tmp/deploy/images/salvator-x/core-image-weston-salvator-x-20160927181256.rootfs.tar.bz2 -C /mnt
NOTE: probably you need to be a root user, hence use "sudo"
Configure U-Boot to boot from SD card
Proper U-Boot command to boot from SD:
# setenv bootargs 'rw root=/dev/mmcblk1p1 rootfstype=ext3 rootwait' # ext2load mmc 0:1 0x48080000 /boot/Image # ext2load mmc 0:1 0x48000000 /boot/Image-r8a7795-salvator-x.dtb # booti 0x48080000 - 0x48000000'
Exaple of a proper hardware log:
baudrate=115200 bootargs_emmc=rw root=/dev/mmcblk0p1 rootfstype=ext3 rootwait bootargs_nfs=rw root=/dev/nfs rootwait ip=dhcp bootargs_sd0=rw root=/dev/mmcblk1p1 rootfstype=ext3 rootwait bootargs_sd2=rw root=/dev/mmcblk2p1 rootfstype=ext3 rootwait bootcmd=run bootcmd_sd0 bootcmd_emmc=set bootargs ${bootargs_emmc};ext2load mmc 1:1 0x48080000 /boot/Image;ext2load mmc 1:1 0x48000000 /boot/${dtb};run booti_cmd bootcmd_nfs=set bootargs ${bootargs_nfs};bootp 0x48080000 Image;tftp 0x48000000 ${dtb};run booti_cmd bootcmd_sd0=set bootargs ${bootargs_sd0};ext2load mmc 0:1 0x48080000 /boot/Image;ext2load mmc 0:1 0x48000000 /boot/${dtb};run booti_cmd bootcmd_sd2=set bootargs ${bootargs_sd2};ext2load mmc 2:1 0x48080000 /boot/Image;ext2load mmc 2:1 0x48000000 /boot/${dtb};run booti_cmd bootdelay=3 booti_cmd=booti 0x48080000 - 0x48000000 dtb=Image-r8a7795-salvator-x.dtb ethact=ravb ethaddr=2E:09:0A:00:BE:11 fdt_high=0xffffffffffffffff initrd_high=0xffffffffffffffff stderr=serial stdin=serial stdout=serial ver=U-Boot 2015.04 (Sep 23 2016 - 13:45:29)
Environment size: 1092/131068 bytes
To verify the SD card you type the following:
=> mmc dev 0 switch to partitions #0, OK mmc0 is current device => mmc info Device: sh-sdhi Manufacturer ID: 3 OEM: 5344 Name: SL64G Tran Speed: 50000000 Rd Block Len: 512 SD version 3.0 High Capacity: Yes Capacity: 59.5 GiB Bus Width: 4-bit Erase Group Size: 512 Bytes => ext2ls mmc 0:1 /boot <DIR> 4096 . <DIR> 4096 .. <SYM> 32 Image 14039040 Image-4.6.0-yocto-standard 69584 Image-r8a7795-salvator-x.dtb
Build scripts examples
- Build preparation
- For Yocto v2.12.0
#!/bin/sh mkdir build || exit cd build WORK=`pwd` echo $WORK git clone git://git.yoctoproject.org/poky git clone git://git.linaro.org/openembedded/meta-linaro.git git clone git://git.openembedded.org/meta-openembedded git clone git://github.com/CogentEmbedded/meta-rcar.git meta-renesas -b v2.12.0 cd $WORK/poky git checkout -b tmp 40376446904ae3529be41737fed9a0b650ed167d cd $WORK/meta-linaro git checkout -b tmp 9b1fd178309544dff1f7453e796a9437125bc0d9 cd $WORK/meta-openembedded git checkout -b tmp 8ab04afbffb4bc5184cfe0655049de6f44269990 cd $WORK/meta-renesas export PATCH_DIR=meta-rcar-gen3/docs/sample/patch/patch-for-linaro-gcc patch -p1 < ${PATCH_DIR}/0001-rcar-gen3-add-readme-for-building-with-Linaro-Gcc.patch unset PATCH_DIR cd $WORK/ PKGS_DIR=$WORK/../proprietary cd $WORK/meta-renesas #sh meta-rcar-gen3/docs/sample/copyscript/copy_proprietary_softwares.sh -f $PKGS_DIR sh meta-rcar-gen3/docs/sample/copyscript/copy_evaproprietary_softwares.sh -f $PKGS_DIR
- For Yocto v2.12.0
- Building yocto for H3ULCB.View board
- For Yocto v2.12.0
#!/bin/sh cd build WORK=`pwd` echo $WORK cd $WORK source poky/oe-init-build-env #cp $WORK/meta-renesas/meta-rcar-gen3/docs/sample/conf/h3ulcb/linaro-gcc/bsp/*.conf ./conf/. #cp $WORK/meta-renesas/meta-rcar-gen3/docs/sample/conf/h3ulcb/linaro-gcc/gfx-only/*.conf ./conf/. cp $WORK/meta-renesas/meta-rcar-gen3/docs/sample/conf/h3ulcb/linaro-gcc/mmp/*.conf ./conf/. cd $WORK/build cp conf/local-wayland.conf conf/local.conf echo "DISTRO_FEATURES_append = \" use_eva_pkg\"" >> $WORK/build/conf/local.conf echo "MACHINE_FEATURES_append = \" h3ulcb-view\"" >> $WORK/build/conf/local.conf #echo "LVDSCAMERA_ONE = \"1\"" >> $WORK/build/conf/local.conf #echo "CA57CA53BOOT = \"1\"" >> $WORK/build/conf/local.conf bitbake core-image-weston
- For Yocto v2.12.0
Known issues and limitations
TBD