2007-01-26 02:55:06 +01:00
|
|
|
/**
|
|
|
|
* ================================================================
|
|
|
|
* SourcePawn (C)2004-2007 AlliedModders LLC. All rights reserved.
|
|
|
|
* ================================================================
|
|
|
|
*
|
|
|
|
* This file is part of the SourceMod/SourcePawn SDK. This file may only be used
|
|
|
|
* or modified under the Terms and Conditions of its License Agreement, which is found
|
|
|
|
* in LICENSE.txt. The Terms and Conditions for making SourceMod extensions/plugins
|
|
|
|
* may change at any time. To view the latest information, see:
|
|
|
|
* http://www.sourcemod.net/license.php
|
|
|
|
*
|
|
|
|
* Version: $Id$
|
|
|
|
*/
|
|
|
|
|
2007-01-19 06:33:04 +01:00
|
|
|
#ifndef _INCLUDE_SPFILE_HEADERS_H
|
|
|
|
#define _INCLUDE_SPFILE_HEADERS_H
|
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
/**
|
|
|
|
* @file sp_file_headers.h
|
|
|
|
* @brief Defines the structure present in a SourcePawn compiled binary.
|
|
|
|
*
|
|
|
|
* Note: These structures should be 1-byte packed to match the file format.
|
|
|
|
*/
|
|
|
|
|
2007-01-19 06:33:04 +01:00
|
|
|
#include <stddef.h>
|
|
|
|
#if defined __GNUC__ || defined HAVE_STDINT_
|
|
|
|
#include <stdint.h>
|
|
|
|
#else
|
|
|
|
#if !defined HAVE_STDINT_H
|
2007-01-26 02:55:06 +01:00
|
|
|
typedef unsigned __int64 uint64_t; /**< 64bit unsigned integer */
|
|
|
|
typedef __int64 int64_t; /**< 64bit signed integer */
|
|
|
|
typedef unsigned __int32 uint32_t; /**< 32bit unsigned integer */
|
|
|
|
typedef __int32 int32_t; /**< 32bit signed integer */
|
|
|
|
typedef unsigned __int16 uint16_t; /**< 16bit unsigned integer */
|
|
|
|
typedef __int16 int16_t; /**< 16bit signed integer */
|
|
|
|
typedef unsigned __int8 uint8_t; /**< 8bit unsigned integer */
|
|
|
|
typedef __int8 int8_t; /**< 8bit signed integer */
|
2007-01-19 06:33:04 +01:00
|
|
|
#define HAVE_STDINT_H
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
#define SPFILE_MAGIC 0x53504646 /**< Source Pawn File Format (SPFF) */
|
|
|
|
#define SPFILE_VERSION 0x0101 /**< Uncompressed bytecode */
|
2007-01-19 06:33:04 +01:00
|
|
|
|
|
|
|
//:TODO: better compiler/nix support
|
|
|
|
#if defined __linux__
|
|
|
|
#pragma pack(1) /* structures must be packed (byte-aligned) */
|
|
|
|
#else
|
|
|
|
#pragma pack(push)
|
|
|
|
#pragma pack(1) /* structures must be packed (byte-aligned) */
|
|
|
|
#endif
|
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
#define SPFILE_COMPRESSION_NONE 0 /**< No compression in file */
|
|
|
|
#define SPFILE_COMPRESSION_GZ 1 /**< GZ compression */
|
2007-01-19 06:33:04 +01:00
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
/**
|
|
|
|
* @brief File section header format.
|
|
|
|
*/
|
2007-01-19 06:33:04 +01:00
|
|
|
typedef struct sp_file_section_s
|
|
|
|
{
|
2007-01-26 02:55:06 +01:00
|
|
|
uint32_t nameoffs; /**< Relative offset into global string table */
|
|
|
|
uint32_t dataoffs; /**< Offset into the data section of the file */
|
|
|
|
uint32_t size; /**< Size of the section's entry in the data section */
|
2007-01-19 06:33:04 +01:00
|
|
|
} sp_file_section_t;
|
|
|
|
|
|
|
|
/**
|
2007-01-26 02:55:06 +01:00
|
|
|
* @brief File header format. If compression is 0, then disksize may be 0
|
|
|
|
* to mean that only the imagesize is needed.
|
2007-01-19 06:33:04 +01:00
|
|
|
*/
|
|
|
|
typedef struct sp_file_hdr_s
|
|
|
|
{
|
2007-01-26 02:55:06 +01:00
|
|
|
uint32_t magic; /**< Magic number */
|
|
|
|
uint16_t version; /**< Version code */
|
|
|
|
uint8_t compression;/**< Compression algorithm */
|
|
|
|
uint32_t disksize; /**< Size on disk */
|
|
|
|
uint32_t imagesize; /**< Size in memory */
|
|
|
|
uint8_t sections; /**< Number of sections */
|
|
|
|
uint32_t stringtab; /**< Offset to string table */
|
|
|
|
uint32_t dataoffs; /**< Offset to file proper (any compression starts here) */
|
2007-01-19 06:33:04 +01:00
|
|
|
} sp_file_hdr_t;
|
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
#define SP_FLAG_DEBUG (1<<0) /**< Debug information is present in the file */
|
2007-01-19 06:33:04 +01:00
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
/**
|
|
|
|
* @brief File-encoded format of the ".code" section.
|
|
|
|
*/
|
2007-01-19 06:33:04 +01:00
|
|
|
typedef struct sp_file_code_s
|
|
|
|
{
|
2007-01-26 02:55:06 +01:00
|
|
|
uint32_t codesize; /**< Codesize in bytes */
|
|
|
|
uint8_t cellsize; /**< Cellsize in bytes */
|
|
|
|
uint8_t codeversion; /**< Version of opcodes supported */
|
|
|
|
uint16_t flags; /**< Flags */
|
|
|
|
uint32_t main; /**< Address to "main," if any */
|
|
|
|
uint32_t code; /**< Relative offset to code */
|
2007-01-19 06:33:04 +01:00
|
|
|
} sp_file_code_t;
|
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
/**
|
|
|
|
* @brief File-encoded format of the ".data" section.
|
|
|
|
*/
|
2007-01-19 06:33:04 +01:00
|
|
|
typedef struct sp_file_data_s
|
|
|
|
{
|
2007-01-26 02:55:06 +01:00
|
|
|
uint32_t datasize; /**< Size of data section in memory */
|
|
|
|
uint32_t memsize; /**< Total mem required (includes data) */
|
|
|
|
uint32_t data; /**< File offset to data (helper) */
|
2007-01-19 06:33:04 +01:00
|
|
|
} sp_file_data_t;
|
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
/**
|
|
|
|
* @brief File-encoded format of the ".publics" section.
|
|
|
|
*/
|
2007-01-19 06:33:04 +01:00
|
|
|
typedef struct sp_file_publics_s
|
|
|
|
{
|
2007-01-26 02:55:06 +01:00
|
|
|
uint32_t address; /**< Address relative to code section */
|
|
|
|
uint32_t name; /**< Index into nametable */
|
2007-01-19 06:33:04 +01:00
|
|
|
} sp_file_publics_t;
|
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
/**
|
|
|
|
* @brief File-encoded format of the ".natives" section.
|
|
|
|
*/
|
2007-01-19 06:33:04 +01:00
|
|
|
typedef struct sp_file_natives_s
|
|
|
|
{
|
2007-01-26 02:55:06 +01:00
|
|
|
uint32_t name; /**< Index into nametable */
|
2007-01-19 06:33:04 +01:00
|
|
|
} sp_file_natives_t;
|
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
/**
|
|
|
|
* @brief File-encoded format of the ".libraries" section (UNUSED).
|
|
|
|
*/
|
2007-01-19 06:33:04 +01:00
|
|
|
typedef struct sp_file_libraries_s
|
|
|
|
{
|
2007-01-26 02:55:06 +01:00
|
|
|
uint32_t name; /**< Index into nametable */
|
2007-01-19 06:33:04 +01:00
|
|
|
} sp_file_libraries_t;
|
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
/**
|
|
|
|
* @brief File-encoded format of the ".pubvars" section.
|
|
|
|
*/
|
2007-01-19 06:33:04 +01:00
|
|
|
typedef struct sp_file_pubvars_s
|
|
|
|
{
|
2007-01-26 02:55:06 +01:00
|
|
|
uint32_t address; /**< Address relative to the DAT section */
|
|
|
|
uint32_t name; /**< Index into nametable */
|
2007-01-19 06:33:04 +01:00
|
|
|
} sp_file_pubvars_t;
|
|
|
|
|
|
|
|
#if defined __linux__
|
|
|
|
#pragma pack() /* reset default packing */
|
|
|
|
#else
|
|
|
|
#pragma pack(pop) /* reset previous packing */
|
|
|
|
#endif
|
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
/**
|
|
|
|
* @brief File-encoded debug information table.
|
|
|
|
*/
|
2007-01-19 06:33:04 +01:00
|
|
|
typedef struct sp_fdbg_info_s
|
|
|
|
{
|
2007-01-26 02:55:06 +01:00
|
|
|
uint32_t num_files; /**< number of files */
|
|
|
|
uint32_t num_lines; /**< number of lines */
|
|
|
|
uint32_t num_syms; /**< number of symbols */
|
|
|
|
uint32_t num_arrays; /**< number of symbols which are arrays */
|
2007-01-19 06:33:04 +01:00
|
|
|
} sp_fdbg_info_t;
|
|
|
|
|
|
|
|
/**
|
2007-01-26 02:55:06 +01:00
|
|
|
* @brief File-encoded debug file table.
|
2007-01-19 06:33:04 +01:00
|
|
|
*/
|
|
|
|
typedef struct sp_fdbg_file_s
|
|
|
|
{
|
2007-01-26 02:55:06 +01:00
|
|
|
uint32_t addr; /**< Address into code */
|
|
|
|
uint32_t name; /**< Offset into debug nametable */
|
2007-01-19 06:33:04 +01:00
|
|
|
} sp_fdbg_file_t;
|
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
/**
|
|
|
|
* @brief File-encoded debug line table.
|
|
|
|
*/
|
2007-01-19 06:33:04 +01:00
|
|
|
typedef struct sp_fdbg_line_s
|
|
|
|
{
|
2007-01-26 02:55:06 +01:00
|
|
|
uint32_t addr; /**< Address into code */
|
|
|
|
uint32_t line; /**< Line number */
|
2007-01-19 06:33:04 +01:00
|
|
|
} sp_fdbg_line_t;
|
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
#define SP_SYM_VARIABLE 1 /**< Cell that has an address and that can be fetched directly (lvalue) */
|
|
|
|
#define SP_SYM_REFERENCE 2 /**< VARIABLE, but must be dereferenced */
|
|
|
|
#define SP_SYM_ARRAY 3 /**< Symbol is an array */
|
|
|
|
#define SP_SYM_REFARRAY 4 /**< An array passed by reference (i.e. a pointer) */
|
|
|
|
#define SP_SYM_FUNCTION 9 /**< Symbol is a function */
|
2007-01-19 06:33:04 +01:00
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
/**
|
|
|
|
* @brief File-encoded debug symbol information.
|
|
|
|
*/
|
2007-01-19 06:33:04 +01:00
|
|
|
typedef struct sp_fdbg_symbol_s
|
|
|
|
{
|
2007-01-26 02:55:06 +01:00
|
|
|
int32_t addr; /**< Address rel to DAT or stack frame */
|
|
|
|
int16_t tagid; /**< Tag id */
|
|
|
|
uint32_t codestart; /**< Start scope validity in code */
|
|
|
|
uint32_t codeend; /**< End scope validity in code */
|
|
|
|
uint8_t ident; /**< Variable type */
|
|
|
|
uint8_t vclass; /**< Scope class (local vs global) */
|
|
|
|
uint16_t dimcount; /**< Dimension count (for arrays) */
|
|
|
|
uint32_t name; /**< Offset into debug nametable */
|
2007-01-19 06:33:04 +01:00
|
|
|
} sp_fdbg_symbol_t;
|
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
/**
|
|
|
|
* @brief File-encoded debug symbol array dimension info.
|
|
|
|
*/
|
2007-01-19 06:33:04 +01:00
|
|
|
typedef struct sp_fdbg_arraydim_s
|
|
|
|
{
|
2007-01-26 02:55:06 +01:00
|
|
|
int16_t tagid; /**< Tag id */
|
|
|
|
uint32_t size; /**< Size of dimension */
|
2007-01-19 06:33:04 +01:00
|
|
|
} sp_fdbg_arraydim_t;
|
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Typedef for .names table */
|
2007-01-19 06:33:04 +01:00
|
|
|
typedef char * sp_file_nametab_t;
|
|
|
|
|
|
|
|
#endif //_INCLUDE_SPFILE_HEADERS_H
|