mirror of
https://github.com/reactos/reactos.git
synced 2025-07-16 07:04:02 +00:00
- Add "log2lines" tool by Jan Roeloffzen. Bug #4342.
- Fix indentation in rsym.h. svn path=/trunk/; revision=40652
This commit is contained in:
parent
d3936f5816
commit
540dda3633
4 changed files with 1330 additions and 257 deletions
1034
reactos/tools/log2lines.c
Normal file
1034
reactos/tools/log2lines.c
Normal file
File diff suppressed because it is too large
Load diff
41
reactos/tools/log2lines.mak
Normal file
41
reactos/tools/log2lines.mak
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
LOG2LINES_BASE = $(TOOLS_BASE)
|
||||||
|
LOG2LINES_BASE_ = $(LOG2LINES_BASE)$(SEP)
|
||||||
|
|
||||||
|
LOG2LINES_INT = $(INTERMEDIATE_)$(LOG2LINES_BASE)
|
||||||
|
LOG2LINES_INT_ = $(LOG2LINES_INT)$(SEP)
|
||||||
|
LOG2LINES_OUT = $(OUTPUT_)$(LOG2LINES_BASE)
|
||||||
|
LOG2LINES_OUT_ = $(LOG2LINES_OUT)$(SEP)
|
||||||
|
|
||||||
|
LOG2LINES_TARGET = \
|
||||||
|
$(LOG2LINES_OUT_)log2lines$(EXEPOSTFIX)
|
||||||
|
|
||||||
|
LOG2LINES_SOURCES = \
|
||||||
|
$(LOG2LINES_BASE_)log2lines.c \
|
||||||
|
$(LOG2LINES_BASE_)rsym_common.c
|
||||||
|
|
||||||
|
LOG2LINES_OBJECTS = \
|
||||||
|
$(addprefix $(INTERMEDIATE_), $(LOG2LINES_SOURCES:.c=.o))
|
||||||
|
|
||||||
|
LOG2LINES_HOST_CFLAGS = $(TOOLS_CFLAGS)
|
||||||
|
|
||||||
|
LOG2LINES_HOST_LFLAGS = $(TOOLS_LFLAGS)
|
||||||
|
|
||||||
|
.PHONY: log2lines
|
||||||
|
log2lines: $(LOG2LINES_TARGET)
|
||||||
|
|
||||||
|
$(LOG2LINES_TARGET): $(LOG2LINES_OBJECTS) | $(LOG2LINES_OUT)
|
||||||
|
$(ECHO_HOSTLD)
|
||||||
|
${host_gcc} $(LOG2LINES_OBJECTS) $(LOG2LINES_HOST_LFLAGS) -o $@
|
||||||
|
|
||||||
|
$(LOG2LINES_INT_)log2lines.o: $(LOG2LINES_BASE_)log2lines.c | $(LOG2LINES_INT)
|
||||||
|
$(ECHO_HOSTCC)
|
||||||
|
${host_gcc} $(LOG2LINES_HOST_CFLAGS) -c $< -o $@
|
||||||
|
|
||||||
|
#$(LOG2LINES_INT_)rsym_common.o: $(LOG2LINES_BASE_)rsym_common.c | $(LOG2LINES_INT)
|
||||||
|
# $(ECHO_HOSTCC)
|
||||||
|
# ${host_gcc} $(LOG2LINES_HOST_CFLAGS) -c $< -o $@
|
||||||
|
|
||||||
|
.PHONY: log2lines_clean
|
||||||
|
log2lines_clean:
|
||||||
|
-@$(rm) $(LOG2LINES_TARGET) $(LOG2LINES_OBJECTS) 2>$(NUL)
|
||||||
|
clean: log2lines_clean
|
|
@ -6,6 +6,8 @@
|
||||||
#define IMAGE_DOS_MAGIC 0x5a4d
|
#define IMAGE_DOS_MAGIC 0x5a4d
|
||||||
#define IMAGE_PE_MAGIC 0x00004550
|
#define IMAGE_PE_MAGIC 0x00004550
|
||||||
#define IMAGE_SIZEOF_SHORT_NAME 8
|
#define IMAGE_SIZEOF_SHORT_NAME 8
|
||||||
|
#define IMAGE_NT_OPTIONAL_HDR32_MAGIC 0x10b
|
||||||
|
#define IMAGE_NT_OPTIONAL_HDR64_MAGIC 0x20b
|
||||||
|
|
||||||
#define IMAGE_FILE_LINE_NUMS_STRIPPED 0x0004
|
#define IMAGE_FILE_LINE_NUMS_STRIPPED 0x0004
|
||||||
#define IMAGE_FILE_LOCAL_SYMS_STRIPPED 0x0008
|
#define IMAGE_FILE_LOCAL_SYMS_STRIPPED 0x0008
|
||||||
|
@ -45,7 +47,6 @@ typedef unsigned long ULONG_PTR;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#pragma pack(push,2)
|
#pragma pack(push,2)
|
||||||
|
|
||||||
typedef struct _IMAGE_DOS_HEADER {
|
typedef struct _IMAGE_DOS_HEADER {
|
||||||
WORD e_magic;
|
WORD e_magic;
|
||||||
WORD e_cblp;
|
WORD e_cblp;
|
||||||
|
@ -66,7 +67,7 @@ typedef struct _IMAGE_DOS_HEADER {
|
||||||
WORD e_oeminfo;
|
WORD e_oeminfo;
|
||||||
WORD e_res2[10];
|
WORD e_res2[10];
|
||||||
LONG e_lfanew;
|
LONG e_lfanew;
|
||||||
} IMAGE_DOS_HEADER,*PIMAGE_DOS_HEADER;
|
} IMAGE_DOS_HEADER, *PIMAGE_DOS_HEADER;
|
||||||
#pragma pack(pop)
|
#pragma pack(pop)
|
||||||
|
|
||||||
#pragma pack(push,4)
|
#pragma pack(push,4)
|
||||||
|
@ -84,7 +85,7 @@ typedef struct _IMAGE_FILE_HEADER {
|
||||||
typedef struct _IMAGE_DATA_DIRECTORY {
|
typedef struct _IMAGE_DATA_DIRECTORY {
|
||||||
DWORD VirtualAddress;
|
DWORD VirtualAddress;
|
||||||
DWORD Size;
|
DWORD Size;
|
||||||
} IMAGE_DATA_DIRECTORY,*PIMAGE_DATA_DIRECTORY;
|
} IMAGE_DATA_DIRECTORY, *PIMAGE_DATA_DIRECTORY;
|
||||||
|
|
||||||
typedef struct _IMAGE_OPTIONAL_HEADER32 {
|
typedef struct _IMAGE_OPTIONAL_HEADER32 {
|
||||||
WORD Magic;
|
WORD Magic;
|
||||||
|
@ -118,7 +119,7 @@ typedef struct _IMAGE_OPTIONAL_HEADER32 {
|
||||||
DWORD LoaderFlags;
|
DWORD LoaderFlags;
|
||||||
DWORD NumberOfRvaAndSizes;
|
DWORD NumberOfRvaAndSizes;
|
||||||
IMAGE_DATA_DIRECTORY DataDirectory[IMAGE_NUMBEROF_DIRECTORY_ENTRIES];
|
IMAGE_DATA_DIRECTORY DataDirectory[IMAGE_NUMBEROF_DIRECTORY_ENTRIES];
|
||||||
} IMAGE_OPTIONAL_HEADER32,*PIMAGE_OPTIONAL_HEADER32;
|
} IMAGE_OPTIONAL_HEADER32, *PIMAGE_OPTIONAL_HEADER32;
|
||||||
|
|
||||||
typedef struct _IMAGE_OPTIONAL_HEADER64 {
|
typedef struct _IMAGE_OPTIONAL_HEADER64 {
|
||||||
WORD Magic;
|
WORD Magic;
|
||||||
|
@ -151,8 +152,7 @@ typedef struct _IMAGE_OPTIONAL_HEADER64 {
|
||||||
DWORD LoaderFlags;
|
DWORD LoaderFlags;
|
||||||
DWORD NumberOfRvaAndSizes;
|
DWORD NumberOfRvaAndSizes;
|
||||||
IMAGE_DATA_DIRECTORY DataDirectory[IMAGE_NUMBEROF_DIRECTORY_ENTRIES];
|
IMAGE_DATA_DIRECTORY DataDirectory[IMAGE_NUMBEROF_DIRECTORY_ENTRIES];
|
||||||
} IMAGE_OPTIONAL_HEADER64,*PIMAGE_OPTIONAL_HEADER64;
|
} IMAGE_OPTIONAL_HEADER64, *PIMAGE_OPTIONAL_HEADER64;
|
||||||
|
|
||||||
|
|
||||||
#ifdef _TARGET_PE64
|
#ifdef _TARGET_PE64
|
||||||
typedef IMAGE_OPTIONAL_HEADER64 IMAGE_OPTIONAL_HEADER;
|
typedef IMAGE_OPTIONAL_HEADER64 IMAGE_OPTIONAL_HEADER;
|
||||||
|
@ -176,14 +176,14 @@ typedef struct _IMAGE_SECTION_HEADER {
|
||||||
WORD NumberOfRelocations;
|
WORD NumberOfRelocations;
|
||||||
WORD NumberOfLinenumbers;
|
WORD NumberOfLinenumbers;
|
||||||
DWORD Characteristics;
|
DWORD Characteristics;
|
||||||
} IMAGE_SECTION_HEADER,*PIMAGE_SECTION_HEADER;
|
} IMAGE_SECTION_HEADER, *PIMAGE_SECTION_HEADER;
|
||||||
|
|
||||||
#pragma pack(push,4)
|
#pragma pack(push,4)
|
||||||
typedef struct _IMAGE_BASE_RELOCATION {
|
typedef struct _IMAGE_BASE_RELOCATION {
|
||||||
DWORD VirtualAddress;
|
DWORD VirtualAddress;
|
||||||
DWORD SizeOfBlock;
|
DWORD SizeOfBlock;
|
||||||
WORD TypeOffset[1];
|
WORD TypeOffset[1];
|
||||||
} IMAGE_BASE_RELOCATION,*PIMAGE_BASE_RELOCATION;
|
} IMAGE_BASE_RELOCATION, *PIMAGE_BASE_RELOCATION;
|
||||||
#pragma pack(pop)
|
#pragma pack(pop)
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
@ -226,6 +226,7 @@ typedef struct _STAB_ENTRY {
|
||||||
} STAB_ENTRY, *PSTAB_ENTRY;
|
} STAB_ENTRY, *PSTAB_ENTRY;
|
||||||
|
|
||||||
/* http://www.math.utah.edu/docs/info/stabs_12.html */
|
/* http://www.math.utah.edu/docs/info/stabs_12.html */
|
||||||
|
|
||||||
#define N_GYSM 0x20
|
#define N_GYSM 0x20
|
||||||
#define N_FNAME 0x22
|
#define N_FNAME 0x22
|
||||||
#define N_FUN 0x24
|
#define N_FUN 0x24
|
||||||
|
@ -274,6 +275,7 @@ typedef struct _STAB_ENTRY {
|
||||||
#define N_TSHIFT (2)
|
#define N_TSHIFT (2)
|
||||||
|
|
||||||
/* derived types, in e_type */
|
/* derived types, in e_type */
|
||||||
|
|
||||||
#define DT_NON (0) /* no derived type */
|
#define DT_NON (0) /* no derived type */
|
||||||
#define DT_PTR (1) /* pointer */
|
#define DT_PTR (1) /* pointer */
|
||||||
#define DT_FCN (2) /* function */
|
#define DT_FCN (2) /* function */
|
||||||
|
@ -284,8 +286,8 @@ typedef struct _STAB_ENTRY {
|
||||||
#define ISPTR(x) (((x) & N_TMASK) == (DT_PTR << N_BTSHFT))
|
#define ISPTR(x) (((x) & N_TMASK) == (DT_PTR << N_BTSHFT))
|
||||||
#define ISFCN(x) (((x) & N_TMASK) == (DT_FCN << N_BTSHFT))
|
#define ISFCN(x) (((x) & N_TMASK) == (DT_FCN << N_BTSHFT))
|
||||||
#define ISARY(x) (((x) & N_TMASK) == (DT_ARY << N_BTSHFT))
|
#define ISARY(x) (((x) & N_TMASK) == (DT_ARY << N_BTSHFT))
|
||||||
#define ISTAG(x) ((x)==C_STRTAG||(x)==C_UNTAG||(x)==C_ENTAG)
|
#define ISTAG(x) ((x) == C_STRTAG || (x) == C_UNTAG || (x) == C_ENTAG)
|
||||||
#define DECREF(x) ((((x)>>N_TSHIFT)&~N_BTMASK)|((x)&N_BTMASK))
|
#define DECREF(x) ((((x) >> N_TSHIFT) & ~N_BTMASK) | ((x) & N_BTMASK))
|
||||||
|
|
||||||
#define C_EFCN 0xff /* physical end of function */
|
#define C_EFCN 0xff /* physical end of function */
|
||||||
#define C_NULL 0
|
#define C_NULL 0
|
||||||
|
@ -313,24 +315,19 @@ typedef struct _STAB_ENTRY {
|
||||||
#define C_FCN 101 /* ".bf" or ".ef" */
|
#define C_FCN 101 /* ".bf" or ".ef" */
|
||||||
#define C_EOS 102 /* end of structure */
|
#define C_EOS 102 /* end of structure */
|
||||||
#define C_FILE 103 /* file name */
|
#define C_FILE 103 /* file name */
|
||||||
#define C_LINE 104 /* line # reformatted as symbol table entry */
|
#define C_LINE 104 /* line# reformatted as symbol table entry */
|
||||||
#define C_ALIAS 105 /* duplicate tag */
|
#define C_ALIAS 105 /* duplicate tag */
|
||||||
#define C_HIDDEN 106 /* ext symbol in dmert public lib */
|
#define C_HIDDEN 106 /* ext symbol in dmert public lib */
|
||||||
|
|
||||||
#pragma pack(1)
|
#pragma pack(1)
|
||||||
typedef struct _COFF_SYMENT
|
typedef struct _COFF_SYMENT {
|
||||||
{
|
union {
|
||||||
union
|
|
||||||
{
|
|
||||||
char e_name[E_SYMNMLEN];
|
char e_name[E_SYMNMLEN];
|
||||||
struct
|
struct {
|
||||||
{
|
|
||||||
ULONG e_zeroes;
|
ULONG e_zeroes;
|
||||||
ULONG e_offset;
|
ULONG e_offset;
|
||||||
}
|
} e;
|
||||||
e;
|
} e;
|
||||||
}
|
|
||||||
e;
|
|
||||||
ULONG e_value;
|
ULONG e_value;
|
||||||
short e_scnum;
|
short e_scnum;
|
||||||
USHORT e_type;
|
USHORT e_type;
|
||||||
|
@ -348,10 +345,10 @@ typedef struct _ROSSYM_ENTRY {
|
||||||
|
|
||||||
#define ROUND_UP(N, S) (((N) + (S) - 1) & ~((S) - 1))
|
#define ROUND_UP(N, S) (((N) + (S) - 1) & ~((S) - 1))
|
||||||
|
|
||||||
extern char*
|
extern char *
|
||||||
convert_path(const char* origpath);
|
convert_path(const char *origpath);
|
||||||
|
|
||||||
extern void*
|
extern void *
|
||||||
load_file ( const char* file_name, size_t* file_size );
|
load_file(const char *file_name, size_t *file_size);
|
||||||
|
|
||||||
#endif/*RSYM_H*/
|
#endif /* RSYM_H */
|
||||||
|
|
|
@ -43,10 +43,11 @@ $(TOOLS_INT_)xml.o: $(TOOLS_BASE_)xml.cpp $(XML_SSPRINTF_HEADERS) | $(TOOLS_INT)
|
||||||
include tools/bin2c.mak
|
include tools/bin2c.mak
|
||||||
include tools/buildno/buildno.mak
|
include tools/buildno/buildno.mak
|
||||||
include tools/gendib/gendib.mak
|
include tools/gendib/gendib.mak
|
||||||
|
include tools/log2lines.mak
|
||||||
|
include tools/nci/nci.mak
|
||||||
ifeq ($(ARCH),powerpc)
|
ifeq ($(ARCH),powerpc)
|
||||||
include tools/ofw_interface/ofw_interface.mak
|
include tools/ofw_interface/ofw_interface.mak
|
||||||
endif
|
endif
|
||||||
include tools/nci/nci.mak
|
|
||||||
include tools/pefixup.mak
|
include tools/pefixup.mak
|
||||||
include tools/raddr2line.mak
|
include tools/raddr2line.mak
|
||||||
include tools/rbuild/rbuild.mak
|
include tools/rbuild/rbuild.mak
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue