Merge remote-tracking branch 'refs/remotes/origin/actions' into actions
This commit is contained in:
@@ -28,7 +28,7 @@ CMAKEVCS="https://gitlab.kitware.com/cmake/cmake.git"
|
|||||||
|
|
||||||
# LLVM Settings
|
# LLVM Settings
|
||||||
LLVMDIR="${SRCDIR}/llvm"
|
LLVMDIR="${SRCDIR}/llvm"
|
||||||
LLVMTAG="llvmorg-16.0.0"
|
LLVMTAG="llvmorg-16.0.6"
|
||||||
LLVMVCS="https://github.com/llvm/llvm-project.git"
|
LLVMVCS="https://github.com/llvm/llvm-project.git"
|
||||||
|
|
||||||
# Make Settings
|
# Make Settings
|
||||||
@@ -533,14 +533,13 @@ 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 windres xtcspecc; do
|
for EXEC in 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
|
||||||
ln -sf ${EXEC} ${BINDIR}/bin/${ARCH}-w64-mingw32-${EXEC}
|
ln -sf ${EXEC} ${BINDIR}/bin/${ARCH}-w64-mingw32-${EXEC}
|
||||||
done
|
done
|
||||||
done
|
done
|
||||||
cp ${WRKDIR}/scripts/exetool ${BINDIR}/bin/
|
|
||||||
cp ${WRKDIR}/scripts/xtclib ${BINDIR}/lib/xtchain/
|
cp ${WRKDIR}/scripts/xtclib ${BINDIR}/lib/xtchain/
|
||||||
cp ${WRKDIR}/scripts/xtchain ${BINDIR}/
|
cp ${WRKDIR}/scripts/xtchain ${BINDIR}/
|
||||||
}
|
}
|
||||||
@@ -628,7 +627,7 @@ rm -rf ${BINDIR}/bin/amdgpu-arch,{clang-{check,exdef-mapping,import-test,offload
|
|||||||
# Save XT Toolchain version
|
# Save XT Toolchain version
|
||||||
cd ${WRKDIR}
|
cd ${WRKDIR}
|
||||||
: ${XTCVER:=$(git describe --exact-match --tags 2>/dev/null)}
|
: ${XTCVER:=$(git describe --exact-match --tags 2>/dev/null)}
|
||||||
: ${XTCVER:=DEV}
|
: ${XTCVER:=DEVEL}
|
||||||
echo "${XTCVER}" > ${BINDIR}/Version
|
echo "${XTCVER}" > ${BINDIR}/Version
|
||||||
|
|
||||||
# Prepare archive
|
# Prepare archive
|
||||||
|
@@ -1,79 +0,0 @@
|
|||||||
#!/usr/bin/env python3
|
|
||||||
|
|
||||||
import sys
|
|
||||||
import struct
|
|
||||||
|
|
||||||
if len(sys.argv) < 3:
|
|
||||||
print("XTChain ExeTool for modifying PE/COFF image subsystem\nNot sufficient parametrs. '[PE/COFF Image File]' '[SubSystem]'")
|
|
||||||
sys.exit(1)
|
|
||||||
|
|
||||||
ImageFile = sys.argv[1]
|
|
||||||
Subsystem = sys.argv[2].upper()
|
|
||||||
|
|
||||||
# Set proper subsystem
|
|
||||||
if Subsystem == "UNKNOWN":
|
|
||||||
ImageSubsystem = 0x00
|
|
||||||
elif Subsystem == "NT_NATIVE":
|
|
||||||
ImageSubsystem = 0x01
|
|
||||||
elif Subsystem == "WINDOWS_GUI":
|
|
||||||
ImageSubsystem = 0x02
|
|
||||||
elif Subsystem == "WINDOWS_CLI":
|
|
||||||
ImageSubsystem = 0x03
|
|
||||||
elif Subsystem == "WINDOWS_CE_OLD":
|
|
||||||
ImageSubsystem = 0x04
|
|
||||||
elif Subsystem == "OS2_CUI":
|
|
||||||
ImageSubsystem = 0x05
|
|
||||||
elif Subsystem == "POSIX_CUI":
|
|
||||||
ImageSubsystem = 0x07
|
|
||||||
elif Subsystem == "NATIVE_WINDOWS":
|
|
||||||
ImageSubsystem = 0x08
|
|
||||||
elif Subsystem == "WINDOWS_CE_GUI":
|
|
||||||
ImageSubsystem = 0x09
|
|
||||||
elif Subsystem == "EFI_APPLICATION":
|
|
||||||
ImageSubsystem = 0x0A
|
|
||||||
elif Subsystem == "EFI_BOOT_SERVICE_DRIVER":
|
|
||||||
ImageSubsystem = 0x0B
|
|
||||||
elif Subsystem == "EFI_RUNTIME_DRIVER":
|
|
||||||
ImageSubsystem = 0x0C
|
|
||||||
elif Subsystem == "EFI_ROM":
|
|
||||||
ImageSubsystem = 0x0D
|
|
||||||
elif Subsystem == "XBOX":
|
|
||||||
ImageSubsystem = 0x0E
|
|
||||||
elif Subsystem == "WINDOWS_BOOT_APPLICATION":
|
|
||||||
ImageSubsystem = 0x10
|
|
||||||
elif Subsystem == "XT_NATIVE_KERNEL":
|
|
||||||
ImageSubsystem = 0x14
|
|
||||||
elif Subsystem == "XT_NATIVE_APPLICATION":
|
|
||||||
ImageSubsystem = 0x15
|
|
||||||
elif Subsystem == "XT_NATIVE_DRIVER":
|
|
||||||
ImageSubsystem = 0x16
|
|
||||||
elif Subsystem == "XT_DYNAMIC_LIBRARY":
|
|
||||||
ImageSubsystem = 0x17
|
|
||||||
elif Subsystem == "XT_APPLICATION_CLI":
|
|
||||||
ImageSubsystem = 0x18
|
|
||||||
elif Subsystem == "XT_APPLICATION_GDI":
|
|
||||||
ImageSubsystem = 0x19
|
|
||||||
else:
|
|
||||||
print("Invalid subsystem privided")
|
|
||||||
exit(2)
|
|
||||||
|
|
||||||
# Open PE/COFF image file
|
|
||||||
PeImage = open(sys.argv[1], "r+b")
|
|
||||||
|
|
||||||
# Get PE header
|
|
||||||
PeImage.seek(0x3C)
|
|
||||||
(PeHeader,)=struct.unpack("H", PeImage.read(2))
|
|
||||||
|
|
||||||
# Get PE signature
|
|
||||||
PeImage.seek(PeHeader)
|
|
||||||
(PeSignature,)=struct.unpack("I", PeImage.read(4))
|
|
||||||
if PeSignature != 0x4550:
|
|
||||||
print("Invalid or corrupted PE header")
|
|
||||||
|
|
||||||
# Set new image subsystem
|
|
||||||
PeImage.seek(PeHeader + 0x5C)
|
|
||||||
print("Setting subsystem to " + str(ImageSubsystem))
|
|
||||||
PeImage.write(struct.pack("H", ImageSubsystem))
|
|
||||||
|
|
||||||
# Close PE/COFF image file
|
|
||||||
PeImage.close()
|
|
@@ -55,7 +55,7 @@ export -f chbuild
|
|||||||
version()
|
version()
|
||||||
{
|
{
|
||||||
echo "###############################################################################"
|
echo "###############################################################################"
|
||||||
echo "# XT Toolchain v${XTCVER} for Linux #"
|
echo "# XT Toolchain v${XTCVER} for Linux #"
|
||||||
echo "# by Rafal Kupiec <belliash@codingworkshop.eu.org> #"
|
echo "# by Rafal Kupiec <belliash@codingworkshop.eu.org> #"
|
||||||
echo "###############################################################################"
|
echo "###############################################################################"
|
||||||
echo
|
echo
|
||||||
|
142
tools/exetool.c
Normal file
142
tools/exetool.c
Normal file
@@ -0,0 +1,142 @@
|
|||||||
|
/**
|
||||||
|
* PROJECT: XTchain
|
||||||
|
* LICENSE: See COPYING.md in the top level directory
|
||||||
|
* FILE: tools/exetool.c
|
||||||
|
* DESCRIPTION: Portable Executable (PE) utility for changing subsystem
|
||||||
|
* DEVELOPERS: Rafal Kupiec <belliash@codingworkshop.eu.org>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "xtchain.h"
|
||||||
|
|
||||||
|
typedef struct _PE_SUBSYSTEM
|
||||||
|
{
|
||||||
|
int Identifier;
|
||||||
|
char *Name;
|
||||||
|
} PE_SUBSYSTEM, *PPE_SUBSYSTEM;
|
||||||
|
|
||||||
|
static PE_SUBSYSTEM SubSystems[] = {
|
||||||
|
{0x01, "NT_NATIVE"},
|
||||||
|
{0x02, "WINDOWS_GUI"},
|
||||||
|
{0x03, "WINDOWS_CLI"},
|
||||||
|
{0x04, "WINDOWS_CE_OLD"},
|
||||||
|
{0x05, "OS2_CUI"},
|
||||||
|
{0x07, "POSIX_CUI"},
|
||||||
|
{0x08, "NATIVE_WINDOWS"},
|
||||||
|
{0x09, "WINDOWS_CE_GUI"},
|
||||||
|
{0x0A, "EFI_APPLICATION"},
|
||||||
|
{0x0B, "EFI_BOOT_SERVICE_DRIVER"},
|
||||||
|
{0x0C, "EFI_RUNTIME_DRIVER"},
|
||||||
|
{0x0D, "EFI_ROM"},
|
||||||
|
{0x0E, "XBOX"},
|
||||||
|
{0x10, "WINDOWS_BOOT_APPLICATION"},
|
||||||
|
{0x14, "XT_NATIVE_KERNEL"},
|
||||||
|
{0x15, "XT_NATIVE_APPLICATION"},
|
||||||
|
{0x16, "XT_NATIVE_DRIVER"},
|
||||||
|
{0x17, "XT_DYNAMIC_LIBRARY"},
|
||||||
|
{0x18, "XT_APPLICATION_CLI"},
|
||||||
|
{0x19, "XT_APPLICATION_GDI"}
|
||||||
|
};
|
||||||
|
|
||||||
|
int getSubSystemID(char *Name)
|
||||||
|
{
|
||||||
|
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(strcmp(SubSystem->Name, Name) == 0)
|
||||||
|
{
|
||||||
|
/* Subsystem found, return its ID */
|
||||||
|
return SubSystem->Identifier;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* No valid subsystem found */
|
||||||
|
return 0x00;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
FILE *ExeFile;
|
||||||
|
unsigned char Signature[4];
|
||||||
|
unsigned int HeaderOffset;
|
||||||
|
unsigned short SubSystem;
|
||||||
|
int NewSubSystem;
|
||||||
|
|
||||||
|
/* Check for proper number of arguments */
|
||||||
|
if(argc != 3)
|
||||||
|
{
|
||||||
|
printf("Usage: %s <filename> <new SubSystem>\n", argv[0]);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Open the EXE file in binary mode */
|
||||||
|
ExeFile = fopen(argv[1], "r+b");
|
||||||
|
if(ExeFile == NULL)
|
||||||
|
{
|
||||||
|
/* Failed to open PE file */
|
||||||
|
printf("ERROR: Unable to open file %s\n", argv[1]);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Verify that the input file has a valid DOS header */
|
||||||
|
fread(Signature, sizeof(unsigned char), 4, ExeFile);
|
||||||
|
if(Signature[0] != 'M' || Signature[1] != 'Z')
|
||||||
|
{
|
||||||
|
/* Invalid DOS header */
|
||||||
|
printf("ERROR: %s is not a valid EXE file\n", argv[1]);
|
||||||
|
fclose(ExeFile);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Verify that the input file has a valid PE header */
|
||||||
|
fseek(ExeFile, 0x3C, SEEK_SET);
|
||||||
|
fread(&HeaderOffset, sizeof(unsigned int), 1, ExeFile);
|
||||||
|
fseek(ExeFile, HeaderOffset, SEEK_SET);
|
||||||
|
fread(Signature, sizeof(unsigned char), 4, ExeFile);
|
||||||
|
if(Signature[0] != 'P' || Signature[1] != 'E' || Signature[2] != 0 || Signature[3] != 0)
|
||||||
|
{
|
||||||
|
/* Invalid PE header */
|
||||||
|
printf("Error: %s is not a valid PE file\n", argv[1]);
|
||||||
|
fclose(ExeFile);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Seek to the offset of the SubSystem field in the optional header */
|
||||||
|
fseek(ExeFile, HeaderOffset + 0x5C, SEEK_SET);
|
||||||
|
|
||||||
|
/* Read the current SubSystem value */
|
||||||
|
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 */
|
||||||
|
fseek(ExeFile, -sizeof(unsigned short), SEEK_CUR);
|
||||||
|
|
||||||
|
/* Write the new SubSystem value */
|
||||||
|
fwrite(&NewSubSystem, sizeof(unsigned short), 1, ExeFile);
|
||||||
|
|
||||||
|
/* Close the file */
|
||||||
|
fclose(ExeFile);
|
||||||
|
|
||||||
|
/* Finished successfully */
|
||||||
|
printf("SubSystem successfully modified!\n");
|
||||||
|
return 0;
|
||||||
|
}
|
Reference in New Issue
Block a user