• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1The goal of the libc crate is to have CI running everywhere to have the
2strongest guarantees about the definitions that this library contains, and as a
3result the CI is pretty complicated and also pretty large! Hopefully this can
4serve as a guide through the sea of scripts in this directory and elsewhere in
5this project.
6
7Note that this documentation is quite outdated. See CI config and scripts
8in the `ci` directory how we run CI now.
9
10# Files
11
12First up, let's talk about the files in this directory:
13
14* `run-docker.sh` - a shell script run by most builders, it will execute
15  `run.sh` inside a Docker container configured for the target.
16
17* `run.sh` - the actual script which runs tests for a particular architecture.
18
19* `dox.sh` - build the documentation of the crate and publish it to gh-pages.
20
21# CI Systems
22
23Currently this repository leverages a combination of GitHub Actions and Cirrus CI
24for running tests. You can find tested triples in [Actions config] or [Cirrus config].
25
26The Windows triples are all pretty standard, they just set up their environment
27then run tests, no need for downloading any extra target libs (we just download
28the right installer). The Intel Linux/OSX builds are similar in that we just
29download the right target libs and run tests. Note that the Intel Linux/OSX
30builds are run on stable/beta/nightly, but are the only ones that do so.
31
32The remaining architectures look like:
33
34* Android runs in a [docker image][android-docker] with an emulator, the NDK,
35  and the SDK already set up. The entire build happens within the docker image.
36* The MIPS, ARM, and AArch64 builds all use the QEMU userspace emulator to run
37  the generated binary to actually verify the tests pass.
38* The MUSL build just has to download a MUSL compiler and target libraries and
39  then otherwise runs tests normally.
40* iOS builds need an extra linker flag currently, but beyond that they're built
41  as standard as everything else.
42* The BSD builds, currently OpenBSD and FreeBSD, use QEMU to boot up a system
43  and compile/run tests. More information on that below.
44
45[Actions config]: https://github.com/rust-lang/libc/tree/master/.github/workflows
46[Cirrus config]: https://github.com/rust-lang/libc/blob/master/.cirrus.yml
47[android-docker]: https://github.com/rust-lang/libc/blob/master/ci/docker/x86_64-linux-android/Dockerfile
48
49## QEMU
50
51Lots of the architectures tested here use QEMU in the tests, so it's worth going
52over all the crazy capabilities QEMU has and the various flavors in which we use
53it!
54
55First up, QEMU has userspace emulation where it doesn't boot a full kernel, it
56just runs a binary from another architecture (using the `qemu-<arch>` wrappers).
57We provide it the runtime path for the dynamically loaded system libraries,
58however. This strategy is used for all Linux architectures that aren't intel.
59Note that one downside of this QEMU system is that threads are barely
60implemented, so we're careful to not spawn many threads.
61
62Finally, the fun part, the BSDs. Quite a few hoops are jumped through to get CI
63working for these platforms, but the gist of it looks like:
64
65* Cross compiling from Linux to any of the BSDs seems to be quite non-standard.
66  We may be able to get it working but it might be difficult at that point to
67  ensure that the libc definitions align with what you'd get on the BSD itself.
68  As a result, we try to do compiles within the BSD distro.
69* We resort to userspace emulation (QEMU).
70
71With all that in mind, the way BSD is tested looks like:
72
731. Download a pre-prepared image for the OS being tested.
742. Generate the tests for the OS being tested. This involves running the `ctest`
75   library over libc to generate a Rust file and a C file which will then be
76   compiled into the final test.
773. Generate a disk image which will later be mounted by the OS being tested.
78   This image is mostly just the libc directory, but some modifications are made
79   to compile the generated files from step 2.
804. The kernel is booted in QEMU, and it is configured to detect the libc-test
81   image being available, run the test script, and then shut down afterwards.
825. Look for whether the tests passed in the serial console output of the kernel.
83
84There's some pretty specific instructions for setting up each image (detailed
85below), but the main gist of this is that we must avoid a vanilla `cargo run`
86inside of the `libc-test` directory (which is what it's intended for) because
87that would compile `syntex_syntax`, a large library, with userspace emulation.
88This invariably times out on CI, so we can't do that.
89
90Once all those hoops are jumped through, however, we can be happy that we're
91testing almost everything!
92
93Below are some details of how to set up the initial OS images which are
94downloaded. Each image must be enabled have input/output over the serial
95console, log in automatically at the serial console, detect if a second drive in
96QEMU is available, and if so mount it, run a script (it'll specifically be
97`run-qemu.sh` in this folder which is copied into the generated image talked
98about above), and then shut down.
99
100### QEMU Setup - FreeBSD
101
1021. [Download the latest stable amd64-bootonly release ISO](https://www.freebsd.org/where.html).
103   E.g. FreeBSD-11.1-RELEASE-amd64-bootonly.iso
1042. Create the disk image: `qemu-img create -f qcow2 FreeBSD-11.1-RELEASE-amd64.qcow2 2G`
1053. Boot the machine: `qemu-system-x86_64 -cdrom FreeBSD-11.1-RELEASE-amd64-bootonly.iso -drive if=virtio,file=FreeBSD-11.1-RELEASE-amd64.qcow2 -net nic,model=virtio -net user`
1064. Run the installer, and install FreeBSD:
107   1. Install
108   1. Continue with default keymap
109   1. Set Hostname: freebsd-ci
110   1. Distribution Select:
111      1. Uncheck lib32
112      1. Uncheck ports
113   1. Network Configuration: vtnet0
114   1. Configure IPv4? Yes
115   1. DHCP? Yes
116   1. Configure IPv6? No
117   1. Resolver Configuration: Ok
118   1. Mirror Selection: Main Site
119   1. Partitioning: Auto (UFS)
120   1. Partition: Entire Disk
121   1. Partition Scheme: MBR
122   1. App Partition: Ok
123   1. Partition Editor: Finish
124   1. Confirmation: Commit
125   1. Wait for sets to install
126   1. Set the root password to nothing (press enter twice)
127   1. Set time zone to UTC
128   1. Set Date: Skip
129   1. Set Time: Skip
130   1. System Configuration:
131      1. Disable sshd
132      1. Disable dumpdev
133   1. System Hardening
134      1. Disable Sendmail service
135   1. Add User Accounts: No
136   1. Final Configuration: Exit
137   1. Manual Configuration: Yes
138   1. `echo 'console="comconsole"' >> /boot/loader.conf`
139   1. `echo 'autoboot_delay="0"' >> /boot/loader.conf`
140   1. `echo 'ext2fs_load="YES"' >> /boot/loader.conf`
141   1. Look at `/etc/ttys`, see what getty argument is for `ttyu0` (E.g. `3wire`)
142   1. Edit `/etc/gettytab` (with `vi` for example), look for `ttyu0` argument,
143      prepend `:al=root` to the line beneath to have the machine auto-login as
144      root. E.g.
145
146          3wire:\
147                   :np:nc:sp#0:
148      becomes:
149
150          3wire:\
151                   :al=root:np:nc:sp#0:
152
153   1. Edit `/root/.login` and put this in it:
154
155          [ -e /dev/vtbd1 ] || exit 0
156          mount -t ext2fs /dev/vtbd1 /mnt
157          sh /mnt/run.sh /mnt
158          poweroff
159
160   1. Exit the post install shell: `exit`
161   1. Back in in the installer choose Reboot
162   1. If all went well the machine should reboot and show a login prompt.
163      If you switch to the serial console by choosing View > serial0 in
164      the qemu menu, you should be logged in as root.
165   1. Shutdown the machine: `shutdown -p now`
166
167Helpful links
168
169* https://en.wikibooks.org/wiki/QEMU/Images
170* https://blog.nekoconeko.nl/blog/2015/06/04/creating-an-openstack-freebsd-image.html
171* https://www.freebsd.org/doc/handbook/serialconsole-setup.html
172
173### QEMU setup - OpenBSD
174
1751. Download CD installer
1762. `qemu-img create -f qcow2 foo.qcow2 2G`
1773. `qemu -cdrom foo.iso -drive if=virtio,file=foo.qcow2 -net nic,model=virtio -net user`
1784. run installer
1795. `echo 'set tty com0' >> /etc/boot.conf`
1806. `echo 'boot' >> /etc/boot.conf`
1817. Modify /etc/ttys, change the `tty00` at the end from 'unknown off' to
182   'vt220 on secure'
1838. Modify same line in /etc/ttys to have `"/root/foo.sh"` as the shell
1849. Add this script to `/root/foo.sh`
185
186```
187#!/bin/sh
188exec 1>/dev/tty00
189exec 2>&1
190
191if mount -t ext2fs /dev/sd1c /mnt; then
192  sh /mnt/run.sh /mnt
193  shutdown -ph now
194fi
195
196# limited shell...
197exec /bin/sh < /dev/tty00
198```
199
20010. `chmod +x /root/foo.sh`
201
202Helpful links:
203
204* https://en.wikibooks.org/wiki/QEMU/Images
205* http://www.openbsd.org/faq/faq7.html#SerCon
206
207# Questions?
208
209Hopefully that's at least somewhat of an introduction to everything going on
210here, and feel free to ping @alexcrichton with questions!
211