Patched toybox as people are lazy
Go to file
Yi-Yo Chiang 2d03a5e677 Fix linux_bionic build
After adding "toybox" to cvd-host_package.tar.gz,
aosp_cf_arm64_phone-userdebug failed to build with error:

  In file included from external/toybox/lib/args.c:10:
  external/toybox/toys.h:8:10: fatal error: 'generated/config.h' file
  not found
  #include "generated/config.h"
           ^~~~~~~~~~~~~~~~~~~~
  1 error generated.

This is because toybox is not configured to be built on linux_bionic
host, and aosp_cf_arm64_phone is trying to build the HOST_CROSS variant
of toybox, which is arm64 linux_bionic.

Bug: 185883642
Test: lunch aosp_cf_arm64_phone-userdebug && m
Change-Id: I64418fb5f88f8a8b8b7e6905b58cc1f7e68ab2e8
2021-04-23 08:25:56 +00:00
.github/workflows Add MacOS 11.0 to CI Builds 2020-12-25 01:51:58 -06:00
android Merge remote-tracking branch 'toybox/master' into HEAD 2021-04-20 10:05:54 -07:00
kconfig Add df to the macOS default configuration. 2021-02-23 01:02:13 -06:00
lib hexedit: various improvements. 2021-04-20 03:36:20 -05:00
scripts Add more shell tests, and teach txpect to do regex matches (RO and RE). 2021-03-16 02:29:15 -05:00
tests Test doesn't need the < /dev/null and input being a pipe doesn't make 2021-04-20 06:00:15 -05:00
toys hexedit: various improvements. 2021-04-20 03:36:20 -05:00
www Remove redundant blake2 mention and move base32 into the implemented list. 2021-01-18 22:22:59 -06:00
.config-device Merge remote-tracking branch 'toybox/master' into HEAD 2021-04-02 14:36:19 -07:00
.config-linux Merge remote-tracking branch 'toybox/master' into HEAD 2021-04-02 14:36:19 -07:00
.config-mac Merge remote-tracking branch 'toybox/master' into HEAD 2021-04-02 14:36:19 -07:00
.gitignore Merge remote-tracking branch 'toybox/master' into HEAD 2016-02-11 19:17:08 -08:00
Android.bp Fix linux_bionic build 2021-04-23 08:25:56 +00:00
Config.in Typo 2021-04-01 04:01:02 -05:00
configure Integrate cross compile support into mkroot, ala "make root CROSS=sh4" 2020-04-06 04:34:19 -05:00
LICENSE The title line is confusing github's license detector thingy. 2019-02-14 13:48:02 -06:00
main.c Add lots of "static" annotations, make a couple things use FLAG() macros, etc. 2021-02-07 17:19:44 -06:00
Makefile Elliott said that chmod 000 debris was confusing host rm -rf, and macos 2020-12-18 05:16:33 -06:00
METADATA Add METADATA to toybox: PublicDomain+0BSD+CC0+UNLICENSE=UNENCUMBERED 2020-04-29 09:59:30 -07:00
MODULE_LICENSE_BSD Add MODULE_LICENSE and NOTICE 2015-05-22 13:45:26 -07:00
OWNERS Switch to system/core/janitors as OWNERS. 2019-01-17 13:16:59 -08:00
README Fluff out the FAQ some more and flush pending README changes. 2020-05-29 04:12:53 -05:00
regenerate.sh Android: separate the (host) linux and mac configs. 2019-08-22 10:54:26 -07:00
run-tests-on-android.sh Harden test setup / cleanup 2021-02-05 00:19:33 +08:00
TEST_MAPPING Move toybox tests to presubmit. 2019-08-06 12:24:30 -07:00
toys.h Remove CONFIG_TOYBOX_I18N and just always support utf8. 2020-12-06 00:02:46 -06:00

Toybox: all-in-one Linux command line.

--- Getting started

You can download static binaries for various targets from:

  http://landley.net/toybox/bin

The special name "." indicates the current directory (just like ".." means
the parent directory), and you can run a program that isn't in the $PATH by
specifying a path to it, so this should work:

  wget http://landley.net/toybox/bin/toybox-x86_64
  chmod +x toybox-x86_64
  ./toybox-x86_64 echo hello world

--- Building toybox

Type "make help" for build instructions.

Toybox uses the "make menuconfig; make; make install" idiom same as
the Linux kernel. Usually you want something like:

  make defconfig
  make
  make install

Or maybe:

  LDFLAGS="--static" CROSS_COMPILE=armv5l- make defconfig toybox
  PREFIX=/path/to/root/filesystem/bin make install_flat

The file "configure" defines default values for many environment variables
that control the toybox build; if export any these variables into your
environment, your value is used instead of the default in that file.

