|
Name |
|
Date |
Size |
#Lines |
LOC |
| .. | | - | - |
| generated/ | | 12-May-2024 | - | 9,815 | 8,106 |
| kconfig/ | | 12-May-2024 | - | 13,025 | 10,885 |
| lib/ | | 12-May-2024 | - | 6,483 | 4,351 |
| openharmony/ | | 12-May-2024 | - | 173 | 134 |
| porting/liteos_a/ | | 12-May-2024 | - | 6,598 | 4,155 |
| scripts/ | | 12-May-2024 | - | 2,956 | 2,077 |
| tests/ | | 12-May-2024 | - | 52,764 | 50,713 |
| toys/ | | 12-May-2024 | - | 62,248 | 42,202 |
| www/ | | 12-May-2024 | - | 13,345 | 11,245 |
| .gitignore | D | 12-May-2024 | 280 | 18 | 17 |
| BUILD.gn | D | 12-May-2024 | 20.9 KiB | 980 | 959 |
| Config.in | D | 12-May-2024 | 5.5 KiB | 187 | 149 |
| LICENSE | D | 12-May-2024 | 666 | 13 | 10 |
| Makefile | D | 12-May-2024 | 2.2 KiB | 88 | 54 |
| OAT.xml | D | 12-May-2024 | 5.3 KiB | 82 | 33 |
| README | D | 12-May-2024 | 6.2 KiB | 179 | 118 |
| README.OpenSource | D | 12-May-2024 | 584 | 12 | 11 |
| bundle.json | D | 12-May-2024 | 848 | 40 | 39 |
| configure | D | 12-May-2024 | 1.5 KiB | 44 | 20 |
| install.py | D | 12-May-2024 | 1.3 KiB | 54 | 35 |
| main.c | D | 12-May-2024 | 7.6 KiB | 264 | 163 |
| toybox.gni | D | 12-May-2024 | 1.6 KiB | 30 | 28 |
| toys.h | D | 12-May-2024 | 3.4 KiB | 129 | 90 |
README
1Toybox: all-in-one Linux command line.
2
3--- Getting started
4
5You can download static binaries for various targets from:
6
7 http://landley.net/toybox/bin
8
9The special name "." indicates the current directory (just like ".." means
10the parent directory), and you can run a program that isn't in the $PATH by
11specifying a path to it, so this should work:
12
13 wget http://landley.net/toybox/bin/toybox-x86_64
14 chmod +x toybox-x86_64
15 ./toybox-x86_64 echo hello world
16
17--- Building toybox
18
19Type "make help" for build instructions.
20
21Toybox uses the "make menuconfig; make; make install" idiom same as
22the Linux kernel. Usually you want something like:
23
24 make defconfig
25 make
26 make install
27
28Or maybe:
29
30 LDFLAGS="--static" CROSS_COMPILE=armv5l- make defconfig toybox
31 PREFIX=/path/to/root/filesystem/bin make install_flat
32
33The file "configure" defines default values for many environment variables
34that control the toybox build; if you export any of these variables into your
35environment, your value is used instead of the default in that file.
36
37The CROSS_COMPILE argument above is optional, the default builds a version of
38toybox to run on the current machine. Cross compiling requires an appropriately
39prefixed cross compiler toolchain, several example toolchains (built using
40the file "scripts/mcm-buildall.sh" in the toybox source) are available at:
41
42 https://mkroot.musl.cc/latest/
43
44For the "CROSS_COMPILE=armv5l-" example above, download
45cross-compiler-armv5l.tar.bz2, extract it, and add its "bin" subdirectory to
46your $PATH. (And yes, the trailing - is significant, because the prefix
47includes a dash.)
48
49For more about cross compiling, see:
50
51 https://landley.net/toybox/faq.html#cross
52 http://landley.net/writing/docs/cross-compiling.html
53 http://landley.net/aboriginal/architectures.html
54
55For a more thorough description of the toybox build process, see:
56
57 http://landley.net/toybox/code.html#building
58
59--- Using toybox
60
61The toybox build produces a multicall binary, a "swiss-army-knife" program
62that acts differently depending on the name it was called by (cp, mv, cat...).
63Installing toybox adds symlinks for each command name to the $PATH.
64
65The special "toybox" command treats its first argument as the command to run.
66With no arguments, it lists available commands. This allows you to use toybox
67without installing it, and is the only command that can have an arbitrary
68suffix (hence "toybox-armv5l").
69
70The "help" command provides information about each command (ala "help cat"),
71and "help toybox" provides general information about toybox.
72
73--- Configuring toybox
74
75It works like the Linux kernel: allnoconfig, defconfig, and menuconfig edit
76a ".config" file that selects which features to include in the resulting
77binary. You can save and re-use your .config file, but may want to
78run "make oldconfig" to re-run the dependency resolver when migrating to
79new versions.
80
81The maximum sane configuration is "make defconfig": allyesconfig isn't
82recommended as a starting point for toybox because it enables unfinished
83commands, debug code, and optional dependencies your build environment may
84not provide.
85
86--- Creating a Toybox-based Linux system
87
88Toybox has a built-in simple system builder (scripts/mkroot.sh) with a
89Makefile target:
90
91 make root
92 sudo chroot root/host/fs /init
93
94Type "exit" to get back out. If you install appropriate cross compilers and
95point it at Linux source code, it can build simple three-package systems
96that boot to a shell prompt under qemu:
97
98 make root CROSS_COMPILE=sh4-linux-musl- LINUX=~/linux
99 cd root/sh4
100 ./qemu-sh4.sh
101
102By calling scripts/mkroot.sh directly you can add additional packages
103to the build, see scripts/root/dropbear as an example.
104
105The FAQ explains this in a lot more detail:
106
107 https://landley.net/toybox/faq.html#system
108 https://landley.net/toybox/faq.html#mkroot
109
110--- Presentations
111
1121) "Why Toybox?" talk at the Embedded Linux Conference in 2013
113
114 outline: http://landley.net/talks/celf-2013.txt
115 video: http://youtu.be/SGmtP5Lg_t0
116
117 The https://landley.net/toybox/about.html page has nav links breaking that
118 talk down into sections.
119
1202) "Why Public Domain?" The rise and fall of copyleft, Ohio LinuxFest 2013
121
122 outline: http://landley.net/talks/ohio-2013.txt
123 audio: https://archive.org/download/OhioLinuxfest2013/24-Rob_Landley-The_Rise_and_Fall_of_Copyleft.mp3
124
1253) Why did I do Aboriginal Linux (which led me here)
126
127 260 slide presentation:
128 https://speakerdeck.com/landley/developing-for-non-x86-targets-using-qemu
129
130 How and why to make android self-hosting:
131 http://landley.net/aboriginal/about.html#selfhost
132
133 More backstory than strictly necessary:
134 https://landley.net/aboriginal/history.html
135
1364) What's new with toybox (ELC 2015 status update):
137
138 video: http://elinux.org/ELC_2015_Presentations
139 outline: http://landley.net/talks/celf-2015.txt
140
1415) Toybox vs BusyBox (2019 ELC talk):
142
143 outline: http://landley.net/talks/elc-2019.txt
144 video: https://www.youtube.com/watch?v=MkJkyMuBm3g
145
146--- Contributing
147
148The three important URLs for communicating with the toybox project are:
149
150 web page: http://landley.net/toybox
151
152 mailing list: http://lists.landley.net/listinfo.cgi/toybox-landley.net
153
154 git repo: http://github.com/landley/toybox
155
156The maintainer prefers patches be sent to the mailing list. If you use git,
157the easy thing to do is:
158
159 git format-patch -1 $HASH
160
161Then send a file attachment. The list holds messages from non-subscribers
162for moderation, but I usually get to them in a day or two.
163
164I download github pull requests as patches and apply them with "git am"
165(which avoids gratuitous merge commits). Sometimes I even remember to close
166the pull request.
167
168If I haven't responded to your patch after one week, feel free to remind
169me of it.
170
171Android's policy for toybox patches is that non-build patches should go
172upstream first (into vanilla toybox, with discussion on the toybox mailing
173list) and then be pulled into android's toybox repo from there. (They
174generally resync on fridays). The exception is patches to their build scripts
175(Android.mk and the checked-in generated/* files) which go directly to AOSP.
176
177(As for the other meaning of "contributing", https://patreon.com/landley is
178always welcome but I warn you up front I'm terrible about updating it.)
179
README.OpenSource
1[
2 {
3 "Name" : "toybox",
4 "License" : "Public Domain",
5 "License File" : "LICENSE",
6 "Version Number" : "0.8.6",
7 "Owner" : "maguangyao@huawei.com",
8 "Upstream URL" : "http://landley.net/toybox",
9 "Description" : "Toybox combines common Linux command line utilities together into a single BSD-licensed executable that's simple, small, fast, reasonably standards-compliant, and powerful enough to turn Android into a development environment."
10 }
11]
12