Name | Last modified | Size | License | |
---|---|---|---|---|
Parent Directory | ||||
MANIFEST | 11-Jan-2018 19:52 | 265 | open | |
MD5SUMS | 11-Jan-2018 19:52 | 285 | open | |
boot.tar.bz2 | 11-Jan-2018 19:52 | 6.3M | open | |
fvp.img.bz2 | 26-Feb-2018 12:16 | 322.7M | open | |
kernel_config | 11-Jan-2018 19:53 | 73.5K | open | |
linaro_android_build_cmds.sh | 11-Jan-2018 19:53 | 8.6K | open | |
pinned-manifest.xml | 11-Jan-2018 19:53 | 90.8K | open | |
ramdisk.img | 11-Jan-2018 19:53 | 918.3K | open | |
source-manifest.xml | 11-Jan-2018 19:53 | 48.9K | open | |
system.img | 26-Feb-2018 12:16 | 750.0M | open | |
system.tar.bz2 | 26-Feb-2018 12:17 | 269.7M | open | |
userdata.img | 26-Feb-2018 12:17 | 550.0M | open | |
userdata.tar.bz2 | 26-Feb-2018 12:17 | 46.3M | open |
About the Reference Linaro Confectionary Release for FVP (Multi-arch 64-bit)
This Reference Linaro Confectionary Release is based on the AOSP Lollipop
Android-5.1.1_r8 version. This build is the userdebug variant
build, it contains multi-arch support allowing full use of the 64-bit
ARMv8-A architecture and supports both 64-bit and 32-bit applications,
and has selinux enabled by default.
Java-only applications will run as 64-bit in the supplied configuration
with no modification. The release uses the kernel from the Linaro ARM
Landing team which is based on Android flavour of Linaro Stable
Kernel version 3.10, and with EFI enabled and all necessary android
configs.
The sources are built using Linaro GCC version 4.9-2015.06 for 64bit
and for 32bit.
To disable SELinux pass “selinux=0” as the boot parameter in the UEFI
bootargs configuration.
The Android AOSP software provided in this release is functionally
tested with CTS version 5.1 R2 and the CTS results are shared with
members.
Additionally, the BIONIC component is validated with Android BIONIC
tests. Multi-arch support has been validated using examples provided in Android NDK.
Sources are also made available so you can build your own images
(see the Building from Source tab).
What is new
- Android source changed to based on the Lollipop Android-5.1.1_r8 version
- Toolchain updated to use GCC version 4.9-2015.06
- CTS package updated to use version 5.1 R2
About the Android flavour of Linaro Stable Kernel (LSK)
The kernel used by Linaro Confectionary Release is based on the Android
flavour of Linaro Stable Kernel (LSK), which is produced, validated and
released by Linaro and is based on the Linux stable kernel tree.
The LSK focuses on quality and stability and is therefore a great
foundation for product development. It also includes backports of
commonly desired features, provided they meet the quality requirements,
and also any bug fixes.
Sources are also made available so you can build your own images (see
Building from Source).
Support
Subscribe to the important Linaro mailing lists and join our IRC
channels to stay on top of Linaro development.
- Linaro Android Development ‘Mailing list’
- Linaro Android IRC channel on irc.freenode.net at #linaro-android
- Bug reports should be filed in ‘Bugzilla’ under “Linaro Android” product and “Reference Linaro Confectionery Release (R-LCR)” component.
- You will need to login to your Linaro account. If you do not have an account or are having problems, email its@linaro.org for help.
- More general bug reports should be filed in Bugzilla against the individual packages that are affected.
- Questions? ‘ask linaro’
- Interested in commercial support? inquire at ‘Linaro Support’
Android Patch Summary
There are patches developed by ARM and Linaro engineering teams
were applied to get Android booting to UI on the ARMv8-A fastmodels platform.
These patches can be found on Linaro’s Android
Git repositories via file LOLLIPOP-MLCR-PATCHSET.
Some of these patches have been submitted to AOSP and are being tracked
for acceptance.
Any patches can be contributed through the instructions described Here
Known Issues and Limitations
Known limitations
- SW rendering for user interface only – there is no hardware accelerated graphics
- Slow on high resolutions – we run on small screen size to avoid excessive delays
- Lack of audio support may cause apps using audio to hang
- HDLCD is not supported yet
- Has long time problem to run some CTS test package because of the performance thing
Known issues
The following known issues are present in this release. Please contact support@linaro.org if you wish to know more information about these issues or have access problems when attempting to view them.
Bug ID | Bug title | Bug summary |
Bug 1581 | Browser crash when opening youtube main page | unhandled input address range fault from android.browser package |
Bug 1492 | android.bionic.string@strncat FAIL | One of our Bionic string routines optimizations seems to violate strict POSIX rules – we are not filling with zeros the remaining unused part of the string. Currently considered WONTFIX. |
Bug 1015 | monkey long run test fails on Juno/TC2 LCR build | java.lang.NumberFormatException from com.android.settings package |
Bug 993 | EVDEV failures in linaro android kernel test suite on 14.12 LCR build | Few EVDEV tests have always been failing for us |
Bug 795 | Failing multimedia codec tests | Codecs give different bitstreams on ARMv8 and ARMv7 platforms and tests matching against exact checksums fail. |
Bug 64 | Test test_pthread_rwlock from bionic libc test suite fails on Juno build – LAVA | |
Bug 23 | backtrace_test reports failures on 64/64 build | Failures reported with local trace and threads |
Prerequisites
Run the build
You’ll need the latest ARM FVP Base models and a license to use the models. Follow the instructions at https://collaborate.linaro.org/display/ITS/FlexLM+and+Fast+Models for the same.
Get artifacts
Click on each link to download:
- boot.tar.bz2
- system.tar.bz2
- userdata.tar.bz2
Get linaro image tools
Run these commands to get all the dependencies for linaro-image-tools and the tip of linaro-image-tools
$ sudo add-apt-repository ppa:linaro-maintainers/tools $ sudo apt-get update $ sudo apt-get install linaro-image-tools
If you’re using a “tip” build then we suggest you use the tip of linaro-image-tools from http://git.linaro.org/ci/linaro-image-tools.git
Create binary for the ARM FVP Base AEMv8 models
Run linaro image tools
$ linaro-android-media-create --image_file mmc.bin --image_size 2000M --dev vexpress --system system.tar.bz2 --userdata userdata.tar.bz2 --boot boot.tar.bz2
If you’re using tip of linaro image tools
$ ./linaro-image-tools/linaro-android-media-create --image_file mmc.bin --image_size 2000M --dev vexpress --system system.tar.bz2 --userdata userdata.tar.bz2 --boot boot.tar.bz2
Extract the preboot files
tar -jxvf boot.tar.bz2
Setup the runtime environment
$ export ARMLMD_LICENSE_FILE="8224@localhost" $ ssh -L 8224:localhost:8224 -L 18224:localhost:18224 -N $USER@flexlm.linaro.org &
Running the models (verified on FVP Base model build 6302)
$ cd boot/ $ /path/to/FVP_Base_AEMv8A-AEMv8A/models/Linux64_GCC-4.1/FVP_Base_AEMv8A-AEMv8A \ -C pctl.startup=0.0.0.0 \ -C bp.secure_memory=0 \ -C cluster0.NUM_CORES=1 \ -C cluster1.NUM_CORES=1 \ -C cache_state_modelled=0 \ -C bp.pl011_uart0.untimed_fifos=1 \ -C bp.secureflashloader.fname=bl1.bin \ -C bp.flashloader0.fname=fvp_fip.bin \ -C bp.virtioblockdevice.image_path=mmc.bin \ -C bp.hostbridge.userNetworking=true \ -C bp.ve_sysregs.mmbSiteDefault=0 \ -C bp.hostbridge.userNetPorts="5555=5555" \ -C bp.smsc_91c111.enabled=1
Console redirection
To redirect the console open a terminal and run
telnet 127.0.0.1 5000
Select UEFI configuration item, boot the build
Stop the UEFI prompt and select the Shell item, then it will boot up directly for you:
$ telnet localhost 5000
Trying ::1…
Trying 127.0.0.1…
Connected to localhost.
Escape character is ‘^]’.
NOTICE: Booting Trusted Firmware
NOTICE: BL1: v1.1(release):789c220
NOTICE: BL1: Built : 08:47:23, Jun 17 2015
NOTICE: BL1: Booting BL2
NOTICE: BL2: v1.1(release):789c220
NOTICE: BL2: Built : 08:47:25, Jun 17 2015
NOTICE: BL1: Booting BL3-1
NOTICE: BL3-1: v1.1(release):789c220
NOTICE: BL3-1: Built : 08:47:30, Jun 17 2015
UEFI firmware (version built at 08:45:45 on Jun 17 2015)[=3h[=3h[=3h[=3h[=3h[=3h
The default boot selection will start in 1 seconds
EFI stub: Booting Linux Kernel…
[ 0.000000] Initializing cgroup subsys cpu
[ 0.000000] Initializing cgroup subsys cpuacct
[ 0.000000] Linux version 3.10.80 (buildslave@x86-64-07-android) (gcc version 4.9.4 20150629 (prerelease) (Linaro GCC 4.9-2015.06) ) #1 SMP PREEMPT Mon Jul 20 13:57:36 CEST 2015
Black screen
The boot screen has been disabled to speed up booting. This means you may not see anything on the CLCD terminal for a while depending on the performance of the machine the model is running on. For example a first boot on a 2 GHz machine with 32 GB of RAM took 20 minutes. Subsequent boots should take approximately half the time to boot.
Run the Android SDK
Attach ADB
If you run the models with the configurations mentioned above at the “Running the models” section, by default you can connect to the adb connection like this:
adb connect 127.0.0.1
ADB on FVP Base models are supported over network as well. Follow the instructions here https://wiki.linaro.org/Internal/Projects/Juice/SetupNetworkingOnModelsUsingBridges to setup networking and use adb.
You can also run all of the standard Android SDK tools. Learn more at http://developer.android.com/sdk/index.html
Please Note: The adb connection will be only available after the Home screen is displayed.
Accessing Source Code
Linaro Android Source Code
Run the linaro_android_build_cmds.sh script, it will download the entire source code for both Android and the kernel and attempt to build it.
The pinned and source manifests can be found here:
Compiling Linaro Android RootFS+Kernel
The following simple steps download, install and compile a complete Linaro Android distribution
- Download and install Ubuntu 14.04 64 bit or newer (download)
- Download the Android building script for this build from the list of artifacts listed above or here
- Run the script
Build from the tip of the source:
chmod a+x linaro_android_build_cmds.sh
./linaro_android_build_cmds.sh -t
Or reproduce the exactly the same as this buid:
chmod a+x linaro_android_build_cmds.sh
./linaro_android_build_cmds.sh -m pinned-manifest.xml
Booting the android with fastmodels
create the image file
$ linaro-android-media-create --image_file mmc.bin --image_size 2000M --dev vexpress --system system.tar.bz2 --userdata userdata.tar.bz2 --boot boot.tar.bz2
Extract the preboot files
tar -jxvf boot.tar.bz2
Setup the runtime environment
$ export ARMLMD_LICENSE_FILE="8224@localhost" $ ssh -L 8224:localhost:8224 -L 18224:localhost:18224 -N $USER@flexlm.linaro.org &
Running the models (verified on FVP Base model build 6302)
$ cd boot/ $ /path/to/FVP_Base_AEMv8A-AEMv8A/models/Linux64_GCC-4.1/FVP_Base_AEMv8A-AEMv8A \ -C pctl.startup=0.0.0.0 \ -C bp.secure_memory=0 \ -C cluster0.NUM_CORES=1 \ -C cluster1.NUM_CORES=1 \ -C cache_state_modelled=0 \ -C bp.pl011_uart0.untimed_fifos=1 \ -C bp.secureflashloader.fname=bl1.bin \ -C bp.flashloader0.fname=fvp_fip.bin \ -C bp.virtioblockdevice.image_path=mmc.bin \ -C bp.hostbridge.userNetworking=true \ -C bp.ve_sysregs.mmbSiteDefault=0 \ -C bp.hostbridge.userNetPorts="5555=5555" \ -C bp.smsc_91c111.enabled=1
Console redirection
To redirect the console open a terminal and run
telnet 127.0.0.1 5000
Select UEFI configuration item, boot the build
Stop the UEFI prompt and select the Shell item, then it will boot up directly for you:
$ telnet localhost 5000
Trying ::1…
Trying 127.0.0.1…
Connected to localhost.
Escape character is ‘^]’.
NOTICE: Booting Trusted Firmware
NOTICE: BL1: v1.1(release):789c220
NOTICE: BL1: Built : 08:47:23, Jun 17 2015
NOTICE: BL1: Booting BL2
NOTICE: BL2: v1.1(release):789c220
NOTICE: BL2: Built : 08:47:25, Jun 17 2015
NOTICE: BL1: Booting BL3-1
NOTICE: BL3-1: v1.1(release):789c220
NOTICE: BL3-1: Built : 08:47:30, Jun 17 2015
UEFI firmware (version built at 08:45:45 on Jun 17 2015)[=3h[=3h[=3h[=3h[=3h[=3h
The default boot selection will start in 1 seconds
EFI stub: Booting Linux Kernel…
[ 0.000000] Initializing cgroup subsys cpu
[ 0.000000] Initializing cgroup subsys cpuacct
[ 0.000000] Linux version 3.10.80 (buildslave@x86-64-07-android) (gcc version 4.9.4 20150629 (prerelease) (Linaro GCC 4.9-2015.06) ) #1 SMP PREEMPT Mon Jul 20 13:57:36 CEST 2015
Black screen
The boot screen has been disabled to speed up booting. This means you may not see anything on the CLCD terminal for a while depending on the performance of the machine the model is running on. For example a first boot on a 2 GHz machine with 32 GB of RAM took 20 minutes. Subsequent boots should take approximately half the time to boot.
Run the Android SDK
Attach ADB
If you run the models with the configurations mentioned above at the “Running the models” section, by default you can connect to the adb connection like this:
adb connect 127.0.0.1
ADB on FVP Base models are supported over network as well. Follow the instructions here https://wiki.linaro.org/Internal/Projects/Juice/SetupNetworkingOnModelsUsingBridges to setup networking and use adb.
You can also run all of the standard Android SDK tools. Learn more at http://developer.android.com/sdk/index.html
Please Note: The adb connection will be only available after the Home screen is displayed.