The CROSS_COMPILE argument above is optional, the default builds a version of
toybox to run on the current machine. Cross compiling requires an appropriately
prefixed cross compiler toolchain, several example toolchains (built using
the file "scripts/mcm-buildall.sh" in the toybox source) are available at:

  https://mkroot.musl.cc/latest/

For the "CROSS_COMPILE=armv5l-" example above, download
cross-compiler-armv5l.tar.bz2, extract it, and add its "bin" subdirectory to
your $PATH. (And yes, the trailing - is significant, because the prefix
includes a dash.)

For more about cross compiling, see:

  https://landley.net/toybox/faq.html#cross
  http://landley.net/writing/docs/cross-compiling.html
  http://landley.net/aboriginal/architectures.html

For a more thorough description of the toybox build process, see:

  http://landley.net/toybox/code.html#building

--- Using toybox

The toybox build produces a multicall binary, a "swiss-army-knife" program
that acts differently depending on the name it was called by (cp, mv, cat...).
Installing toybox adds symlinks for each command name to the $PATH.

The special "toybox" command treats its first argument as the command to run.
With no arguments, it lists available commands. This allows you to use toybox
without installing it, and is the only command that can have an arbitrary
suffix (hence "toybox-armv5l").

The "help" command provides information about each command (ala "help cat"),
and "help toybox" provides general information about toybox.

--- Configuring toybox

It works like the Linux kernel: allnoconfig, defconfig, and menuconfig edit
a ".config" file that selects which features to include in the resulting
binary. You can save and re-use your .config file, but may want to
run "make oldconfig" to re-run the dependency resolver when migrating to
new versions.

The maximum sane configuration is "make defconfig": allyesconfig isn't
recommended as a starting point for toybox because it enables unfinished
commands, debug code, and optional dependencies your build environment may
not provide.

--- Creating a Toybox-based Linux system

Toybox has a built-in simple system builder (scripts/mkroot.sh) with a
Makefile target:

  make root
  sudo chroot root/host/fs /init

Type "exit" to get back out. If you install appropriate cross compilers and
point it at Linux source code, it can build simple three-package systems
that boot to a shell prompt under qemu:

  make root CROSS_COMPILE=sh4-linux-musl- LINUX=~/linux
  cd root/sh4
  ./qemu-sh4.sh

By calling scripts/mkroot.sh directly you can add additional packages
to the build, see scripts/root/dropbear as an example.

The FAQ explains this in a lot more detail:

  https://landley.net/toybox/faq.html#system
  https://landley.net/toybox/faq.html#mkroot

--- Presentations

1) "Why Toybox?" talk at the Embedded Linux Conference in 2013

    outline: http://landley.net/talks/celf-2013.txt
    video: http://youtu.be/SGmtP5Lg_t0

    The https://landley.net/toybox/about.html page has nav links breaking that
    talk down into sections.

2) "Why Public Domain?" The rise and fall of copyleft, Ohio LinuxFest 2013

    outline: http://landley.net/talks/ohio-2013.txt
    audio: https://archive.org/download/OhioLinuxfest2013/24-Rob_Landley-The_Rise_and_Fall_of_Copyleft.mp3

3) Why did I do Aboriginal Linux (which led me here)

    260 slide presentation:
      https://speakerdeck.com/landley/developing-for-non-x86-targets-using-qemu

    How and why to make android self-hosting:
      http://landley.net/aboriginal/about.html#selfhost

    More backstory than strictly necessary:
      https://landley.net/aboriginal/history.html

4) What's new with toybox (ELC 2015 status update):

    video: http://elinux.org/ELC_2015_Presentations
    outline: http://landley.net/talks/celf-2015.txt

5) Toybox vs BusyBox (2019 ELC talk):

    outline: http://landley.net/talks/elc-2019.txt
    video: https://www.youtube.com/watch?v=MkJkyMuBm3g

--- Contributing

The three important URLs for communicating with the toybox project are:

  web page: http://landley.net/toybox

  mailing list: http://lists.landley.net/listinfo.cgi/toybox-landley.net

  git repo: http://github.com/landley/toybox

The maintainer prefers patches be sent to the mailing list. If you use git,
the easy thing to do is:

  git format-patch -1 $HASH

Then send a file attachment. The list holds messages from non-subscribers
for moderation, but I usually get to them in a day or two.

I download github pull requests as patches and apply them with "git am"
(which avoids gratuitous merge commits). Sometimes I even remember to close
the pull request.

If I haven't responded to your patch after one week, feel free to remind
me of it.

Android's policy for toybox patches is that non-build patches should go
upstream first (into vanilla toybox, with discussion on the toybox mailing
list) and then be pulled into android's toybox repo from there. (They
generally resync on fridays). The exception is patches to their build scripts
(Android.mk and the checked-in generated/* files) which go directly to AOSP.

(As for the other meaning of "contributing", https://patreon.com/landley is
always welcome but I warn you up front I'm terrible about updating it.)