-
Notifications
You must be signed in to change notification settings - Fork 2
User_documentation
Fabien edited this page Apr 21, 2021
·
9 revisions
Last update : 2020-2021
In this page, you will find all useful details for an user to go further in this project use. If you want to learn more or to help, we advise you to read the developers documentation afterward.
Table of content :
To begin, you need to clone the git repositories of TuxML where you want to have it :
git clone https://github.com/TuxML/tuxml.git
Or if you don't want to use git, you can download the .zip and move manually TuxML where you want.
- python3
- docker
- internet access (at least for the first use to get docker images and needed if you want to send results to database)
$ python3 kernel_generator.py --help
usage: kernel_generator.py [-h] [--boot] [--checksize] [--dev] [--local] [--tiny] [--configs CONFIGS [CONFIGS ...]] [--seed SEED] [--linux_version LINUX_VERSION] [--compiler COMPILER] [--logs LOGS] [-s]
[--unit_testing] [-n NUMBER_CPU]
[nbcontainer] [incremental]
positional arguments:
nbcontainer Provide the number of container to run. Have to be over 0.
incremental Optional. Provide the number of additional incremental compilation. Have to be 0 or over.
optional arguments:
-h, --help show this help message and exit
--boot Optional. Try to boot the kernel after compilation if the compilation has been successful
--checksize Optional. Compute additional size measurements on the kernel and send the results to the 'sizes' table (can be heavy).
--dev Use the image with dev tag instead of prod's one.
--local Don't try update the image to run, i.e. use the local version.
--tiny Use Linux tiny configuration. Incompatible with --configs argument.
--configs CONFIGS [CONFIGS ...]
Give a path to specific configuration files. Incompatible wit --tiny argument.
--seed SEED Give a path to a specific seed options file. These options will be activated before the others are randomly chosen. The file will replace tuxml.config
--linux_version LINUX_VERSION
Optional. Give a specific linux version to compile (can be v4 or v5). Note that its local, will take some time to download the kernel after compiling, and that the image use to compile
it will be deleted afterward.
--compiler COMPILER Optional. Give a specific compiler version.
--logs LOGS Optional. Save the logs to the specified path.
-s, --silent Prevent printing on standard output when compiling. Will still display the feature warning.
--unit_testing Optional. Run the unit testing of the compilation script. Prevent any compilation to happen. Will disable --tiny, --configs, --linux_version, --silent, --fetch_kernel and incremental
feature during runtime.
-n NUMBER_CPU, --number_cpu NUMBER_CPU
Optional. Specify the number of cpu cores to use while compiling.Useful if your computer can't handle the process at full power.
--json Optional. Return a json which contain importants
informations.
--mount_host_dev Optional. permit us to use the local file without
recreate the images
Here are some examples to get you started:
- A simple compilation:
kernel_generator.py
(nothing else !) - With unit testing :
kernel_generator.py –unit-testing
- With a custom .config file:
kernel_generator.py –config <path/to/.config>
- Running 100 compilations on 2 cpu cores:
kernel_generator.py 100 -n 2
orkernel_generator.py 100 –number_cpu 2
- Running 4 compilations on 16 cpu cores with kernel version 4.15.1:
kernel_generator.py 4 -n 16 –linux4_version 15.1
- A simple compilation:
python3 kernel_generator.py
- With unit testing:
python3 kernel_generator.py --unit-testing
- With a custom .config file:
python3 kernel_generator.py --config /.config
- With gcc version 8 :
python3 kernel_generator.py --compiler gcc8
- Running 100 compilations on 2 cpu cores:
python3 kernel_generator.py 100 -n 2
orpython3 kernel_generator.py 100 --number_cpu 2
- Running 4 compilations on 16 cpu cores with kernel version 4.15.1:
python3 kernel_generator.py 4 -n 16 --linux_version 4.15.1
- TuxML Website: https://tuxmlweb.istic.univ-rennes1.fr
- Local generated .json: if you use the argument
--json
you will find a json file locally with the result of the compilation in the root folderJson/
Consult the Developer's documentation