Changes in / [39bcc99:0c96e6cb] in mainline


Ignore:
Files:
10 added
3 deleted
16 edited

Legend:

Unmodified
Added
Removed
  • HelenOS.config

    r39bcc99 r0c96e6cb  
    291291@ "gcc_cross" GNU C Compiler (cross-compiler)
    292292@ "gcc_native" GNU C Compiler (native)
     293@ "gcc_helenos" GNU C Compiler (experimental HelenOS-specific cross-compiler)
    293294@ "icc" Intel C Compiler
    294295@ "clang" Clang
     
    299300@ "gcc_native" GNU C Compiler (native)
    300301@ "icc" Intel C Compiler
     302@ "gcc_helenos" GNU C Compiler (experimental HelenOS-specific cross-compiler)
    301303! [PLATFORM=ia64] COMPILER (choice)
    302304
     
    304306@ "gcc_cross" GNU C Compiler (cross-compiler)
    305307@ "gcc_native" GNU C Compiler (native)
     308@ "gcc_helenos" GNU C Compiler (experimental HelenOS-specific cross-compiler)
    306309! [PLATFORM=mips32|PLATFORM=mips64|PLATFORM=ppc32] COMPILER (choice)
    307310
     
    309312@ "gcc_cross" GNU C Compiler (cross-compiler)
    310313@ "gcc_native" GNU C Compiler (native)
     314@ "gcc_helenos" GNU C Compiler (experimental HelenOS-specific cross-compiler)
    311315@ "clang" Clang
    312316! [PLATFORM=abs32le|PLATFORM=arm32|PLATFORM=sparc64] COMPILER (choice)
     
    319323@ "ia32" Intel IA-32
    320324@ "mips32" MIPS 32-bit
    321 ! [PLATFORM=abs32le&COMPILER=gcc_cross] CROSS_TARGET (choice)
     325! [PLATFORM=abs32le&(COMPILER=gcc_cross|COMPILER=gcc_helenos)] CROSS_TARGET (choice)
    322326
    323327
  • boot/Makefile.build

    r39bcc99 r0c96e6cb  
    7575endif
    7676
     77ifeq ($(COMPILER),gcc_helenos)
     78        CFLAGS = $(GCC_CFLAGS) $(EXTRA_CFLAGS)
     79        DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS)
     80endif
     81
     82
    7783ifeq ($(COMPILER),icc)
    7884        CFLAGS = $(ICC_CFLAGS) $(EXTRA_CFLAGS)
  • kernel/Makefile

    r39bcc99 r0c96e6cb  
    167167
    168168ifeq ($(COMPILER),gcc_cross)
     169        CFLAGS = $(GCC_CFLAGS)
     170        DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS)
     171        INSTRUMENTATION = -finstrument-functions
     172endif
     173
     174ifeq ($(COMPILER),gcc_helenos)
    169175        CFLAGS = $(GCC_CFLAGS)
    170176        DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS)
  • tools/autotool.py

    r39bcc99 r0c96e6cb  
    186186        gnu_target = None
    187187        clang_target = None
     188        helenos_target = None
    188189        cc_args = []
    189190       
     
    195196                        gnu_target = "arm-linux-gnueabi"
    196197                        clang_target = "arm-unknown-linux"
     198                        helenos_target = "arm-helenos-gnueabi"
    197199               
    198200                if (config['CROSS_TARGET'] == "ia32"):
    199201                        gnu_target = "i686-pc-linux-gnu"
    200202                        clang_target = "i386-unknown-linux"
     203                        helenos_target = "i686-pc-helenos"
    201204               
    202205                if (config['CROSS_TARGET'] == "mips32"):
    203206                        gnu_target = "mipsel-linux-gnu"
    204207                        clang_target = "mipsel-unknown-linux"
     208                        helenos_target = "mipsel-helenos"
    205209                        common['CC_ARGS'].append("-mabi=32")
    206210       
     
    209213                gnu_target = "amd64-linux-gnu"
    210214                clang_target = "x86_64-unknown-linux"
     215                helenos_target = "amd64-helenos"
    211216       
    212217        if (config['PLATFORM'] == "arm32"):
     
    214219                gnu_target = "arm-linux-gnueabi"
    215220                clang_target = "arm-unknown-linux"
     221                helenos_target = "arm-helenos-gnueabi"
    216222       
    217223        if (config['PLATFORM'] == "ia32"):
     
    219225                gnu_target = "i686-pc-linux-gnu"
    220226                clang_target = "i386-unknown-linux"
     227                helenos_target = "i686-pc-helenos"
    221228       
    222229        if (config['PLATFORM'] == "ia64"):
    223230                target = config['PLATFORM']
    224231                gnu_target = "ia64-pc-linux-gnu"
     232                helenos_target = "ia64-pc-helenos"
    225233       
    226234        if (config['PLATFORM'] == "mips32"):
     
    232240                        gnu_target = "mipsel-linux-gnu"
    233241                        clang_target = "mipsel-unknown-linux"
     242                        helenos_target = "mipsel-helenos"
    234243               
    235244                if ((config['MACHINE'] == "bmalta")):
     
    237246                        gnu_target = "mips-linux-gnu"
    238247                        clang_target = "mips-unknown-linux"
     248                        helenos_target = "mips-helenos"
    239249       
    240250        if (config['PLATFORM'] == "mips64"):
     
    246256                        gnu_target = "mips64el-linux-gnu"
    247257                        clang_target = "mips64el-unknown-linux"
     258                        helenos_target = "mips64el-helenos"
    248259       
    249260        if (config['PLATFORM'] == "ppc32"):
     
    251262                gnu_target = "ppc-linux-gnu"
    252263                clang_target = "powerpc-unknown-linux"
     264                helenos_target = "ppc-helenos"
    253265       
    254266        if (config['PLATFORM'] == "sparc64"):
     
    256268                gnu_target = "sparc64-linux-gnu"
    257269                clang_target = "sparc-unknown-linux"
    258        
    259         return (target, cc_args, gnu_target, clang_target)
     270                helenos_target = "sparc64-helenos"
     271       
     272        return (target, cc_args, gnu_target, clang_target, helenos_target)
    260273
    261274def check_app(args, name, details):
     
    697710                cross_prefix = "/usr/local/cross"
    698711       
     712        # HelenOS cross-compiler prefix
     713        if ('CROSS_HELENOS_PREFIX' in os.environ):
     714                cross_helenos_prefix = os.environ['CROSS_HELENOS_PREFIX']
     715        else:
     716                cross_helenos_prefix = "/usr/local/cross-helenos"
     717       
    699718        # Prefix binutils tools on Solaris
    700719        if (os.uname()[0] == "SunOS"):
     
    719738                common['CC_ARGS'] = []
    720739                if (config['COMPILER'] == "gcc_cross"):
    721                         target, cc_args, gnu_target, clang_target = get_target(config)
     740                        target, cc_args, gnu_target, clang_target, helenos_target = get_target(config)
    722741                       
    723742                        if (target is None) or (gnu_target is None):
     
    727746                        path = "%s/%s/bin" % (cross_prefix, target)
    728747                        prefix = "%s-" % gnu_target
     748                       
     749                        check_gcc(path, prefix, common, PACKAGE_CROSS)
     750                        check_binutils(path, prefix, common, PACKAGE_CROSS)
     751                       
     752                        check_common(common, "GCC")
     753                        common['CC'] = common['GCC']
     754                        common['CC_ARGS'].extend(cc_args)
     755               
     756                if (config['COMPILER'] == "gcc_helenos"):
     757                        target, cc_args, gnu_target, clang_target, helenos_target = get_target(config)
     758                       
     759                        if (target is None) or (helenos_target is None):
     760                                print_error(["Unsupported compiler target for GNU GCC.",
     761                                             "Please contact the developers of HelenOS."])
     762                       
     763                        path = "%s/%s/bin" % (cross_helenos_prefix, target)
     764                        prefix = "%s-" % helenos_target
    729765                       
    730766                        check_gcc(path, prefix, common, PACKAGE_CROSS)
  • tools/toolchain.sh

    r39bcc99 r0c96e6cb  
    5555BINUTILS_VERSION="2.23.1"
    5656BINUTILS_RELEASE=""
     57BINUTILS_PATCHES="toolchain-binutils-2.23.1.patch"
    5758GCC_VERSION="4.8.1"
     59GCC_PATCHES="toolchain-gcc-4.8.1-targets.patch toolchain-gcc-4.8.1-headers.patch"
    5860GDB_VERSION="7.6.1"
     61GDB_PATCHES="toolchain-gdb-7.6.1.patch"
    5962
    6063BASEDIR="`pwd`"
     
    6265GCC="gcc-${GCC_VERSION}.tar.bz2"
    6366GDB="gdb-${GDB_VERSION}.tar.bz2"
     67
     68REAL_INSTALL=true
     69USE_HELENOS_TARGET=false
     70INSTALL_DIR="${BASEDIR}/PKG"
    6471
    6572#
     
    135142        echo
    136143        echo "Syntax:"
    137         echo " $0 <platform>"
     144        echo " $0 [--no-install] [--helenos-target] <platform>"
    138145        echo
    139146        echo "Possible target platforms are:"
     
    152159        echo " 2-way      same as 'all', but 2-way parallel"
    153160        echo
    154         echo "The toolchain will be installed to the directory specified by"
    155         echo "the CROSS_PREFIX environment variable. If the variable is not"
    156         echo "defined, /usr/local/cross will be used by default."
     161        echo "The toolchain is installed into directory specified by the"
     162        echo "CROSS_PREFIX environment variable. If the variable is not"
     163        echo "defined, /usr/local/cross/ is used as default."
     164        echo
     165        echo "If --no-install is present, the toolchain still uses the"
     166        echo "CROSS_PREFIX as the target directory but the installation"
     167        echo "copies the files into PKG/ subdirectory without affecting"
     168        echo "the actual root file system. That is only useful if you do"
     169        echo "not want to run the script under the super user."
     170        echo
     171        echo "The --helenos-target will build HelenOS-specific toolchain"
     172        echo "(i.e. it will use *-helenos-* triplet instead of *-linux-*)."
     173        echo "This toolchain is installed into /usr/local/cross-helenos by"
     174        echo "default. The settings can be changed by setting environment"
     175        echo "variable CROSS_HELENOS_PREFIX."
     176        echo "Using the HelenOS-specific toolchain is still an experimental"
     177        echo "feature that is not fully supported."
    157178        echo
    158179       
     
    292313}
    293314
     315patch_sources() {
     316        PATCH_FILE="$1"
     317        PATCH_STRIP="$2"
     318        DESC="$3"
     319       
     320        change_title "Patching ${DESC}"
     321        echo " >>> Patching ${DESC} with ${PATCH_FILE}"
     322       
     323        patch -t "-p${PATCH_STRIP}" <"$PATCH_FILE"
     324        check_error $? "Error patching ${DESC}."
     325}
     326
    294327prepare() {
    295328        show_dependencies
     
    306339}
    307340
     341set_target_from_platform() {
     342        case "$1" in
     343                "amd64")
     344                        LINUX_TARGET="amd64-linux-gnu"
     345                        HELENOS_TARGET="amd64-helenos"
     346                        ;;
     347                "arm32")
     348                        LINUX_TARGET="arm-linux-gnueabi"
     349                        HELENOS_TARGET="arm-helenos-gnueabi"
     350                        ;;
     351                "ia32")
     352                        LINUX_TARGET="i686-pc-linux-gnu"
     353                        HELENOS_TARGET="i686-pc-helenos"
     354                        ;;
     355                "ia64")
     356                        LINUX_TARGET="ia64-pc-linux-gnu"
     357                        HELENOS_TARGET="ia64-pc-helenos"
     358                        ;;
     359                "mips32")
     360                        LINUX_TARGET="mipsel-linux-gnu"
     361                        HELENOS_TARGET="mipsel-helenos"
     362                        ;;
     363                "mips32eb")
     364                        LINUX_TARGET="mips-linux-gnu"
     365                        HELENOS_TARGET="mips-helenos"
     366                        ;;
     367                "mips64")
     368                        LINUX_TARGET="mips64el-linux-gnu"
     369                        HELENOS_TARGET="mips64el-helenos"
     370                        ;;
     371                "ppc32")
     372                        LINUX_TARGET="ppc-linux-gnu"
     373                        HELENOS_TARGET="ppc-helenos"
     374                        ;;
     375                "ppc64")
     376                        LINUX_TARGET="ppc64-linux-gnu"
     377                        HELENOS_TARGET="ppc64-helenos"
     378                        ;;
     379                "sparc64")
     380                        LINUX_TARGET="sparc64-linux-gnu"
     381                        HELENOS_TARGET="sparc64-helenos"
     382                        ;;
     383                *)
     384                        check_error 1 "No target known for $1."
     385                        ;;
     386        esac
     387}
     388
    308389build_target() {
    309390        PLATFORM="$1"
    310         TARGET="$2"
     391        # This sets the *_TARGET variables
     392        set_target_from_platform "$PLATFORM"
     393        if $USE_HELENOS_TARGET; then
     394                TARGET="$HELENOS_TARGET"
     395        else
     396                TARGET="$LINUX_TARGET"
     397        fi
    311398       
    312399        WORKDIR="${BASEDIR}/${PLATFORM}"
     
    319406                CROSS_PREFIX="/usr/local/cross"
    320407        fi
    321        
    322         PREFIX="${CROSS_PREFIX}/${PLATFORM}"
     408        if [ -z "${CROSS_HELENOS_PREFIX}" ] ; then
     409                CROSS_HELENOS_PREFIX="/usr/local/cross-helenos"
     410        fi
     411       
     412        if $USE_HELENOS_TARGET; then
     413                PREFIX="${CROSS_HELENOS_PREFIX}/${PLATFORM}"
     414        else
     415                PREFIX="${CROSS_PREFIX}/${PLATFORM}"
     416        fi
    323417       
    324418        echo ">>> Downloading tarballs"
     
    328422       
    329423        echo ">>> Removing previous content"
    330         cleanup_dir "${PREFIX}"
     424        $REAL_INSTALL && cleanup_dir "${PREFIX}"
    331425        cleanup_dir "${WORKDIR}"
    332426       
    333         create_dir "${PREFIX}" "destination directory"
     427        $REAL_INSTALL && create_dir "${PREFIX}" "destination directory"
    334428        create_dir "${OBJDIR}" "GCC object directory"
    335429       
     
    344438        unpack_tarball "${BASEDIR}/${GDB}" "GDB"
    345439       
     440        echo ">>> Applying patches"
     441        for p in $BINUTILS_PATCHES; do
     442                patch_sources "${BASEDIR}/${p}" 0 "binutils"
     443        done
     444        for p in $GCC_PATCHES; do
     445                patch_sources "${BASEDIR}/${p}" 0 "GCC"
     446        done
     447        for p in $GDB_PATCHES; do
     448                patch_sources "${BASEDIR}/${p}" 0 "GDB"
     449        done
     450       
    346451        echo ">>> Processing binutils (${PLATFORM})"
    347452        cd "${BINUTILSDIR}"
     
    349454       
    350455        change_title "binutils: configure (${PLATFORM})"
    351         CFLAGS=-Wno-error ./configure "--target=${TARGET}" "--prefix=${PREFIX}" "--program-prefix=${TARGET}-" --disable-nls --disable-werror
     456        CFLAGS=-Wno-error ./configure \
     457                "--target=${TARGET}" \
     458                "--prefix=${PREFIX}" "--program-prefix=${TARGET}-" \
     459                --disable-nls --disable-werror
    352460        check_error $? "Error configuring binutils."
    353461       
    354462        change_title "binutils: make (${PLATFORM})"
    355         make all install
    356         check_error $? "Error compiling/installing binutils."
     463        make all
     464        check_error $? "Error compiling binutils."
     465       
     466        change_title "binutils: install (${PLATFORM})"
     467        if $REAL_INSTALL; then
     468                make install
     469        else
     470                make install "DESTDIR=${INSTALL_DIR}"
     471        fi
     472        check_error $? "Error installing binutils."
     473       
    357474       
    358475        echo ">>> Processing GCC (${PLATFORM})"
     
    361478       
    362479        change_title "GCC: configure (${PLATFORM})"
    363         "${GCCDIR}/configure" "--target=${TARGET}" "--prefix=${PREFIX}" "--program-prefix=${TARGET}-" --with-gnu-as --with-gnu-ld --disable-nls --disable-threads --enable-languages=c,objc,c++,obj-c++ --disable-multilib --disable-libgcj --without-headers --disable-shared --enable-lto --disable-werror
     480        PATH="$PATH:${INSTALL_DIR}/${PREFIX}/bin" "${GCCDIR}/configure" \
     481                "--target=${TARGET}" \
     482                "--prefix=${PREFIX}" "--program-prefix=${TARGET}-" \
     483                --with-gnu-as --with-gnu-ld --disable-nls --disable-threads \
     484                --enable-languages=c,objc,c++,obj-c++ \
     485                --disable-multilib --disable-libgcj --without-headers \
     486                --disable-shared --enable-lto --disable-werror
    364487        check_error $? "Error configuring GCC."
    365488       
    366489        change_title "GCC: make (${PLATFORM})"
    367         PATH="${PATH}:${PREFIX}/bin" make all-gcc install-gcc
    368         check_error $? "Error compiling/installing GCC."
     490        PATH="${PATH}:${PREFIX}/bin:${INSTALL_DIR}/${PREFIX}/bin" make all-gcc
     491        check_error $? "Error compiling GCC."
     492       
     493        change_title "GCC: install (${PLATFORM})"
     494        if $REAL_INSTALL; then
     495                PATH="${PATH}:${PREFIX}/bin" make install-gcc
     496        else
     497                PATH="${PATH}:${INSTALL_DIR}/${PREFIX}/bin" make install-gcc "DESTDIR=${INSTALL_DIR}"
     498        fi
     499        check_error $? "Error installing GCC."
     500       
    369501       
    370502        echo ">>> Processing GDB (${PLATFORM})"
     
    373505       
    374506        change_title "GDB: configure (${PLATFORM})"
    375         ./configure "--target=${TARGET}" "--prefix=${PREFIX}" "--program-prefix=${TARGET}-"
     507        PATH="$PATH:${INSTALL_DIR}/${PREFIX}/bin" ./configure \
     508                "--target=${TARGET}" \
     509                "--prefix=${PREFIX}" "--program-prefix=${TARGET}-"
    376510        check_error $? "Error configuring GDB."
    377511       
    378512        change_title "GDB: make (${PLATFORM})"
    379         make all install
    380         check_error $? "Error compiling/installing GDB."
     513        PATH="${PATH}:${PREFIX}/bin:${INSTALL_DIR}/${PREFIX}/bin" make all
     514        check_error $? "Error compiling GDB."
     515       
     516        change_title "GDB: make (${PLATFORM})"
     517        if $REAL_INSTALL; then
     518                PATH="${PATH}:${PREFIX}/bin" make install
     519        else
     520                PATH="${PATH}:${INSTALL_DIR}/${PREFIX}/bin" make install "DESTDIR=${INSTALL_DIR}"
     521        fi
     522        check_error $? "Error installing GDB."
     523       
    381524       
    382525        cd "${BASEDIR}"
     
    389532        echo ">>> Cross-compiler for ${TARGET} installed."
    390533}
     534
     535while [ "$#" -gt 1 ]; do
     536        case "$1" in
     537                --no-install)
     538                        REAL_INSTALL=false
     539                        shift
     540                        ;;
     541                --helenos-target)
     542                        USE_HELENOS_TARGET=true
     543                        shift
     544                        ;;
     545                *)
     546                        show_usage
     547                        ;;
     548        esac
     549done
    391550
    392551if [ "$#" -lt "1" ]; then
     
    395554
    396555case "$1" in
    397         "amd64")
     556        amd64|arm32|ia32|ia64|mips32|mips32eb|mips64|ppc32|ppc64|sparc64)
    398557                prepare
    399                 build_target "amd64" "amd64-linux-gnu"
    400                 ;;
    401         "arm32")
    402                 prepare
    403                 build_target "arm32" "arm-linux-gnueabi"
    404                 ;;
    405         "ia32")
    406                 prepare
    407                 build_target "ia32" "i686-pc-linux-gnu"
    408                 ;;
    409         "ia64")
    410                 prepare
    411                 build_target "ia64" "ia64-pc-linux-gnu"
    412                 ;;
    413         "mips32")
    414                 prepare
    415                 build_target "mips32" "mipsel-linux-gnu"
    416                 ;;
    417         "mips32eb")
    418                 prepare
    419                 build_target "mips32eb" "mips-linux-gnu"
    420                 ;;
    421         "mips64")
    422                 prepare
    423                 build_target "mips64" "mips64el-linux-gnu"
    424                 ;;
    425         "ppc32")
    426                 prepare
    427                 build_target "ppc32" "ppc-linux-gnu"
    428                 ;;
    429         "ppc64")
    430                 prepare
    431                 build_target "ppc64" "ppc64-linux-gnu"
    432                 ;;
    433         "sparc64")
    434                 prepare
    435                 build_target "sparc64" "sparc64-linux-gnu"
     558                build_target "$1"
    436559                ;;
    437560        "all")
    438561                prepare
    439                 build_target "amd64" "amd64-linux-gnu"
    440                 build_target "arm32" "arm-linux-gnueabi"
    441                 build_target "ia32" "i686-pc-linux-gnu"
    442                 build_target "ia64" "ia64-pc-linux-gnu"
    443                 build_target "mips32" "mipsel-linux-gnu"
    444                 build_target "mips32eb" "mips-linux-gnu"
    445                 build_target "mips64" "mips64el-linux-gnu"
    446                 build_target "ppc32" "ppc-linux-gnu"
    447                 build_target "ppc64" "ppc64-linux-gnu"
    448                 build_target "sparc64" "sparc64-linux-gnu"
     562                build_target "amd64"
     563                build_target "arm32"
     564                build_target "ia32"
     565                build_target "ia64"
     566                build_target "mips32"
     567                build_target "mips32eb"
     568                build_target "mips64"
     569                build_target "ppc32"
     570                build_target "ppc64"
     571                build_target "sparc64"
    449572                ;;
    450573        "parallel")
    451574                prepare
    452                 build_target "amd64" "amd64-linux-gnu" &
    453                 build_target "arm32" "arm-linux-gnueabi" &
    454                 build_target "ia32" "i686-pc-linux-gnu" &
    455                 build_target "ia64" "ia64-pc-linux-gnu" &
    456                 build_target "mips32" "mipsel-linux-gnu" &
    457                 build_target "mips32eb" "mips-linux-gnu" &
    458                 build_target "mips64" "mips64el-linux-gnu" &
    459                 build_target "ppc32" "ppc-linux-gnu" &
    460                 build_target "ppc64" "ppc64-linux-gnu" &
    461                 build_target "sparc64" "sparc64-linux-gnu" &
     575                build_target "amd64" &
     576                build_target "arm32" &
     577                build_target "ia32" &
     578                build_target "ia64" &
     579                build_target "mips32" &
     580                build_target "mips32eb" &
     581                build_target "mips64" &
     582                build_target "ppc32" &
     583                build_target "ppc64" &
     584                build_target "sparc64" &
    462585                wait
    463586                ;;
    464587        "2-way")
    465588                prepare
    466                 build_target "amd64" "amd64-linux-gnu" &
    467                 build_target "arm32" "arm-linux-gnueabi" &
     589                build_target "amd64" &
     590                build_target "arm32" &
    468591                wait
    469592               
    470                 build_target "ia32" "i686-pc-linux-gnu" &
    471                 build_target "ia64" "ia64-pc-linux-gnu" &
     593                build_target "ia32" &
     594                build_target "ia64" &
    472595                wait
    473596               
    474                 build_target "mips32" "mipsel-linux-gnu" &
    475                 build_target "mips32eb" "mips-linux-gnu" &
     597                build_target "mips32" &
     598                build_target "mips32eb" &
    476599                wait
    477600               
    478                 build_target "mips64" "mips64el-linux-gnu" &
    479                 build_target "ppc32" "ppc-linux-gnu" &
     601                build_target "mips64" &
     602                build_target "ppc32" &
    480603                wait
    481604               
    482                 build_target "ppc64" "ppc64-linux-gnu" &
    483                 build_target "sparc64" "sparc64-linux-gnu" &
     605                build_target "ppc64" &
     606                build_target "sparc64" &
    484607                wait
    485608                ;;
  • uspace/Makefile.common

    r39bcc99 r0c96e6cb  
    248248endif
    249249
     250ifeq ($(COMPILER),gcc_helenos)
     251        CFLAGS += $(GCC_CFLAGS) $(EXTRA_CFLAGS)
     252        DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS)
     253endif
     254
    250255ifeq ($(COMPILER),gcc_native)
    251256        CFLAGS += $(GCC_CFLAGS) $(EXTRA_CFLAGS)
  • uspace/lib/c/generic/bitops.c

    r39bcc99 r0c96e6cb  
    3333#include <bitops.h>
    3434
    35 extern int __popcountsi2(int a)
     35int __popcountsi2(int a)
    3636{
    37         return __builtin_popcount(a);
     37        int bits = 0;
     38        for (unsigned int i = 0; i < sizeof(a) * 8; i++)         {
     39                if (((a >> i) & 1) != 0) {
     40                        bits++;
     41                }
     42        }
     43        return bits;                                                                   
    3844}
    3945
  • uspace/lib/posix/Makefile

    r39bcc99 r0c96e6cb  
    4242FIXED_C_LIBRARY = libc4posix.a
    4343
    44 REDEFS_HIDE_LIBC = redefs-hide-libc.xargs
    45 REDEFS_SHOW_LIBPOSIX = redefs-show-posix.xargs
     44REDEFS_HIDE_LIBC = redefs-hide-libc-symbols.list
     45REDEFS_SHOW_LIBPOSIX = redefs-show-posix-symbols.list
    4646COLLISIONS_LIST = collisions.list
    4747
     
    6161        source/locale.c \
    6262        source/math.c \
     63        source/pthread/condvar.c \
     64        source/pthread/keys.c \
     65        source/pthread/mutex.c \
     66        source/pthread/threads.c \
    6367        source/pwd.c \
    6468        source/signal.c \
     
    8185
    8286$(FIXED_C_LIBRARY): $(REDEFS_HIDE_LIBC) $(REDEFS_SHOW_LIBPOSIX)
    83         ./tools/transform-symbols.sh \
    84                 $(OBJCOPY) $(AR) echo \
    85                 $(LIBC_FILE) $@ \
    86                 $(REDEFS_HIDE_LIBC) $(REDEFS_SHOW_LIBPOSIX)
     87        $(OBJCOPY) --redefine-syms=$(REDEFS_HIDE_LIBC) $(LIBC_FILE) $@
     88        $(OBJCOPY) --redefine-syms=$(REDEFS_SHOW_LIBPOSIX) $@ $@
    8789
    8890$(FIXED_POSIX_LIBRARY): $(LIBRARY).a $(REDEFS_HIDE_LIBC) $(REDEFS_SHOW_LIBPOSIX)
    89         ./tools/transform-symbols.sh \
    90                 $(OBJCOPY) $(AR) echo \
    91                 $(LIBRARY).a $@ \
    92                 $(REDEFS_HIDE_LIBC) $(REDEFS_SHOW_LIBPOSIX)
     91        $(OBJCOPY) --redefine-syms=$(REDEFS_HIDE_LIBC) $(LIBRARY).a $@
     92        $(OBJCOPY) --redefine-syms=$(REDEFS_SHOW_LIBPOSIX) $@ $@
    9393
    9494$(REDEFS_HIDE_LIBC): $(COLLISIONS_LIST)
    95         ./tools/create-redefines.sh "" "__helenos_libc_" <$(COLLISIONS_LIST) >$@
    96        
     95        sed 's/.*/& __helenos_libc_&/' <$(COLLISIONS_LIST) >$@
     96
    9797$(REDEFS_SHOW_LIBPOSIX): $(COLLISIONS_LIST)
    98         ./tools/create-redefines.sh "posix_" "" <$(COLLISIONS_LIST) >$@
     98        sed 's/.*/posix_& &/' <$(COLLISIONS_LIST) >$@
    9999
    100100$(COLLISIONS_LIST):
    101         ./tools/get-collision-list.sh ./include/posix >$@
     101        find ./include/posix -name '*.h' -exec \
     102                sed -n -e '/^#/d' -e 's/__POSIX_DEF__/\n&/gp' {} \; | \
     103                sed -n -e 's/__POSIX_DEF__(\([^)]*\)).*/\1/p' | \
     104                sort -u >$@
  • uspace/lib/posix/include/posix/float.h

    r39bcc99 r0c96e6cb  
    6161        #undef FLT_RADIX
    6262        #define FLT_RADIX __FLT_RADIX__
     63        #undef FLT_MIN
     64        #define FLT_MIN __FLT_MIN__
     65        #undef FLT_MAX
     66        #define FLT_MAX __FLT_MAX__
     67        #undef FLT_EPSILON
     68        #define FLT_EPSILON __FLT_EPSILON__
     69        #undef FLT_MANT_DIG
     70        #define FLT_MANT_DIG __FLT_MANT_DIG__
     71        #undef LDBL_MANT_DIG
     72        #define LDBL_MANT_DIG __LDBL_MANT_DIG__
    6373#else
    6474/* For something else than GCC, following definitions are provided.
  • uspace/lib/posix/include/posix/stdint.h

    r39bcc99 r0c96e6cb  
    108108
    109109
     110/*
     111 * Fast* and least* integer types.
     112 *
     113 * The definitions below are definitely safe if not the best.
     114 */
     115typedef uint8_t uint_least8_t;
     116typedef uint16_t uint_least16_t;
     117typedef uint32_t uint_least32_t;
     118typedef uint64_t uint_least64_t;
     119
     120typedef int8_t int_least8_t;
     121typedef int16_t int_least16_t;
     122typedef int32_t int_least32_t;
     123typedef int64_t int_least64_t;
     124
     125typedef uint8_t uint_fast8_t;
     126typedef uint16_t uint_fast16_t;
     127typedef uint32_t uint_fast32_t;
     128typedef uint64_t uint_fast64_t;
     129
     130typedef int8_t int_fast8_t;
     131typedef int16_t int_fast16_t;
     132typedef int32_t int_fast32_t;
     133typedef int64_t int_fast64_t;
     134
    110135#endif /* POSIX_STDINT_H_ */
    111136
  • uspace/lib/posix/include/posix/stdio.h

    r39bcc99 r0c96e6cb  
    123123
    124124extern void setvbuf(FILE *, void *, int, size_t);
    125 
     125extern void setbuf(FILE *, void *);
    126126
    127127/* POSIX specific stuff. */
  • uspace/lib/posix/include/posix/time.h

    r39bcc99 r0c96e6cb  
    104104extern char *__POSIX_DEF__(ctime_r)(const time_t *timer, char *buf);
    105105extern char *__POSIX_DEF__(ctime)(const time_t *timer);
     106extern time_t time(time_t *t);
    106107
    107108/* Clocks */
  • uspace/lib/posix/source/internal/common.h

    r39bcc99 r0c96e6cb  
    3939#include <stdlib.h>
    4040
    41 #define not_implemented() (fprintf(stderr, \
    42     "Function %s() in file %s at line %d is not implemented\n", \
    43     __func__, __FILE__, __LINE__), abort())
     41#define not_implemented() do { \
     42                static int __not_implemented_counter = 0; \
     43                if (__not_implemented_counter == 0) { \
     44                        fprintf(stderr, "%s() not implemented in %s:%d, something will NOT work.\n", \
     45                                __func__, __FILE__, __LINE__); \
     46                } \
     47                __not_implemented_counter++; \
     48        } while (0)
    4449
    4550/* A little helper macro to avoid typing this over and over. */
  • uspace/lib/posix/source/math.c

    r39bcc99 r0c96e6cb  
    4949        // TODO: low priority, just a compile-time dependency of binutils
    5050        not_implemented();
     51        return 0.0;
    5152}
    5253
     
    6162        // TODO: low priority, just a compile-time dependency of binutils
    6263        not_implemented();
     64        return 0.0;
    6365}
    6466
     
    7274        // TODO: Python dependency
    7375        not_implemented();
     76        return 0.0;
    7477}
    7578
     
    8487        // TODO: Python dependency
    8588        not_implemented();
     89        return 0.0;
    8690}
    8791
     
    9599        // TODO: Python dependency
    96100        not_implemented();
     101        return 0.0;
    97102}
    98103
     
    106111        // TODO: Python dependency
    107112        not_implemented();
     113        return 0.0;
    108114}
    109115
     
    118124        // TODO: Python dependency
    119125        not_implemented();
     126        return 0.0;
    120127}
    121128
     
    130137        // TODO: Python dependency
    131138        not_implemented();
     139        return 0.0;
    132140}
    133141
     
    141149        // TODO: Python dependency
    142150        not_implemented();
     151        return 0.0;
    143152}
    144153
     
    153162        // TODO: Python dependency
    154163        not_implemented();
     164        return 0.0;
    155165}
    156166
     
    164174        // TODO: Python dependency
    165175        not_implemented();
     176        return 0.0;
    166177}
    167178
     
    175186        // TODO: Python dependency
    176187        not_implemented();
     188        return 0.0;
    177189}
    178190
     
    186198        // TODO: Python dependency
    187199        not_implemented();
     200        return 0.0;
    188201}
    189202
  • uspace/lib/posix/source/stdlib.c

    r39bcc99 r0c96e6cb  
    6363        // TODO: low priority, just a compile-time dependency of binutils
    6464        not_implemented();
    65         return 1;
     65        return 0;
    6666}
    6767
  • uspace/lib/posix/source/unistd.c

    r39bcc99 r0c96e6cb  
    389389        // TODO: low priority, just a compile-time dependency of binutils
    390390        not_implemented();
     391        return -1;
    391392}
    392393
     
    399400        // TODO: low priority, just a compile-time dependency of binutils
    400401        not_implemented();
     402        return -1;
    401403}
    402404
     
    411413        // TODO: low priority, just a compile-time dependency of binutils
    412414        not_implemented();
     415        return -1;
    413416}
    414417
     
    423426        // TODO: low priority, just a compile-time dependency of binutils
    424427        not_implemented();
     428        return -1;
    425429}
    426430
     
    434438        // TODO: low priority, just a compile-time dependency of binutils
    435439        not_implemented();
     440        return -1;
    436441}
    437442
Note: See TracChangeset for help on using the changeset viewer.