1e889a0ba4048a8de4fe0f0586335169076b8da5
[platform/upstream/gdb.git] / include / vms / lbr.h
1 /* Alpha VMS external format of Libraries.
2
3    Copyright (C) 2010-2014 Free Software Foundation, Inc.
4    Written by Tristan Gingold <gingold@adacore.com>, AdaCore.
5
6    This file is part of BFD, the Binary File Descriptor library.
7
8    This program is free software; you can redistribute it and/or modify
9    it under the terms of the GNU General Public License as published by
10    the Free Software Foundation; either version 3 of the License, or
11    (at your option) any later version.
12
13    This program is distributed in the hope that it will be useful,
14    but WITHOUT ANY WARRANTY; without even the implied warranty of
15    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16    GNU General Public License for more details.
17
18    You should have received a copy of the GNU General Public License
19    along with this program; if not, write to the Free Software
20    Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
21    MA 02110-1301, USA.  */
22
23 #ifndef _VMS_LBR_H
24 #define _VMS_LBR_H
25
26 /* Libray HeaDer.  */
27
28 /* Magic numbers.  Should match the major version.  */
29
30 #define LHD_SANEID_DCX 319232342
31 #define LHD_SANEID3 233579905
32 #define LHD_SANEID6 233579911
33
34 /* Library type.  */
35 #define LBR__C_TYP_UNK    0     /* Unknown / unspecified.  */
36 #define LBR__C_TYP_OBJ    1     /* Vax object.  */
37 #define LBR__C_TYP_MLB    2     /* Macro.  */
38 #define LBR__C_TYP_HLP    3     /* Help.  */
39 #define LBR__C_TYP_TXT    4     /* Text.  */
40 #define LBR__C_TYP_SHSTB  5     /* Vax shareable image.  */
41 #define LBR__C_TYP_NCS    6     /* NCS.  */
42 #define LBR__C_TYP_EOBJ   7     /* Alpha object.  */
43 #define LBR__C_TYP_ESHSTB 8     /* Alpha shareable image.  */
44 #define LBR__C_TYP_IOBJ   9     /* IA-64 object.  */
45 #define LBR__C_TYP_ISHSTB 10    /* IA-64 shareable image.  */
46
47 struct vms_lhd
48 {
49   /* Type of the library.  See above.  */
50   unsigned char type;
51
52   /* Number of indexes.  Generally 1, 2 for object libraries.  */
53   unsigned char nindex;
54
55   unsigned char fill_1[2];
56
57   /* Sanity Id.  */
58   unsigned char sanity[4];
59
60   /* Version.  */
61   unsigned char majorid[2];
62   unsigned char minorid[2];
63
64   /* Tool name.  */
65   unsigned char lbrver[32];
66
67   /* Create time.  */
68   unsigned char credat[8];
69
70   /* Update time.  */
71   unsigned char updtim[8];
72
73   /* Size of the MHD.  */
74   unsigned char mhdusz;
75
76   unsigned char idxblkf[2];     /* Unused.  */
77   unsigned char fill_2;
78   unsigned char closerror[2];
79
80   unsigned char spareword[2];
81
82   /* First free block, and number of free blocks.  */
83   unsigned char freevbn[4];
84   unsigned char freeblk[4];
85
86   unsigned char nextrfa[6];
87   unsigned char nextvbn[4];
88
89   /* Free pre-allocated index block.  */
90   /* Number of free blocks.  */
91   unsigned char freidxblk[4];
92   /* VBN of a simply linked list of free blocks.  The list is terminated by a
93      nul VBN.  */
94   unsigned char freeidx[4];
95
96   /* Highest pre-allocated index block and in use.  */
97   unsigned char hipreal[4];
98   unsigned char hiprusd[4];
99
100   /* Number of index blocks in use.  */
101   unsigned char idxblks[4];
102
103   /* Number of index entries.  */
104   unsigned char idxcnt[4];
105
106   /* Number of modules entries.  */
107   unsigned char modcnt[4];
108
109   unsigned char fill_3[2];
110
111   /* Number of module headers.  */
112   unsigned char modhdrs[4];
113
114   /* Overhead index pointers.  */
115   unsigned char idxovh[4];
116
117   /* Update history records.  */
118   unsigned char maxluhrec[2];
119   unsigned char numluhrec[2];
120   unsigned char begluhrfa[6];
121   unsigned char endluhrfa[6];
122
123   /* DCX map.  */
124   unsigned char dcxmapvbn[4];
125
126   unsigned char fill_4[4 * 13];
127 };
128
129 /* Known major ids.  */
130 #define LBR_MAJORID 3           /* Alpha libraries.  */
131 #define LBR_ELFMAJORID 6        /* Elf libraries (new index, new data).  */
132
133 /* Offset of the first IDD.  */
134 #define LHD_IDXDESC 196
135
136 /* InDex Description.  */
137 struct vms_idd
138 {
139   unsigned char flags[2];
140
141   /* Max length of the key.  */
142   unsigned char keylen[2];
143
144   /* First index block.  */
145   unsigned char vbn[4];
146 };
147
148 /* IDD flags.  */
149 #define IDD__FLAGS_ASCII 1
150 #define IDD__FLAGS_LOCKED 2
151 #define IDD__FLAGS_VARLENIDX 4
152 #define IDD__FLAGS_NOCASECMP 8
153 #define IDD__FLAGS_NOCASENTR 16
154 #define IDD__FLAGS_UPCASNTRY 32
155
156 #define IDD_LENGTH 8
157
158 /* Index block.  */
159 #define INDEXDEF__LENGTH 512
160 #define INDEXDEF__BLKSIZ 500
161
162 struct vms_indexdef
163 {
164   /* Number of bytes used.  */
165   unsigned char used[2];
166
167   /* VBN of the parent.  */
168   unsigned char parent[4];
169
170   unsigned char fill_1[6];
171
172   /* The key field contains vms_idx/vms_elfidx structures, which are
173      simply a key (= a string) and a rfa.  */
174   unsigned char keys[INDEXDEF__BLKSIZ];
175 };
176
177 /* An offset in a file.  */
178
179 struct vms_rfa
180 {
181   /* Logical block number, 1 based.
182      0 means that the field is absent.  Block size is 512.  */
183   unsigned char vbn[4];
184
185   /* Offset within the block.  */
186   unsigned char offset[2];
187 };
188
189 /* Index keys.  For version 3.  */
190
191 struct vms_idx
192 {
193   /* Offset from the start of the vbn, so minimum should be
194      DATA__DATA (ie 6).  */
195   struct vms_rfa rfa;
196
197   unsigned char keylen;
198   /* The length of this field is in fact keylen.  */
199   unsigned char keyname[256];
200 };
201
202 /* Index keys, for version 4 and later.  */
203
204 struct vms_elfidx
205 {
206   struct vms_rfa rfa;
207
208   unsigned char keylen[2];
209   unsigned char flags;
210   unsigned char keyname[256];
211 };
212
213 /* Flags of elfidx.  */
214
215 #define ELFIDX__WEAK 0x01       /* Weak symbol.  */
216 #define ELFIDX__GROUP 0x02      /* Group symbol.  */
217 #define ELFIDX__LISTRFA 0x04    /* RFA field points to an LHS.  */
218 #define ELFIDX__SYMESC 0x08     /* Long symbol.  */
219
220 #define RFADEF__C_INDEX 0xffff
221
222 /* List head structure.  That's what is pointed by rfa when LISTRFA flag
223    is set in elfidx.  */
224
225 struct vms_lhs
226 {
227   struct vms_rfa ng_g_rfa;      /* Non-group global.  */
228   struct vms_rfa ng_wk_rfa;     /* Non-group weak.  */
229   struct vms_rfa g_g_rfa;       /* Group global.  */
230   struct vms_rfa g_wk_rfa;      /* Group weak.  */
231   unsigned char flags;
232 };
233
234 /* List node structure.  Fields of LHS point to this structure.  */
235
236 struct vms_lns
237 {
238   /* Next node in the list.  */
239   struct vms_rfa nxtrfa;
240
241   /* Module associated with the key.  */
242   struct vms_rfa modrfa;
243 };
244
245 struct vms_datadef
246 {
247   /* Number of records in this block.  */
248   unsigned char recs;
249   unsigned char fill_1;
250
251   /* Next vbn.  */
252   unsigned char link[4];
253
254   /* Data.  The first word is the record length, followed by record
255      data and a possible pad byte so that record length is always aligned.  */
256   unsigned char data[506];
257 };
258 #define DATA__LENGTH 512
259 #define DATA__DATA 6
260
261 /* Key name block.  This is used for keys longer than 128 bytes.  */
262
263 struct vms_kbn
264 {
265   /* Length of the key chunk.  */
266   unsigned char keylen[2];
267
268   /* RFA of the next chunk.  */
269   struct vms_rfa rfa;
270
271   /* Followed by the key chunk.  */
272 };
273
274 /* Module header.  */
275 struct vms_mhd
276 {
277   /* Fixed part.  */
278   unsigned char lbrflag;
279   unsigned char id;
280   unsigned char fill_1[2];
281   unsigned char refcnt[4];
282   unsigned char datim[8];
283
284   unsigned char objstat;
285   /* Ident or GSMATCH.  */
286   unsigned char objidlng;
287   unsigned char objid[31];
288
289   unsigned char pad1[3];
290   unsigned char otherefcnt[4];
291   unsigned char modsize[4];
292   unsigned char pad2[4];
293 };
294
295 #define MHD__C_MHDID 0xad       /* Value for id.  */
296 #define MHD__C_MHDLEN 16        /* Fixed part length.  */
297 #define MHD__C_USRDAT 16
298
299 /* Flags for objstat.  */
300 #define MHD__M_SELSRC 0x1       /* Selective search.  */
301 #define MHD__M_OBJTIR 0x2
302 #define MHD__M_WKSYM  0x4
303
304 struct vms_luh
305 {
306   unsigned char nxtluhblk[4];
307   unsigned char spare[2];
308   unsigned char data[506];
309 };
310
311 struct vms_luhdef
312 {
313   unsigned char rechdr[2];
314   unsigned char reclen[2];
315 };
316 #define LUH__RECHDRLEN 4
317 #define LUH__RECHDRMRK 0xabba
318 #define LUH__DATAFLDLEN 506
319
320 /* Entry in the history.  */
321
322 struct vms_leh
323 {
324   unsigned char date[8];
325   unsigned char nbr_units[2];
326   unsigned char action[2]; /* 1: delete, 2: insert, 3: replaced.  */
327   unsigned char idlen;
328   /* username
329      modules... */
330 };
331
332 #endif /* _VMS_LBR_H */