summaryrefslogtreecommitdiff
path: root/gcc/vmsdbg.h
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/vmsdbg.h')
-rw-r--r--gcc/vmsdbg.h248
1 files changed, 164 insertions, 84 deletions
diff --git a/gcc/vmsdbg.h b/gcc/vmsdbg.h
index 65147a6cf5d..4d48d7989ca 100644
--- a/gcc/vmsdbg.h
+++ b/gcc/vmsdbg.h
@@ -1,45 +1,72 @@
-/* This file contains definitions for the data structures and codes used in
- VMS debugging information. */
+/* Definitions for the data structures and codes used in VMS debugging. */
+ Copyright (C) 2001 Free Software Foundation, Inc.
-#ifndef VMSDBG_H
-#define VMSDBG_H 1
-
-typedef unsigned short int DST_DTYPE;
-#define DST_K_SOURCE 155
-#define DST_K_PROLOG 162
-#define DST_K_BLKBEG 176
-#define DST_K_BLKEND 177
-#define DST_K_LINE_NUM 185
-#define DST_K_MODBEG 188
-#define DST_K_MODEND 189
-#define DST_K_RTNBEG 190
-#define DST_K_RTNEND 191
-
-typedef struct _DST_HEADER {
- union {
- unsigned short int dst_w_length;
- unsigned short int dst_x_length;
- } dst__header_length;
- union {
- DST_DTYPE dst_w_type;
- DST_DTYPE dst_x_type;
- } dst__header_type;
+This file is part of GCC.
+
+GCC is free software; you can redistribute it and/or modify it under
+the terms of the GNU General Public License as published by the Free
+Software Foundation; either version 2, or (at your option) any later
+version.
+
+GCC is distributed in the hope that it will be useful, but WITHOUT ANY
+WARRANTY; without even the implied warranty of MERCHANTABILITY or
+FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+for more details.
+
+You should have received a copy of the GNU General Public License
+along with GCC; see the file COPYING. If not, write to the Free
+Software Foundation, 59 Temple Place - Suite 330, Boston, MA
+02111-1307, USA. */
+
+#ifndef GCC_VMSDBG_H
+#define GCC_VMSDBG_H 1
+
+/* We define types and constants used in VMS Debug output. Note that the
+ structs only approximate the output that is written. We write the output
+ explicitly, field by field. This output would only agree with the
+ structs in this file if no padding were done. The sizes after each
+ struct are the size actually written, which is usually smaller than the
+ size of the struct. */
+
+/* Header type codes. */
+typedef enum _DST_TYPE {DST_K_SOURCE = 155, DST_K_PROLOG = 162,
+ DST_K_BLKBEG = 176, DST_K_BLKEND = 177,
+ DST_K_LINE_NUM = 185, DST_K_MODBEG = 188,
+ DST_K_MODEND = 189, DST_K_RTNBEG = 190,
+ DST_K_RTNEND = 191} DST_DTYPE;
+
+/* Header. */
+
+typedef struct _DST_HEADER
+{
+ union
+ {
+ unsigned short int dst_w_length;
+ unsigned short int dst_x_length;
+ } dst__header_length;
+ union
+ {
+ ENUM_BITFIELD (_DST_DTYPE) dst_w_type : 16;
+ ENUM_BITFIELD (_DST_DTYPE) dst_x_type : 16;
+ } dst__header_type;
} DST_HEADER;
-#define DST_K_DST_HEADER_SIZE 4
-
-typedef unsigned int DST_LANGUAGE;
-#define DST_K_FORTRAN 1
-#define DST_K_C 7
-#define DST_K_ADA 9
-#define DST_K_UNKNOWN 10
-#define DST_K_CXX 15
-typedef struct _DST_MODULE_BEGIN {
+#define DST_K_DST_HEADER_SIZE sizeof 4
+
+/* Language type codes. */
+typedef enum _DST_LANGUAGE {DST_K_FORTRAN = 1, DST_K_C = 7, DST_K_ADA = 9,
+ DST_K_UNKNOWN = 10, DST_K_CXX = 15} DST_LANGUAGE;
+
+/* Module header (a module is the result of a single compilation). */
+
+typedef struct _DST_MODULE_BEGIN
+{
DST_HEADER dst_a_modbeg_header;
- struct {
- unsigned dst_v_modbeg_hide : 1;
- unsigned dst_v_modbeg_version : 1;
- unsigned dst_v_modbeg_unused : 6;
- } dst_b_modbeg_flags;
+ struct
+ {
+ unsigned dst_v_modbeg_hide : 1;
+ unsigned dst_v_modbeg_version : 1;
+ unsigned dst_v_modbeg_unused : 6;
+ } dst_b_modbeg_flags;
unsigned char dst_b_modbeg_unused;
DST_LANGUAGE dst_l_modbeg_language;
unsigned short int dst_w_version_major;
@@ -47,63 +74,98 @@ typedef struct _DST_MODULE_BEGIN {
unsigned char dst_b_modbeg_name;
} DST_MODULE_BEGIN;
#define DST_K_MODBEG_SIZE 15
-
-typedef struct _DST_MB_TRLR {
+
+/* Module trailer. */
+
+typedef struct _DST_MB_TRLR
+{
unsigned char dst_b_compiler;
} DST_MB_TRLR;
+
#define DST_K_MB_TRLR_SIZE 1
+
#define DST_K_VERSION_MAJOR 1
#define DST_K_VERSION_MINOR 13
-typedef struct _DST_MODULE_END {
+
+typedef struct _DST_MODULE_END
+{
DST_HEADER dst_a_modend_header;
} DST_MODULE_END;
-#define DST_K_MODEND_SIZE 4
-typedef struct _DST_ROUTINE_BEGIN {
+#define DST_K_MODEND_SIZE sizeof 4
+
+/* Routine header. */
+
+typedef struct _DST_ROUTINE_BEGIN
+{
DST_HEADER dst_a_rtnbeg_header;
- struct {
- unsigned dst_v_rtnbeg_unused : 4;
- unsigned dst_v_rtnbeg_unalloc : 1;
- unsigned dst_v_rtnbeg_prototype : 1;
- unsigned dst_v_rtnbeg_inlined : 1;
- unsigned dst_v_rtnbeg_no_call : 1;
- } dst_b_rtnbeg_flags;
+ struct
+ {
+ unsigned dst_v_rtnbeg_unused : 4;
+ unsigned dst_v_rtnbeg_unalloc : 1;
+ unsigned dst_v_rtnbeg_prototype : 1;
+ unsigned dst_v_rtnbeg_inlined : 1;
+ unsigned dst_v_rtnbeg_no_call : 1;
+ } dst_b_rtnbeg_flags;
int *dst_l_rtnbeg_address;
int *dst_l_rtnbeg_pd_address;
unsigned char dst_b_rtnbeg_name;
} DST_ROUTINE_BEGIN;
#define DST_K_RTNBEG_SIZE 14
-typedef struct _DST_ROUTINE_END {
+
+/* Routine trailer */
+
+typedef struct _DST_ROUTINE_END
+{
DST_HEADER dst_a_rtnend_header;
char dst_b_rtnend_unused;
unsigned int dst_l_rtnend_size;
} DST_ROUTINE_END;
#define DST_K_RTNEND_SIZE 9
-typedef struct _DST_BLOCK_BEGIN {
+
+/* Block header. */
+
+typedef struct _DST_BLOCK_BEGIN
+{
DST_HEADER dst_a_blkbeg_header;
unsigned char dst_b_blkbeg_unused;
int *dst_l_blkbeg_address;
unsigned char dst_b_blkbeg_name;
} DST_BLOCK_BEGIN;
#define DST_K_BLKBEG_SIZE 10
-typedef struct _DST_BLOCK_END {
+
+/* Block trailer. */
+
+typedef struct _DST_BLOCK_END
+{
DST_HEADER dst_a_blkend_header;
unsigned char dst_b_blkend_unused;
unsigned int dst_l_blkend_size;
} DST_BLOCK_END;
#define DST_K_BLKEND_SIZE 9
-typedef struct _DST_LINE_NUM_HEADER {
+
+/* Line number header. */
+
+typedef struct _DST_LINE_NUM_HEADER
+{
DST_HEADER dst_a_line_num_header;
} DST_LINE_NUM_HEADER;
#define DST_K_LINE_NUM_HEADER_SIZE 4
-typedef struct _DST_PCLINE_COMMANDS {
+/* PC to Line number correlation. */
+
+typedef struct _DST_PCLINE_COMMANDS
+{
char dst_b_pcline_command;
- union {
- unsigned int dst_l_pcline_unslong;
- unsigned short int dst_w_pcline_unsword;
- unsigned char dst_b_pcline_unsbyte;
- } dst_a_pcline_access_fields;
+ union
+ {
+ unsigned int dst_l_pcline_unslong;
+ unsigned short int dst_w_pcline_unsword;
+ unsigned char dst_b_pcline_unsbyte;
+ } dst_a_pcline_access_fields;
} DST_PCLINE_COMMANDS;
+
+/* PC and Line number correlation codes. */
+
#define DST_K_PCLINE_COMMANDS_SIZE 5
#define DST_K_PCLINE_COMMANDS_SIZE_MIN 2
#define DST_K_PCLINE_COMMANDS_SIZE_MAX 5
@@ -118,10 +180,16 @@ typedef struct _DST_PCLINE_COMMANDS {
#define DST_K_INCR_LINUM_L 18
#define DST_K_SET_LINUM_B 19
#define DST_K_SET_LINUM_L 20
-typedef struct _DST_SOURCE_CORR {
+
+/* Source file correlation header. */
+
+typedef struct _DST_SOURCE_CORR
+{
DST_HEADER dst_a_source_corr_header;
} DST_SOURCE_CORR;
#define DST_K_SOURCE_CORR_HEADER_SIZE 4
+
+/* Source file correlation codes. */
#define DST_K_SRC_DECLFILE 1
#define DST_K_SRC_SETFILE 2
@@ -135,39 +203,51 @@ typedef struct _DST_SOURCE_CORR {
#define DST_K_SRC_FORMFEED 16
#define DST_K_SRC_MIN_CMD 1
#define DST_K_SRC_MAX_CMD 16
-typedef struct _DST_SRC_COMMAND {
+
+/* Source file header. */
+
+typedef struct _DST_SRC_COMMAND
+{
unsigned char dst_b_src_command;
- union {
- struct {
- unsigned char dst_b_src_df_length;
- unsigned char dst_b_src_df_flags;
- unsigned short int dst_w_src_df_fileid;
+ union
+ {
+ struct
+ {
+ unsigned char dst_b_src_df_length;
+ unsigned char dst_b_src_df_flags;
+ unsigned short int dst_w_src_df_fileid;
#ifdef __GNUC__
- long long dst_q_src_df_rms_cdt;
+ long long dst_q_src_df_rms_cdt;
#else
- __int64 dst_q_src_df_rms_cdt;
+ __int64 dst_q_src_df_rms_cdt;
#endif
- unsigned int dst_l_src_df_rms_ebk;
- unsigned short int dst_w_src_df_rms_ffb;
- unsigned char dst_b_src_df_rms_rfo;
- unsigned char dst_b_src_df_filename;
- } dst_a_src_decl_src;
- unsigned int dst_l_src_unslong;
- unsigned short int dst_w_src_unsword;
- unsigned char dst_b_src_unsbyte;
- } dst_a_src_cmd_fields;
+ unsigned int dst_l_src_df_rms_ebk;
+ unsigned short int dst_w_src_df_rms_ffb;
+ unsigned char dst_b_src_df_rms_rfo;
+ unsigned char dst_b_src_df_filename;
+ } dst_a_src_decl_src;
+ unsigned int dst_l_src_unslong;
+ unsigned short int dst_w_src_unsword;
+ unsigned char dst_b_src_unsbyte;
+ } dst_a_src_cmd_fields;
} DST_SRC_COMMAND;
#define DST_K_SRC_COMMAND_SIZE 21
-
-typedef struct _DST_SRC_CMDTRLR {
+
+/* Source file trailer. */
+
+typedef struct _DST_SRC_CMDTRLR
+{
unsigned char dst_b_src_df_libmodname;
} DST_SRC_CMDTRLR;
#define DST_K_SRC_CMDTRLR_SIZE 1
-
-typedef struct _DST_PROLOG {
+
+/* Prolog header. */
+
+typedef struct _DST_PROLOG
+{
DST_HEADER dst_a_prolog_header;
unsigned int dst_l_prolog_bkpt_addr;
} DST_PROLOG;
#define DST_K_PROLOG_SIZE 8
-#endif /* VMSDBG_H */
+#endif /* GCC_VMSDBG_H */