1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
/* Copyright (C) 2021-2023 Free Software Foundation, Inc.
Contributed by Oracle.
This file is part of GNU Binutils.
This program 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 3, or (at your option)
any later version.
This program 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 this program; if not, write to the Free Software
Foundation, 51 Franklin Street - Fifth Floor, Boston,
MA 02110-1301, USA. */
#ifndef _INFO_H
#define _INFO_H
/* Header file for .info section format */
#include <inttypes.h>
/* The format of the .info section from a single object file is:
* Fixed-length info_header
* Variable length string padded to a multiple of 4 bytes, giving
* the name of the source file from which this contribution comes.
* Zero or more entries.
*
* In an executable, there will be multiple occurrences of the above.
* The size of the info section will be a multiple of 4 bytes.
*/
struct info_header
{
char endian; /* 0 for big, 1 for little */
char magic[3]; /* The string "SUN" */
uint32_t cnt; /* number of entries for this section */
uint16_t len; /* The length of the header, including the string */
uint16_t version; /* The version number of this block */
uint16_t phase; /* The compiler phase that produced this info */
uint16_t spare;
};
#define PHASE_UNKNOWN 0
#define PHASE_F77 1
#define PHASE_CC 2
#define PHASE_CPLUS 3
#define PHASE_F95 4
#define PHASE_IROPT 5
#define PHASE_MAX 255
#define F95_COPYINOUT ((PHASE_F95 << 24) | 1)
/* An entry consists of a fixed-size struct entry, possibly followed by
* a variable length data structure whose format is determined by the
* type of an entry. The size of an entry is a multiple of 4 bytes.
*/
struct entry_header
{
uint32_t type; /* The type of this entry. High 8 bits is the phase.
* Low 24 bits is the type. */
uint16_t len; /* length of this entry */
uint16_t col; /* Column number in source line */
uint32_t msgnum; /* Message number. High 8 bits is the phase.
* Low 24 bits is the type. */
uint32_t line; /* Line number in source file */
};
#endif
|