Compare commits
29 Commits
Author | SHA1 | Date | |
---|---|---|---|
ef1065278b | |||
391a58dffc | |||
bd4b7763d4 | |||
33ce9e38d2 | |||
409aa4ffb4 | |||
b951abd511 | |||
2171eaeed6 | |||
7075a9ad58 | |||
9025a85bcc | |||
3342b87fd0 | |||
cd4b20b701 | |||
fc120f4f33 | |||
b8d5a76ee7 | |||
009d4a3421 | |||
460d5820da | |||
83e84c3ebf | |||
eeb1953d87 | |||
e9707563d7 | |||
11d0593c9e | |||
22a5abd279 | |||
8c047d6083 | |||
1832a39ed3 | |||
2a00526666 | |||
1f72016fc2 | |||
a522cdc583 | |||
37230435aa | |||
737dda2960 | |||
0d468bf245 | |||
b0baae79ba |
3
.gitignore
vendored
Normal file
3
.gitignore
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
binaries/*
|
||||||
|
sources/*
|
||||||
|
xtchain-*.zst
|
11
README.md
11
README.md
@ -2,8 +2,11 @@
|
|||||||
<a href="https://git.codingworkshop.eu.org/xt-sys/xtchain">
|
<a href="https://git.codingworkshop.eu.org/xt-sys/xtchain">
|
||||||
<img alt="GIT Repository" src="https://img.shields.io/badge/Source-GIT-purple">
|
<img alt="GIT Repository" src="https://img.shields.io/badge/Source-GIT-purple">
|
||||||
</a>
|
</a>
|
||||||
<a href="https://ci.codingworkshop.eu.org/xt-sys/xtchain">
|
<a href="https://git.codingworkshop.eu.org/xt-sys/xtchain/actions">
|
||||||
<img alt="Build Status" src="https://ci.codingworkshop.eu.org/api/badges/xt-sys/xtchain/status.svg">
|
<img alt="Build Status" src="https://codingworkshop.eu.org/actions.php?project=xt-sys/xtchain">
|
||||||
|
</a>
|
||||||
|
<a href="https://github.com/xt-sys/xtchain/releases">
|
||||||
|
<img alt="Releases" src="https://img.shields.io/github/v/release/xt-sys/xtchain?label=Release&color=blueviolet">
|
||||||
</a>
|
</a>
|
||||||
<a href="https://git.codingworkshop.eu.org/xt-sys/xtchain/src/branch/master/COPYING.md">
|
<a href="https://git.codingworkshop.eu.org/xt-sys/xtchain/src/branch/master/COPYING.md">
|
||||||
<img alt="License" src="https://img.shields.io/badge/License-GPLv3-blue.svg">
|
<img alt="License" src="https://img.shields.io/badge/License-GPLv3-blue.svg">
|
||||||
@ -11,8 +14,8 @@
|
|||||||
<a href="https://github.com/sponsors/xt-sys/">
|
<a href="https://github.com/sponsors/xt-sys/">
|
||||||
<img alt="Sponsors" src="https://img.shields.io/badge/Sponsor-%E2%9D%A4-red?logo=GitHub">
|
<img alt="Sponsors" src="https://img.shields.io/badge/Sponsor-%E2%9D%A4-red?logo=GitHub">
|
||||||
</a>
|
</a>
|
||||||
<a href="https://discord.com/invite/3zgjQDVmAe">
|
<a href="https://discord.com/invite/zBzJ5qMGX7">
|
||||||
<img alt="Discord" src="https://img.shields.io/discord/723186294540206100?label=Chat">
|
<img alt="Discord" src="https://img.shields.io/badge/Chat-Join%20Discord-success">
|
||||||
</a>
|
</a>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
|
@ -16,24 +16,19 @@ WRKDIR="$(pwd)"
|
|||||||
ARCHS="aarch64 armv7 i686 x86_64"
|
ARCHS="aarch64 armv7 i686 x86_64"
|
||||||
GENERIC="generic-w64-mingw32"
|
GENERIC="generic-w64-mingw32"
|
||||||
|
|
||||||
# Binutils Settings
|
|
||||||
BINUTILSDIR="${SRCDIR}/binutils"
|
|
||||||
BINUTILSTAG="binutils-2_40"
|
|
||||||
BINUTILSVCS="git://sourceware.org/git/binutils-gdb.git"
|
|
||||||
|
|
||||||
# CMake Settings
|
# CMake Settings
|
||||||
CMAKEDIR="${SRCDIR}/cmake"
|
CMAKEDIR="${SRCDIR}/cmake"
|
||||||
CMAKETAG="v3.24.2"
|
CMAKETAG="v3.31.3"
|
||||||
CMAKEVCS="https://gitlab.kitware.com/cmake/cmake.git"
|
CMAKEVCS="https://gitlab.kitware.com/cmake/cmake.git"
|
||||||
|
|
||||||
# LLVM Settings
|
# LLVM Settings
|
||||||
LLVMDIR="${SRCDIR}/llvm"
|
LLVMDIR="${SRCDIR}/llvm"
|
||||||
LLVMTAG="llvmorg-16.0.6"
|
LLVMTAG="llvmorg-19.1.6"
|
||||||
LLVMVCS="https://github.com/llvm/llvm-project.git"
|
LLVMVCS="https://github.com/llvm/llvm-project.git"
|
||||||
|
|
||||||
# Make Settings
|
# Make Settings
|
||||||
MAKEDIR="${SRCDIR}/make"
|
MAKEDIR="${SRCDIR}/make"
|
||||||
MAKETAG="4.3"
|
MAKETAG="4.4.1"
|
||||||
MAKEVCS="git://git.savannah.gnu.org/make"
|
MAKEVCS="git://git.savannah.gnu.org/make"
|
||||||
|
|
||||||
# Mingw-w64 Settings
|
# Mingw-w64 Settings
|
||||||
@ -43,20 +38,15 @@ MINGWTAG="master"
|
|||||||
MINGWNTV="0x601"
|
MINGWNTV="0x601"
|
||||||
MINGWVCS="https://github.com/mirror/mingw-w64.git"
|
MINGWVCS="https://github.com/mirror/mingw-w64.git"
|
||||||
|
|
||||||
# NASM Settings
|
|
||||||
NASMDIR="${SRCDIR}/nasm"
|
|
||||||
NASMTAG="nasm-2.15.05"
|
|
||||||
NASMVCS="https://github.com/netwide-assembler/nasm.git"
|
|
||||||
|
|
||||||
# Ninja Settings
|
# Ninja Settings
|
||||||
NINJADIR="${SRCDIR}/ninja"
|
NINJADIR="${SRCDIR}/ninja"
|
||||||
NINJATAG="v1.11.0"
|
NINJATAG="v1.12.1"
|
||||||
NINJAVCS="https://github.com/ninja-build/ninja.git"
|
NINJAVCS="https://github.com/ninja-build/ninja.git"
|
||||||
|
|
||||||
# Wine Settings
|
# Wine Settings
|
||||||
WINEDIR="${SRCDIR}/wine"
|
WINEDIR="${SRCDIR}/wine"
|
||||||
WINETAG="wine-7.9"
|
WINETAG="wine-9.8"
|
||||||
WINEVCS="git://source.winehq.org/git/wine.git"
|
WINEVCS="https://github.com/wine-mirror/wine.git"
|
||||||
|
|
||||||
|
|
||||||
# This function applies a patches to the 3rd party project
|
# This function applies a patches to the 3rd party project
|
||||||
@ -84,51 +74,6 @@ apply_patches()
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# This function compiles and installs GNU BINUTILS
|
|
||||||
binutils_build()
|
|
||||||
{
|
|
||||||
echo ">>> Building BINUTILS ..."
|
|
||||||
for ARCH in ${ARCHS}; do
|
|
||||||
[ -z ${CLEAN} ] || rm -rf ${BINUTILSDIR}/build-${ARCH}
|
|
||||||
mkdir -p ${BINUTILSDIR}/build-${ARCH}
|
|
||||||
cd ${BINUTILSDIR}/build-${ARCH}
|
|
||||||
case ${ARCH} in
|
|
||||||
"armv7")
|
|
||||||
TARGET="arm"
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
TARGET="${ARCH}"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
../configure \
|
|
||||||
--target=${TARGET}-w64-mingw32 \
|
|
||||||
--disable-binutils \
|
|
||||||
--disable-gdb \
|
|
||||||
--disable-gprof \
|
|
||||||
--disable-ld \
|
|
||||||
--disable-multilib \
|
|
||||||
--disable-nls \
|
|
||||||
--disable-werror \
|
|
||||||
--with-zlib=yes
|
|
||||||
make -j${CORES}
|
|
||||||
cp ${BINUTILSDIR}/build-${ARCH}/gas/as-new ${BINDIR}/bin/${ARCH}-w64-mingw32-gas
|
|
||||||
done
|
|
||||||
cd ${WRKDIR}
|
|
||||||
}
|
|
||||||
|
|
||||||
# This function downloads GNU BINUTILS from VCS
|
|
||||||
binutils_fetch()
|
|
||||||
{
|
|
||||||
if [ ! -d ${BINUTILSDIR} ]; then
|
|
||||||
echo ">>> Downloading BINUTILS ..."
|
|
||||||
git clone ${BINUTILSVCS} ${BINUTILSDIR}
|
|
||||||
cd ${BINUTILSDIR}
|
|
||||||
git checkout tags/${BINUTILSTAG}
|
|
||||||
apply_patches ${BINUTILSDIR##*/} ${BINUTILSTAG##*-}
|
|
||||||
cd ${WRKDIR}
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# This function compiles and installs CMAKE
|
# This function compiles and installs CMAKE
|
||||||
cmake_build()
|
cmake_build()
|
||||||
{
|
{
|
||||||
@ -150,9 +95,8 @@ cmake_fetch()
|
|||||||
{
|
{
|
||||||
if [ ! -d ${CMAKEDIR} ]; then
|
if [ ! -d ${CMAKEDIR} ]; then
|
||||||
echo ">>> Downloading CMAKE ..."
|
echo ">>> Downloading CMAKE ..."
|
||||||
git clone ${CMAKEVCS} ${CMAKEDIR}
|
git clone --depth 1 --branch ${CMAKETAG} ${CMAKEVCS} ${CMAKEDIR}
|
||||||
cd ${CMAKEDIR}
|
cd ${CMAKEDIR}
|
||||||
git checkout tags/${CMAKETAG}
|
|
||||||
apply_patches ${CMAKEDIR##*/} ${CMAKETAG}
|
apply_patches ${CMAKEDIR##*/} ${CMAKETAG}
|
||||||
cd ${WRKDIR}
|
cd ${WRKDIR}
|
||||||
fi
|
fi
|
||||||
@ -287,9 +231,8 @@ llvm_fetch()
|
|||||||
{
|
{
|
||||||
if [ ! -d ${LLVMDIR} ]; then
|
if [ ! -d ${LLVMDIR} ]; then
|
||||||
echo ">>> Downloading LLVM ..."
|
echo ">>> Downloading LLVM ..."
|
||||||
git clone ${LLVMVCS} ${LLVMDIR}
|
git clone --depth 1 --branch ${LLVMTAG} ${LLVMVCS} ${LLVMDIR}
|
||||||
cd ${LLVMDIR}
|
cd ${LLVMDIR}
|
||||||
git checkout tags/${LLVMTAG}
|
|
||||||
apply_patches ${LLVMDIR##*/} ${LLVMTAG##*-}
|
apply_patches ${LLVMDIR##*/} ${LLVMTAG##*-}
|
||||||
cd ${WRKDIR}
|
cd ${WRKDIR}
|
||||||
fi
|
fi
|
||||||
@ -324,9 +267,8 @@ make_fetch()
|
|||||||
{
|
{
|
||||||
if [ ! -d ${MAKEDIR} ]; then
|
if [ ! -d ${MAKEDIR} ]; then
|
||||||
echo ">>> Downloading Make ..."
|
echo ">>> Downloading Make ..."
|
||||||
git clone ${MAKEVCS} ${MAKEDIR}
|
git clone --depth 1 --branch ${MAKETAG} ${MAKEVCS} ${MAKEDIR}
|
||||||
cd ${MAKEDIR}
|
cd ${MAKEDIR}
|
||||||
git checkout tags/${MAKETAG}
|
|
||||||
apply_patches ${MAKEDIR##*/} ${MAKETAG}
|
apply_patches ${MAKEDIR##*/} ${MAKETAG}
|
||||||
cd ${WRKDIR}
|
cd ${WRKDIR}
|
||||||
fi
|
fi
|
||||||
@ -421,7 +363,7 @@ mingw_build_libs()
|
|||||||
# This function compiles and installs MINGW tools
|
# This function compiles and installs MINGW tools
|
||||||
mingw_build_tools()
|
mingw_build_tools()
|
||||||
{
|
{
|
||||||
for TOOL in gendef genidl genlib genpeimg widl; do
|
for TOOL in gendef genidl genpeimg widl; do
|
||||||
for ARCH in ${ARCHS}; do
|
for ARCH in ${ARCHS}; do
|
||||||
echo ">>> Building Mingw-w64 (tools) for ${ARCH} ..."
|
echo ">>> Building Mingw-w64 (tools) for ${ARCH} ..."
|
||||||
[ -z ${CLEAN} ] || rm -rf ${MINGWDIR}/mingw-w64-tools/${TOOL}/build-${ARCH}
|
[ -z ${CLEAN} ] || rm -rf ${MINGWDIR}/mingw-w64-tools/${TOOL}/build-${ARCH}
|
||||||
@ -445,11 +387,8 @@ mingw_fetch()
|
|||||||
{
|
{
|
||||||
if [ ! -d ${MINGWDIR} ]; then
|
if [ ! -d ${MINGWDIR} ]; then
|
||||||
echo ">>> Downloading MinGW-w64 ..."
|
echo ">>> Downloading MinGW-w64 ..."
|
||||||
git clone ${MINGWVCS} ${MINGWDIR}
|
git clone --depth 1 --branch ${MINGWTAG} ${MINGWVCS} ${MINGWDIR}
|
||||||
cd ${MINGWDIR}
|
cd ${MINGWDIR}
|
||||||
if [ x"${MINGWTAG}" != x"master" ]; then
|
|
||||||
git checkout tags/${MINGWTAG}
|
|
||||||
fi
|
|
||||||
apply_patches ${MINGWDIR##*/} ${MINGWTAG}
|
apply_patches ${MINGWDIR##*/} ${MINGWTAG}
|
||||||
cd ${WRKDIR}
|
cd ${WRKDIR}
|
||||||
fi
|
fi
|
||||||
@ -472,9 +411,8 @@ ninja_fetch()
|
|||||||
{
|
{
|
||||||
if [ ! -d ${NINJADIR} ]; then
|
if [ ! -d ${NINJADIR} ]; then
|
||||||
echo ">>> Downloading NINJA ..."
|
echo ">>> Downloading NINJA ..."
|
||||||
git clone ${NINJAVCS} ${NINJADIR}
|
git clone --depth 1 --branch ${NINJATAG} ${NINJAVCS} ${NINJADIR}
|
||||||
cd ${NINJADIR}
|
cd ${NINJADIR}
|
||||||
git checkout tags/${NINJATAG}
|
|
||||||
apply_patches ${NINJADIR##*/} ${NINJATAG}
|
apply_patches ${NINJADIR##*/} ${NINJATAG}
|
||||||
cd ${WRKDIR}
|
cd ${WRKDIR}
|
||||||
fi
|
fi
|
||||||
@ -507,9 +445,8 @@ wine_fetch()
|
|||||||
{
|
{
|
||||||
if [ ! -d ${WINEDIR} ]; then
|
if [ ! -d ${WINEDIR} ]; then
|
||||||
echo ">>> Downloading WINE ..."
|
echo ">>> Downloading WINE ..."
|
||||||
git clone ${WINEVCS} ${WINEDIR}
|
git clone --depth 1 --branch ${WINETAG} ${WINEVCS} ${WINEDIR}
|
||||||
cd ${WINEDIR}
|
cd ${WINEDIR}
|
||||||
git checkout tags/${WINETAG}
|
|
||||||
apply_patches ${WINEDIR##*/} ${WINETAG##*-}
|
apply_patches ${WINEDIR##*/} ${WINETAG##*-}
|
||||||
cd ${WRKDIR}
|
cd ${WRKDIR}
|
||||||
fi
|
fi
|
||||||
@ -533,7 +470,7 @@ xtchain_build()
|
|||||||
for EXEC in dlltool ld objdump; do
|
for EXEC in dlltool ld objdump; do
|
||||||
ln -sf ../${GENERIC}/bin/${EXEC}-wrapper ${BINDIR}/bin/${ARCH}-w64-mingw32-${EXEC}
|
ln -sf ../${GENERIC}/bin/${EXEC}-wrapper ${BINDIR}/bin/${ARCH}-w64-mingw32-${EXEC}
|
||||||
done
|
done
|
||||||
for EXEC in exetool windres xtcspecc; do
|
for EXEC in bin2c exetool windres xtcspecc; do
|
||||||
if [ ! -e ${BINDIR}/bin/${EXEC} ]; then
|
if [ ! -e ${BINDIR}/bin/${EXEC} ]; then
|
||||||
gcc ${WRKDIR}/tools/${EXEC}.c -o ${BINDIR}/bin/${EXEC}
|
gcc ${WRKDIR}/tools/${EXEC}.c -o ${BINDIR}/bin/${EXEC}
|
||||||
fi
|
fi
|
||||||
@ -589,12 +526,6 @@ mingw_build_libs
|
|||||||
# Build and install Mingw-W64 tools
|
# Build and install Mingw-W64 tools
|
||||||
mingw_build_tools
|
mingw_build_tools
|
||||||
|
|
||||||
# Download Binutils
|
|
||||||
binutils_fetch
|
|
||||||
|
|
||||||
# Build and install Binutils
|
|
||||||
binutils_build
|
|
||||||
|
|
||||||
# Download Wine
|
# Download Wine
|
||||||
wine_fetch
|
wine_fetch
|
||||||
|
|
||||||
|
@ -1,32 +0,0 @@
|
|||||||
diff --git a/gas/Makefile.in b/gas/Makefile.in
|
|
||||||
index 8319181b472..e4386b38621 100644
|
|
||||||
--- a/gas/Makefile.in
|
|
||||||
+++ b/gas/Makefile.in
|
|
||||||
@@ -2231,7 +2231,7 @@ de-stage3:
|
|
||||||
|
|
||||||
doc/asconfig.texi: doc/$(CONFIG).texi doc/$(am__dirstamp)
|
|
||||||
$(AM_V_at)rm -f doc/asconfig.texi
|
|
||||||
- $(AM_V_GEN)cp $(srcdir)/doc/$(CONFIG).texi doc/asconfig.texi
|
|
||||||
+ $(AM_V_GEN)cp -p $(srcdir)/doc/$(CONFIG).texi doc/asconfig.texi
|
|
||||||
$(AM_V_at)chmod u+w doc/asconfig.texi
|
|
||||||
|
|
||||||
# Maintenance
|
|
||||||
diff --git a/gas/doc/.dirstamp b/gas/doc/.dirstamp
|
|
||||||
deleted file mode 100644
|
|
||||||
index e69de29bb2d..00000000000
|
|
||||||
diff --git a/gas/doc/local.mk b/gas/doc/local.mk
|
|
||||||
index f611a50913c..de13e3ca8b8 100644
|
|
||||||
--- a/gas/doc/local.mk
|
|
||||||
+++ b/gas/doc/local.mk
|
|
||||||
@@ -41,7 +41,7 @@ TEXI2DVI = texi2dvi -I "$(srcdir)/%D%" -I %D% -I "$(srcdir)/../libiberty" \
|
|
||||||
|
|
||||||
%D%/asconfig.texi: %D%/$(CONFIG).texi %D%/$(am__dirstamp)
|
|
||||||
$(AM_V_at)rm -f %D%/asconfig.texi
|
|
||||||
- $(AM_V_GEN)cp $(srcdir)/%D%/$(CONFIG).texi %D%/asconfig.texi
|
|
||||||
+ $(AM_V_GEN)cp -p $(srcdir)/%D%/$(CONFIG).texi %D%/asconfig.texi
|
|
||||||
$(AM_V_at)chmod u+w %D%/asconfig.texi
|
|
||||||
|
|
||||||
CPU_DOCS = \
|
|
||||||
--
|
|
||||||
2.39.2
|
|
||||||
|
|
@ -1,60 +0,0 @@
|
|||||||
From ec231dd4c9ceb09140178b79e30ed0917bb2c955 Mon Sep 17 00:00:00 2001
|
|
||||||
From: belliash <belliash@codingworkshop.eu.org>
|
|
||||||
Date: Sat, 25 Mar 2023 19:33:33 +0100
|
|
||||||
Subject: [PATCH] test2
|
|
||||||
|
|
||||||
---
|
|
||||||
bfd/config.bfd | 8 +++++++-
|
|
||||||
gas/configure.tgt | 3 ++-
|
|
||||||
2 files changed, 9 insertions(+), 2 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/bfd/config.bfd b/bfd/config.bfd
|
|
||||||
index 1b0111fd410..ada7889d362 100644
|
|
||||||
--- a/bfd/config.bfd
|
|
||||||
+++ b/bfd/config.bfd
|
|
||||||
@@ -249,7 +249,7 @@ case "${targ}" in
|
|
||||||
targ_selvecs="aarch64_elf64_be_vec aarch64_elf32_le_vec aarch64_elf32_be_vec arm_elf32_le_vec arm_elf32_be_vec aarch64_pei_le_vec aarch64_pe_le_vec"
|
|
||||||
want64=true
|
|
||||||
;;
|
|
||||||
- aarch64-*-pe*)
|
|
||||||
+ aarch64-*-pe* | aarch64-*-mingw32)
|
|
||||||
targ_defvec=aarch64_pe_le_vec
|
|
||||||
targ_selvecs="aarch64_pe_le_vec aarch64_pei_le_vec"
|
|
||||||
want64=true
|
|
||||||
@@ -409,6 +409,12 @@ case "${targ}" in
|
|
||||||
targ_selvecs="arm_pe_le_vec arm_pe_be_vec arm_pei_le_vec arm_pei_be_vec"
|
|
||||||
targ_underscore=yes
|
|
||||||
;;
|
|
||||||
+ arm-*-mingw32)
|
|
||||||
+ targ_defvec=arm_pe_le_vec
|
|
||||||
+ targ_selvecs="arm_pe_le_vec arm_pe_be_vec arm_pei_le_vec arm_pei_be_vec"
|
|
||||||
+ targ_underscore=no
|
|
||||||
+ targ_cflags="-DARM_COFF_BUGFIX"
|
|
||||||
+ ;;
|
|
||||||
arm-*-phoenix*)
|
|
||||||
targ_defvec=arm_elf32_le_vec
|
|
||||||
targ_selvecs=arm_elf32_be_vec
|
|
||||||
diff --git a/gas/configure.tgt b/gas/configure.tgt
|
|
||||||
index 765ba73633d..9bfef1f72e8 100644
|
|
||||||
--- a/gas/configure.tgt
|
|
||||||
+++ b/gas/configure.tgt
|
|
||||||
@@ -136,6 +136,7 @@ case ${generic_target} in
|
|
||||||
aarch64*-*-netbsd*) fmt=elf em=nbsd;;
|
|
||||||
aarch64*-*-openbsd*) fmt=elf;;
|
|
||||||
aarch64*-*-pe*) fmt=coff em=pepaarch64 ;;
|
|
||||||
+ aarch64*-*-mingw32) fmt=coff em=pepaarch64 ;;
|
|
||||||
alpha-*-*vms*) fmt=evax ;;
|
|
||||||
alpha-*-osf*) fmt=ecoff ;;
|
|
||||||
alpha-*-linux*ecoff*) fmt=ecoff ;;
|
|
||||||
@@ -163,7 +164,7 @@ case ${generic_target} in
|
|
||||||
arm-*-nto*) fmt=elf ;;
|
|
||||||
arm-wince-pe | arm-*-wince | arm*-*-mingw32ce* | arm*-*-cegcc*)
|
|
||||||
fmt=coff em=wince-pe ;;
|
|
||||||
- arm-*-pe) fmt=coff em=pe ;;
|
|
||||||
+ arm-*-pe | arm-*-mingw32) fmt=coff em=pe ;;
|
|
||||||
arm-*-fuchsia*) fmt=elf ;;
|
|
||||||
arm-*-haiku*) fmt=elf em=haiku ;;
|
|
||||||
|
|
||||||
--
|
|
||||||
2.39.2
|
|
||||||
|
|
@ -1,13 +0,0 @@
|
|||||||
diff --git a/src/job.c b/src/job.c
|
|
||||||
index d6e28d3..f8f6950 100644
|
|
||||||
--- a/src/job.c
|
|
||||||
+++ b/src/job.c
|
|
||||||
@@ -2391,7 +2391,7 @@ child_execute_job (struct childbase *child, int good_stdin, char **argv)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
- cmd = (char *)find_in_given_path (argv[0], p, 0);
|
|
||||||
+ cmd = (char *)find_in_given_path (argv[0], p, 0, false);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!cmd)
|
|
@ -51,6 +51,19 @@ chbuild()
|
|||||||
}
|
}
|
||||||
export -f chbuild
|
export -f chbuild
|
||||||
|
|
||||||
|
# Prints help
|
||||||
|
help()
|
||||||
|
{
|
||||||
|
version
|
||||||
|
echo "XTChain defines an internal list of commands:"
|
||||||
|
echo " * charch [arch] - sets the target CPU architecture [aarch64/armv7/i686/amd64]"
|
||||||
|
echo " * chbuild [type] - sets build type [debug/release]"
|
||||||
|
echo " * help - prints this message"
|
||||||
|
echo " * version - prints XTChain and its components version"
|
||||||
|
echo " * xbuild - builds an application with a Ninja build system"
|
||||||
|
}
|
||||||
|
export -f help
|
||||||
|
|
||||||
# Displays version banner
|
# Displays version banner
|
||||||
version()
|
version()
|
||||||
{
|
{
|
||||||
@ -66,9 +79,26 @@ version()
|
|||||||
echo "Wine Message Compiler Version: $(${XTCDIR}/bin/wmc -V | grep 'version' | cut -d' ' -f5)"
|
echo "Wine Message Compiler Version: $(${XTCDIR}/bin/wmc -V | grep 'version' | cut -d' ' -f5)"
|
||||||
echo "Wine Resource Compiler Version: $(${XTCDIR}/bin/wrc --version | grep 'version' | cut -d' ' -f5)"
|
echo "Wine Resource Compiler Version: $(${XTCDIR}/bin/wrc --version | grep 'version' | cut -d' ' -f5)"
|
||||||
echo
|
echo
|
||||||
charch ${TARGET}
|
charch ${TARGET:-amd64}
|
||||||
chbuild DEBUG
|
chbuild ${BUILD_TYPE:-DEBUG}
|
||||||
echo
|
echo
|
||||||
echo
|
echo
|
||||||
}
|
}
|
||||||
export -f version
|
export -f version
|
||||||
|
|
||||||
|
# Builds application (wrapper to Ninja)
|
||||||
|
xbuild()
|
||||||
|
{
|
||||||
|
if [ ! -f build.arch ]; then
|
||||||
|
ninja "$@"
|
||||||
|
else
|
||||||
|
ARCH=$(cat build.arch)
|
||||||
|
if [ x"${ARCH}" != x"${TARGET}" ]; then
|
||||||
|
echo "Build is configured for '${ARCH}' while current target set to '${TARGET}'!"
|
||||||
|
echo "Cannot continue until conflict is resolved ..."
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
ninja "$@"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
export -f xbuild
|
||||||
|
74
tools/bin2c.c
Normal file
74
tools/bin2c.c
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
/**
|
||||||
|
* PROJECT: XTchain
|
||||||
|
* LICENSE: See COPYING.md in the top level directory
|
||||||
|
* FILE: tools/bin2c.c
|
||||||
|
* DESCRIPTION: Binary to C converter
|
||||||
|
* DEVELOPERS: Rafal Kupiec <belliash@codingworkshop.eu.org>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "xtchain.h"
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
/* Check for proper number of arguments */
|
||||||
|
if(argc != 4)
|
||||||
|
{
|
||||||
|
printf("Usage: %s <input binary> <output file> <structure name>\n", argv[0]);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Open the input binary file in binary mode */
|
||||||
|
FILE *inputFile = fopen(argv[1], "rb");
|
||||||
|
if(inputFile == NULL)
|
||||||
|
{
|
||||||
|
printf("Error: unable to open file %s\n", argv[1]);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Open the destination source code file in text mode */
|
||||||
|
FILE *outputFile = fopen(argv[2], "w");
|
||||||
|
if(outputFile == NULL)
|
||||||
|
{
|
||||||
|
printf("Error: unable to open file %s\n", argv[2]);
|
||||||
|
fclose(inputFile);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Get the size of the binary file */
|
||||||
|
fseek(inputFile, 0, SEEK_END);
|
||||||
|
long binSize = ftell(inputFile);
|
||||||
|
rewind(inputFile);
|
||||||
|
|
||||||
|
/* Allocate memory for the binary data */
|
||||||
|
unsigned char *binData = (unsigned char *)malloc(binSize);
|
||||||
|
if(binData == NULL)
|
||||||
|
{
|
||||||
|
printf("Error: unable to allocate memory for binary data\n");
|
||||||
|
fclose(inputFile);
|
||||||
|
fclose(outputFile);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Read the binary data into memory */
|
||||||
|
fread(binData, sizeof(unsigned char), binSize, inputFile);
|
||||||
|
|
||||||
|
/* Write the C structure to the header file */
|
||||||
|
fprintf(outputFile, "unsigned char %s[] = {", argv[3]);
|
||||||
|
for(int i = 0; i < binSize; i++)
|
||||||
|
{
|
||||||
|
fprintf(outputFile, "0x%02X", binData[i]);
|
||||||
|
if(i < binSize - 1)
|
||||||
|
{
|
||||||
|
fprintf(outputFile, ",");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fprintf(outputFile, "};\nunsigned int %s_size = %ld;\n", argv[3], binSize);
|
||||||
|
free(binData);
|
||||||
|
|
||||||
|
/* Close all open files */
|
||||||
|
fclose(inputFile);
|
||||||
|
fclose(outputFile);
|
||||||
|
|
||||||
|
printf("Binary data converted to C structure successfully.\n");
|
||||||
|
return 0;
|
||||||
|
}
|
@ -2,7 +2,7 @@
|
|||||||
* PROJECT: XTchain
|
* PROJECT: XTchain
|
||||||
* LICENSE: See COPYING.md in the top level directory
|
* LICENSE: See COPYING.md in the top level directory
|
||||||
* FILE: tools/exetool.c
|
* FILE: tools/exetool.c
|
||||||
* DESCRIPTION: Portable Executable (PE) utility for changing subsystem
|
* DESCRIPTION: Portable Executable (PE) utility for changing its signature and subsystem
|
||||||
* DEVELOPERS: Rafal Kupiec <belliash@codingworkshop.eu.org>
|
* DEVELOPERS: Rafal Kupiec <belliash@codingworkshop.eu.org>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -15,6 +15,7 @@ typedef struct _PE_SUBSYSTEM
|
|||||||
} PE_SUBSYSTEM, *PPE_SUBSYSTEM;
|
} PE_SUBSYSTEM, *PPE_SUBSYSTEM;
|
||||||
|
|
||||||
static PE_SUBSYSTEM SubSystems[] = {
|
static PE_SUBSYSTEM SubSystems[] = {
|
||||||
|
{0x00, "INVALID_SUBSYSTEM"},
|
||||||
{0x01, "NT_NATIVE"},
|
{0x01, "NT_NATIVE"},
|
||||||
{0x02, "WINDOWS_GUI"},
|
{0x02, "WINDOWS_GUI"},
|
||||||
{0x03, "WINDOWS_CLI"},
|
{0x03, "WINDOWS_CLI"},
|
||||||
@ -37,7 +38,7 @@ static PE_SUBSYSTEM SubSystems[] = {
|
|||||||
{0x19, "XT_APPLICATION_GDI"}
|
{0x19, "XT_APPLICATION_GDI"}
|
||||||
};
|
};
|
||||||
|
|
||||||
int getSubSystemID(char *Name)
|
PPE_SUBSYSTEM getSubSystem(char *Name)
|
||||||
{
|
{
|
||||||
int Index;
|
int Index;
|
||||||
int SubSystemsCount;
|
int SubSystemsCount;
|
||||||
@ -50,15 +51,39 @@ int getSubSystemID(char *Name)
|
|||||||
for(Index = 0; Index < SubSystemsCount; Index++)
|
for(Index = 0; Index < SubSystemsCount; Index++)
|
||||||
{
|
{
|
||||||
SubSystem = &SubSystems[Index];
|
SubSystem = &SubSystems[Index];
|
||||||
if(strcmp(SubSystem->Name, Name) == 0)
|
if(strcasecmp(SubSystem->Name, Name) == 0)
|
||||||
{
|
{
|
||||||
/* Subsystem found, return its ID */
|
/* Subsystem found, return its ID */
|
||||||
return SubSystem->Identifier;
|
return SubSystem;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* No valid subsystem found */
|
/* No valid subsystem found */
|
||||||
return 0x00;
|
return &SubSystems[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
char *getSubSystemName(int Identifier)
|
||||||
|
{
|
||||||
|
int Index;
|
||||||
|
int SubSystemsCount;
|
||||||
|
PPE_SUBSYSTEM SubSystem;
|
||||||
|
|
||||||
|
/* Count number of subsystems avaialble */
|
||||||
|
SubSystemsCount = sizeof(SubSystems) / sizeof(PE_SUBSYSTEM);
|
||||||
|
|
||||||
|
/* Find subsystem */
|
||||||
|
for(Index = 0; Index < SubSystemsCount; Index++)
|
||||||
|
{
|
||||||
|
SubSystem = &SubSystems[Index];
|
||||||
|
if(SubSystem->Identifier == Identifier)
|
||||||
|
{
|
||||||
|
/* Subsystem found, return its ID */
|
||||||
|
return SubSystem->Name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* No valid subsystem found */
|
||||||
|
return SubSystems[0].Name;
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
@ -66,8 +91,9 @@ int main(int argc, char *argv[])
|
|||||||
FILE *ExeFile;
|
FILE *ExeFile;
|
||||||
unsigned char Signature[4];
|
unsigned char Signature[4];
|
||||||
unsigned int HeaderOffset;
|
unsigned int HeaderOffset;
|
||||||
|
unsigned int ImageSignature;
|
||||||
unsigned short SubSystem;
|
unsigned short SubSystem;
|
||||||
int NewSubSystem;
|
PPE_SUBSYSTEM NewSubSystem;
|
||||||
|
|
||||||
/* Check for proper number of arguments */
|
/* Check for proper number of arguments */
|
||||||
if(argc != 3)
|
if(argc != 3)
|
||||||
@ -76,13 +102,22 @@ int main(int argc, char *argv[])
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Parse the new SubSystem value from the command line argument */
|
||||||
|
NewSubSystem = getSubSystem(argv[2]);
|
||||||
|
if(NewSubSystem->Identifier == 0)
|
||||||
|
{
|
||||||
|
/* Invalid SubSystem provided */
|
||||||
|
printf("Error: %s is not a valid PE SubSystem\n", argv[2]);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
/* Open the EXE file in binary mode */
|
/* Open the EXE file in binary mode */
|
||||||
ExeFile = fopen(argv[1], "r+b");
|
ExeFile = fopen(argv[1], "r+b");
|
||||||
if(ExeFile == NULL)
|
if(ExeFile == NULL)
|
||||||
{
|
{
|
||||||
/* Failed to open PE file */
|
/* Failed to open PE file */
|
||||||
printf("ERROR: Unable to open file %s\n", argv[1]);
|
printf("ERROR: Unable to open file %s\n", argv[1]);
|
||||||
return 1;
|
return 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Verify that the input file has a valid DOS header */
|
/* Verify that the input file has a valid DOS header */
|
||||||
@ -92,7 +127,7 @@ int main(int argc, char *argv[])
|
|||||||
/* Invalid DOS header */
|
/* Invalid DOS header */
|
||||||
printf("ERROR: %s is not a valid EXE file\n", argv[1]);
|
printf("ERROR: %s is not a valid EXE file\n", argv[1]);
|
||||||
fclose(ExeFile);
|
fclose(ExeFile);
|
||||||
return 1;
|
return 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Verify that the input file has a valid PE header */
|
/* Verify that the input file has a valid PE header */
|
||||||
@ -100,43 +135,48 @@ int main(int argc, char *argv[])
|
|||||||
fread(&HeaderOffset, sizeof(unsigned int), 1, ExeFile);
|
fread(&HeaderOffset, sizeof(unsigned int), 1, ExeFile);
|
||||||
fseek(ExeFile, HeaderOffset, SEEK_SET);
|
fseek(ExeFile, HeaderOffset, SEEK_SET);
|
||||||
fread(Signature, sizeof(unsigned char), 4, ExeFile);
|
fread(Signature, sizeof(unsigned char), 4, ExeFile);
|
||||||
if(Signature[0] != 'P' || Signature[1] != 'E' || Signature[2] != 0 || Signature[3] != 0)
|
if((Signature[0] != 'P' || Signature[1] != 'E' || Signature[2] != 0 || Signature[3] != 0) &&
|
||||||
|
(Signature[0] != 'P' || Signature[1] != 'E' || Signature[2] != 'X' || Signature[3] != 'T'))
|
||||||
{
|
{
|
||||||
/* Invalid PE header */
|
/* Invalid PE header */
|
||||||
printf("Error: %s is not a valid PE file\n", argv[1]);
|
printf("Error: %s is not a valid PE file\n", argv[1]);
|
||||||
fclose(ExeFile);
|
fclose(ExeFile);
|
||||||
return 1;
|
return 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Check if setting XT subsystem */
|
||||||
|
if(NewSubSystem->Identifier >= 0x14 && NewSubSystem->Identifier <= 0x19)
|
||||||
|
{
|
||||||
|
/* Write PEXT signature */
|
||||||
|
ImageSignature = 0x54584550;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* Write PE00 signature */
|
||||||
|
ImageSignature = 0x00004550;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Seek back to header offset and write new signature */
|
||||||
|
fseek(ExeFile, HeaderOffset, SEEK_SET);
|
||||||
|
fwrite(&ImageSignature, sizeof(ImageSignature), 1, ExeFile);
|
||||||
|
|
||||||
/* Seek to the offset of the SubSystem field in the optional header */
|
/* Seek to the offset of the SubSystem field in the optional header */
|
||||||
fseek(ExeFile, HeaderOffset + 0x5C, SEEK_SET);
|
fseek(ExeFile, HeaderOffset + 0x5C, SEEK_SET);
|
||||||
|
|
||||||
/* Read the current SubSystem value */
|
/* Read the current SubSystem value */
|
||||||
fread(&SubSystem, sizeof(unsigned short), 1, ExeFile);
|
fread(&SubSystem, sizeof(unsigned short), 1, ExeFile);
|
||||||
printf("Original SubSystem: 0x%04X\n", SubSystem);
|
|
||||||
|
|
||||||
/* Parse the new SubSystem value from the command line argument */
|
|
||||||
NewSubSystem = getSubSystemID(argv[2]);
|
|
||||||
if(NewSubSystem == 0)
|
|
||||||
{
|
|
||||||
/* Invalid SubSystem provided */
|
|
||||||
printf("Error: %s is not a valid PE SubSystem\n", argv[2]);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Print new SubSystem identifier */
|
|
||||||
printf("New SubSystem: 0x%04X\n", NewSubSystem);
|
|
||||||
|
|
||||||
/* Seek back to the SubSystem field in the optional header */
|
/* Seek back to the SubSystem field in the optional header */
|
||||||
fseek(ExeFile, -sizeof(unsigned short), SEEK_CUR);
|
fseek(ExeFile, -sizeof(unsigned short), SEEK_CUR);
|
||||||
|
|
||||||
/* Write the new SubSystem value */
|
/* Write the new SubSystem value */
|
||||||
fwrite(&NewSubSystem, sizeof(unsigned short), 1, ExeFile);
|
fwrite(&NewSubSystem->Identifier, sizeof(unsigned short), 1, ExeFile);
|
||||||
|
|
||||||
/* Close the file */
|
/* Close the file */
|
||||||
fclose(ExeFile);
|
fclose(ExeFile);
|
||||||
|
|
||||||
/* Finished successfully */
|
/* Finished successfully */
|
||||||
printf("SubSystem successfully modified!\n");
|
printf("PE SubSystem modified: 0x%02X <%s> to 0x%02X <%s>\n",
|
||||||
|
SubSystem, getSubSystemName(SubSystem), NewSubSystem->Identifier, NewSubSystem->Name);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -169,9 +169,9 @@ void check_num_args(int arg,
|
|||||||
int main(int argc,
|
int main(int argc,
|
||||||
char* argv[])
|
char* argv[])
|
||||||
{
|
{
|
||||||
const char *dir;
|
char *dir;
|
||||||
const char *basename;
|
char *basename;
|
||||||
const char *target;
|
char *target;
|
||||||
|
|
||||||
split_argv(argv[0], &dir, &basename, &target, NULL);
|
split_argv(argv[0], &dir, &basename, &target, NULL);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user