diff options
Diffstat (limited to 'etc/README')
-rw-r--r-- | etc/README | 230 |
1 files changed, 230 insertions, 0 deletions
diff --git a/etc/README b/etc/README new file mode 100644 index 00000000..5cab545e --- /dev/null +++ b/etc/README @@ -0,0 +1,230 @@ + + Obtaining and installing a Midipix distribution + Last update: Sun, 24 Apr 2016 09:42:40 +0000 + +A Midipix distribution consists of the following: +a) the native Midipix toolchain, consisting of perk, gcc, its dependencies, + and binutils, +b) musl, a lightweight, fast, simple, and free libc[1] used by Midipix, +c) the Midipix runtime components that bridge the gap between the libc and the + executive subsystems of all Windows NT-derived Windows OS starting with and + including Windows XP, and +d) a steadily increasing number of 3rd party open source packages, as expected in + any modern POSIX-compliant *nix environment, including GNU coreutils, shells, + libraries such as ncurses, libressl, as well as Perl and Python. + +Compressed Midipix distribution tarballs and, separately, source tarballs are, +at present, produced every four (4) hours UTC after each successful build and +subsequently signed. This process is fully automated by a portable Bourne shell +script; all of the above mentioned components are cross-compiled. + +Thus, the most hassle-free way to get started with Midipix is to simply download +the most recent distribution tarball and follow the instructions below. It is, +however, recommended to anyone intending to use Midipix as a development platform +to familiarise themselves with the build process. Other reasons to prefer building +a Midipix distribution yourself include integrating new 3rd party software or local +runtime component patches. At present, a full build from scratch takes about 30 +(thirty) minutes to finish on an 8-core host with eight simultaneous make jobs, +minus the generation of the tarballs. The build script can be obtained from the +following GitHub repository: <https://github.com/lalbornoz/midipix_build>. + +If you obtained a Midipix distribution tarball, extract it into a directory and +drive of your choice, henceforth referred to as target directory; the drive can +be a network drive. Do _not_ use anything but a true UNIX environment tar(1), as +e.g. WinRAR or WinZip handle extracting hard links incorrectly. +If you built Midipix yourself, the target directory is equivalent to the ${PREFIX} +configured in build.vars, which defaults to ${HOME}/midipix. + +At present, providing an interactive Midipix environment still requires the Cygwin +terminal emulator Mintty and a shell; this does not include pseudoterminals, which +are entirely handled by Midipix. Both can be installed via the 64-bit Cygwin setup +program at <https://www.cygwin.com/setup-x86_64.exe>. + +Once installed, launching a Midipix shell is accomplished by the `midipix.sh' shell +script provided in the target directory from within a Cygwin shell prompt in Mintty +and the target directory. This may either simply be done manually each time, or +automated by a shortcut. As shortcuts cannot be distributed, it can be created by +either: +a) Opening (executing) the VBScript script in the target directory from within the + latter cscript.exe, providing the fully qualified pathname to Mintty, if it differs + from the default value of C:\cygwin64\bin\mintty.exe or +b) manually creating a shortcut to Mintty with `Start in:' set to the target directory + and the following command line: + [ ... ]\mintty.exe -i /Cygwin-Terminal.ico -e sh midipix.sh, or + +References: +Sun, 24 Apr 2016 09:04:08 +0000 [1] musl FAQ <http://www.musl-libc.org/faq.html> + + Linux distribution-related errata + +Busybox based distributions need the gawk, gsed, and coreutils packages to build perl. + + Midipix status report + Last update: Tue, 26 Apr 2016 10:16:16 +0000 + +The following build status codes are defined: +C -- Complete build w/ at least the default configuration, +B -- Broken, e.g. doesn't work at all or only minimally, +I -- Integrated (e.g. linked against) with other packages, +E -- Extensively tested and confirmed to work by multiple sources, possibly via a testsuite, +P -- Patches needed to build that haven't been committed upstream yet, and +U -- Update to latest stable version or HEAD pending. + +Component type Name Version Status Comments +Host toolchain binutils 2.24.51 C--EPU +Host toolchain file 5.28 C----- +Host toolchain gcc 4.6.4 ---EPU Excludes libstdc++ +Host toolchain musl 1.1.12 C-IEPU +Host toolchain perk HEAD C-IE-- +Host toolchain pkgconf 0.28 C--E-- +Host toolchain slibtool 0.5.7 C--E-- +Native toolchain binutils 2.24.51 C--EPU +Native toolchain gcc 4.6.4 ---EPU Excludes libstdc++ +Native toolchain gmp 5.1.3 C-IEPU +Native toolchain libelf 0.8.13 C-IEP- +Native toolchain mpc 1.0.1 C-IE-U +Native toolchain mpfr 3.1.2 C-IE-U +Native toolchain musl 1.1.12 C-IEPU +Native toolchain perk HEAD C-IE-- +Native toolchain pkgconf 0.28 C-IE-- +Runtime components dalist HEAD C-IE-- +Runtime components ntapi HEAD C-IE-- +Runtime components ntcon HEAD C-IE-- +Runtime components ntctty HEAD C-IE-- +Runtime components pemagine HEAD C-IE-- +Runtime components psxscl HEAD C-IE-- Excludes clone(2) and dlopen(3) +Runtime components psxtypes HEAD C-IE-- +Runtime components ptycon HEAD C-IE-- +3rd party libraries bzip2 1.0.6 C-IE-- +3rd party libraries curl 7.47.1 C---P- +3rd party libraries expat 2.2.0 C----- +3rd party libraries gdbm 1.12 C-I--- +3rd party libraries glib 2.46.2 C-I-P- Shared object not built +3rd party libraries gzip 1.2.4 C-IE-- +3rd party libraries inputproto 2.3.2 C----- +3rd party libraries kbproto 1.0.7 C----- +3rd party libraries libarchive 3.1.2 C-I-P- +3rd party libraries libassuan 2.4.3 C-I--- +3rd party libraries libevent 2.0.22-stable C-I--- +3rd party libraries libfetch 2.33 C-I-P- +3rd party libraries libffi 3.2.1 C-I-P- +3rd party libraries libfirm HEAD C-I-P- +3rd party libraries libgcrypt 1.7.3 C-I--- +3rd party libraries libgpg_error 1.24 C-I-P- +3rd party libraries libICE 1.0.9 C----- +3rd party libraries libksba 1.3.5 C-I-P- +3rd party libraries libpipeline 1.4.1 C-I--- +3rd party libraries libpthread-stubs 0.3 C----- +3rd party libraries libressl 2.2.6 C-I-P- +3rd party libraries libSM 1.2.2 C----- +3rd party libraries libX11 1.6.3 C----- +3rd party libraries libXau 1.0.8 C----- +3rd party libraries libXaw 1.0.13 C----- +3rd party libraries libXext 1.3.3 C----- +3rd party libraries libxkbfile 1.0.9 C----- +3rd party libraries libXmu 1.1.2 C----- +3rd party libraries libXpm 3.5.11 C----- +3rd party libraries libXt 1.1.5 C----- +3rd party libraries libz 1.2.8.2015.05.20 C-I--- +3rd party libraries lua 5.3.3 C---P- +3rd party libraries ncurses 6.0 C-IEP- ncurses, ncursestw, and ncursesw built +3rd party libraries npth 1.2 C-I--- +3rd party libraries pcre 8.39 C-I--- +3rd party libraries renderproto 0.11.1 C----- +3rd party libraries xcb 1.12 C----- Needs pthreads / clone(2) +3rd party libraries xcb-proto 1.12 C----- +3rd party libraries xextproto 7.3.0 C----- +3rd party libraries xproto 7.0.29 C----- +3rd party libraries Xrender 0.9.9 C----- +3rd party libraries xtrans 1.1 C----- +3rd party libraries xz 5.2.2 C-IE-- +3rd party packages apk_tools 2.6.6 C---P- +3rd party packages bash 4.3 C-I-P- Linked against ncursesw +3rd party packages coreutils 8.23 C---P- Needs extensive testing +3rd party packages cparser HEAD C-I-P- +3rd party packages cron HEAD C---P- +3rd party packages dash 0.5.8 C----- Provides /bin/sh +3rd party packages diffutils 3.3 C----- +3rd party packages dos2unix 7.3.4 C----- +3rd party packages ed 1.13 C----- +3rd party packages file 5.28 C----- +3rd party packages findutils 4.5.14 C---P- +3rd party packages gawk 4.1.3 C----- +3rd party packages git 2.7.1 C----- Needs clone(2) +3rd party packages gnupg 2.1.15 C----- Needs /dev/[u]random, extensive testing +3rd party packages grep 2.22 C----- +3rd party packages hexcurse 1.60.0 C-I-P- Linked against ncursesw +3rd party packages htop 2.0.1 C-I-P- Linked against ncursesw +3rd party packages inetutils 1.9.4 C----- +3rd party packages infounzip 6.0 C----- +3rd party packages infozip 3.0 C----- +3rd party packages irssi 0.8.18 CB--P- DNS and /EXEC require clone(2) due to pthreads (see psxscl;) no Perl support +3rd party packages john 1.8.0 C---P- +3rd party packages less 481 C-I--- Linked against ncursesw +3rd party packages lynx 2.8.8rel2 C----- +3rd party packages make 3.81 C----- +3rd party packages man_db 2.7.5 C----- +3rd party packages mc 4.8.17 C----- +3rd party packages mksh R52c C----- +3rd party packages nano 2.5.3 C-I--- Linked against ncursesw +3rd party packages netcat 110 C---P- +3rd party packages openssh 7.1p2 C-I--- Linked against libressl +3rd party packages p7zip HEAD C----- +3rd party packages pacman 5.0.1 C---P- +3rd party packages patch 2.7 C----- +3rd party packages perl 5.22.1 ------ No dlopen(3) (see psxscl,) modules missing +3rd party packages procps-ng 3.3.12 C----- +3rd party packages python 3.5.1 -B--P- No dlopen(3) (see psxscl,) modules missing +3rd party packages rsync 3.1.2 C----- +3rd party packages rxvt-unicode 9.22 C-I--- No Perl support +3rd party packages sed 4.2.2 C----- +3rd party packages tar 1.28 C----- +3rd party packages tcsh 6.19.00 C-I-P- +3rd party packages the silver searcher 0.32.0 C----- +3rd party packages tmux 2.2 C---P- +3rd party packages util_linux 2.27.1 C----- Needs extensive testing +3rd party packages vim 7.4.1952 C----- Provides /bin/vi +3rd party packages weechat 1.6 C----- +3rd party packages which 2.21 C----- +3rd party packages whois 5.2.12 C----- +3rd party packages xeyes 1.1.1 C-I--- +3rd party packages xwd 1.0.6 C-I--- +3rd party packages zsh 5.2 C-I--- Linked against ncursesw + + Midipix roadmap/TODO list + Last update: Fri, 03 Jun 2016 12:47:13 +0000 + +midipix alpha release: the final stretch +======================================== + +my.own.tasks@midipix.org +------------------------ + +* ofd tables: additional bucket allocation as needed. +* `ls -R //c`: check for the cause of individual failures. + (might be related to the above ofd bucket allocation). +* integrate clone and the initial ldso implementation. +* integrate the signal queue, check signal implementation for + semantic completion, especially in the context of multi-threaded + applications. +* implement /dev/random and /dev/urandom, as well as other virtual + folders needed by core applications. +* implement the scheduler functions. +* implement (possibly as stubs) missing system calls, fix existing + system calls as needed by the core applications. +* toolchain: provided the few interfaces missing for C++ support. +* porting of mintty. + + +porting and other release-related tasks +--------------------------------------- + +* testing of ncurses. +* testing of bash and dash when built with ncurses. +* testing of all of the coreutils, seeing which ones fail due to + a missing virtual file or folder, which ones fail due to a missing + system call (crash), and which ones fail due to an incomplete or + incorrect system call. +* porting of gdb. + +vim:expandtab sw=8 ts=8 tw=0 nowrap |