- Add "log2lines" tool by Jan Roeloffzen. Bug #4342.

- Fix indentation in rsym.h.

svn path=/trunk/; revision=40652
This commit is contained in:
Dmitry Gorbachev 2009-04-22 16:50:44 +00:00
parent d3936f5816
commit 540dda3633
4 changed files with 1330 additions and 257 deletions

1034
reactos/tools/log2lines.c Normal file

File diff suppressed because it is too large Load diff

View 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

View file

@ -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 */

View file

@ -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