Compare commits
No commits in common. "f8cc093e17b28c6abc8e6f3535b1a17e12487275" and "d9899f1c3da90f4d256fb67ad7bb24ee07c3d847" have entirely different histories.
f8cc093e17
...
d9899f1c3d
1
.gitignore
vendored
1
.gitignore
vendored
@ -19,4 +19,3 @@ base/etc/skel/LICENSE
|
|||||||
kernel/config.cmake
|
kernel/config.cmake
|
||||||
ports/out/
|
ports/out/
|
||||||
ports/temp/
|
ports/temp/
|
||||||
ports/dev/
|
|
||||||
|
@ -95,6 +95,8 @@ void handle_cpu_exception(int signo, const char* err, Registers* regs)
|
|||||||
kerrorln("R12: %.16lx R13: %.16lx R14: %.16lx R15: %.16lx", regs->r12, regs->r13, regs->r14, regs->r15);
|
kerrorln("R12: %.16lx R13: %.16lx R14: %.16lx R15: %.16lx", regs->r12, regs->r13, regs->r14, regs->r15);
|
||||||
kerrorln("RIP: %.16lx CS: %.16lx SS: %.16lx FLAGS: %.16lx", regs->rip, regs->cs, regs->ss, regs->rflags);
|
kerrorln("RIP: %.16lx CS: %.16lx SS: %.16lx FLAGS: %.16lx", regs->rip, regs->cs, regs->ss, regs->rflags);
|
||||||
|
|
||||||
|
CPU::print_stack_trace_at(regs);
|
||||||
|
|
||||||
if (!is_in_kernel(regs))
|
if (!is_in_kernel(regs))
|
||||||
{
|
{
|
||||||
auto* current = Scheduler::current();
|
auto* current = Scheduler::current();
|
||||||
|
@ -187,10 +187,7 @@ void Thread::process_pending_signals(Registers* current_regs)
|
|||||||
switch (action)
|
switch (action)
|
||||||
{
|
{
|
||||||
case DefaultSignalAction::Ignore: return;
|
case DefaultSignalAction::Ignore: return;
|
||||||
case DefaultSignalAction::Terminate:
|
case DefaultSignalAction::Terminate: exit_and_signal_parent(signo | _SIGBIT);
|
||||||
kwarnln("Terminating thread %d with signal %d", id, signo);
|
|
||||||
CPU::print_stack_trace_at(current_regs);
|
|
||||||
exit_and_signal_parent(signo | _SIGBIT);
|
|
||||||
case DefaultSignalAction::Stop: stop();
|
case DefaultSignalAction::Stop: stop();
|
||||||
default: return;
|
default: return;
|
||||||
}
|
}
|
||||||
|
@ -3,8 +3,6 @@
|
|||||||
.global _start
|
.global _start
|
||||||
.extern exit
|
.extern exit
|
||||||
.extern libc_init
|
.extern libc_init
|
||||||
.extern _init
|
|
||||||
.extern _fini
|
|
||||||
_start:
|
_start:
|
||||||
# Set up end of the stack frame linked list.
|
# Set up end of the stack frame linked list.
|
||||||
movq $0, %rbp
|
movq $0, %rbp
|
||||||
@ -28,11 +26,6 @@ _start:
|
|||||||
# Run main
|
# Run main
|
||||||
call main
|
call main
|
||||||
|
|
||||||
# Store the exit code before calling _fini.
|
|
||||||
push %rax
|
|
||||||
|
|
||||||
call _fini
|
|
||||||
|
|
||||||
# Terminate the process with the exit code.
|
# Terminate the process with the exit code.
|
||||||
pop %rdi
|
movl %eax, %edi
|
||||||
call exit
|
call exit
|
||||||
|
@ -7,14 +7,6 @@ extern char** environ;
|
|||||||
extern "C" FILE* _fdopen_impl(int, const char*, int);
|
extern "C" FILE* _fdopen_impl(int, const char*, int);
|
||||||
extern "C" void _init_stdio();
|
extern "C" void _init_stdio();
|
||||||
|
|
||||||
typedef void initfunc_t(void);
|
|
||||||
extern initfunc_t *__init_array_start[], *__init_array_end[];
|
|
||||||
|
|
||||||
static void handle_init_array(void)
|
|
||||||
{
|
|
||||||
for (initfunc_t** p = __init_array_start; p != __init_array_end; p++) (*p)();
|
|
||||||
}
|
|
||||||
|
|
||||||
extern "C"
|
extern "C"
|
||||||
{
|
{
|
||||||
void libc_init(int argc, char** argv, int envc, char** envp)
|
void libc_init(int argc, char** argv, int envc, char** envp)
|
||||||
@ -27,7 +19,5 @@ extern "C"
|
|||||||
stdin = _fdopen_impl(STDIN_FILENO, "r", _IOLBF);
|
stdin = _fdopen_impl(STDIN_FILENO, "r", _IOLBF);
|
||||||
stdout = _fdopen_impl(STDOUT_FILENO, "w", _IOLBF);
|
stdout = _fdopen_impl(STDOUT_FILENO, "w", _IOLBF);
|
||||||
stderr = _fdopen_impl(STDERR_FILENO, "w", _IONBF);
|
stderr = _fdopen_impl(STDERR_FILENO, "w", _IONBF);
|
||||||
|
|
||||||
handle_init_array();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,5 +19,5 @@ do_patch()
|
|||||||
|
|
||||||
do_configure()
|
do_configure()
|
||||||
{
|
{
|
||||||
$srcdir/configure --host=$LUNA_ARCH-luna --with-build-sysroot=$LUNA_BASE --disable-nls --disable-werror --enable-warn-rwx-segments=no --prefix=/usr --enable-gold=no --enable-ld=yes --enable-gprofng=no --enable-initfini-array
|
$srcdir/configure --host=$LUNA_ARCH-luna --with-build-sysroot=$LUNA_BASE --disable-nls --disable-werror --enable-warn-rwx-segments=no --prefix=/usr --enable-gold=no --enable-ld=yes --enable-gprofng=no
|
||||||
}
|
}
|
||||||
|
@ -17,7 +17,7 @@ do_patch()
|
|||||||
|
|
||||||
do_configure()
|
do_configure()
|
||||||
{
|
{
|
||||||
$srcdir/configure --prefix=/usr --target=$LUNA_ARCH-luna --host=$LUNA_ARCH-luna --disable-nls --with-build-sysroot=$LUNA_BASE --enable-languages=c,c++ --enable-checking --enable-initfini-array
|
$srcdir/configure --prefix=/usr --target=$LUNA_ARCH-luna --host=$LUNA_ARCH-luna --disable-nls --with-build-sysroot=$LUNA_BASE --enable-languages=c,c++ --enable-checking
|
||||||
}
|
}
|
||||||
|
|
||||||
do_build()
|
do_build()
|
||||||
|
@ -23,7 +23,6 @@ luna_test(libluna/TestSharedPtr.cpp TestSharedPtr)
|
|||||||
luna_test(libc/TestScanf.cpp TestScanf)
|
luna_test(libc/TestScanf.cpp TestScanf)
|
||||||
luna_test(libc/TestString.cpp TestString)
|
luna_test(libc/TestString.cpp TestString)
|
||||||
luna_test(libc/TestEnv.cpp TestEnv)
|
luna_test(libc/TestEnv.cpp TestEnv)
|
||||||
luna_test(libc/TestGlobalCtors.cpp TestGlobalCtors)
|
|
||||||
|
|
||||||
luna_app(run-tests.cpp run-tests)
|
luna_app(run-tests.cpp run-tests)
|
||||||
endif()
|
endif()
|
||||||
|
@ -1,42 +0,0 @@
|
|||||||
#include <stdio.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <test.h>
|
|
||||||
#include <time.h>
|
|
||||||
|
|
||||||
struct TestStruct
|
|
||||||
{
|
|
||||||
TestStruct(const char* name) : m_name(name)
|
|
||||||
{
|
|
||||||
// Just to make sure this constructor doesn't get optimized out
|
|
||||||
time_t t = time(NULL);
|
|
||||||
ctime(&t);
|
|
||||||
}
|
|
||||||
|
|
||||||
const char* name()
|
|
||||||
{
|
|
||||||
return m_name;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
const char* m_name;
|
|
||||||
};
|
|
||||||
|
|
||||||
TestStruct g_struct("Example Struct");
|
|
||||||
|
|
||||||
TestResult test_successful_global_constructor()
|
|
||||||
{
|
|
||||||
validate(g_struct.name());
|
|
||||||
|
|
||||||
validate(!strcmp(g_struct.name(), "Example Struct"));
|
|
||||||
|
|
||||||
test_success;
|
|
||||||
}
|
|
||||||
|
|
||||||
Result<void> test_main()
|
|
||||||
{
|
|
||||||
test_prelude;
|
|
||||||
|
|
||||||
run_test(test_successful_global_constructor);
|
|
||||||
|
|
||||||
return {};
|
|
||||||
}
|
|
@ -13,7 +13,7 @@ then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
export WORKDIR=${WORKDIR:-$LUNA_ROOT/ports/temp}
|
export WORKDIR=$LUNA_ROOT/ports/temp/
|
||||||
|
|
||||||
show_error()
|
show_error()
|
||||||
{
|
{
|
||||||
@ -28,13 +28,11 @@ source ports/$PORT_NAME/PACKAGE
|
|||||||
[ -z ${format+x} ] && show_error "error: The port's PACKAGE file does not have a 'format' key."
|
[ -z ${format+x} ] && show_error "error: The port's PACKAGE file does not have a 'format' key."
|
||||||
[ -z ${url+x} ] && show_error "error: The port's PACKAGE file does not have a 'url' key."
|
[ -z ${url+x} ] && show_error "error: The port's PACKAGE file does not have a 'url' key."
|
||||||
|
|
||||||
if [ -x ${skip_dependencies+x} ]; then
|
if ! [ -z ${dependencies+x} ]; then
|
||||||
if ! [ -z ${dependencies+x} ]; then
|
echo "Installing dependencies of $name: (${dependencies[@]})"
|
||||||
echo "Installing dependencies of $name: (${dependencies[@]})"
|
for dep in ${dependencies[@]}; do
|
||||||
for dep in ${dependencies[@]}; do
|
tools/install-package.sh $dep
|
||||||
tools/install-package.sh $dep
|
done
|
||||||
done
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
export portdir=$LUNA_ROOT/ports/$name/
|
export portdir=$LUNA_ROOT/ports/$name/
|
||||||
@ -45,39 +43,37 @@ export installdir=$WORKDIR/pkgroot-$name
|
|||||||
mkdir -p $WORKDIR
|
mkdir -p $WORKDIR
|
||||||
cd $WORKDIR
|
cd $WORKDIR
|
||||||
|
|
||||||
if [ -z ${skip_download_sources+x} ]; then
|
# Download package sources
|
||||||
# Download package sources
|
case $format in
|
||||||
case $format in
|
tar)
|
||||||
tar)
|
[ -z ${output+x} ] && show_error "error: The 'tar' download format needs an 'output' key."
|
||||||
[ -z ${output+x} ] && show_error "error: The 'tar' download format needs an 'output' key."
|
[ -z ${sha256sum+x} ] && show_error "error: The 'tar' download format needs a 'sha256sum' key."
|
||||||
[ -z ${sha256sum+x} ] && show_error "error: The 'tar' download format needs a 'sha256sum' key."
|
if ! [ -f $output ]; then
|
||||||
if ! [ -f $output ]; then
|
echo "Downloading tarball for $name..."
|
||||||
echo "Downloading tarball for $name..."
|
wget $url --quiet
|
||||||
wget $url --quiet
|
else
|
||||||
else
|
echo "Using cached tarball for $name."
|
||||||
echo "Using cached tarball for $name."
|
fi
|
||||||
fi
|
echo "$sha256sum $output" | sha256sum -c
|
||||||
echo "$sha256sum $output" | sha256sum -c
|
tar xf $output
|
||||||
tar xf $output
|
;;
|
||||||
;;
|
git)
|
||||||
git)
|
if ! [ -d $srcdir ]; then
|
||||||
if ! [ -d $srcdir ]; then
|
echo "Cloning repository for $name..."
|
||||||
echo "Cloning repository for $name..."
|
git clone $url $srcdir
|
||||||
git clone $url $srcdir
|
else
|
||||||
else
|
echo "Using local repository for $name."
|
||||||
echo "Using local repository for $name."
|
fi
|
||||||
fi
|
if ! [ -z ${tag+x} ]; then
|
||||||
if ! [ -z ${tag+x} ]; then
|
cd $srcdir
|
||||||
cd $srcdir
|
git checkout $tag
|
||||||
git checkout $tag
|
cd -
|
||||||
cd -
|
fi
|
||||||
fi
|
;;
|
||||||
;;
|
*)
|
||||||
*)
|
show_error "error: Unrecognized 'format' key in PACKAGE file: '$format'"
|
||||||
show_error "error: Unrecognized 'format' key in PACKAGE file: '$format'"
|
;;
|
||||||
;;
|
esac
|
||||||
esac
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! [ "$set_cc_variables" = "no" ]; then
|
if ! [ "$set_cc_variables" = "no" ]; then
|
||||||
export CC=x86_64-luna-gcc
|
export CC=x86_64-luna-gcc
|
||||||
@ -93,65 +89,54 @@ fi
|
|||||||
mkdir -p $builddir
|
mkdir -p $builddir
|
||||||
cd $builddir
|
cd $builddir
|
||||||
|
|
||||||
if [ -z ${skip_patch+x} ]; then
|
declare -F do_patch &>/dev/null && do_patch
|
||||||
declare -F do_patch &>/dev/null && do_patch
|
|
||||||
|
echo "Configuring $name..."
|
||||||
|
|
||||||
|
if [ "$use_default_configure" = "true" ]; then
|
||||||
|
$srcdir/configure --host=$LUNA_ARCH-luna --prefix=/usr
|
||||||
|
elif [ "$use_cmake_configure" = "true" ]; then
|
||||||
|
cmake -S $srcdir -B . -DCMAKE_C_COMPILER=$LUNA_ARCH-luna-gcc -DCMAKE_CXX_COMPILER=$LUNA_ARCH-luna-g++ -G "Unix Makefiles"
|
||||||
|
else
|
||||||
|
declare -F do_configure &>/dev/null || show_error "error: If not using a default configure line, the PACKAGE file must provide a 'do_configure' function."
|
||||||
|
do_configure
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -z ${skip_configure+x} ]; then
|
echo "Building $name..."
|
||||||
echo "Configuring $name..."
|
|
||||||
|
|
||||||
if [ "$use_default_configure" = "true" ]; then
|
export MAKEJOBS=$(nproc)
|
||||||
$srcdir/configure --host=$LUNA_ARCH-luna --prefix=/usr
|
|
||||||
elif [ "$use_cmake_configure" = "true" ]; then
|
if [ "$default_build_make" = "true" ]; then
|
||||||
cmake -S $srcdir -B . -DCMAKE_C_COMPILER=$LUNA_ARCH-luna-gcc -DCMAKE_CXX_COMPILER=$LUNA_ARCH-luna-g++ -G "Unix Makefiles"
|
make -j$MAKEJOBS
|
||||||
else
|
elif [ "$default_build_cmake" = "true" ]; then
|
||||||
declare -F do_configure &>/dev/null || show_error "error: If not using a default configure line, the PACKAGE file must provide a 'do_configure' function."
|
cmake --build .
|
||||||
do_configure
|
else
|
||||||
fi
|
declare -F do_build &>/dev/null || show_error "error: If not using a default build preset, the PACKAGE file must provide a 'do_build' function."
|
||||||
|
do_build
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -z ${skip_build+x} ]; then
|
echo "Installing $name..."
|
||||||
echo "Building $name..."
|
|
||||||
|
|
||||||
export MAKEJOBS=$(nproc)
|
mkdir -p $installdir
|
||||||
|
export DESTDIR=$installdir
|
||||||
|
|
||||||
if [ "$default_build_make" = "true" ]; then
|
if [ "$default_install_make" = "true" ]; then
|
||||||
make -j$MAKEJOBS
|
make install
|
||||||
elif [ "$default_build_cmake" = "true" ]; then
|
elif [ "$default_install_cmake" = "true" ]; then
|
||||||
cmake --build .
|
cmake --install $builddir --prefix /usr
|
||||||
else
|
else
|
||||||
declare -F do_build &>/dev/null || show_error "error: If not using a default build preset, the PACKAGE file must provide a 'do_build' function."
|
declare -F do_install &>/dev/null || show_error "error: If not using a default install preset, the PACKAGE file must provide a 'do_install' function."
|
||||||
do_build
|
do_install
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -z ${skip_install+x} ]; then
|
rm -f $installdir/usr/lib/*.la # remove all libtool .la files, as they use host stuff which we don't want at all
|
||||||
echo "Installing $name..."
|
set +e
|
||||||
|
$LUNA_ARCH-luna-strip $installdir/usr/bin/* # strip all binaries
|
||||||
|
set -e
|
||||||
|
|
||||||
rm -rf $installdir # clean it if it already existed
|
cd $installdir
|
||||||
mkdir -p $installdir
|
|
||||||
export DESTDIR=$installdir
|
|
||||||
|
|
||||||
if [ "$default_install_make" = "true" ]; then
|
tar czf $LUNA_ROOT/ports/out/$name-$version.tar.gz *
|
||||||
make install
|
|
||||||
elif [ "$default_install_cmake" = "true" ]; then
|
|
||||||
cmake --install $builddir --prefix /usr
|
|
||||||
else
|
|
||||||
declare -F do_install &>/dev/null || show_error "error: If not using a default install preset, the PACKAGE file must provide a 'do_install' function."
|
|
||||||
do_install
|
|
||||||
fi
|
|
||||||
|
|
||||||
rm -f $installdir/usr/lib/*.la # remove all libtool .la files, as they use host stuff which we don't want at all
|
cd $LUNA_ROOT
|
||||||
set +e
|
rm -rf $WORKDIR
|
||||||
$LUNA_ARCH-luna-strip $installdir/usr/bin/* # strip all binaries
|
|
||||||
set -e
|
|
||||||
|
|
||||||
cd $installdir
|
|
||||||
|
|
||||||
tar czf $LUNA_ROOT/ports/out/$name-$version.tar.gz *
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z ${preserve_workdir+x} ]; then
|
|
||||||
cd $LUNA_ROOT
|
|
||||||
rm -rf $WORKDIR
|
|
||||||
fi
|
|
||||||
|
@ -1,95 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
set -e
|
|
||||||
|
|
||||||
source $(dirname $0)/env.sh
|
|
||||||
|
|
||||||
cd $LUNA_ROOT
|
|
||||||
|
|
||||||
SUBCOMMAND=$1
|
|
||||||
PORT_NAME=$2
|
|
||||||
|
|
||||||
if [ "$SUBCOMMAND" = "help" ]; then
|
|
||||||
echo "TODO: add help"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! [ -f ports/$PORT_NAME/PACKAGE ]
|
|
||||||
then
|
|
||||||
echo "Package $PORT_NAME does not exist. Make sure there is a valid PACKAGE file in the appropriate directory!"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
source ports/$PORT_NAME/PACKAGE
|
|
||||||
|
|
||||||
export preserve_workdir=1
|
|
||||||
export WORKDIR=$LUNA_ROOT/ports/dev
|
|
||||||
|
|
||||||
case $SUBCOMMAND in
|
|
||||||
download)
|
|
||||||
export skip_configure=1
|
|
||||||
export skip_build=1
|
|
||||||
export skip_install=1
|
|
||||||
export skip_dependencies=1
|
|
||||||
export skip_patch=1
|
|
||||||
|
|
||||||
tools/make-package.sh $PORT_NAME
|
|
||||||
|
|
||||||
if [ "$format" = "tar" ]; then
|
|
||||||
cd ${srcdir:-$WORKDIR/$name-$version}
|
|
||||||
git init
|
|
||||||
git add .
|
|
||||||
git commit -m "Temporary development git repository for diffs."
|
|
||||||
cd $LUNA_ROOT
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Created dev source tree in ${srcdir:-$WORKDIR/$name-$version}."
|
|
||||||
;;
|
|
||||||
setup-dependencies)
|
|
||||||
export skip_download_sources=1
|
|
||||||
export skip_build=1
|
|
||||||
export skip_install=1
|
|
||||||
export skip_configure=1
|
|
||||||
export skip_patch=1
|
|
||||||
|
|
||||||
tools/make-package.sh $PORT_NAME
|
|
||||||
;;
|
|
||||||
patch)
|
|
||||||
export skip_download_sources=1
|
|
||||||
export skip_build=1
|
|
||||||
export skip_install=1
|
|
||||||
export skip_configure=1
|
|
||||||
export skip_dependencies=1
|
|
||||||
|
|
||||||
tools/make-package.sh $PORT_NAME
|
|
||||||
;;
|
|
||||||
configure)
|
|
||||||
export skip_download_sources=1
|
|
||||||
export skip_build=1
|
|
||||||
export skip_install=1
|
|
||||||
export skip_dependencies=1
|
|
||||||
export skip_patch=1
|
|
||||||
|
|
||||||
tools/make-package.sh $PORT_NAME
|
|
||||||
;;
|
|
||||||
compile)
|
|
||||||
export skip_download_sources=1
|
|
||||||
export skip_configure=1
|
|
||||||
export skip_dependencies=1
|
|
||||||
export skip_patch=1
|
|
||||||
|
|
||||||
tools/make-package.sh $PORT_NAME
|
|
||||||
|
|
||||||
echo "Packaged dev build as $LUNA_ROOT/ports/out/$name-$version.tar.gz. Install it using tools/install-package.sh."
|
|
||||||
;;
|
|
||||||
generate-diff)
|
|
||||||
cd ${srcdir:-$WORKDIR/$name-$version}
|
|
||||||
git diff > $LUNA_ROOT/ports/$name/$name.patch
|
|
||||||
echo "Created $LUNA_ROOT/ports/$name/$name.patch. Remember to add patching code to the PACKAGE file!"
|
|
||||||
;;
|
|
||||||
cleanup)
|
|
||||||
rm -rfv $WORKDIR/*$name*
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "No such subcommand. Run 'tools/package-helper.sh help $name' for help."
|
|
||||||
;;
|
|
||||||
esac
|
|
@ -39,7 +39,7 @@ unset CXX
|
|||||||
unset LD
|
unset LD
|
||||||
unset AR
|
unset AR
|
||||||
|
|
||||||
../binutils-$LUNA_BINUTILS_VERSION_REQUIRED/configure --prefix="$BUILD_PREFIX" --target=$BUILD_TARGET --disable-nls --with-sysroot=$BUILD_SYSROOT --disable-werror --enable-warn-rwx-segments=no --enable-initfini-array
|
../binutils-$LUNA_BINUTILS_VERSION_REQUIRED/configure --prefix="$BUILD_PREFIX" --target=$BUILD_TARGET --disable-nls --with-sysroot=$BUILD_SYSROOT --disable-werror --enable-warn-rwx-segments=no
|
||||||
|
|
||||||
echo Building Binutils...
|
echo Building Binutils...
|
||||||
|
|
||||||
|
@ -51,7 +51,7 @@ unset CXX
|
|||||||
unset LD
|
unset LD
|
||||||
unset AR
|
unset AR
|
||||||
|
|
||||||
../gcc-$LUNA_GCC_VERSION_REQUIRED/configure --prefix="$BUILD_PREFIX" --target=$BUILD_TARGET --disable-nls --with-sysroot=$BUILD_SYSROOT --enable-languages=c,c++ --enable-initfini-array
|
../gcc-$LUNA_GCC_VERSION_REQUIRED/configure --prefix="$BUILD_PREFIX" --target=$BUILD_TARGET --disable-nls --with-sysroot=$BUILD_SYSROOT --enable-languages=c,c++
|
||||||
|
|
||||||
echo Building GCC...
|
echo Building GCC...
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user