Diff markup
001 001
002 Contents of the extra/ directory 002 Contents of the extra/ directory
003 ================================ 003 ================================
004 004
005 Data and configuration files to support genera 005 Data and configuration files to support generation of sos on non-x86
006 and/or grub-less hosts: 006 and/or grub-less hosts:
007 - dot.mkvars: file to copy as .mkvars in the 007 - dot.mkvars: file to copy as .mkvars in the root directory to
008 compile on a non-x86 host, and to generate 008 compile on a non-x86 host, and to generate the grub floppy image on
009 a grub-less host 009 a grub-less host
010 - grub.img.gz: compressed image of a Grub flo 010 - grub.img.gz: compressed image of a Grub floppy (without any
011 kernel). Used by dot.mkvars. 011 kernel). Used by dot.mkvars.
012 - mtoolsrc: file needed by .mkvars to compile 012 - mtoolsrc: file needed by .mkvars to compile a the floppy image
013 013
014 Support of a sos-specific boot sector: 014 Support of a sos-specific boot sector:
015 - Makefile: rules to compile sos_bsect.img, t 015 - Makefile: rules to compile sos_bsect.img, the floppy image with the
016 boot sector and the Sos 016 boot sector and the Sos
017 - bootsect.S: x86 Sos boot sector (GNU as). D 017 - bootsect.S: x86 Sos boot sector (GNU as). Depends on sos_bsect.lds
018 - sos_bsect.lds: ld script to bind the boot s 018 - sos_bsect.lds: ld script to bind the boot sector with the remaining
019 of the kernel 019 of the kernel
020 020
021 Misc: 021 Misc:
022 - patch-qemu-port-e9.diff: patch over qemu to !! 022 - qemu-port-e9.diff: patch over qemu to support the bochs "port 0xe9 hack"
023 0xe9 hack" <<
024 - patch-qemu-pty.diff: patch over qemu to fix <<
025 handling of the "-monitor pty" and "-serial <<
026 - termslave.c: Linux program to dial with qem <<
027 line) from within a terminal. See comments <<
028 023
029 024
030 What you can do with these files 025 What you can do with these files
031 ================================ 026 ================================
032 027
033 028
034 *** Compile SOS from another architecture: 029 *** Compile SOS from another architecture:
035 ------------------------------------------ 030 ------------------------------------------
036 - compile a cross-compiler for the i586-gnu t 031 - compile a cross-compiler for the i586-gnu target. This involves
037 compiling the binutils and gcc. Here are ex 032 compiling the binutils and gcc. Here are example configuration
038 options for them: 033 options for them:
039 binutils (replace sparc-cun-solaris with yo 034 binutils (replace sparc-cun-solaris with your arch):
040 ../binutils-2.13/configure --prefix=/udd/ 035 ../binutils-2.13/configure --prefix=/udd/ddecotig/temp_dd/xgcc/host-sparc-solaris7/stow/binutils-2.11 --host=sparc-sun-solaris2.7 i586-gnu
041 make && make install 036 make && make install
042 gcc (ditto): 037 gcc (ditto):
043 CFLAGS="-O2 -Dinhibit_libc" ../gcc-3.2/co 038 CFLAGS="-O2 -Dinhibit_libc" ../gcc-3.2/configure --target=i586-gnu --prefix=/udd/ddecotig/temp_dd/xgcc/host-sparc-solaris7/stow/gcc-3.2 --with-as=/udd/ddecotig/temp_dd/xgcc/host-sparc-solaris7/bin/as --with-ld=/udd/ddecotig/temp_dd/xgcc/host-sparc-solaris7/bin/ld --with-gnu-as --with-gnu-ld --enable-languages=c --disable-shared --disable-multilib --disable-nls --enable-threads=single
044 make && make install 039 make && make install
045 - compile the mtools 040 - compile the mtools
046 - copy dot.mkvars to the root directory of SO 041 - copy dot.mkvars to the root directory of SOS, as ".mkvars"
047 - customize the CC/LD/... variables to suit y 042 - customize the CC/LD/... variables to suit your cross-compiler
048 installatioon 043 installatioon
049 - now you may run make from the SOS root dire 044 - now you may run make from the SOS root directory, it should
050 generate the Grub boot floppy image. The fo 045 generate the Grub boot floppy image. The following warning is
051 normal: 046 normal:
052 .mkvars:16: attention : écrasement des co 047 .mkvars:16: attention : écrasement des commandes pour la cible « grub-sos.img »
053 Makefile:92: attention : anciennes comman 048 Makefile:92: attention : anciennes commandes ignorées pour la cible « grub-sos.img »
054 049
055 050
056 *** To compile SOS from an x86 where grub is n 051 *** To compile SOS from an x86 where grub is not or incorrectly installed:
057 ---------------------------------------------- 052 --------------------------------------------------------------------------
058 - copy dot.mkvars to the root directory of SO 053 - copy dot.mkvars to the root directory of SOS, as ".mkvars"
059 - customize the CC/LD/... variables to suit y 054 - customize the CC/LD/... variables to suit your cross-compiler
060 installatioon 055 installatioon
061 - now you may run make from the SOS root dire 056 - now you may run make from the SOS root directory, it should
062 generate the Grub boot floppy image. The fo 057 generate the Grub boot floppy image. The following warning is
063 normal: 058 normal:
064 .mkvars:16: attention : écrasement des co 059 .mkvars:16: attention : écrasement des commandes pour la cible « grub-sos.img »
065 Makefile:92: attention : anciennes comman 060 Makefile:92: attention : anciennes commandes ignorées pour la cible « grub-sos.img »
066 061
067 062
068 *** To compile SOS with its own bootloader: 063 *** To compile SOS with its own bootloader:
069 ------------------------------------------- 064 -------------------------------------------
070 - for cross-architecture compilation: see abo 065 - for cross-architecture compilation: see above
071 - cd to this extra/ directory 066 - cd to this extra/ directory
072 - run 'make' 067 - run 'make'
073 - the floppy image is: sos_bsect.img for use 068 - the floppy image is: sos_bsect.img for use with bochs or on a real
074 floppy disk 069 floppy disk
075 to use the image under qemu: use sos_qemu.i 070 to use the image under qemu: use sos_qemu.img
076 071
077 NOTE : From article 2 onward, be warned that 072 NOTE : From article 2 onward, be warned that using this bootsect
078 might lead to system crashes. This wou 073 might lead to system crashes. This would be because the
079 solution we use to retrieve the RAM si 074 solution we use to retrieve the RAM size might not work
080 properly on some systems (BIOS buggy o 075 properly on some systems (BIOS buggy or more than 1G RAM). THE
081 best way to boot SOS is always to use 076 best way to boot SOS is always to use Grub.
082 077
083 078
084 -- 079 --
085 David Decotigny 080 David Decotigny